angular-slickgrid 5.2.2 → 5.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -68,7 +68,11 @@ export const GlobalGridOptions = {
68
68
  }
69
69
  },
70
70
  dataView: {
71
- syncGridSelection: true,
71
+ // when enabled, this will preserve the row selection even after filtering/sorting/grouping
72
+ syncGridSelection: {
73
+ preserveHidden: false,
74
+ preserveHiddenOnSelectionChange: true
75
+ },
72
76
  syncGridSelectionWithBackendService: false, // but disable it when using backend services
73
77
  },
74
78
  datasetIdPropertyName: 'id',
@@ -240,4 +244,4 @@ function pickerHeaderColumnValueExtractor(column) {
240
244
  }
241
245
  return column && column.name || '';
242
246
  }
243
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-grid-options.js","sourceRoot":"","sources":["../../../../../src/app/modules/angular-slickgrid/global-grid-options.ts"],"names":[],"mappings":"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","sourcesContent":["import { Column, DelimiterType, EventNamingStyle, FileType, Filters, OperatorType, TreeDataOption } from '@slickgrid-universal/common';\nimport { GridOption, RowDetailView } from './models/index';\n\n/** Global Grid Options Defaults */\nexport const GlobalGridOptions: Partial<GridOption> = {\n  alwaysShowVerticalScroll: true,\n  autoEdit: false,\n  asyncEditorLoading: false,\n  autoFitColumnsOnFirstLoad: true,\n  autoResize: {\n    applyResizeToContainer: true,\n    calculateAvailableSizeBy: 'window',\n    bottomPadding: 20,\n    minHeight: 180,\n    minWidth: 300,\n    rightPadding: 0\n  },\n  cellHighlightCssClass: 'slick-cell-modified',\n  checkboxSelector: {\n    cssClass: 'slick-cell-checkboxsel'\n  },\n  columnPicker: {\n    fadeSpeed: 0,\n    hideForceFitButton: false,\n    hideSyncResizeButton: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\n  },\n  cellMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideCommandSection: false,\n    hideOptionSection: false,\n  },\n  contextMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideClearAllGrouping: false,\n    hideCollapseAllGroups: false,\n    hideCommandSection: false,\n    hideCopyCellValueCommand: false,\n    hideExpandAllGroups: false,\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideMenuOnScroll: true,\n    hideOptionSection: false,\n    iconCopyCellValueCommand: 'fa fa-clone',\n    iconExportCsvCommand: 'fa fa-download',\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\n    iconExportTextDelimitedCommand: 'fa fa-download',\n  },\n  customFooterOptions: {\n    dateFormat: 'YYYY-MM-DD, hh:mm a',\n    hideRowSelectionCount: false,\n    hideTotalItemCount: false,\n    hideLastUpdateTimestamp: true,\n    footerHeight: 25,\n    leftContainerClass: 'col-xs-12 col-sm-5',\n    rightContainerClass: 'col-xs-6 col-sm-7',\n    metricSeparator: '|',\n    metricTexts: {\n      items: 'items',\n      itemsKey: 'ITEMS',\n      itemsSelected: 'items selected',\n      itemsSelectedKey: 'ITEMS_SELECTED',\n      of: 'of',\n      ofKey: 'OF',\n    }\n  },\n  dataView: {\n    syncGridSelection: true, // when enabled, this will preserve the row selection even after filtering/sorting/grouping\n    syncGridSelectionWithBackendService: false, // but disable it when using backend services\n  },\n  datasetIdPropertyName: 'id',\n  defaultFilter: Filters.input,\n  defaultBackendServiceFilterTypingDebounce: 500,\n  defaultColumnSortFieldId: 'id',\n  defaultFilterPlaceholder: '🔎︎',\n  defaultFilterRangeOperator: OperatorType.rangeInclusive,\n  editable: false,\n  enableAutoResize: true,\n  enableAutoSizeColumns: true,\n  enableCellNavigation: false,\n  enableColumnPicker: true,\n  enableColumnReorder: true,\n  enableColumnResizeOnDoubleClick: true,\n  enableContextMenu: true,\n  enableExcelExport: true, // Excel Export is the new default,\n  enableTextExport: false, // CSV/Text with Tab Delimited\n  enableFilterTrimWhiteSpace: false, // do we want to trim white spaces on all Filters?\n  enableGridMenu: true,\n  enableHeaderMenu: true,\n  enableEmptyDataWarningMessage: true,\n  emptyDataWarning: {\n    className: 'slick-empty-data-warning',\n    message: 'No data to display.',\n    messageKey: 'EMPTY_DATA_WARNING_MESSAGE',\n    hideFrozenLeftWarning: false,\n    hideFrozenRightWarning: false,\n    leftViewportMarginLeft: '40%',\n    rightViewportMarginLeft: '40%',\n    frozenLeftViewportMarginLeft: '0px',\n    frozenRightViewportMarginLeft: '40%',\n  },\n  enableMouseHoverHighlightRow: true,\n  enableSorting: true,\n  enableTextSelectionOnCells: true,\n  eventNamingStyle: EventNamingStyle.camelCase,\n  explicitInitialization: true,\n  excelExportOptions: {\n    addGroupIndentation: true,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.xlsx,\n    groupingColumnHeaderTitle: 'Group By',\n    groupCollapsedSymbol: '⮞',\n    groupExpandedSymbol: '⮟',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n  },\n  textExportOptions: {\n    delimiter: DelimiterType.comma,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.csv,\n    groupingColumnHeaderTitle: 'Group By',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n    useUtf8WithBom: true\n  },\n  filterTypingDebounce: 0,\n  forceFitColumns: false,\n  frozenHeaderWidthCalcDifferential: 0,\n  gridMenu: {\n    dropSide: 'left',\n    commandLabels: {\n      clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',\n      clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',\n      clearFrozenColumnsCommandKey: 'CLEAR_PINNING',\n      exportCsvCommandKey: 'EXPORT_TO_CSV',\n      exportExcelCommandKey: 'EXPORT_TO_EXCEL',\n      exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',\n      refreshDatasetCommandKey: 'REFRESH_DATASET',\n      toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',\n      togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',\n    },\n    hideClearAllFiltersCommand: false,\n    hideClearAllSortingCommand: false,\n    hideClearFrozenColumnsCommand: true, // opt-in command\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideForceFitButton: false,\n    hideRefreshDatasetCommand: false,\n    hideSyncResizeButton: true,\n    hideToggleFilterCommand: false,\n    hideTogglePreHeaderCommand: false,\n    iconCssClass: 'fa fa-bars',\n    iconClearAllFiltersCommand: 'fa fa-filter text-danger',\n    iconClearAllSortingCommand: 'fa fa-unsorted text-danger',\n    iconClearFrozenColumnsCommand: 'fa fa-times',\n    iconExportCsvCommand: 'fa fa-download',\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\n    iconExportTextDelimitedCommand: 'fa fa-download',\n    iconRefreshDatasetCommand: 'fa fa-refresh',\n    iconToggleFilterCommand: 'fa fa-random',\n    iconTogglePreHeaderCommand: 'fa fa-random',\n    menuWidth: 16,\n    resizeOnShowHeaderRow: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\n  },\n  headerMenu: {\n    autoAlign: true,\n    autoAlignOffset: 12,\n    minWidth: 140,\n    iconClearFilterCommand: 'fa fa-filter text-danger',\n    iconClearSortCommand: 'fa fa-unsorted',\n    iconFreezeColumns: 'fa fa-thumb-tack',\n    iconSortAscCommand: 'fa fa-sort-amount-asc',\n    iconSortDescCommand: 'fa fa-sort-amount-desc',\n    iconColumnHideCommand: 'fa fa-times',\n    iconColumnResizeByContentCommand: 'fa fa-arrows-h',\n    hideColumnResizeByContentCommand: false,\n    hideColumnHideCommand: false,\n    hideClearFilterCommand: false,\n    hideClearSortCommand: false,\n    hideFreezeColumnsCommand: true, // opt-in command\n    hideSortCommands: false\n  },\n  headerRowHeight: 35,\n  multiColumnSort: true,\n  numberedMultiColumnSort: true,\n  tristateMultiColumnSort: false,\n  sortColNumberInSeparateSpan: true,\n  suppressActiveCellChangeOnEdit: true,\n  pagination: {\n    pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],\n    pageSize: 25,\n    totalItems: 0\n  },\n  // technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options\n  rowDetailView: {\n    collapseAllOnSort: true,\n    cssClass: 'detail-view-toggle',\n    panelRows: 1,\n    keyPrefix: '__',\n    useRowClick: false,\n    useSimpleViewportCalc: true,\n    saveDetailViewOnScroll: false,\n  } as RowDetailView,\n  rowHeight: 35,\n  topPanelHeight: 35,\n  translationNamespaceSeparator: ':',\n  resetFilterSearchValueAfterOnBeforeCancellation: true,\n  resizeByContentOnlyOnFirstLoad: true,\n  resizeByContentOptions: {\n    alwaysRecalculateColumnWidth: false,\n    cellCharWidthInPx: 7.8,\n    cellPaddingWidthInPx: 14,\n    defaultRatioForStringType: 0.88,\n    formatterPaddingWidthInPx: 0,\n    maxItemToInspectCellContentWidth: 1000,\n    maxItemToInspectSingleColumnWidthByContent: 5000,\n    widthToRemoveFromExceededWidthReadjustment: 50,\n  },\n  treeDataOptions: {\n    exportIndentMarginLeft: 5,\n    exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',\n  } as unknown as TreeDataOption\n};\n\n/**\n * Value Extractor for both ColumnPicker & GridMenu Picker\n * when using Column Header Grouping, we'll prefix the column group title\n * else we'll simply return the column name title\n */\nfunction pickerHeaderColumnValueExtractor(column: Column) {\n  const headerGroup = column && column.columnGroup || '';\n  if (headerGroup) {\n    return headerGroup + ' - ' + column.name;\n  }\n  return column && column.name || '';\n}\n"]}
247
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-grid-options.js","sourceRoot":"","sources":["../../../../../src/app/modules/angular-slickgrid/global-grid-options.ts"],"names":[],"mappings":"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","sourcesContent":["import { Column, DelimiterType, EventNamingStyle, FileType, Filters, OperatorType, TreeDataOption } from '@slickgrid-universal/common';\nimport { GridOption, RowDetailView } from './models/index';\n\n/** Global Grid Options Defaults */\nexport const GlobalGridOptions: Partial<GridOption> = {\n  alwaysShowVerticalScroll: true,\n  autoEdit: false,\n  asyncEditorLoading: false,\n  autoFitColumnsOnFirstLoad: true,\n  autoResize: {\n    applyResizeToContainer: true,\n    calculateAvailableSizeBy: 'window',\n    bottomPadding: 20,\n    minHeight: 180,\n    minWidth: 300,\n    rightPadding: 0\n  },\n  cellHighlightCssClass: 'slick-cell-modified',\n  checkboxSelector: {\n    cssClass: 'slick-cell-checkboxsel'\n  },\n  columnPicker: {\n    fadeSpeed: 0,\n    hideForceFitButton: false,\n    hideSyncResizeButton: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\n  },\n  cellMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideCommandSection: false,\n    hideOptionSection: false,\n  },\n  contextMenu: {\n    autoAdjustDrop: true,\n    autoAlignSide: true,\n    hideCloseButton: true,\n    hideClearAllGrouping: false,\n    hideCollapseAllGroups: false,\n    hideCommandSection: false,\n    hideCopyCellValueCommand: false,\n    hideExpandAllGroups: false,\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideMenuOnScroll: true,\n    hideOptionSection: false,\n    iconCopyCellValueCommand: 'fa fa-clone',\n    iconExportCsvCommand: 'fa fa-download',\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\n    iconExportTextDelimitedCommand: 'fa fa-download',\n  },\n  customFooterOptions: {\n    dateFormat: 'YYYY-MM-DD, hh:mm a',\n    hideRowSelectionCount: false,\n    hideTotalItemCount: false,\n    hideLastUpdateTimestamp: true,\n    footerHeight: 25,\n    leftContainerClass: 'col-xs-12 col-sm-5',\n    rightContainerClass: 'col-xs-6 col-sm-7',\n    metricSeparator: '|',\n    metricTexts: {\n      items: 'items',\n      itemsKey: 'ITEMS',\n      itemsSelected: 'items selected',\n      itemsSelectedKey: 'ITEMS_SELECTED',\n      of: 'of',\n      ofKey: 'OF',\n    }\n  },\n  dataView: {\n    // when enabled, this will preserve the row selection even after filtering/sorting/grouping\n    syncGridSelection: {\n      preserveHidden: false,\n      preserveHiddenOnSelectionChange: true\n    },\n    syncGridSelectionWithBackendService: false, // but disable it when using backend services\n  },\n  datasetIdPropertyName: 'id',\n  defaultFilter: Filters.input,\n  defaultBackendServiceFilterTypingDebounce: 500,\n  defaultColumnSortFieldId: 'id',\n  defaultFilterPlaceholder: '🔎︎',\n  defaultFilterRangeOperator: OperatorType.rangeInclusive,\n  editable: false,\n  enableAutoResize: true,\n  enableAutoSizeColumns: true,\n  enableCellNavigation: false,\n  enableColumnPicker: true,\n  enableColumnReorder: true,\n  enableColumnResizeOnDoubleClick: true,\n  enableContextMenu: true,\n  enableExcelExport: true, // Excel Export is the new default,\n  enableTextExport: false, // CSV/Text with Tab Delimited\n  enableFilterTrimWhiteSpace: false, // do we want to trim white spaces on all Filters?\n  enableGridMenu: true,\n  enableHeaderMenu: true,\n  enableEmptyDataWarningMessage: true,\n  emptyDataWarning: {\n    className: 'slick-empty-data-warning',\n    message: 'No data to display.',\n    messageKey: 'EMPTY_DATA_WARNING_MESSAGE',\n    hideFrozenLeftWarning: false,\n    hideFrozenRightWarning: false,\n    leftViewportMarginLeft: '40%',\n    rightViewportMarginLeft: '40%',\n    frozenLeftViewportMarginLeft: '0px',\n    frozenRightViewportMarginLeft: '40%',\n  },\n  enableMouseHoverHighlightRow: true,\n  enableSorting: true,\n  enableTextSelectionOnCells: true,\n  eventNamingStyle: EventNamingStyle.camelCase,\n  explicitInitialization: true,\n  excelExportOptions: {\n    addGroupIndentation: true,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.xlsx,\n    groupingColumnHeaderTitle: 'Group By',\n    groupCollapsedSymbol: '⮞',\n    groupExpandedSymbol: '⮟',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n  },\n  textExportOptions: {\n    delimiter: DelimiterType.comma,\n    exportWithFormatter: false,\n    filename: 'export',\n    format: FileType.csv,\n    groupingColumnHeaderTitle: 'Group By',\n    groupingAggregatorRowText: '',\n    sanitizeDataExport: false,\n    useUtf8WithBom: true\n  },\n  filterTypingDebounce: 0,\n  forceFitColumns: false,\n  frozenHeaderWidthCalcDifferential: 0,\n  gridMenu: {\n    dropSide: 'left',\n    commandLabels: {\n      clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',\n      clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',\n      clearFrozenColumnsCommandKey: 'CLEAR_PINNING',\n      exportCsvCommandKey: 'EXPORT_TO_CSV',\n      exportExcelCommandKey: 'EXPORT_TO_EXCEL',\n      exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',\n      refreshDatasetCommandKey: 'REFRESH_DATASET',\n      toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',\n      togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',\n    },\n    hideClearAllFiltersCommand: false,\n    hideClearAllSortingCommand: false,\n    hideClearFrozenColumnsCommand: true, // opt-in command\n    hideExportCsvCommand: false,\n    hideExportExcelCommand: false,\n    hideExportTextDelimitedCommand: true,\n    hideForceFitButton: false,\n    hideRefreshDatasetCommand: false,\n    hideSyncResizeButton: true,\n    hideToggleFilterCommand: false,\n    hideTogglePreHeaderCommand: false,\n    iconCssClass: 'fa fa-bars',\n    iconClearAllFiltersCommand: 'fa fa-filter text-danger',\n    iconClearAllSortingCommand: 'fa fa-unsorted text-danger',\n    iconClearFrozenColumnsCommand: 'fa fa-times',\n    iconExportCsvCommand: 'fa fa-download',\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\n    iconExportTextDelimitedCommand: 'fa fa-download',\n    iconRefreshDatasetCommand: 'fa fa-refresh',\n    iconToggleFilterCommand: 'fa fa-random',\n    iconTogglePreHeaderCommand: 'fa fa-random',\n    menuWidth: 16,\n    resizeOnShowHeaderRow: true,\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\n  },\n  headerMenu: {\n    autoAlign: true,\n    autoAlignOffset: 12,\n    minWidth: 140,\n    iconClearFilterCommand: 'fa fa-filter text-danger',\n    iconClearSortCommand: 'fa fa-unsorted',\n    iconFreezeColumns: 'fa fa-thumb-tack',\n    iconSortAscCommand: 'fa fa-sort-amount-asc',\n    iconSortDescCommand: 'fa fa-sort-amount-desc',\n    iconColumnHideCommand: 'fa fa-times',\n    iconColumnResizeByContentCommand: 'fa fa-arrows-h',\n    hideColumnResizeByContentCommand: false,\n    hideColumnHideCommand: false,\n    hideClearFilterCommand: false,\n    hideClearSortCommand: false,\n    hideFreezeColumnsCommand: true, // opt-in command\n    hideSortCommands: false\n  },\n  headerRowHeight: 35,\n  multiColumnSort: true,\n  numberedMultiColumnSort: true,\n  tristateMultiColumnSort: false,\n  sortColNumberInSeparateSpan: true,\n  suppressActiveCellChangeOnEdit: true,\n  pagination: {\n    pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],\n    pageSize: 25,\n    totalItems: 0\n  },\n  // technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options\n  rowDetailView: {\n    collapseAllOnSort: true,\n    cssClass: 'detail-view-toggle',\n    panelRows: 1,\n    keyPrefix: '__',\n    useRowClick: false,\n    useSimpleViewportCalc: true,\n    saveDetailViewOnScroll: false,\n  } as RowDetailView,\n  rowHeight: 35,\n  topPanelHeight: 35,\n  translationNamespaceSeparator: ':',\n  resetFilterSearchValueAfterOnBeforeCancellation: true,\n  resizeByContentOnlyOnFirstLoad: true,\n  resizeByContentOptions: {\n    alwaysRecalculateColumnWidth: false,\n    cellCharWidthInPx: 7.8,\n    cellPaddingWidthInPx: 14,\n    defaultRatioForStringType: 0.88,\n    formatterPaddingWidthInPx: 0,\n    maxItemToInspectCellContentWidth: 1000,\n    maxItemToInspectSingleColumnWidthByContent: 5000,\n    widthToRemoveFromExceededWidthReadjustment: 50,\n  },\n  treeDataOptions: {\n    exportIndentMarginLeft: 5,\n    exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',\n  } as unknown as TreeDataOption\n};\n\n/**\n * Value Extractor for both ColumnPicker & GridMenu Picker\n * when using Column Header Grouping, we'll prefix the column group title\n * else we'll simply return the column name title\n */\nfunction pickerHeaderColumnValueExtractor(column: Column) {\n  const headerGroup = column && column.columnGroup || '';\n  if (headerGroup) {\n    return headerGroup + ' - ' + column.name;\n  }\n  return column && column.name || '';\n}\n"]}
@@ -5,13 +5,15 @@
5
5
  */
6
6
  export function unsubscribeAllObservables(subscriptions) {
7
7
  if (Array.isArray(subscriptions)) {
8
- subscriptions.forEach((subscription) => {
9
- if (subscription && subscription.unsubscribe) {
8
+ let subscription = subscriptions.pop();
9
+ while (subscription) {
10
+ if (typeof subscription.unsubscribe === 'function') {
10
11
  subscription.unsubscribe();
11
12
  }
12
- });
13
- subscriptions = [];
13
+ subscription = subscriptions.pop();
14
+ }
14
15
  }
16
+ // TODO: deprecated, remove the return type in next major version
15
17
  return subscriptions;
16
18
  }
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2FuZ3VsYXItc2xpY2tncmlkL3NlcnZpY2VzL3V0aWxpdGllcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLHlCQUF5QixDQUFDLGFBQTZCO0lBQ3JFLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRTtRQUNoQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsWUFBMEIsRUFBRSxFQUFFO1lBQ25ELElBQUksWUFBWSxJQUFJLFlBQVksQ0FBQyxXQUFXLEVBQUU7Z0JBQzVDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQzthQUM1QjtRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0gsYUFBYSxHQUFHLEVBQUUsQ0FBQztLQUNwQjtJQUVELE9BQU8sYUFBYSxDQUFDO0FBQ3ZCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBVbnN1YnNjcmliZSBhbGwgT2JzZXJ2YWJsZXMgU3Vic2NyaXB0aW9uc1xuICogSXQgd2lsbCByZXR1cm4gYW4gZW1wdHkgYXJyYXkgaWYgaXQgYWxsIHdlbnQgd2VsbFxuICogQHBhcmFtIHN1YnNjcmlwdGlvbnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVuc3Vic2NyaWJlQWxsT2JzZXJ2YWJsZXMoc3Vic2NyaXB0aW9uczogU3Vic2NyaXB0aW9uW10pOiBTdWJzY3JpcHRpb25bXSB7XG4gIGlmIChBcnJheS5pc0FycmF5KHN1YnNjcmlwdGlvbnMpKSB7XG4gICAgc3Vic2NyaXB0aW9ucy5mb3JFYWNoKChzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbikgPT4ge1xuICAgICAgaWYgKHN1YnNjcmlwdGlvbiAmJiBzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUpIHtcbiAgICAgICAgc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgICB9XG4gICAgfSk7XG4gICAgc3Vic2NyaXB0aW9ucyA9IFtdO1xuICB9XG5cbiAgcmV0dXJuIHN1YnNjcmlwdGlvbnM7XG59XG4iXX0=
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2FuZ3VsYXItc2xpY2tncmlkL3NlcnZpY2VzL3V0aWxpdGllcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLHlCQUF5QixDQUFDLGFBQWlEO0lBQ3pGLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRTtRQUNoQyxJQUFJLFlBQVksR0FBRyxhQUFhLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDdkMsT0FBTyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxPQUFPLFlBQVksQ0FBQyxXQUFXLEtBQUssVUFBVSxFQUFFO2dCQUNsRCxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7YUFDNUI7WUFDRCxZQUFZLEdBQUcsYUFBYSxDQUFDLEdBQUcsRUFBRSxDQUFDO1NBQ3BDO0tBQ0Y7SUFFRCxpRUFBaUU7SUFDakUsT0FBTyxhQUFhLENBQUM7QUFDdkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVW5zdWJzY3JpYmUgYWxsIE9ic2VydmFibGVzIFN1YnNjcmlwdGlvbnNcbiAqIEl0IHdpbGwgcmV0dXJuIGFuIGVtcHR5IGFycmF5IGlmIGl0IGFsbCB3ZW50IHdlbGxcbiAqIEBwYXJhbSBzdWJzY3JpcHRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1bnN1YnNjcmliZUFsbE9ic2VydmFibGVzKHN1YnNjcmlwdGlvbnM6IEFycmF5PHsgdW5zdWJzY3JpYmU6ICgpPT4gdm9pZDsgfT4pOiBhbnlbXSB7XG4gIGlmIChBcnJheS5pc0FycmF5KHN1YnNjcmlwdGlvbnMpKSB7XG4gICAgbGV0IHN1YnNjcmlwdGlvbiA9IHN1YnNjcmlwdGlvbnMucG9wKCk7XG4gICAgd2hpbGUgKHN1YnNjcmlwdGlvbikge1xuICAgICAgaWYgKHR5cGVvZiBzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgICB9XG4gICAgICBzdWJzY3JpcHRpb24gPSBzdWJzY3JpcHRpb25zLnBvcCgpO1xuICAgIH1cbiAgfVxuXG4gIC8vIFRPRE86IGRlcHJlY2F0ZWQsIHJlbW92ZSB0aGUgcmV0dXJuIHR5cGUgaW4gbmV4dCBtYWpvciB2ZXJzaW9uXG4gIHJldHVybiBzdWJzY3JpcHRpb25zO1xufVxuIl19
@@ -8,10 +8,10 @@ import { TranslateModule } from '@ngx-translate/core';
8
8
  import { SlickRowDetailView as SlickRowDetailView$1 } from '@slickgrid-universal/row-detail-view-plugin';
9
9
  import { Observable } from 'rxjs';
10
10
  import * as DOMPurify from 'dompurify';
11
- import 'slickgrid/dist/slick.core.min';
12
- import 'slickgrid/dist/slick.interactions.min';
13
- import 'slickgrid/dist/slick.grid.min';
14
- import 'slickgrid/dist/slick.dataview.min';
11
+ import 'slickgrid/slick.core';
12
+ import 'slickgrid/slick.interactions';
13
+ import 'slickgrid/slick.grid';
14
+ import 'slickgrid/slick.dataview';
15
15
  import { EventPubSubService } from '@slickgrid-universal/event-pub-sub';
16
16
  import { SlickEmptyWarningComponent } from '@slickgrid-universal/empty-warning-component';
17
17
  import { SlickFooterComponent } from '@slickgrid-universal/custom-footer-component';
@@ -145,13 +145,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
145
145
  */
146
146
  function unsubscribeAllObservables(subscriptions) {
147
147
  if (Array.isArray(subscriptions)) {
148
- subscriptions.forEach((subscription) => {
149
- if (subscription && subscription.unsubscribe) {
148
+ let subscription = subscriptions.pop();
149
+ while (subscription) {
150
+ if (typeof subscription.unsubscribe === 'function') {
150
151
  subscription.unsubscribe();
151
152
  }
152
- });
153
- subscriptions = [];
153
+ subscription = subscriptions.pop();
154
+ }
154
155
  }
156
+ // TODO: deprecated, remove the return type in next major version
155
157
  return subscriptions;
156
158
  }
157
159
 
@@ -522,7 +524,11 @@ const GlobalGridOptions = {
522
524
  }
523
525
  },
524
526
  dataView: {
525
- syncGridSelection: true,
527
+ // when enabled, this will preserve the row selection even after filtering/sorting/grouping
528
+ syncGridSelection: {
529
+ preserveHidden: false,
530
+ preserveHiddenOnSelectionChange: true
531
+ },
526
532
  syncGridSelectionWithBackendService: false, // but disable it when using backend services
527
533
  },
528
534
  datasetIdPropertyName: 'id',
@@ -1252,12 +1258,12 @@ class AngularSlickgridComponent {
1252
1258
  }
1253
1259
  /**
1254
1260
  * On a Pagination changed, we will trigger a Grid State changed with the new pagination info
1255
- * Also if we use Row Selection or the Checkbox Selector, we need to reset any selection
1261
+ * Also if we use Row Selection or the Checkbox Selector with a Backend Service (Odata, GraphQL), we need to reset any selection
1256
1262
  */
1257
1263
  paginationChanged(pagination) {
1258
- var _a, _b;
1264
+ var _a, _b, _c;
1259
1265
  const isSyncGridSelectionEnabled = (_b = (_a = this.gridStateService) === null || _a === void 0 ? void 0 : _a.needToPreserveRowSelection()) !== null && _b !== void 0 ? _b : false;
1260
- if (!isSyncGridSelectionEnabled && (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector)) {
1266
+ if (this.slickGrid && !isSyncGridSelectionEnabled && ((_c = this.gridOptions) === null || _c === void 0 ? void 0 : _c.backendServiceApi) && (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector)) {
1261
1267
  this.slickGrid.setSelectedRows([]);
1262
1268
  }
1263
1269
  const { pageNumber, pageSize } = pagination;
@@ -1727,15 +1733,13 @@ class AngularSlickgridComponent {
1727
1733
  else if (Array.isArray(gridRowIndexes) && gridRowIndexes.length > 0) {
1728
1734
  dataContextIds = this.dataView.mapRowsToIds(gridRowIndexes) || [];
1729
1735
  }
1730
- this.gridStateService.selectedRowDataContextIds = dataContextIds;
1731
- // change the selected rows except UNLESS it's a Local Grid with Pagination
1732
- // local Pagination uses the DataView and that also trigger a change/refresh
1733
- // and we don't want to trigger 2 Grid State changes just 1
1734
- if ((this._isLocalGrid && !this.gridOptions.enablePagination) || !this._isLocalGrid) {
1735
- setTimeout(() => {
1736
- if (this.slickGrid && Array.isArray(gridRowIndexes)) {
1737
- this.slickGrid.setSelectedRows(gridRowIndexes);
1738
- }
1736
+ // apply row selection when defined as grid presets
1737
+ if (this.slickGrid && Array.isArray(gridRowIndexes)) {
1738
+ this.slickGrid.setSelectedRows(gridRowIndexes);
1739
+ this.dataView.setSelectedIds(dataContextIds || [], {
1740
+ isRowBeingAdded: true,
1741
+ shouldTriggerEvent: false,
1742
+ applyRowSelectionToGrid: true
1739
1743
  });
1740
1744
  }
1741
1745
  }