2022-11-28 22:48:42 +00:00
|
|
|
/**
|
|
|
|
* An object that represents an entry of the command in the history
|
|
|
|
*
|
|
|
|
* @typedef CommandEntry
|
|
|
|
* @property {string} id A unique ID generated for this entry
|
|
|
|
* @property {string} title The title passed to the command being run
|
|
|
|
* @property {() => void | Promise<void>} undo A method to undo whatever the command did
|
|
|
|
* @property {() => void | Promise<void>} redo A method to redo whatever undo did
|
2023-01-22 05:48:56 +00:00
|
|
|
* @property {() => any | Promise<any>} export A method to export the command
|
2022-11-28 22:48:42 +00:00
|
|
|
* @property {{[key: string]: any}} state The state of the current command instance
|
2023-01-25 02:48:09 +00:00
|
|
|
* @property {{[key: string]: any}} extra Extra information saved with the command
|
2022-11-28 22:48:42 +00:00
|
|
|
*/
|
|
|
|
|
2023-01-04 19:23:02 +00:00
|
|
|
/**
|
|
|
|
* Extra command information
|
|
|
|
*
|
|
|
|
* @typedef CommandExtraParams
|
|
|
|
* @property {boolean} recordHistory The title passed to the command being run
|
2023-01-22 05:48:56 +00:00
|
|
|
* @property {any} importData Data to restore the command from
|
2023-01-04 19:23:02 +00:00
|
|
|
* @property {Record<string, any>} extra Extra information to be stored in the history entry
|
|
|
|
*/
|
|
|
|
|
2022-11-28 22:48:42 +00:00
|
|
|
/**
|
|
|
|
* A command, which is run, then returns a CommandEntry object that can be used to manually undo/redo it
|
|
|
|
*
|
|
|
|
* @callback Command
|
|
|
|
* @param {string} title The title passed to the command being run
|
2023-01-04 19:23:02 +00:00
|
|
|
* @param {any} options A options object for the command
|
|
|
|
* @param {CommandExtraParams} extra A options object for the command
|
2022-11-28 22:48:42 +00:00
|
|
|
* @returns {Promise<CommandEntry>}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A method for running a command (or redoing it)
|
|
|
|
*
|
|
|
|
* @callback CommandDoCallback
|
|
|
|
* @param {string} title The title passed to the command being run
|
|
|
|
* @param {*} options A options object for the command
|
|
|
|
* @param {{[key: string]: any}} state The state of the current command instance
|
|
|
|
* @returns {void | Promise<void>}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A method for undoing a command
|
|
|
|
*
|
|
|
|
* @callback CommandUndoCallback
|
|
|
|
* @param {string} title The title passed to the command when it was run
|
|
|
|
* @param {{[key: string]: any}} state The state of the current command instance
|
|
|
|
* @returns {void | Promise<void>}
|
|
|
|
*/
|