mirror of
https://github.com/nasa/openmct.git
synced 2025-01-18 02:39:56 +00:00
[Persistence] Add TransactionManager JSDoc
Fixes #1059 (or, rather, concludes work on said fix)
This commit is contained in:
parent
99227d2e42
commit
d263b80810
@ -23,20 +23,48 @@
|
|||||||
define([], function () {
|
define([], function () {
|
||||||
/**
|
/**
|
||||||
* Manages transactions to support the TransactionalPersistenceCapability.
|
* Manages transactions to support the TransactionalPersistenceCapability.
|
||||||
|
* This assumes that all commit/cancel callbacks for a given domain
|
||||||
|
* object are equivalent, and only need to be added once to any active
|
||||||
|
* transaction. Violating this assumption may cause unexpected behavior.
|
||||||
|
* @constructor
|
||||||
|
* @memberof platform/commonUI/edit
|
||||||
*/
|
*/
|
||||||
function TransactionManager(transactionService) {
|
function TransactionManager(transactionService) {
|
||||||
this.transactionService = transactionService;
|
this.transactionService = transactionService;
|
||||||
this.clearTransactionFns = {};
|
this.clearTransactionFns = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a transaction is currently active.
|
||||||
|
* @returns {boolean} true if there is a transaction active
|
||||||
|
*/
|
||||||
TransactionManager.prototype.isActive = function () {
|
TransactionManager.prototype.isActive = function () {
|
||||||
return this.transactionService.isActive();
|
return this.transactionService.isActive();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if callbacks associated with this domain object have already
|
||||||
|
* been added to the active transaction.
|
||||||
|
* @private
|
||||||
|
* @param {DomainObject} domainObject the object to check
|
||||||
|
* @returns {boolean} true if callbacks have been added
|
||||||
|
*/
|
||||||
TransactionManager.prototype.isScheduled = function (domainObject) {
|
TransactionManager.prototype.isScheduled = function (domainObject) {
|
||||||
return !!this.clearTransactionFns[domainObject.getId()];
|
return !!this.clearTransactionFns[domainObject.getId()];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add callbacks associated with this domain object to the active
|
||||||
|
* transaction. Both callbacks are expected to return promises that
|
||||||
|
* resolve when their associated behavior is complete.
|
||||||
|
*
|
||||||
|
* If callbacks associated with this domain object have already been
|
||||||
|
* added to the active transaction, this call will be ignored.
|
||||||
|
*
|
||||||
|
* @param {DomainObject} domainObject the associated domain object
|
||||||
|
* @param {Function} onCommit behavior to invoke when committing transaction
|
||||||
|
* @param {Function} onCancel behavior to invoke when cancelling transaction
|
||||||
|
*/
|
||||||
TransactionManager.prototype.addToTransaction = function (
|
TransactionManager.prototype.addToTransaction = function (
|
||||||
domainObject,
|
domainObject,
|
||||||
onCommit,
|
onCommit,
|
||||||
@ -59,6 +87,11 @@ define([], function () {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove any callbacks associated with this domain object from the
|
||||||
|
* active transaction.
|
||||||
|
* @param {DomainObject} domainObject the domain object
|
||||||
|
*/
|
||||||
TransactionManager.prototype.clearTransactionsFor = function (domainObject) {
|
TransactionManager.prototype.clearTransactionsFor = function (domainObject) {
|
||||||
if (this.isScheduled(domainObject)) {
|
if (this.isScheduled(domainObject)) {
|
||||||
this.clearTransactionFns[domainObject.getId()]();
|
this.clearTransactionFns[domainObject.getId()]();
|
||||||
@ -66,6 +99,12 @@ define([], function () {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Release the cached "remove from transaction" function that has been
|
||||||
|
* stored in association with this domain object.
|
||||||
|
* @param {DomainObject} domainObject the domain object
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
TransactionManager.prototype.releaseClearFn = function (domainObject) {
|
TransactionManager.prototype.releaseClearFn = function (domainObject) {
|
||||||
delete this.clearTransactionFns[domainObject.getId()];
|
delete this.clearTransactionFns[domainObject.getId()];
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user