跳到主要内容

Class: UserDefinedTransactionHandle<T>

A strongly typed transaction handle to enforce type safety when adding user defined transactions.
This transaction handle becomes the context for adding the transaction to the transaction manager.
You can obtain one of these handles by calling registerUserDefinedTransactionHandler

Type parameters

Type parameter
T

Constructors

new UserDefinedTransactionHandle()

new UserDefinedTransactionHandle<T>(nativeHandle, transactionManager): UserDefinedTransactionHandle<T>

Parameters

ParameterType
nativeHandleUserDefinedTransactionHandlerId
transactionManagerTransactionManager

Returns

UserDefinedTransactionHandle<T>

Remarks

Constructs a new instance of the UserDefinedTransactionHandle class

Methods

addUserDefinedOperation()

addUserDefinedOperation(payload, transactionName): void

Parameters

ParameterTypeDescription
payloadTThe data object to be inserted into the transaction log.
transactionNamestringA string name that will be associated with this operation

Returns

void

Remarks

Add a user defined transaction operation to the transaction manager with a payload of the specified type. This allows the extension to open a transaction, and insert custom data objects into the transaction log which are stored until an undo or redo event occurs. The payload data added here is stored and then passed to the undo/redo handlers (registered with registerUserDefinedTransactionHandler) when an undo/redo event is requested. NOTE:
Transactions can contain multiple operations - you can open a transaction and add any (reasonable) number of operations to it (of the same or differing types) before committing to the transaction log. NOTE/WARNING:
The payload data is serialized to JSON before being inserted into the transaction log and the underlying implementation uses the JSON.stringify() function to serialize the data. Any non-primitive data, such as classes or minecraft native objects will not serialize to JSON properly, so you should avoid using them as payload data.