- 
                Notifications
    You must be signed in to change notification settings 
- Fork 156
Transaction specification
| Version | User | Date | Notes | 
|---|---|---|---|
| 0.1 | Milko Venkov | Aug 30, 2018 | Initial Draft | 
| 0.2 | Milko Venkov | Sep 04, 2018 | Transaction state | 
| 0.3 | Milko Venkov | Sep 04, 2018 | Update API and functionality | 
| 0.4 | Milko Venkov | Oct 18, 2018 | Test scenarios and API update | 
| 0.5 | Viktor Slavov | Oct 18, 2018 | Update getAggregatedStatedescription | 
| 0.6 | Milko Venkov | Feb 11, 2020 | Update API | 
| 0.7 | Viktor Aladzhov | Jul, 23, 2020 | HierarchicalTransactionService commit method | 
igxTransactionService should be able to plug between given component and its data source. While plugged in igxTransactionService should collect all the transactions performed in the component without send them to the data source. igxTransactionService should be able to update the data source and commit all the transactions when needed.
- there is no end users stories as igxTransactionServiceshould be an Angular Service.
- be able to enable transaction on a given component
- be able to retrieve all the transactions - transaction log
- be able to get updated state of the data including all transactions in the transaction log
- be able to update data source with all the transactions currently in the transaction log
- be able to undo the last change
- be able to redo the change that was undone
- be able to reset all the transactions in the transaction log
- be able to start adding of pending transactions
- be able to finish adding of pending transactions and commit or discard all pending transactions
3.1. End User Experience
3.2. Developer Experience
Developers are able to inject the igxTransactionService. Then developers should be able to add transaction to the transaction log. After some transactions are added developers should be able to retrieve updated data source state, including all transactions in the transaction log; update the data source when needed; reset all the transactions in the transaction log; perform undo and redo actions. Developers should be able to add pending transactions. This will allow adding of some transactions without include them in transaction log. At some point developer should be able to commit aggregated state of all pending transaction as a single transaction or dismiss all pending transactions.
Here is what will happen with transaction state when new transactions is added:
- 
Addtransaction type - when adding such a transaction one should not provideinitialValue. After successfully adding of such transaction it will be reflected in aggregated state likeAddtransaction type. If such a transaction is then added withDeletetransaction type it will be removed from aggregated state. Adding ofAddtransaction type with id which already exists in aggregated state will throw an exception;
- 
Updatetransaction type - when adding such a transaction one should provideinitialValue. After successfully adding of such transaction it will be reflected in aggregated state likeUpdatetransaction type. If an aggregated transactions change results in the same as theinitialValuethen it will not be reflected in the state. One can also updateAddtransaction type - this will be reflected in aggregated state likeAddtransaction type. One can also updateUpdatetransaction type - this will remain likeUpdatetransaction type in aggregated state. If one tries to updateDeletetransaction type an exception will be thrown.
- Delete transaction type - when adding such a transaction one should provide initialValue. After successfully adding of such transaction it will be reflected in aggregated state likeDeletedtransaction type. One can also deleteAddtransaction type, this will remove the record from the aggregated state. One can also deleteUpdatetransaction type, this will change the aggregated type toDelete. If one tries to deleteDeletetransaction type an exception will be thrown.
Here is visual representation of all possible transactions paths:

3.3. API
TransactionService
| Name | Description | 
|---|---|
| enabled | Returns whether transaction is enabled for this service | 
| canUndo | Returns if there are any transactions in the Undo stack | 
| canRedo | Returns if there are any transactions in the Redo stack | 
TransactionService
| Name | Description | Parameters | 
|---|---|---|
| add | Adds provided transaction with recordRef if any | transaction, recordRef? | 
| getTransactionLog | Returns an array of all transactions. If id is provided returns last transaction for provided id | id? | 
| undo | Remove the last transaction if any | - | 
| redo | Applies the last undone transaction if any | - | 
| getAggregatedChanges | Returns aggregated changes from all transactions | mergeChanges | 
| getState | Returns the state of the record with provided id | id, pending? | 
| getAggregatedValue | Returns value of the required id including all uncommitted changes | id, mergeChanges | 
| commit | Applies all transactions over the provided data | data, id? or data, primaryKey, childDataKey, id? | 
| clear | Clears all transactions | id? | 
| startPending | Starts pending transactions. All transactions passed after call to startPending will not be added to transaction | - | 
| endPending | Clears all pending transactions and aggregated pending state. If commit is set to true commits pending states as single transaction | commit | 
HierarchicalTransactionService
The HierarchicalTransactionService inherits all the methods of the TransactionService and adds and overload for the commit method.
| Name | Description | Parameters | 
|---|---|---|
| commit | Applies all transactions over the provided data | data, primaryKey, childDataKey, id? | 
TransactionService
| Name | Description | 
|---|---|
| onStateUpdate | Event fired when transaction state has changed - add transaction, commit all transactions, undo and redo | 
There are no any assumptions or limitations.
- Should initialize transactions log properly.
- Should add transactions to the transactions log.
- Should throw an error when trying to add duplicate transaction.
- Should throw an error when trying to update transaction with no recordRef.
- Should throw an error when trying to delete an already deleted item.
- Should throw an error when trying to update an already deleted item.
- Should get a transaction by transaction id.
- Should add ADD type transaction - all feasible paths
- Should add DELETE type transaction - all feasible paths.
- Should add UPDATE type transaction - all feasible paths.
- Should update data when data is list of objects.
- Should update data when data is list of primitives.
- Should add pending transaction and push it to transaction log.
- Should not add pending transaction and push it to transaction log.