Skip to content

Commit

Permalink
fix(demo): edit outline should follow on filter/pagination changed
Browse files Browse the repository at this point in the history
- the cell orange outline, which tells us the cell wasn't saved yet, should follow the row for both cases of a filter and/or pagination change
- the previous implementation was also not always working to remove all edit cell styling, it works a lot better by keeping a styling queue with the a style key and to remove all styles we simply loop through that queue
  • Loading branch information
ghiscoding committed Aug 2, 2022
1 parent e370eef commit 3e9a6c7
Showing 1 changed file with 17 additions and 12 deletions.
29 changes: 17 additions & 12 deletions examples/webpack-demo-vanilla-bundle/src/examples/example12.ts
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ export class Example12 {
isCompositeDisabled = false;
isMassSelectionDisabled = true;
gridContainerElm: HTMLDivElement;
cellCssStyleQueue = [];
complexityLevelList = [
{ value: 0, label: 'Very Simple' },
{ value: 1, label: 'Simple' },
Expand Down Expand Up @@ -129,7 +130,8 @@ export class Example12 {
this._bindingEventService.bind(this.gridContainerElm, 'ongridstatechanged', this.handleOnGridStateChanged.bind(this));
this._bindingEventService.bind(this.gridContainerElm, 'ondblclick', () => this.openCompositeModal('edit', 50));
this._bindingEventService.bind(this.gridContainerElm, 'oncompositeeditorchange', this.handleOnCompositeEditorChange.bind(this));
this._bindingEventService.bind(this.gridContainerElm, 'onpaginationchanged', this.handlePaginationChanged.bind(this));
this._bindingEventService.bind(this.gridContainerElm, 'onpaginationchanged', this.handleReRenderUnsavedStyling.bind(this));
this._bindingEventService.bind(this.gridContainerElm, 'onfilterchanged', this.handleReRenderUnsavedStyling.bind(this));
}

dispose() {
Expand Down Expand Up @@ -609,7 +611,7 @@ export class Example12 {
*/
}

handlePaginationChanged() {
handleReRenderUnsavedStyling() {
this.removeAllUnsavedStylingFromCell();
this.renderUnsavedStylingOnAllVisibleCells();
}
Expand Down Expand Up @@ -638,19 +640,20 @@ export class Example12 {

removeUnsavedStylingFromCell(_item: any, column: Column, row: number) {
// remove unsaved css class from that cell
this.sgb.slickGrid.removeCellCssStyles(`unsaved_highlight_${[column.id]}${row}`);
const cssStyleKey = `unsaved_highlight_${[column.id]}${row}`;
this.sgb.slickGrid.removeCellCssStyles(cssStyleKey);
const foundIdx = this.cellCssStyleQueue.findIndex(styleKey => styleKey === cssStyleKey);
if (foundIdx >= 0) {
this.cellCssStyleQueue.splice(foundIdx, 1);
}
}

removeAllUnsavedStylingFromCell() {
for (const lastEdit of this.editQueue) {
const lastEditCommand = lastEdit?.editCommand;
if (lastEditCommand) {
// remove unsaved css class from that cell
for (const lastEditColumn of lastEdit.columns) {
this.removeUnsavedStylingFromCell(lastEdit.item, lastEditColumn, lastEditCommand.row);
}
}
}
let cssStyleKey;
do {
cssStyleKey = this.cellCssStyleQueue.pop();
this.sgb.slickGrid.removeCellCssStyles(cssStyleKey);
} while (cssStyleKey);
}

renderUnsavedStylingOnAllVisibleCells() {
Expand All @@ -671,7 +674,9 @@ export class Example12 {
const row = this.sgb.dataView.getRowByItem(item);
if (row >= 0) {
const hash = { [row]: { [column.id]: 'unsaved-editable-field' } };
const cssStyleKey = `unsaved_highlight_${[column.id]}${row}`;
this.sgb.slickGrid.setCellCssStyles(`unsaved_highlight_${[column.id]}${row}`, hash);
this.cellCssStyleQueue.push(cssStyleKey);
}
}
}
Expand Down

0 comments on commit 3e9a6c7

Please sign in to comment.