Skip to content

Commit

Permalink
Listen for reset events to update task state disable state
Browse files Browse the repository at this point in the history
Signed-off-by: Taylor Smock <[email protected]>
  • Loading branch information
tsmock committed Sep 25, 2023
1 parent 3b54de2 commit 0a88b11
Showing 1 changed file with 31 additions and 9 deletions.
40 changes: 31 additions & 9 deletions frontend/src/components/rapidEditor.js
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,29 @@ function resizeRapid(rapidContext) {
}
}

/**
* Check if there are changes
* @param changes The changes to check
* @returns {boolean} {@code true} if there are changes
*/
function thereAreChanges(changes) {
return changes.modified.length || changes.created.length || changes.deleted.length;
}

/**
* Update the disable state for the sidebar map actions
* @param {function(boolean)} setDisable
* @param {EditSystem} editSystem The edit system
* @type {import('@rapideditor/rapid/modules').EditSystem} EditSystem
*/
function updateDisableState(setDisable, editSystem) {
if (thereAreChanges(editSystem.changes())) {
setDisable(true);
} else {
setDisable(false);
}
}

/**
* Create a new RapidEditor component
* @param {function(boolean)} setDisable
Expand Down Expand Up @@ -198,6 +221,7 @@ function RapidEditor({

useEffect(() => {
const containerRoot = document.getElementById('rapid-container-root');
const editListener = () => updateDisableState(setDisable, context.systems.edits);
if (context && dom) {
containerRoot.appendChild(dom);
// init the ui or restart if it was loaded previously
Expand All @@ -215,22 +239,20 @@ function RapidEditor({
promise.then(() => {
/* Keep track of edits */
const editSystem = context.systems.edits;
const thereAreChanges = (changes) =>
changes.modified.length || changes.created.length || changes.deleted.length;

editSystem.on('change', () => {
if (thereAreChanges(editSystem.changes())) {
setDisable(true);
} else {
setDisable(false);
}
});
editSystem.on('change', editListener);
editSystem.on('reset', editListener);
});
}
return () => {
if (containerRoot?.childNodes && dom in containerRoot.childNodes) {
document.getElementById('rapid-container-root')?.removeChild(dom);
}
if (context?.systems?.edits) {
const editSystem = context.systems.edits;
editSystem.off('change', editListener);
editSystem.off('reset', editListener);
}
};
}, [dom, context, setDisable]);

Expand Down

0 comments on commit 0a88b11

Please sign in to comment.