lsp-grid 1.0.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.
- package/README.md +34 -0
- package/dist/cjs/app-globals-Bfsg1bDt.js +16 -0
- package/dist/cjs/app-globals-Bfsg1bDt.js.map +1 -0
- package/dist/cjs/cell-renderer-DtuYp7tj.js +106 -0
- package/dist/cjs/cell-renderer-DtuYp7tj.js.map +1 -0
- package/dist/cjs/column.drag.plugin-BIptTmfz.js +2554 -0
- package/dist/cjs/column.drag.plugin-BIptTmfz.js.map +1 -0
- package/dist/cjs/column.service-BnVSAfcu.js +1391 -0
- package/dist/cjs/column.service-BnVSAfcu.js.map +1 -0
- package/dist/cjs/data.store-CrF4Nf9q.js +3615 -0
- package/dist/cjs/data.store-CrF4Nf9q.js.map +1 -0
- package/dist/cjs/debounce-DgeyTQM0.js +498 -0
- package/dist/cjs/debounce-DgeyTQM0.js.map +1 -0
- package/dist/cjs/edit.utils-Bw-E3Fj6.js +118 -0
- package/dist/cjs/edit.utils-Bw-E3Fj6.js.map +1 -0
- package/dist/cjs/events-D0Syn6ut.js +46 -0
- package/dist/cjs/events-D0Syn6ut.js.map +1 -0
- package/dist/cjs/filter.button-CaAAXq-6.js +49 -0
- package/dist/cjs/filter.button-CaAAXq-6.js.map +1 -0
- package/dist/cjs/header-cell-renderer-DhRJqZ-w.js +356 -0
- package/dist/cjs/header-cell-renderer-DhRJqZ-w.js.map +1 -0
- package/dist/cjs/index-VM40U6Gh.js +2549 -0
- package/dist/cjs/index-VM40U6Gh.js.map +1 -0
- package/dist/cjs/index.cjs.js +346 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/loader.cjs.js +19 -0
- package/dist/cjs/loader.cjs.js.map +1 -0
- package/dist/cjs/revo-grid.cjs.entry.js +2187 -0
- package/dist/cjs/revo-grid.cjs.entry.js.map +1 -0
- package/dist/cjs/revo-grid.cjs.js +31 -0
- package/dist/cjs/revo-grid.cjs.js.map +1 -0
- package/dist/cjs/revo-grid.entry.cjs.js.map +1 -0
- package/dist/cjs/revogr-attribution.revogr-extra.revogr-focus.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.cjs.js.map +1 -0
- package/dist/cjs/revogr-attribution_7.cjs.entry.js +1463 -0
- package/dist/cjs/revogr-attribution_7.cjs.entry.js.map +1 -0
- package/dist/cjs/revogr-clipboard.revogr-edit.revogr-order-editor.entry.cjs.js.map +1 -0
- package/dist/cjs/revogr-clipboard_3.cjs.entry.js +456 -0
- package/dist/cjs/revogr-clipboard_3.cjs.entry.js.map +1 -0
- package/dist/cjs/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.cjs.js.map +1 -0
- package/dist/cjs/revogr-data_4.cjs.entry.js +948 -0
- package/dist/cjs/revogr-data_4.cjs.entry.js.map +1 -0
- package/dist/cjs/revogr-filter-panel.cjs.entry.js +382 -0
- package/dist/cjs/revogr-filter-panel.cjs.entry.js.map +1 -0
- package/dist/cjs/revogr-filter-panel.entry.cjs.js.map +1 -0
- package/dist/cjs/row-header-utils-DL640c7x.js +420 -0
- package/dist/cjs/row-header-utils-DL640c7x.js.map +1 -0
- package/dist/cjs/text-editor-DWChyeVV.js +81 -0
- package/dist/cjs/text-editor-DWChyeVV.js.map +1 -0
- package/dist/cjs/throttle-Bb1Bbfd1.js +278 -0
- package/dist/cjs/throttle-Bb1Bbfd1.js.map +1 -0
- package/dist/cjs/viewport.helpers-CI6uB8tu.js +59 -0
- package/dist/cjs/viewport.helpers-CI6uB8tu.js.map +1 -0
- package/dist/collection/collection-manifest.json +28 -0
- package/dist/collection/components/attribution/revogr-attribution.js +20 -0
- package/dist/collection/components/attribution/revogr-attribution.js.map +1 -0
- package/dist/collection/components/clipboard/revogr-clipboard.js +396 -0
- package/dist/collection/components/clipboard/revogr-clipboard.js.map +1 -0
- package/dist/collection/components/data/cell-renderer.js +44 -0
- package/dist/collection/components/data/cell-renderer.js.map +1 -0
- package/dist/collection/components/data/column.service.js +293 -0
- package/dist/collection/components/data/column.service.js.map +1 -0
- package/dist/collection/components/data/revogr-data-style.css +75 -0
- package/dist/collection/components/data/revogr-data.js +697 -0
- package/dist/collection/components/data/revogr-data.js.map +1 -0
- package/dist/collection/components/data/row-highlight.plugin.js +51 -0
- package/dist/collection/components/data/row-highlight.plugin.js.map +1 -0
- package/dist/collection/components/data/row-renderer.js +16 -0
- package/dist/collection/components/data/row-renderer.js.map +1 -0
- package/dist/collection/components/editors/edit.utils.js +13 -0
- package/dist/collection/components/editors/edit.utils.js.map +1 -0
- package/dist/collection/components/editors/revogr-edit-style.css +16 -0
- package/dist/collection/components/editors/revogr-edit.js +346 -0
- package/dist/collection/components/editors/revogr-edit.js.map +1 -0
- package/dist/collection/components/editors/text-editor.js +74 -0
- package/dist/collection/components/editors/text-editor.js.map +1 -0
- package/dist/collection/components/extra/revogr-extra.js +125 -0
- package/dist/collection/components/extra/revogr-extra.js.map +1 -0
- package/dist/collection/components/header/header-cell-renderer.js +34 -0
- package/dist/collection/components/header/header-cell-renderer.js.map +1 -0
- package/dist/collection/components/header/header-group-renderer.js +25 -0
- package/dist/collection/components/header/header-group-renderer.js.map +1 -0
- package/dist/collection/components/header/header-renderer.js +61 -0
- package/dist/collection/components/header/header-renderer.js.map +1 -0
- package/dist/collection/components/header/resizable.directive.js +237 -0
- package/dist/collection/components/header/resizable.directive.js.map +1 -0
- package/dist/collection/components/header/resizable.element.js +38 -0
- package/dist/collection/components/header/resizable.element.js.map +1 -0
- package/dist/collection/components/header/revogr-header-style.css +144 -0
- package/dist/collection/components/header/revogr-header.js +573 -0
- package/dist/collection/components/header/revogr-header.js.map +1 -0
- package/dist/collection/components/order/order-renderer.js +50 -0
- package/dist/collection/components/order/order-renderer.js.map +1 -0
- package/dist/collection/components/order/order-row.service.js +72 -0
- package/dist/collection/components/order/order-row.service.js.map +1 -0
- package/dist/collection/components/order/revogr-order-editor.js +461 -0
- package/dist/collection/components/order/revogr-order-editor.js.map +1 -0
- package/dist/collection/components/overlay/autofill.service.js +224 -0
- package/dist/collection/components/overlay/autofill.service.js.map +1 -0
- package/dist/collection/components/overlay/keyboard.service.js +158 -0
- package/dist/collection/components/overlay/keyboard.service.js.map +1 -0
- package/dist/collection/components/overlay/revogr-overlay-selection.js +1515 -0
- package/dist/collection/components/overlay/revogr-overlay-selection.js.map +1 -0
- package/dist/collection/components/overlay/revogr-overlay-style.css +95 -0
- package/dist/collection/components/overlay/selection.utils.js +136 -0
- package/dist/collection/components/overlay/selection.utils.js.map +1 -0
- package/dist/collection/components/revoGrid/grid.helpers.js +33 -0
- package/dist/collection/components/revoGrid/grid.helpers.js.map +1 -0
- package/dist/collection/components/revoGrid/plugin.service.js +81 -0
- package/dist/collection/components/revoGrid/plugin.service.js.map +1 -0
- package/dist/collection/components/revoGrid/revo-grid-style.css +567 -0
- package/dist/collection/components/revoGrid/revo-grid.js +3671 -0
- package/dist/collection/components/revoGrid/revo-grid.js.map +1 -0
- package/dist/collection/components/revoGrid/viewport.helpers.js +49 -0
- package/dist/collection/components/revoGrid/viewport.helpers.js.map +1 -0
- package/dist/collection/components/revoGrid/viewport.resize.service.js +55 -0
- package/dist/collection/components/revoGrid/viewport.resize.service.js.map +1 -0
- package/dist/collection/components/revoGrid/viewport.scrolling.service.js +90 -0
- package/dist/collection/components/revoGrid/viewport.scrolling.service.js.map +1 -0
- package/dist/collection/components/revoGrid/viewport.service.js +237 -0
- package/dist/collection/components/revoGrid/viewport.service.js.map +1 -0
- package/dist/collection/components/rowHeaders/revogr-row-headers.js +291 -0
- package/dist/collection/components/rowHeaders/revogr-row-headers.js.map +1 -0
- package/dist/collection/components/rowHeaders/row-header-render.js +5 -0
- package/dist/collection/components/rowHeaders/row-header-render.js.map +1 -0
- package/dist/collection/components/scroll/revogr-viewport-scroll-style.css +69 -0
- package/dist/collection/components/scroll/revogr-viewport-scroll.js +601 -0
- package/dist/collection/components/scroll/revogr-viewport-scroll.js.map +1 -0
- package/dist/collection/components/scrollable/autohide-scroll.plugin.js +44 -0
- package/dist/collection/components/scrollable/autohide-scroll.plugin.js.map +1 -0
- package/dist/collection/components/scrollable/revogr-scroll-style.css +34 -0
- package/dist/collection/components/scrollable/revogr-scroll-virtual.js +295 -0
- package/dist/collection/components/scrollable/revogr-scroll-virtual.js.map +1 -0
- package/dist/collection/components/selectionFocus/revogr-focus-style.css +7 -0
- package/dist/collection/components/selectionFocus/revogr-focus.js +400 -0
- package/dist/collection/components/selectionFocus/revogr-focus.js.map +1 -0
- package/dist/collection/components/selectionTempRange/revogr-temp-range-style.css +28 -0
- package/dist/collection/components/selectionTempRange/revogr-temp-range.js +171 -0
- package/dist/collection/components/selectionTempRange/revogr-temp-range.js.map +1 -0
- package/dist/collection/components/vnode/vnode-converter.js +84 -0
- package/dist/collection/components/vnode/vnode-converter.js.map +1 -0
- package/dist/collection/components/vnode/vnode.utils.js +18 -0
- package/dist/collection/components/vnode/vnode.utils.js.map +1 -0
- package/dist/collection/global/global.js +19 -0
- package/dist/collection/global/global.js.map +1 -0
- package/dist/collection/index.js +13 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/collection/plugins/add-rows-on-paste.plugin.js +40 -0
- package/dist/collection/plugins/add-rows-on-paste.plugin.js.map +1 -0
- package/dist/collection/plugins/base.plugin.js +90 -0
- package/dist/collection/plugins/base.plugin.js.map +1 -0
- package/dist/collection/plugins/column.auto-size.plugin.js +225 -0
- package/dist/collection/plugins/column.auto-size.plugin.js.map +1 -0
- package/dist/collection/plugins/column.stretch.plugin.js +96 -0
- package/dist/collection/plugins/column.stretch.plugin.js.map +1 -0
- package/dist/collection/plugins/dispatcher.js +40 -0
- package/dist/collection/plugins/dispatcher.js.map +1 -0
- package/dist/collection/plugins/export/csv.js +72 -0
- package/dist/collection/plugins/export/csv.js.map +1 -0
- package/dist/collection/plugins/export/export.plugin.js +157 -0
- package/dist/collection/plugins/export/export.plugin.js.map +1 -0
- package/dist/collection/plugins/export/types.js +2 -0
- package/dist/collection/plugins/export/types.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/equal.js +21 -0
- package/dist/collection/plugins/filter/conditions/equal.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/number/greaterThan.js +14 -0
- package/dist/collection/plugins/filter/conditions/number/greaterThan.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/number/greaterThanOrEqual.js +11 -0
- package/dist/collection/plugins/filter/conditions/number/greaterThanOrEqual.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/number/lessThan.js +16 -0
- package/dist/collection/plugins/filter/conditions/number/lessThan.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/number/lessThanOrEqual.js +11 -0
- package/dist/collection/plugins/filter/conditions/number/lessThanOrEqual.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/set.js +7 -0
- package/dist/collection/plugins/filter/conditions/set.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/string/beginswith.js +21 -0
- package/dist/collection/plugins/filter/conditions/string/beginswith.js.map +1 -0
- package/dist/collection/plugins/filter/conditions/string/contains.js +25 -0
- package/dist/collection/plugins/filter/conditions/string/contains.js.map +1 -0
- package/dist/collection/plugins/filter/filter.button.js +28 -0
- package/dist/collection/plugins/filter/filter.button.js.map +1 -0
- package/dist/collection/plugins/filter/filter.indexed.js +49 -0
- package/dist/collection/plugins/filter/filter.indexed.js.map +1 -0
- package/dist/collection/plugins/filter/filter.panel.js +610 -0
- package/dist/collection/plugins/filter/filter.panel.js.map +1 -0
- package/dist/collection/plugins/filter/filter.plugin.js +388 -0
- package/dist/collection/plugins/filter/filter.plugin.js.map +1 -0
- package/dist/collection/plugins/filter/filter.style.css +165 -0
- package/dist/collection/plugins/filter/filter.types.js +9 -0
- package/dist/collection/plugins/filter/filter.types.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.const.js +16 -0
- package/dist/collection/plugins/groupingRow/grouping.const.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.row.expand.service.js +79 -0
- package/dist/collection/plugins/groupingRow/grouping.row.expand.service.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.row.plugin.js +245 -0
- package/dist/collection/plugins/groupingRow/grouping.row.plugin.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.row.renderer.js +38 -0
- package/dist/collection/plugins/groupingRow/grouping.row.renderer.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.row.types.js +2 -0
- package/dist/collection/plugins/groupingRow/grouping.row.types.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.service.js +178 -0
- package/dist/collection/plugins/groupingRow/grouping.service.js.map +1 -0
- package/dist/collection/plugins/groupingRow/grouping.trimmed.service.js +61 -0
- package/dist/collection/plugins/groupingRow/grouping.trimmed.service.js.map +1 -0
- package/dist/collection/plugins/index.js +15 -0
- package/dist/collection/plugins/index.js.map +1 -0
- package/dist/collection/plugins/moveColumn/column.drag.plugin.js +175 -0
- package/dist/collection/plugins/moveColumn/column.drag.plugin.js.map +1 -0
- package/dist/collection/plugins/moveColumn/order-column.handler.js +71 -0
- package/dist/collection/plugins/moveColumn/order-column.handler.js.map +1 -0
- package/dist/collection/plugins/rtl/rtl.plugin.js +110 -0
- package/dist/collection/plugins/rtl/rtl.plugin.js.map +1 -0
- package/dist/collection/plugins/sorting/sorting.func.js +82 -0
- package/dist/collection/plugins/sorting/sorting.func.js.map +1 -0
- package/dist/collection/plugins/sorting/sorting.plugin.js +224 -0
- package/dist/collection/plugins/sorting/sorting.plugin.js.map +1 -0
- package/dist/collection/plugins/sorting/sorting.sign.js +9 -0
- package/dist/collection/plugins/sorting/sorting.sign.js.map +1 -0
- package/dist/collection/plugins/sorting/sorting.types.js +2 -0
- package/dist/collection/plugins/sorting/sorting.types.js.map +1 -0
- package/dist/collection/plugins/wcag/index.js +84 -0
- package/dist/collection/plugins/wcag/index.js.map +1 -0
- package/dist/collection/serve/controller.js +344 -0
- package/dist/collection/serve/data.js +201 -0
- package/dist/collection/services/cell.helpers.js +12 -0
- package/dist/collection/services/cell.helpers.js.map +1 -0
- package/dist/collection/services/column.data.provider.js +119 -0
- package/dist/collection/services/column.data.provider.js.map +1 -0
- package/dist/collection/services/data.provider.js +89 -0
- package/dist/collection/services/data.provider.js.map +1 -0
- package/dist/collection/services/dimension.provider.js +176 -0
- package/dist/collection/services/dimension.provider.js.map +1 -0
- package/dist/collection/services/local.scroll.service.js +124 -0
- package/dist/collection/services/local.scroll.service.js.map +1 -0
- package/dist/collection/services/local.scroll.timer.js +81 -0
- package/dist/collection/services/local.scroll.timer.js.map +1 -0
- package/dist/collection/services/selection.store.connector.js +307 -0
- package/dist/collection/services/selection.store.connector.js.map +1 -0
- package/dist/collection/services/viewport.provider.js +17 -0
- package/dist/collection/services/viewport.provider.js.map +1 -0
- package/dist/collection/store/dataSource/data.proxy.js +45 -0
- package/dist/collection/store/dataSource/data.proxy.js.map +1 -0
- package/dist/collection/store/dataSource/data.store.js +144 -0
- package/dist/collection/store/dataSource/data.store.js.map +1 -0
- package/dist/collection/store/dataSource/index.js +7 -0
- package/dist/collection/store/dataSource/index.js.map +1 -0
- package/dist/collection/store/dataSource/trimmed.plugin.js +34 -0
- package/dist/collection/store/dataSource/trimmed.plugin.js.map +1 -0
- package/dist/collection/store/dimension/dimension.helpers.js +101 -0
- package/dist/collection/store/dimension/dimension.helpers.js.map +1 -0
- package/dist/collection/store/dimension/dimension.recalculate.plugin.js +35 -0
- package/dist/collection/store/dimension/dimension.recalculate.plugin.js.map +1 -0
- package/dist/collection/store/dimension/dimension.store.js +109 -0
- package/dist/collection/store/dimension/dimension.store.js.map +1 -0
- package/dist/collection/store/dimension/dimension.trim.plugin.js +61 -0
- package/dist/collection/store/dimension/dimension.trim.plugin.js.map +1 -0
- package/dist/collection/store/dimension/index.js +6 -0
- package/dist/collection/store/dimension/index.js.map +1 -0
- package/dist/collection/store/index.js +17 -0
- package/dist/collection/store/index.js.map +1 -0
- package/dist/collection/store/selection/index.js +6 -0
- package/dist/collection/store/selection/index.js.map +1 -0
- package/dist/collection/store/selection/selection.helpers.js +53 -0
- package/dist/collection/store/selection/selection.helpers.js.map +1 -0
- package/dist/collection/store/selection/selection.store.js +85 -0
- package/dist/collection/store/selection/selection.store.js.map +1 -0
- package/dist/collection/store/vp/index.js +6 -0
- package/dist/collection/store/vp/index.js.map +1 -0
- package/dist/collection/store/vp/viewport.helpers.js +251 -0
- package/dist/collection/store/vp/viewport.helpers.js.map +1 -0
- package/dist/collection/store/vp/viewport.store.js +151 -0
- package/dist/collection/store/vp/viewport.store.js.map +1 -0
- package/dist/collection/themeManager/theme.compact.js +9 -0
- package/dist/collection/themeManager/theme.compact.js.map +1 -0
- package/dist/collection/themeManager/theme.default.js +9 -0
- package/dist/collection/themeManager/theme.default.js.map +1 -0
- package/dist/collection/themeManager/theme.material.js +9 -0
- package/dist/collection/themeManager/theme.material.js.map +1 -0
- package/dist/collection/themeManager/theme.service.js +53 -0
- package/dist/collection/themeManager/theme.service.js.map +1 -0
- package/dist/collection/types/dimension.js +2 -0
- package/dist/collection/types/dimension.js.map +1 -0
- package/dist/collection/types/events.js +118 -0
- package/dist/collection/types/events.js.map +1 -0
- package/dist/collection/types/index.js +12 -0
- package/dist/collection/types/index.js.map +1 -0
- package/dist/collection/types/interfaces.js +2 -0
- package/dist/collection/types/interfaces.js.map +1 -0
- package/dist/collection/types/plugin.js +2 -0
- package/dist/collection/types/plugin.js.map +1 -0
- package/dist/collection/types/plugin.types.js +2 -0
- package/dist/collection/types/plugin.types.js.map +1 -0
- package/dist/collection/types/selection.js +2 -0
- package/dist/collection/types/selection.js.map +1 -0
- package/dist/collection/types/theme.js +2 -0
- package/dist/collection/types/theme.js.map +1 -0
- package/dist/collection/types/viewport.interfaces.js +2 -0
- package/dist/collection/types/viewport.interfaces.js.map +1 -0
- package/dist/collection/utils/browser.js +7 -0
- package/dist/collection/utils/browser.js.map +1 -0
- package/dist/collection/utils/closest.polifill.js +22 -0
- package/dist/collection/utils/closest.polifill.js.map +1 -0
- package/dist/collection/utils/column.utils.js +153 -0
- package/dist/collection/utils/column.utils.js.map +1 -0
- package/dist/collection/utils/consts.js +26 -0
- package/dist/collection/utils/consts.js.map +1 -0
- package/dist/collection/utils/events.js +39 -0
- package/dist/collection/utils/events.js.map +1 -0
- package/dist/collection/utils/header.utils.js +24 -0
- package/dist/collection/utils/header.utils.js.map +1 -0
- package/dist/collection/utils/index.js +140 -0
- package/dist/collection/utils/index.js.map +1 -0
- package/dist/collection/utils/key.codes.js +80 -0
- package/dist/collection/utils/key.codes.js.map +1 -0
- package/dist/collection/utils/key.utils.js +90 -0
- package/dist/collection/utils/key.utils.js.map +1 -0
- package/dist/collection/utils/mobile.js +7 -0
- package/dist/collection/utils/mobile.js.map +1 -0
- package/dist/collection/utils/platform.js +9 -0
- package/dist/collection/utils/platform.js.map +1 -0
- package/dist/collection/utils/row-header-utils.js +9 -0
- package/dist/collection/utils/row-header-utils.js.map +1 -0
- package/dist/collection/utils/store.types.js +2 -0
- package/dist/collection/utils/store.types.js.map +1 -0
- package/dist/collection/utils/store.utils.js +15 -0
- package/dist/collection/utils/store.utils.js.map +1 -0
- package/dist/esm/app-globals-FBz64o-g.js +14 -0
- package/dist/esm/app-globals-FBz64o-g.js.map +1 -0
- package/dist/esm/cell-renderer-Ca_PCGjJ.js +98 -0
- package/dist/esm/cell-renderer-Ca_PCGjJ.js.map +1 -0
- package/dist/esm/column.drag.plugin-BtuUyB-2.js +2528 -0
- package/dist/esm/column.drag.plugin-BtuUyB-2.js.map +1 -0
- package/dist/esm/column.service-CTqFIQUy.js +1343 -0
- package/dist/esm/column.service-CTqFIQUy.js.map +1 -0
- package/dist/esm/data.store-B-lvmoFH.js +3553 -0
- package/dist/esm/data.store-B-lvmoFH.js.map +1 -0
- package/dist/esm/debounce-DTUQ1fY7.js +488 -0
- package/dist/esm/debounce-DTUQ1fY7.js.map +1 -0
- package/dist/esm/edit.utils-CyCANCLB.js +103 -0
- package/dist/esm/edit.utils-CyCANCLB.js.map +1 -0
- package/dist/esm/events-CKtYJJSv.js +43 -0
- package/dist/esm/events-CKtYJJSv.js.map +1 -0
- package/dist/esm/filter.button-CjABZQgg.js +39 -0
- package/dist/esm/filter.button-CjABZQgg.js.map +1 -0
- package/dist/esm/header-cell-renderer-DnjpJuXq.js +351 -0
- package/dist/esm/header-cell-renderer-DnjpJuXq.js.map +1 -0
- package/dist/esm/index-BAoInZ4V.js +2519 -0
- package/dist/esm/index-BAoInZ4V.js.map +1 -0
- package/dist/esm/index.js +181 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/loader.js +17 -0
- package/dist/esm/loader.js.map +1 -0
- package/dist/esm/revo-grid.entry.js +2185 -0
- package/dist/esm/revo-grid.entry.js.map +1 -0
- package/dist/esm/revo-grid.js +27 -0
- package/dist/esm/revo-grid.js.map +1 -0
- package/dist/esm/revogr-attribution.revogr-extra.revogr-focus.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.js.map +1 -0
- package/dist/esm/revogr-attribution_7.entry.js +1455 -0
- package/dist/esm/revogr-attribution_7.entry.js.map +1 -0
- package/dist/esm/revogr-clipboard.revogr-edit.revogr-order-editor.entry.js.map +1 -0
- package/dist/esm/revogr-clipboard_3.entry.js +452 -0
- package/dist/esm/revogr-clipboard_3.entry.js.map +1 -0
- package/dist/esm/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.js.map +1 -0
- package/dist/esm/revogr-data_4.entry.js +943 -0
- package/dist/esm/revogr-data_4.entry.js.map +1 -0
- package/dist/esm/revogr-filter-panel.entry.js +380 -0
- package/dist/esm/revogr-filter-panel.entry.js.map +1 -0
- package/dist/esm/row-header-utils-vnoLGj5A.js +407 -0
- package/dist/esm/row-header-utils-vnoLGj5A.js.map +1 -0
- package/dist/esm/text-editor-Cp7lwBZi.js +79 -0
- package/dist/esm/text-editor-Cp7lwBZi.js.map +1 -0
- package/dist/esm/throttle-DiUrHjcY.js +273 -0
- package/dist/esm/throttle-DiUrHjcY.js.map +1 -0
- package/dist/esm/viewport.helpers-Ch4AQMMg.js +53 -0
- package/dist/esm/viewport.helpers-Ch4AQMMg.js.map +1 -0
- package/dist/index.cjs.js +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/revo-grid/app-globals-FBz64o-g.js +14 -0
- package/dist/revo-grid/app-globals-FBz64o-g.js.map +1 -0
- package/dist/revo-grid/cell-renderer-Ca_PCGjJ.js +98 -0
- package/dist/revo-grid/cell-renderer-Ca_PCGjJ.js.map +1 -0
- package/dist/revo-grid/column.drag.plugin-BtuUyB-2.js +2528 -0
- package/dist/revo-grid/column.drag.plugin-BtuUyB-2.js.map +1 -0
- package/dist/revo-grid/column.service-CTqFIQUy.js +1343 -0
- package/dist/revo-grid/column.service-CTqFIQUy.js.map +1 -0
- package/dist/revo-grid/data.store-B-lvmoFH.js +3553 -0
- package/dist/revo-grid/data.store-B-lvmoFH.js.map +1 -0
- package/dist/revo-grid/debounce-DTUQ1fY7.js +488 -0
- package/dist/revo-grid/debounce-DTUQ1fY7.js.map +1 -0
- package/dist/revo-grid/edit.utils-CyCANCLB.js +103 -0
- package/dist/revo-grid/edit.utils-CyCANCLB.js.map +1 -0
- package/dist/revo-grid/events-CKtYJJSv.js +43 -0
- package/dist/revo-grid/events-CKtYJJSv.js.map +1 -0
- package/dist/revo-grid/filter.button-CjABZQgg.js +39 -0
- package/dist/revo-grid/filter.button-CjABZQgg.js.map +1 -0
- package/dist/revo-grid/header-cell-renderer-DnjpJuXq.js +351 -0
- package/dist/revo-grid/header-cell-renderer-DnjpJuXq.js.map +1 -0
- package/dist/revo-grid/index-BAoInZ4V.js +2490 -0
- package/dist/revo-grid/index-BAoInZ4V.js.map +1 -0
- package/dist/revo-grid/index.esm.js +181 -0
- package/dist/revo-grid/index.esm.js.map +1 -0
- package/dist/revo-grid/loader.esm.js.map +1 -0
- package/dist/revo-grid/revo-grid.entry.esm.js.map +1 -0
- package/dist/revo-grid/revo-grid.entry.js +2185 -0
- package/dist/revo-grid/revo-grid.entry.js.map +1 -0
- package/dist/revo-grid/revo-grid.esm.js +27 -0
- package/dist/revo-grid/revo-grid.esm.js.map +1 -0
- package/dist/revo-grid/revogr-attribution.revogr-extra.revogr-focus.revogr-overlay-selection.revogr-row-headers.revogr-scroll-virtual.revogr-temp-range.entry.esm.js.map +1 -0
- package/dist/revo-grid/revogr-attribution_7.entry.js +1455 -0
- package/dist/revo-grid/revogr-attribution_7.entry.js.map +1 -0
- package/dist/revo-grid/revogr-clipboard.revogr-edit.revogr-order-editor.entry.esm.js.map +1 -0
- package/dist/revo-grid/revogr-clipboard_3.entry.js +452 -0
- package/dist/revo-grid/revogr-clipboard_3.entry.js.map +1 -0
- package/dist/revo-grid/revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.esm.js.map +1 -0
- package/dist/revo-grid/revogr-data_4.entry.js +943 -0
- package/dist/revo-grid/revogr-data_4.entry.js.map +1 -0
- package/dist/revo-grid/revogr-filter-panel.entry.esm.js.map +1 -0
- package/dist/revo-grid/revogr-filter-panel.entry.js +380 -0
- package/dist/revo-grid/revogr-filter-panel.entry.js.map +1 -0
- package/dist/revo-grid/row-header-utils-vnoLGj5A.js +407 -0
- package/dist/revo-grid/row-header-utils-vnoLGj5A.js.map +1 -0
- package/dist/revo-grid/text-editor-Cp7lwBZi.js +79 -0
- package/dist/revo-grid/text-editor-Cp7lwBZi.js.map +1 -0
- package/dist/revo-grid/throttle-DiUrHjcY.js +273 -0
- package/dist/revo-grid/throttle-DiUrHjcY.js.map +1 -0
- package/dist/revo-grid/viewport.helpers-Ch4AQMMg.js +53 -0
- package/dist/revo-grid/viewport.helpers-Ch4AQMMg.js.map +1 -0
- package/dist/types/components/attribution/revogr-attribution.d.ts +12 -0
- package/dist/types/components/clipboard/revogr-clipboard.d.ts +89 -0
- package/dist/types/components/data/cell-renderer.d.ts +12 -0
- package/dist/types/components/data/column.service.d.ts +61 -0
- package/dist/types/components/data/revogr-data.d.ts +107 -0
- package/dist/types/components/data/row-highlight.plugin.d.ts +10 -0
- package/dist/types/components/data/row-renderer.d.ts +12 -0
- package/dist/types/components/editors/edit.utils.d.ts +3 -0
- package/dist/types/components/editors/revogr-edit.d.ts +63 -0
- package/dist/types/components/editors/text-editor.d.ts +43 -0
- package/dist/types/components/extra/revogr-extra.d.ts +38 -0
- package/dist/types/components/header/header-cell-renderer.d.ts +9 -0
- package/dist/types/components/header/header-group-renderer.d.ts +15 -0
- package/dist/types/components/header/header-renderer.d.ts +16 -0
- package/dist/types/components/header/resizable.directive.d.ts +55 -0
- package/dist/types/components/header/resizable.element.d.ts +5 -0
- package/dist/types/components/header/revogr-header.d.ts +90 -0
- package/dist/types/components/order/order-renderer.d.ts +29 -0
- package/dist/types/components/order/order-row.service.d.ts +27 -0
- package/dist/types/components/order/revogr-order-editor.d.ts +56 -0
- package/dist/types/components/overlay/autofill.service.d.ts +80 -0
- package/dist/types/components/overlay/keyboard.service.d.ts +28 -0
- package/dist/types/components/overlay/revogr-overlay-selection.d.ts +278 -0
- package/dist/types/components/overlay/selection.utils.d.ts +47 -0
- package/dist/types/components/revoGrid/grid.helpers.d.ts +17 -0
- package/dist/types/components/revoGrid/plugin.service.d.ts +37 -0
- package/dist/types/components/revoGrid/revo-grid.d.ts +686 -0
- package/dist/types/components/revoGrid/viewport.helpers.d.ts +39 -0
- package/dist/types/components/revoGrid/viewport.resize.service.d.ts +17 -0
- package/dist/types/components/revoGrid/viewport.scrolling.service.d.ts +20 -0
- package/dist/types/components/revoGrid/viewport.service.d.ts +59 -0
- package/dist/types/components/rowHeaders/revogr-row-headers.d.ts +51 -0
- package/dist/types/components/rowHeaders/row-header-render.d.ts +9 -0
- package/dist/types/components/scroll/revogr-viewport-scroll.d.ts +117 -0
- package/dist/types/components/scrollable/autohide-scroll.plugin.d.ts +22 -0
- package/dist/types/components/scrollable/revogr-scroll-virtual.d.ts +43 -0
- package/dist/types/components/selectionFocus/revogr-focus.d.ts +58 -0
- package/dist/types/components/selectionTempRange/revogr-temp-range.d.ts +28 -0
- package/dist/types/components/vnode/vnode-converter.d.ts +19 -0
- package/dist/types/components/vnode/vnode.utils.d.ts +9 -0
- package/dist/types/components.d.ts +2583 -0
- package/dist/types/global/global.d.ts +1 -0
- package/dist/types/index.d.ts +9 -0
- package/dist/types/plugins/add-rows-on-paste.plugin.d.ts +14 -0
- package/dist/types/plugins/base.plugin.d.ts +51 -0
- package/dist/types/plugins/column.auto-size.plugin.d.ts +55 -0
- package/dist/types/plugins/column.stretch.plugin.d.ts +20 -0
- package/dist/types/plugins/dispatcher.d.ts +20 -0
- package/dist/types/plugins/export/csv.d.ts +9 -0
- package/dist/types/plugins/export/export.plugin.d.ts +24 -0
- package/dist/types/plugins/export/types.d.ts +23 -0
- package/dist/types/plugins/filter/conditions/equal.d.ts +4 -0
- package/dist/types/plugins/filter/conditions/number/greaterThan.d.ts +3 -0
- package/dist/types/plugins/filter/conditions/number/greaterThanOrEqual.d.ts +3 -0
- package/dist/types/plugins/filter/conditions/number/lessThan.d.ts +3 -0
- package/dist/types/plugins/filter/conditions/number/lessThanOrEqual.d.ts +3 -0
- package/dist/types/plugins/filter/conditions/set.d.ts +4 -0
- package/dist/types/plugins/filter/conditions/string/beginswith.d.ts +3 -0
- package/dist/types/plugins/filter/conditions/string/contains.d.ts +4 -0
- package/dist/types/plugins/filter/filter.button.d.ts +14 -0
- package/dist/types/plugins/filter/filter.indexed.d.ts +20 -0
- package/dist/types/plugins/filter/filter.panel.d.ts +53 -0
- package/dist/types/plugins/filter/filter.plugin.d.ts +73 -0
- package/dist/types/plugins/filter/filter.types.d.ts +129 -0
- package/dist/types/plugins/groupingRow/grouping.const.d.ts +12 -0
- package/dist/types/plugins/groupingRow/grouping.row.expand.service.d.ts +15 -0
- package/dist/types/plugins/groupingRow/grouping.row.plugin.d.ts +39 -0
- package/dist/types/plugins/groupingRow/grouping.row.renderer.d.ts +6 -0
- package/dist/types/plugins/groupingRow/grouping.row.types.d.ts +103 -0
- package/dist/types/plugins/groupingRow/grouping.service.d.ts +36 -0
- package/dist/types/plugins/groupingRow/grouping.trimmed.service.d.ts +10 -0
- package/dist/types/plugins/index.d.ts +11 -0
- package/dist/types/plugins/moveColumn/column.drag.plugin.d.ts +42 -0
- package/dist/types/plugins/moveColumn/order-column.handler.d.ts +16 -0
- package/dist/types/plugins/rtl/rtl.plugin.d.ts +37 -0
- package/dist/types/plugins/sorting/sorting.func.d.ts +9 -0
- package/dist/types/plugins/sorting/sorting.plugin.d.ts +48 -0
- package/dist/types/plugins/sorting/sorting.sign.d.ts +6 -0
- package/dist/types/plugins/sorting/sorting.types.d.ts +14 -0
- package/dist/types/plugins/wcag/index.d.ts +26 -0
- package/dist/types/services/cell.helpers.d.ts +2 -0
- package/dist/types/services/column.data.provider.d.ts +27 -0
- package/dist/types/services/data.provider.d.ts +36 -0
- package/dist/types/services/dimension.provider.d.ts +66 -0
- package/dist/types/services/local.scroll.service.d.ts +36 -0
- package/dist/types/services/local.scroll.timer.d.ts +32 -0
- package/dist/types/services/selection.store.connector.d.ts +79 -0
- package/dist/types/services/viewport.provider.d.ts +7 -0
- package/dist/types/stencil-public-runtime.d.ts +1709 -0
- package/dist/types/store/dataSource/data.proxy.d.ts +14 -0
- package/dist/types/store/dataSource/data.store.d.ts +74 -0
- package/dist/types/store/dataSource/index.d.ts +3 -0
- package/dist/types/store/dataSource/trimmed.plugin.d.ts +12 -0
- package/dist/types/store/dimension/dimension.helpers.d.ts +24 -0
- package/dist/types/store/dimension/dimension.recalculate.plugin.d.ts +9 -0
- package/dist/types/store/dimension/dimension.store.d.ts +21 -0
- package/dist/types/store/dimension/dimension.trim.plugin.d.ts +13 -0
- package/dist/types/store/dimension/index.d.ts +2 -0
- package/dist/types/store/index.d.ts +8 -0
- package/dist/types/store/selection/index.d.ts +2 -0
- package/dist/types/store/selection/selection.helpers.d.ts +6 -0
- package/dist/types/store/selection/selection.store.d.ts +22 -0
- package/dist/types/store/vp/index.d.ts +7 -0
- package/dist/types/store/vp/viewport.helpers.d.ts +54 -0
- package/dist/types/store/vp/viewport.store.d.ts +26 -0
- package/dist/types/themeManager/theme.compact.d.ts +4 -0
- package/dist/types/themeManager/theme.default.d.ts +4 -0
- package/dist/types/themeManager/theme.material.d.ts +4 -0
- package/dist/types/themeManager/theme.service.d.ts +13 -0
- package/dist/types/types/dimension.d.ts +8 -0
- package/dist/types/types/events.d.ts +2 -0
- package/dist/types/types/index.d.ts +8 -0
- package/dist/types/types/interfaces.d.ts +768 -0
- package/dist/types/types/plugin.d.ts +9 -0
- package/dist/types/types/plugin.types.d.ts +48 -0
- package/dist/types/types/selection.d.ts +178 -0
- package/dist/types/types/theme.d.ts +7 -0
- package/dist/types/types/viewport.interfaces.d.ts +45 -0
- package/dist/types/utils/browser.d.ts +1 -0
- package/dist/types/utils/closest.polifill.d.ts +0 -0
- package/dist/types/utils/column.utils.d.ts +52 -0
- package/dist/types/utils/consts.d.ts +22 -0
- package/dist/types/utils/events.d.ts +5 -0
- package/dist/types/utils/header.utils.d.ts +2 -0
- package/dist/types/utils/index.d.ts +32 -0
- package/dist/types/utils/key.codes.d.ts +73 -0
- package/dist/types/utils/key.utils.d.ts +13 -0
- package/dist/types/utils/mobile.d.ts +1 -0
- package/dist/types/utils/platform.d.ts +4 -0
- package/dist/types/utils/row-header-utils.d.ts +2 -0
- package/dist/types/utils/store.types.d.ts +97 -0
- package/dist/types/utils/store.utils.d.ts +10 -0
- package/hydrate/index.d.ts +273 -0
- package/hydrate/index.js +33890 -0
- package/hydrate/index.mjs +33882 -0
- package/hydrate/package.json +12 -0
- package/loader/cdn.js +4 -0
- package/loader/index.cjs.js +4 -0
- package/loader/index.d.ts +24 -0
- package/loader/index.es2017.js +4 -0
- package/loader/index.js +5 -0
- package/package.json +101 -0
- package/react/dist/index.d.ts +6191 -0
- package/react/dist/react-datagrid.js +260 -0
- package/react/dist/react-datagrid.umd.cjs +272 -0
- package/standalone/column.service.js +1345 -0
- package/standalone/column.service.js.map +1 -0
- package/standalone/consts.js +30 -0
- package/standalone/consts.js.map +1 -0
- package/standalone/data.store.js +3099 -0
- package/standalone/data.store.js.map +1 -0
- package/standalone/debounce.js +215 -0
- package/standalone/debounce.js.map +1 -0
- package/standalone/dimension.helpers.js +229 -0
- package/standalone/dimension.helpers.js.map +1 -0
- package/standalone/filter.button.js +39 -0
- package/standalone/filter.button.js.map +1 -0
- package/standalone/index.d.ts +68 -0
- package/standalone/index.js +217 -0
- package/standalone/index.js.map +1 -0
- package/standalone/index2.js +140 -0
- package/standalone/index2.js.map +1 -0
- package/standalone/local.scroll.timer.js +207 -0
- package/standalone/local.scroll.timer.js.map +1 -0
- package/standalone/platform.js +90 -0
- package/standalone/platform.js.map +1 -0
- package/standalone/revo-grid.d.ts +11 -0
- package/standalone/revo-grid.js +4884 -0
- package/standalone/revo-grid.js.map +1 -0
- package/standalone/revogr-attribution.d.ts +11 -0
- package/standalone/revogr-attribution.js +12 -0
- package/standalone/revogr-attribution.js.map +1 -0
- package/standalone/revogr-attribution2.js +32 -0
- package/standalone/revogr-attribution2.js.map +1 -0
- package/standalone/revogr-clipboard.d.ts +11 -0
- package/standalone/revogr-clipboard.js +12 -0
- package/standalone/revogr-clipboard.js.map +1 -0
- package/standalone/revogr-clipboard2.js +164 -0
- package/standalone/revogr-clipboard2.js.map +1 -0
- package/standalone/revogr-data.d.ts +11 -0
- package/standalone/revogr-data.js +12 -0
- package/standalone/revogr-data.js.map +1 -0
- package/standalone/revogr-data2.js +378 -0
- package/standalone/revogr-data2.js.map +1 -0
- package/standalone/revogr-edit.d.ts +11 -0
- package/standalone/revogr-edit.js +12 -0
- package/standalone/revogr-edit.js.map +1 -0
- package/standalone/revogr-edit2.js +334 -0
- package/standalone/revogr-edit2.js.map +1 -0
- package/standalone/revogr-extra.d.ts +11 -0
- package/standalone/revogr-extra.js +12 -0
- package/standalone/revogr-extra.js.map +1 -0
- package/standalone/revogr-extra2.js +73 -0
- package/standalone/revogr-extra2.js.map +1 -0
- package/standalone/revogr-filter-panel.d.ts +11 -0
- package/standalone/revogr-filter-panel.js +411 -0
- package/standalone/revogr-filter-panel.js.map +1 -0
- package/standalone/revogr-focus.d.ts +11 -0
- package/standalone/revogr-focus.js +12 -0
- package/standalone/revogr-focus.js.map +1 -0
- package/standalone/revogr-focus2.js +112 -0
- package/standalone/revogr-focus2.js.map +1 -0
- package/standalone/revogr-header.d.ts +11 -0
- package/standalone/revogr-header.js +12 -0
- package/standalone/revogr-header.js.map +1 -0
- package/standalone/revogr-header2.js +707 -0
- package/standalone/revogr-header2.js.map +1 -0
- package/standalone/revogr-order-editor.d.ts +11 -0
- package/standalone/revogr-order-editor.js +12 -0
- package/standalone/revogr-order-editor.js.map +1 -0
- package/standalone/revogr-order-editor2.js +201 -0
- package/standalone/revogr-order-editor2.js.map +1 -0
- package/standalone/revogr-overlay-selection.d.ts +11 -0
- package/standalone/revogr-overlay-selection.js +12 -0
- package/standalone/revogr-overlay-selection.js.map +1 -0
- package/standalone/revogr-overlay-selection2.js +972 -0
- package/standalone/revogr-overlay-selection2.js.map +1 -0
- package/standalone/revogr-row-headers.d.ts +11 -0
- package/standalone/revogr-row-headers.js +12 -0
- package/standalone/revogr-row-headers.js.map +1 -0
- package/standalone/revogr-row-headers2.js +520 -0
- package/standalone/revogr-row-headers2.js.map +1 -0
- package/standalone/revogr-scroll-virtual.d.ts +11 -0
- package/standalone/revogr-scroll-virtual.js +12 -0
- package/standalone/revogr-scroll-virtual.js.map +1 -0
- package/standalone/revogr-scroll-virtual2.js +184 -0
- package/standalone/revogr-scroll-virtual2.js.map +1 -0
- package/standalone/revogr-temp-range.d.ts +11 -0
- package/standalone/revogr-temp-range.js +12 -0
- package/standalone/revogr-temp-range.js.map +1 -0
- package/standalone/revogr-temp-range2.js +93 -0
- package/standalone/revogr-temp-range2.js.map +1 -0
- package/standalone/revogr-viewport-scroll.d.ts +11 -0
- package/standalone/revogr-viewport-scroll.js +12 -0
- package/standalone/revogr-viewport-scroll.js.map +1 -0
- package/standalone/revogr-viewport-scroll2.js +421 -0
- package/standalone/revogr-viewport-scroll2.js.map +1 -0
- package/standalone/selection.utils.js +179 -0
- package/standalone/selection.utils.js.map +1 -0
- package/standalone/throttle.js +75 -0
- package/standalone/throttle.js.map +1 -0
- package/standalone/toNumber.js +282 -0
- package/standalone/toNumber.js.map +1 -0
- package/standalone/vnode-converter.js +46 -0
- package/standalone/vnode-converter.js.map +1 -0
- package/standalone/vnode-html.d.ts +11 -0
- package/standalone/vnode-html.js +12 -0
- package/standalone/vnode-html.js.map +1 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"revogr-data.revogr-header.revogr-viewport-scroll.vnode-html.entry.js","mappings":"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","names":["GroupHeaderRenderer"],"sources":["src/components/data/row-highlight.plugin.ts","src/components/vnode/vnode.utils.ts","src/components/data/revogr-data-style.scss?tag=revogr-data","src/components/data/revogr-data.tsx","node_modules/lodash/_defineProperty.js","node_modules/lodash/_baseAssignValue.js","node_modules/lodash/_arrayAggregator.js","node_modules/lodash/_baseAggregator.js","node_modules/lodash/_createAggregator.js","node_modules/lodash/keyBy.js","src/components/header/header-renderer.tsx","src/components/header/header-group-renderer.tsx","src/components/header/revogr-header-style.scss?tag=revogr-header","src/components/header/revogr-header.tsx","src/components/revoGrid/viewport.resize.service.ts","src/components/scroll/revogr-viewport-scroll-style.scss?tag=revogr-viewport-scroll","src/components/scroll/revogr-viewport-scroll.tsx","src/components/vnode/vnode-converter.tsx"],"sourcesContent":["import { type VNode } from '@stencil/core';\r\nimport { ROW_FOCUSED_CLASS } from '../../utils/consts';\r\nimport { RangeArea } from '@type';\r\n\r\n/**\r\n * Class is responsible for highlighting rows in a table.\r\n */\r\nexport class RowHighlightPlugin {\r\n private currentRange: RangeArea | null = null;\r\n selectionChange(e: RangeArea, renderedRows: Map<number, VNode>) {\r\n // clear previous range\r\n if (this.currentRange) {\r\n renderedRows.forEach((row, y) => {\r\n // skip current range\r\n if (e && y >= e.y && y <= e.y1) {\r\n return;\r\n }\r\n\r\n // clear previous range\r\n if (\r\n row &&\r\n row.$elm$ instanceof HTMLElement &&\r\n row.$elm$.classList.contains(ROW_FOCUSED_CLASS)\r\n ) {\r\n row.$elm$.classList.remove(ROW_FOCUSED_CLASS);\r\n if (row.$attrs$?.class.includes(ROW_FOCUSED_CLASS)) {\r\n row.$attrs$.class = row.$attrs$.class.replace(\r\n ROW_FOCUSED_CLASS,\r\n '',\r\n );\r\n }\r\n }\r\n });\r\n }\r\n\r\n // apply new range\r\n if (e) {\r\n for (let y = e.y; y <= e.y1; y++) {\r\n const row = renderedRows.get(y);\r\n if (\r\n row &&\r\n row.$elm$ instanceof HTMLElement &&\r\n !row.$elm$.classList.contains(ROW_FOCUSED_CLASS)\r\n ) {\r\n const attrs = (row.$attrs$ = row.$attrs$ || {});\r\n attrs.class = (attrs.class || '') + ' ' + ROW_FOCUSED_CLASS;\r\n row.$elm$.classList.add(ROW_FOCUSED_CLASS);\r\n }\r\n }\r\n }\r\n this.currentRange = e;\r\n }\r\n\r\n isRowFocused(y: number) {\r\n return (\r\n this.currentRange && y >= this.currentRange.y && y <= this.currentRange.y1\r\n );\r\n }\r\n}\r\n","import { type VNode } from '@stencil/core';\r\nimport { type JSX } from '../../components';\r\n\r\n/**\r\n * Converts a VNode element into an HTML element and appends it to the specified parentHolder.\r\n */\r\nexport function convertVNodeToHTML(parentHolder: Element, redraw: JSX.VnodeHtml['redraw']): Promise<{ html: string; vnodes: (VNode[]) | null }> {\r\n return new Promise<{ html: string; vnodes: (VNode[]) | null }>(resolve => {\r\n const vnode = document.createElement('vnode-html');\r\n parentHolder.appendChild(vnode);\r\n vnode.redraw = redraw;\r\n vnode.addEventListener('html', e => {\r\n vnode.remove();\r\n resolve(e.detail);\r\n });\r\n });\r\n}\r\n","revogr-data {\r\n display: block;\r\n width: 100%;\r\n position: relative;\r\n\r\n .rgRow {\r\n position: absolute;\r\n width: 100%;\r\n left: 0;\r\n\r\n &.groupingRow {\r\n font-weight: 600;\r\n text-align: left;\r\n\r\n .group-expand {\r\n width: 25px;\r\n height: 100%;\r\n max-height: 25px;\r\n margin-right: 2px;\r\n background-color: transparent;\r\n border-color: transparent;\r\n vertical-align: middle;\r\n padding-left: 5px;\r\n display: inline-flex;\r\n\r\n svg {\r\n width: 7px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .revo-draggable {\r\n $w: 24px;\r\n\r\n border: none;\r\n height: 32px;\r\n display: inline-flex;\r\n outline: 0;\r\n padding: 0;\r\n font-size: 0.8125rem;\r\n box-sizing: border-box;\r\n align-items: center;\r\n white-space: nowrap;\r\n vertical-align: middle;\r\n justify-content: center;\r\n text-decoration: none;\r\n width: $w;\r\n height: 100%;\r\n cursor: pointer;\r\n display: inline-flex;\r\n\r\n &:hover {\r\n > .revo-drag-icon {\r\n opacity: 1;\r\n zoom: 1.2;\r\n font-weight: 600;\r\n }\r\n }\r\n\r\n > .revo-drag-icon {\r\n pointer-events: none;\r\n transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, zoom 300ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;\r\n }\r\n }\r\n\r\n .rgCell {\r\n top: 0;\r\n left: 0;\r\n position: absolute;\r\n box-sizing: border-box;\r\n height: 100%;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n outline: none;\r\n\r\n &.align-center {\r\n text-align: center;\r\n }\r\n &.align-left {\r\n text-align: left;\r\n }\r\n &.align-right {\r\n text-align: right;\r\n }\r\n }\r\n}\r\n","import {\r\n type VNode,\r\n Component,\r\n Host,\r\n Watch,\r\n Element,\r\n Event,\r\n Prop,\r\n EventEmitter,\r\n h,\r\n Method,\r\n State,\r\n} from '@stencil/core';\r\n\r\nimport ColumnService from './column.service';\r\nimport { DATA_COL, DATA_ROW, ROW_FOCUSED_CLASS } from '../../utils/consts';\r\n\r\nimport { type DSourceState, getSourceItem } from '@store';\r\nimport RowRenderer, { PADDING_DEPTH } from './row-renderer';\r\nimport GroupingRowRenderer from '../../plugins/groupingRow/grouping.row.renderer';\r\nimport { isGrouping } from '../../plugins/groupingRow/grouping.service';\r\nimport type { AllDimensionType, CellTemplateProp, DimensionCols, DimensionRows } from '@type';\r\nimport { RowHighlightPlugin } from './row-highlight.plugin';\r\nimport { convertVNodeToHTML } from '../vnode/vnode.utils';\r\nimport { CellRenderer } from './cell-renderer';\r\nimport type {\r\n ViewportState,\r\n DimensionSettingsState,\r\n BeforeRowRenderEvent,\r\n Providers,\r\n ColumnRegular,\r\n DataType,\r\n CellProps,\r\n BeforeCellRenderEvent,\r\n DragStartEvent,\r\n VirtualPositionItem,\r\n RangeArea,\r\n SelectionStoreState,\r\n} from '@type';\r\nimport type { Observable } from '../../utils';\r\nimport type { RowGroupingProps } from '../../plugins';\r\n\r\n/**\r\n * This component is responsible for rendering data\r\n * Rows, columns, groups and cells\r\n */\r\n@Component({\r\n tag: 'revogr-data',\r\n styleUrl: 'revogr-data-style.scss',\r\n})\r\nexport class RevogrData {\r\n // #region Properties\r\n /**\r\n * Readonly mode\r\n */\r\n @Prop() readonly: boolean;\r\n /**\r\n * Range allowed\r\n */\r\n @Prop() range: boolean;\r\n\r\n /**\r\n * Defines property from which to read row class\r\n */\r\n @Prop() rowClass: string;\r\n /**\r\n * Additional data to pass to renderer\r\n * Used in plugins such as vue or react to pass root app entity to cells\r\n */\r\n @Prop() additionalData: any;\r\n /** Stores */\r\n /** Selection, range, focus for row selection */\r\n @Prop() rowSelectionStore!: Observable<SelectionStoreState>;\r\n /** Viewport Y */\r\n @Prop() viewportRow!: Observable<ViewportState>;\r\n /** Viewport X */\r\n @Prop() viewportCol!: Observable<ViewportState>;\r\n /** Dimension settings Y */\r\n @Prop() dimensionRow!: Observable<DimensionSettingsState>;\r\n\r\n /** Static stores, not expected to change during component lifetime */\r\n /**\r\n * Column source\r\n */\r\n @Prop() colData!: Observable<DSourceState<ColumnRegular, DimensionCols>>;\r\n /**\r\n * Data rows source\r\n */\r\n @Prop() dataStore!: Observable<DSourceState<DataType, DimensionRows>>;\r\n /**\r\n * Row data type\r\n */\r\n @Prop({ reflect: true }) type!: DimensionRows;\r\n\r\n /**\r\n * Column data type\r\n */\r\n @Prop({ reflect: true }) colType!: DimensionCols | 'rowHeaders';\r\n\r\n /**\r\n * Prevent rendering until job is done.\r\n * Can be used for initial rendering performance improvement.\r\n * When several plugins require initial rendering this will prevent double initial rendering.\r\n */\r\n @Prop() jobsBeforeRender: (Promise<any> | (() => Promise<any>))[] = [];\r\n // #endregion\r\n\r\n /**\r\n * Before each row render\r\n */\r\n @Event() beforerowrender: EventEmitter<BeforeRowRenderEvent>;\r\n \r\n /**\r\n * When data render finished for the designated type\r\n */\r\n @Event() afterrender: EventEmitter<{ type: DimensionRows }>;\r\n /**\r\n * Before each cell render function. Allows to override cell properties\r\n */\r\n @Event({ eventName: 'beforecellrender' })\r\n beforeCellRender: EventEmitter<BeforeCellRenderEvent<CellTemplateProp>>;\r\n\r\n /**\r\n * Before data render\r\n */\r\n @Event({ eventName: 'beforedatarender' })\r\n beforeDataRender: EventEmitter<AllDimensionType>;\r\n /**\r\n * Event emitted on cell drag start\r\n */\r\n @Event({ eventName: 'dragstartcell' })\r\n dragStartCell: EventEmitter<DragStartEvent>;\r\n\r\n /**\r\n * Pointed cell update.\r\n */\r\n @Method() async updateCell(e: {\r\n row: number; // virtual\r\n col: number; // virtual\r\n }) {\r\n // Stencil tweak to update cell content\r\n const cell = this.renderedRows.get(e.row)?.$children$?.[e.col];\r\n if (cell?.$attrs$?.redraw) {\r\n const children = await convertVNodeToHTML(\r\n this.element,\r\n cell.$attrs$.redraw,\r\n );\r\n cell.$elm$.innerHTML = children.html;\r\n cell.$key$ = Math.random();\r\n }\r\n }\r\n\r\n @Element() element!: Element;\r\n @State() providers: Providers;\r\n private columnService: ColumnService;\r\n private rowHighlightPlugin: RowHighlightPlugin;\r\n /**\r\n * Rendered rows - virtual index vs vnode\r\n */\r\n private renderedRows = new Map<number, VNode>();\r\n private rangeUnsubscribe: (() => void) | undefined;\r\n\r\n @Watch('dataStore') onDataStoreChange() {\r\n this.onStoreChange();\r\n }\r\n @Watch('colData') onColDataChange() {\r\n this.onStoreChange();\r\n }\r\n onStoreChange() {\r\n this.columnService?.destroy();\r\n this.columnService = new ColumnService(this.dataStore, this.colData);\r\n // make sure we have correct data, before render\r\n this.providers = {\r\n type: this.type,\r\n colType: this.colType,\r\n readonly: this.readonly,\r\n data: this.dataStore,\r\n columns: this.colData,\r\n viewport: this.viewportCol,\r\n dimension: this.dimensionRow,\r\n selection: this.rowSelectionStore,\r\n };\r\n\r\n this.rangeUnsubscribe?.();\r\n this.rangeUnsubscribe = this.rowSelectionStore.onChange(\r\n 'range',\r\n (e: RangeArea) =>\r\n this.rowHighlightPlugin.selectionChange(e, this.renderedRows),\r\n );\r\n }\r\n\r\n connectedCallback() {\r\n this.rowHighlightPlugin = new RowHighlightPlugin();\r\n this.onStoreChange();\r\n }\r\n\r\n disconnectedCallback() {\r\n this.columnService?.destroy();\r\n this.rangeUnsubscribe?.();\r\n }\r\n\r\n async componentWillRender() {\r\n this.beforeDataRender.emit({\r\n rowType: this.type,\r\n colType: this.colType as DimensionCols,\r\n });\r\n return Promise.all(this.jobsBeforeRender.map(p => typeof p === 'function' ? p() : p));\r\n }\r\n\r\n componentDidRender() {\r\n this.afterrender.emit({ type: this.type });\r\n }\r\n\r\n render() {\r\n this.renderedRows = new Map();\r\n const columnsData = this.columnService.columns;\r\n if (!columnsData.length) {\r\n return;\r\n }\r\n const rows = this.viewportRow.get('items');\r\n if (!rows.length) {\r\n return;\r\n }\r\n const cols = this.viewportCol.get('items');\r\n if (!cols.length) {\r\n return;\r\n }\r\n const rowsEls: VNode[] = [];\r\n const depth = this.dataStore.get('groupingDepth');\r\n const groupingCustomRenderer = this.dataStore.get('groupingCustomRenderer');\r\n const groupDepth = this.columnService.hasGrouping ? depth : 0;\r\n for (let rgRow of rows) {\r\n const dataItem = getSourceItem(this.dataStore, rgRow.itemIndex);\r\n\r\n // #region Grouping\r\n if (isGrouping(dataItem)) {\r\n const gmodel: RowGroupingProps = {\r\n ...rgRow,\r\n index: rgRow.itemIndex,\r\n model: dataItem,\r\n groupingCustomRenderer,\r\n // Only show expand button if grouping is enabled and not in row headers\r\n hasExpand: this.columnService.hasGrouping && this.colType !== 'rowHeaders',\r\n columnItems: cols,\r\n providers: this.providers,\r\n };\r\n rowsEls.push(<GroupingRowRenderer {...gmodel} />);\r\n continue;\r\n }\r\n // #endregion\r\n const cells: (VNode | string | void)[] = [];\r\n\r\n // #region Cells\r\n for (let rgCol of cols) {\r\n const smodel: CellTemplateProp = {\r\n ...this.columnService.rowDataModel(\r\n rgRow.itemIndex,\r\n rgCol.itemIndex,\r\n ),\r\n providers: this.providers,\r\n };\r\n\r\n // call before cell render\r\n const cellEvent = this.triggerBeforeCellRender(smodel, rgRow, rgCol);\r\n\r\n // if event was prevented\r\n if (cellEvent.defaultPrevented) {\r\n continue;\r\n }\r\n\r\n const {\r\n detail: { column: columnProps, row: rowProps, model: schemaModel },\r\n } = cellEvent;\r\n\r\n const defaultProps: CellProps = {\r\n [DATA_COL]: columnProps.itemIndex,\r\n [DATA_ROW]: rowProps.itemIndex,\r\n style: {\r\n width: `${columnProps.size}px`,\r\n transform: `translateX(${columnProps.start}px)`,\r\n height: rowProps.size ? `${rowProps.size}px` : undefined,\r\n },\r\n };\r\n /**\r\n * For grouping, can be removed in the future and replaced with event\r\n */\r\n if (groupDepth && !columnProps.itemIndex && defaultProps.style) {\r\n defaultProps.style.paddingLeft = `${PADDING_DEPTH * groupDepth}px`;\r\n }\r\n\r\n const props = this.columnService.mergeProperties(\r\n rowProps.itemIndex,\r\n columnProps.itemIndex,\r\n defaultProps,\r\n schemaModel,\r\n );\r\n\r\n // Never use webcomponent for cell render\r\n // It's very slow because of webcomponent initialization takes time\r\n const cellNode = <CellRenderer\r\n renderProps={{\r\n schemaModel,\r\n additionalData: this.additionalData,\r\n dragStartCell: this.dragStartCell,\r\n }}\r\n cellProps={props}\r\n />;\r\n cells.push(cellNode);\r\n }\r\n // #endregion\r\n\r\n // #region Rows\r\n let rowClass = this.rowClass\r\n ? this.columnService.getRowClass(rgRow.itemIndex, this.rowClass)\r\n : '';\r\n if (this.rowHighlightPlugin.isRowFocused(rgRow.itemIndex)) {\r\n rowClass += ` ${ROW_FOCUSED_CLASS}`;\r\n }\r\n const row: VNode = (\r\n <RowRenderer\r\n index={rgRow.itemIndex}\r\n rowClass={rowClass}\r\n size={rgRow.size}\r\n start={rgRow.start}\r\n >\r\n {cells}\r\n </RowRenderer>\r\n );\r\n this.beforerowrender.emit({\r\n node: row,\r\n item: rgRow,\r\n model: dataItem,\r\n colType: this.columnService.type,\r\n rowType: this.type,\r\n });\r\n rowsEls.push(row);\r\n this.renderedRows.set(rgRow.itemIndex, row);\r\n // #endregion\r\n }\r\n return (\r\n <Host>\r\n <slot />\r\n {rowsEls}\r\n </Host>\r\n );\r\n }\r\n\r\n triggerBeforeCellRender(\r\n model: CellTemplateProp,\r\n row: VirtualPositionItem,\r\n column: VirtualPositionItem,\r\n ) {\r\n const detail: BeforeCellRenderEvent<CellTemplateProp> = {\r\n column,\r\n row,\r\n model,\r\n rowType: model.type,\r\n colType: model.colType,\r\n };\r\n return this.beforeCellRender.emit(detail);\r\n }\r\n}\r\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nexport default defineProperty;\n","import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nexport default baseAssignValue;\n","/**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n}\n\nexport default arrayAggregator;\n","import baseEach from './_baseEach.js';\n\n/**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n}\n\nexport default baseAggregator;\n","import arrayAggregator from './_arrayAggregator.js';\nimport baseAggregator from './_baseAggregator.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\nfunction createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\n };\n}\n\nexport default createAggregator;\n","import baseAssignValue from './_baseAssignValue.js';\nimport createAggregator from './_createAggregator.js';\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n * { 'dir': 'left', 'code': 97 },\n * { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n * return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\nvar keyBy = createAggregator(function(result, value, key) {\n baseAssignValue(result, key, value);\n});\n\nexport default keyBy;\n","import { h } from '@stencil/core';\r\nimport type {\r\n VirtualPositionItem,\r\n ColumnTemplateProp,\r\n InitialHeaderClick,\r\n RangeArea\r\n} from '@type';\r\n\r\nimport { FilterButton } from '../../plugins/filter/filter.button';\r\nimport { SortingSign } from '../../plugins/sorting/sorting.sign';\r\nimport { ResizeEvent, ResizeProps } from './resizable.directive';\r\nimport {\r\n DATA_COL,\r\n FOCUS_CLASS,\r\n HEADER_CLASS,\r\n HEADER_SORTABLE_CLASS,\r\n MIN_COL_SIZE,\r\n} from '../../utils/consts';\r\nimport { HeaderCellRenderer } from './header-cell-renderer';\r\nimport { ResizableElementHTMLAttributes } from './resizable.element';\r\n\r\nexport type HeaderRenderProps = {\r\n column: VirtualPositionItem;\r\n additionalData: any;\r\n data: ColumnTemplateProp;\r\n range?: RangeArea | null;\r\n canResize?: boolean;\r\n canFilter?: boolean;\r\n onResize?(e: ResizeEvent): void;\r\n onClick?(data: InitialHeaderClick): void;\r\n onDblClick?(data: InitialHeaderClick): void;\r\n} & Partial<Pick<ResizeProps, 'active'>>;\r\n\r\nconst HeaderRenderer = (p: HeaderRenderProps): ReturnType<typeof h> => {\r\n const cellClass: { [key: string]: boolean } = {\r\n [HEADER_CLASS]: true,\r\n [HEADER_SORTABLE_CLASS]: !!p.data?.sortable,\r\n };\r\n if (p.data?.order) {\r\n cellClass[p.data.order] = true;\r\n }\r\n const dataProps: ResizableElementHTMLAttributes = {\r\n [DATA_COL]: p.column.itemIndex,\r\n canResize: p.canResize,\r\n minWidth: p.data?.minSize || MIN_COL_SIZE,\r\n maxWidth: p.data?.maxSize,\r\n active: p.active || ['r'],\r\n class: cellClass,\r\n style: {\r\n width: `${p.column.size}px`,\r\n transform: `translateX(${p.column.start}px)`,\r\n },\r\n onResize: p.onResize,\r\n onDblClick(originalEvent: MouseEvent) {\r\n p.onDblClick?.({\r\n column: p.data,\r\n index: p.column.itemIndex,\r\n originalEvent,\r\n providers: p.data.providers,\r\n });\r\n },\r\n onClick(originalEvent: MouseEvent) {\r\n if (originalEvent.defaultPrevented || !p.onClick) {\r\n return;\r\n }\r\n p.onClick({\r\n column: p.data,\r\n index: p.column.itemIndex,\r\n originalEvent,\r\n providers: p.data.providers,\r\n });\r\n },\r\n };\r\n if (p.range) {\r\n if (p.column.itemIndex >= p.range.x && p.column.itemIndex <= p.range.x1) {\r\n if (typeof dataProps.class === 'object') {\r\n dataProps.class[FOCUS_CLASS] = true;\r\n }\r\n }\r\n }\r\n return (\r\n <HeaderCellRenderer\r\n data={p.data}\r\n props={dataProps}\r\n additionalData={p.additionalData}\r\n >\r\n {<SortingSign column={p.data} />}\r\n {p.canFilter && p.data?.filter !== false ? (\r\n <FilterButton column={p.data} />\r\n ) : (\r\n ''\r\n )}\r\n </HeaderCellRenderer>\r\n );\r\n};\r\n\r\nexport default HeaderRenderer;\r\n","import { h } from '@stencil/core';\r\nimport { Group } from '@store';\r\nimport type { CellProps, ProvidersColumns } from '@type';\r\nimport { ResizeEvent, ResizeProps } from './resizable.directive';\r\nimport { HEADER_CLASS, MIN_COL_SIZE } from '../../utils/consts';\r\nimport { HeaderCellRenderer } from './header-cell-renderer';\r\n\r\nexport type HeaderGroupRendererProps = {\r\n start: number;\r\n end: number;\r\n group: Group;\r\n providers: ProvidersColumns;\r\n additionalData: any;\r\n canResize?: boolean;\r\n onResize?(e: ResizeEvent): void;\r\n} & Partial<Pick<ResizeProps, 'active'>>;\r\n\r\nconst HeaderGroupRenderer = (p: HeaderGroupRendererProps): ReturnType<typeof h> => {\r\n const groupProps: CellProps & Partial<ResizeProps> = {\r\n canResize: p.canResize,\r\n minWidth: p.group.indexes.length * MIN_COL_SIZE,\r\n maxWidth: 0,\r\n\r\n active: p.active || ['r'],\r\n class: {\r\n [HEADER_CLASS]: true,\r\n },\r\n style: {\r\n transform: `translateX(${p.start}px)`,\r\n width: `${p.end - p.start}px`,\r\n },\r\n onResize: p.onResize,\r\n };\r\n return (\r\n <HeaderCellRenderer\r\n data={{\r\n ...p.group,\r\n prop: '',\r\n providers: p.providers,\r\n index: p.start,\r\n }}\r\n props={groupProps}\r\n additionalData={p.additionalData}\r\n />\r\n );\r\n};\r\n\r\nexport default HeaderGroupRenderer;\r\n","revogr-header {\r\n position: relative;\r\n z-index: 5;\r\n display: block;\r\n\r\n .header-rgRow {\r\n display: block;\r\n position: relative;\r\n\r\n &.group {\r\n z-index: 0;\r\n }\r\n }\r\n\r\n .group-rgRow {\r\n position: relative;\r\n overflow: hidden;\r\n }\r\n\r\n .rgHeaderCell {\r\n &:hover {\r\n .header-cell-drag {\r\n opacity: 70%;\r\n }\r\n }\r\n\r\n position: absolute;\r\n box-sizing: border-box;\r\n height: 100%;\r\n z-index: 1;\r\n display: flex;\r\n\r\n &.align-center {\r\n text-align: center;\r\n }\r\n &.align-left {\r\n text-align: left;\r\n }\r\n &.align-right {\r\n text-align: right;\r\n }\r\n &.sortable {\r\n cursor: pointer;\r\n }\r\n\r\n .header-cell-drag {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n opacity: 0%;\r\n cursor: grab;\r\n transition: opacity 0.2s ease-in-out;\r\n\r\n &:hover {\r\n opacity: 100%;\r\n }\r\n\r\n & > svg {\r\n position: absolute;\r\n left: 4px;\r\n }\r\n }\r\n\r\n i {\r\n &.asc,\r\n &.desc {\r\n &:after {\r\n font-size: 13px;\r\n }\r\n }\r\n &.asc {\r\n &:after {\r\n content: '↑';\r\n }\r\n }\r\n &.desc {\r\n &:after {\r\n content: '↓';\r\n }\r\n }\r\n }\r\n &.active {\r\n z-index: 10;\r\n\r\n .resizable {\r\n background-color: deepskyblue;\r\n }\r\n }\r\n .header-content {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n flex-grow: 1;\r\n }\r\n .resizable {\r\n display: block;\r\n position: absolute;\r\n z-index: 90;\r\n touch-action: none;\r\n user-select: none;\r\n &:hover {\r\n background-color: deepskyblue;\r\n }\r\n }\r\n $size: 6px;\r\n > .resizable-r {\r\n cursor: ew-resize;\r\n width: $size;\r\n right: 0;\r\n top: 0;\r\n height: 100%;\r\n }\r\n > .resizable-rb {\r\n cursor: se-resize;\r\n width: $size;\r\n height: $size;\r\n right: 0;\r\n bottom: 0;\r\n }\r\n\r\n > .resizable-b {\r\n cursor: s-resize;\r\n height: $size;\r\n bottom: 0;\r\n width: 100%;\r\n left: 0;\r\n }\r\n\r\n > .resizable-lb {\r\n cursor: sw-resize;\r\n width: $size;\r\n height: $size;\r\n left: 0;\r\n bottom: 0;\r\n }\r\n\r\n > .resizable-l {\r\n cursor: w-resize;\r\n width: $size;\r\n left: 0;\r\n height: 100%;\r\n top: 0;\r\n }\r\n\r\n > .resizable-lt {\r\n cursor: nw-resize;\r\n width: $size;\r\n height: $size;\r\n left: 0;\r\n top: 0;\r\n }\r\n\r\n > .resizable-t {\r\n cursor: n-resize;\r\n height: $size;\r\n top: 0;\r\n width: 100%;\r\n left: 0;\r\n }\r\n\r\n > .resizable-rt {\r\n cursor: ne-resize;\r\n width: $size;\r\n height: $size;\r\n right: 0;\r\n top: 0;\r\n }\r\n }\r\n .rv-filter {\r\n visibility: hidden;\r\n }\r\n}\r\n","import {\r\n Component,\r\n Element,\r\n Event,\r\n EventEmitter,\r\n h,\r\n Prop,\r\n type VNode,\r\n} from '@stencil/core';\r\nimport keyBy from 'lodash/keyBy';\r\n\r\nimport { getItemByIndex, Groups } from '@store';\r\nimport { HEADER_ACTUAL_ROW_CLASS, HEADER_ROW_CLASS } from '../../utils/consts';\r\nimport HeaderRenderer, { HeaderRenderProps } from './header-renderer';\r\nimport { ResizeProps } from './resizable.directive';\r\nimport type {\r\n ColumnRegular,\r\n DimensionSettingsState,\r\n InitialHeaderClick,\r\n ViewportState,\r\n ViewSettingSizeProp,\r\n DimensionCols,\r\n SelectionStoreState,\r\n RangeArea,\r\n VirtualPositionItem,\r\n ProvidersColumns,\r\n} from '@type';\r\nimport type { Observable } from '../../utils';\r\nimport GroupHeaderRenderer, {\r\n HeaderGroupRendererProps,\r\n} from './header-group-renderer';\r\n\r\n@Component({\r\n tag: 'revogr-header',\r\n styleUrl: 'revogr-header-style.scss',\r\n})\r\nexport class RevogrHeaderComponent {\r\n // #region Properties\r\n /**\r\n * Stores\r\n */\r\n /** Viewport X */\r\n @Prop() viewportCol: Observable<ViewportState>;\r\n /** Dimension settings X */\r\n @Prop() dimensionCol: Observable<DimensionSettingsState>;\r\n /** Selection, range, focus */\r\n @Prop() selectionStore: Observable<SelectionStoreState>;\r\n\r\n /**\r\n * Column groups\r\n */\r\n @Prop() groups: Groups;\r\n /**\r\n * Grouping depth, how many levels of grouping\r\n */\r\n @Prop() groupingDepth = 0;\r\n\r\n /**\r\n * Readonly mode\r\n */\r\n @Prop() readonly: boolean;\r\n /**\r\n * If columns can be resized\r\n */\r\n @Prop() canResize: boolean;\r\n /**\r\n * Defines resize position\r\n */\r\n @Prop() resizeHandler: ResizeProps['active'];\r\n\r\n /**\r\n * Columns - defines an array of grid columns.\r\n */\r\n @Prop() colData: ColumnRegular[];\r\n\r\n /**\r\n * Column filter\r\n */\r\n @Prop() columnFilter: boolean;\r\n\r\n /**\r\n * Column type\r\n */\r\n @Prop() type!: DimensionCols | 'rowHeaders';\r\n\r\n /**\r\n * Extra properties to pass into header renderer, such as vue or react components to handle parent\r\n */\r\n @Prop() additionalData: any = {};\r\n // #endregion\r\n\r\n // #region Events\r\n\r\n /**\r\n * On initial header click\r\n */\r\n @Event({\r\n eventName: 'beforeheaderclick',\r\n })\r\n initialHeaderClick: EventEmitter<InitialHeaderClick>;\r\n\r\n /**\r\n * On header resize\r\n */\r\n @Event({\r\n eventName: 'headerresize',\r\n })\r\n headerresize: EventEmitter<ViewSettingSizeProp>;\r\n\r\n /**\r\n * On before header resize\r\n */\r\n @Event({ eventName: 'beforeheaderresize', cancelable: true })\r\n beforeResize: EventEmitter<ColumnRegular[]>;\r\n\r\n /**\r\n * On header double click\r\n */\r\n @Event({\r\n eventName: 'headerdblclick',\r\n })\r\n headerdblClick: EventEmitter<InitialHeaderClick>;\r\n\r\n /**\r\n * Before each header cell render function. Allows to override cell properties\r\n */\r\n @Event({ eventName: 'beforeheaderrender' })\r\n beforeHeaderRender: EventEmitter<HeaderRenderProps>;\r\n\r\n /**\r\n * Before each group header cell render function. Allows to override group header cell properties\r\n */\r\n @Event({ eventName: 'beforegroupheaderrender' })\r\n beforeGroupHeaderRender: EventEmitter<HeaderGroupRendererProps>;\r\n\r\n /**\r\n * After all header cells rendered. Finalizes cell rendering.\r\n */\r\n @Event({ eventName: 'afterheaderrender' })\r\n afterHeaderRender: EventEmitter<ProvidersColumns>;\r\n\r\n // #endregion\r\n\r\n @Element() element!: HTMLElement;\r\n\r\n private onResize({ width }: { width?: number }, index: number) {\r\n const col = this.colData[index];\r\n const event = this.beforeResize.emit([\r\n {\r\n ...col,\r\n size: width || undefined,\r\n },\r\n ]);\r\n if (event.defaultPrevented) {\r\n return;\r\n }\r\n this.headerresize.emit({ [index]: width || 0 });\r\n }\r\n\r\n private onResizeGroup(\r\n changedX: number,\r\n startIndex: number,\r\n endIndex: number,\r\n ) {\r\n const sizes: ViewSettingSizeProp = {};\r\n const cols = keyBy(this.viewportCol.get('items'), 'itemIndex');\r\n const change = changedX / (endIndex - startIndex + 1);\r\n for (let i = startIndex; i <= endIndex; i++) {\r\n const item = cols[i];\r\n if (item) {\r\n sizes[i] = item.size + change;\r\n }\r\n }\r\n this.headerresize.emit(sizes);\r\n }\r\n\r\n componentDidRender() {\r\n this.afterHeaderRender.emit(this.providers);\r\n }\r\n\r\n render() {\r\n const cols = this.viewportCol.get('items');\r\n const range = this.selectionStore?.get('range');\r\n\r\n const { cells } = this.renderHeaderColumns(cols, range);\r\n const groupRow = this.renderGroupingColumns();\r\n\r\n return [\r\n <div class=\"group-rgRow\">{groupRow}</div>,\r\n <div class={`${HEADER_ROW_CLASS} ${HEADER_ACTUAL_ROW_CLASS}`}>\r\n {cells}\r\n </div>,\r\n ];\r\n }\r\n\r\n private renderHeaderColumns(\r\n cols: VirtualPositionItem[],\r\n range: RangeArea | null,\r\n ) {\r\n const cells: VNode[] = [];\r\n for (let rgCol of cols) {\r\n const colData = this.colData[rgCol.itemIndex];\r\n const props: HeaderRenderProps = {\r\n range,\r\n column: rgCol,\r\n data: {\r\n ...colData,\r\n index: rgCol.itemIndex,\r\n providers: this.providers,\r\n },\r\n canFilter: !!this.columnFilter,\r\n canResize: this.canResize,\r\n active: this.resizeHandler,\r\n additionalData: this.additionalData,\r\n onResize: e => this.onResize(e, rgCol.itemIndex),\r\n onDblClick: e => this.headerdblClick.emit(e),\r\n onClick: e => this.initialHeaderClick.emit(e),\r\n };\r\n const event = this.beforeHeaderRender.emit(props);\r\n if (!event.defaultPrevented) {\r\n cells.push(<HeaderRenderer {...event.detail} />);\r\n }\r\n }\r\n return { cells };\r\n }\r\n\r\n private renderGroupingColumns(): VNode[] {\r\n const groupRow: VNode[] = [];\r\n for (let i = 0; i < this.groupingDepth; i++) {\r\n if (this.groups[i]) {\r\n for (let group of this.groups[i]) {\r\n const groupStartIndex = group.indexes[0] ?? -1;\r\n if (groupStartIndex > -1) {\r\n const groupEndIndex = groupStartIndex + group.indexes.length - 1;\r\n\r\n const groupStart = getItemByIndex(\r\n this.dimensionCol.state,\r\n groupStartIndex,\r\n ).start;\r\n const groupEnd = getItemByIndex(\r\n this.dimensionCol.state,\r\n groupEndIndex,\r\n ).end;\r\n\r\n const props: HeaderGroupRendererProps = {\r\n providers: this.providers,\r\n start: groupStart,\r\n end: groupEnd,\r\n group,\r\n active: this.resizeHandler,\r\n canResize: this.canResize,\r\n additionalData: this.additionalData,\r\n onResize: e =>\r\n this.onResizeGroup(\r\n e.changedX ?? 0,\r\n groupStartIndex,\r\n groupEndIndex,\r\n ),\r\n };\r\n const event = this.beforeGroupHeaderRender.emit(props);\r\n if (!event.defaultPrevented) {\r\n groupRow.push(<GroupHeaderRenderer {...event.detail} />);\r\n }\r\n }\r\n }\r\n }\r\n groupRow.push(<div class={`${HEADER_ROW_CLASS} group`} />);\r\n }\r\n return groupRow;\r\n }\r\n\r\n get providers(): ProvidersColumns<DimensionCols | 'rowHeaders'> {\r\n return {\r\n type: this.type,\r\n readonly: this.readonly,\r\n data: this.colData,\r\n viewport: this.viewportCol,\r\n dimension: this.dimensionCol,\r\n selection: this.selectionStore,\r\n };\r\n }\r\n}\r\n","import throttle from 'lodash/throttle';\r\ntype ResizeEntry = {\r\n width: number;\r\n height: number;\r\n};\r\nexport default class GridResizeService {\r\n private resizeObserver: ResizeObserver | null = null;\r\n private previousSize: ResizeEntry = {\r\n width: 0,\r\n height: 0,\r\n };\r\n readonly apply = throttle(\r\n (e: { width: number, height: number }) => {\r\n const entry = {\r\n width: e.width,\r\n height: e.height,\r\n };\r\n this.resize?.(entry, this.previousSize);\r\n this.previousSize = entry;\r\n },\r\n 40,\r\n {\r\n leading: false,\r\n trailing: true,\r\n }\r\n );\r\n constructor(\r\n el: HTMLElement,\r\n private readonly resize: (\r\n entry: ResizeEntry,\r\n previousSize: ResizeEntry,\r\n ) => void,\r\n elements: (HTMLElement | undefined)[],\r\n ) {\r\n const extras: HTMLElement[] = [];\r\n elements.forEach((element) => {\r\n if (element) {\r\n extras.push(element);\r\n }\r\n });\r\n this.init(el, extras);\r\n }\r\n\r\n init(el: HTMLElement, extras: HTMLElement[] = []) {\r\n const observer = this.resizeObserver = new ResizeObserver((e) => {\r\n if (e.length) {\r\n if (e[0].target === el) {\r\n this.apply(e[0].contentRect);\r\n } else {\r\n this.apply(el.getBoundingClientRect());\r\n }\r\n }\r\n });\r\n observer.observe(el);\r\n extras.forEach((extra) => {\r\n observer.observe(extra);\r\n });\r\n }\r\n\r\n destroy() {\r\n this.resizeObserver?.disconnect();\r\n this.resizeObserver = null;\r\n }\r\n}\r\n","@mixin noScroll {\r\n /* Hide scrollbar for IE and Edge */\r\n -ms-overflow-style: none;\r\n scrollbar-width: none; /* Firefox */\r\n /* Hide scrollbar for Chrome, Safari and Opera */\r\n &::-webkit-scrollbar {\r\n display: none;\r\n -webkit-appearance: none;\r\n }\r\n}\r\n\r\n.rowHeaders {\r\n z-index: 2;\r\n font-size: 10px;\r\n display: flex;\r\n height: 100%;\r\n\r\n revogr-data .rgCell {\r\n text-align: center;\r\n }\r\n\r\n .rgCell {\r\n padding: 0 1em !important;\r\n min-width: 100%;\r\n }\r\n}\r\n\r\nrevogr-viewport-scroll {\r\n @include noScroll;\r\n\r\n overflow-x: auto;\r\n overflow-y: hidden;\r\n position: relative;\r\n z-index: 1;\r\n height: 100%;\r\n\r\n &.colPinStart,\r\n &.colPinEnd {\r\n z-index: 2;\r\n }\r\n\r\n // make sure it would work\r\n &.colPinEnd:has(.active) {\r\n overflow: visible;\r\n }\r\n\r\n &.rgCol {\r\n flex-grow: 1;\r\n }\r\n\r\n .content-wrapper {\r\n overflow: hidden;\r\n }\r\n\r\n .inner-content-table {\r\n display: flex;\r\n flex-direction: column;\r\n max-height: 100%;\r\n width: 100%;\r\n min-width: 100%;\r\n position: relative;\r\n z-index: 0;\r\n }\r\n\r\n .vertical-inner {\r\n overflow-y: auto;\r\n position: relative;\r\n width: 100%;\r\n flex-grow: 1;\r\n outline: none; // avoid accessibility focus issue\r\n @include noScroll;\r\n\r\n revogr-data,\r\n revogr-overlay-selection {\r\n height: 100%;\r\n }\r\n }\r\n}\r\n","import {\r\n Component,\r\n Event,\r\n EventEmitter,\r\n h,\r\n Method,\r\n Element,\r\n Prop,\r\n Host,\r\n Listen,\r\n} from '@stencil/core';\r\n\r\nimport GridResizeService from '../revoGrid/viewport.resize.service';\r\nimport LocalScrollService from '../../services/local.scroll.service';\r\nimport { LocalScrollTimer } from '../../services/local.scroll.timer';\r\nimport {\r\n CONTENT_SLOT,\r\n FOOTER_SLOT,\r\n HEADER_SLOT,\r\n} from '../revoGrid/viewport.helpers';\r\nimport type {\r\n DimensionCols,\r\n DimensionType,\r\n ElementScroll,\r\n ScrollCoordinateEvent,\r\n ViewPortResizeEvent,\r\n ViewPortScrollEvent,\r\n} from '@type';\r\n\r\ntype Delta = 'deltaX' | 'deltaY';\r\ntype LocalScrollEvent = {\r\n preventDefault(): void;\r\n} & { [x in Delta]: number };\r\n\r\n/**\r\n * Viewport scroll component for RevoGrid\r\n * @slot - content\r\n * @slot header - header\r\n * @slot footer - footer\r\n */\r\n@Component({\r\n tag: 'revogr-viewport-scroll',\r\n styleUrl: 'revogr-viewport-scroll-style.scss',\r\n})\r\nexport class RevogrViewportScroll implements ElementScroll {\r\n /**\r\n * Enable row header\r\n */\r\n @Prop() readonly rowHeader: boolean;\r\n\r\n /**\r\n * Width of inner content\r\n */\r\n @Prop() contentWidth = 0;\r\n /**\r\n * Height of inner content\r\n */\r\n @Prop() contentHeight = 0;\r\n\r\n @Prop() colType!: DimensionCols | 'rowHeaders';\r\n\r\n /**\r\n * Before scroll event\r\n */\r\n @Event({ eventName: 'scrollviewport', bubbles: true })\r\n scrollViewport: EventEmitter<ViewPortScrollEvent>;\r\n /**\r\n * Viewport resize\r\n */\r\n @Event({ eventName: 'resizeviewport' })\r\n resizeViewport: EventEmitter<ViewPortResizeEvent>;\r\n\r\n /**\r\n * Triggered on scroll change, can be used to get information about scroll visibility\r\n */\r\n @Event() scrollchange: EventEmitter<{\r\n type: DimensionType;\r\n hasScroll: boolean;\r\n }>;\r\n\r\n /**\r\n * Silently scroll to coordinate\r\n * Made to align negative coordinates for mobile devices\r\n */\r\n @Event({ eventName: 'scrollviewportsilent' })\r\n silentScroll: EventEmitter<ViewPortScrollEvent>;\r\n\r\n @Element() horizontalScroll: HTMLElement;\r\n\r\n private verticalScroll?: HTMLElement;\r\n private header?: HTMLElement;\r\n private footer?: HTMLElement;\r\n\r\n /**\r\n * Static functions to bind wheel change\r\n */\r\n private horizontalMouseWheel: (e: Partial<LocalScrollEvent>) => void;\r\n private verticalMouseWheel: (e: Partial<LocalScrollEvent>) => void;\r\n\r\n private resizeService?: GridResizeService;\r\n private localScrollService: LocalScrollService;\r\n private localScrollTimer: LocalScrollTimer;\r\n\r\n @Method() async setScroll(e: ViewPortScrollEvent) {\r\n this.localScrollTimer.latestScrollUpdate(e.dimension);\r\n this.localScrollService?.setScroll(e);\r\n }\r\n\r\n /**\r\n * update on delta in case we don't know existing position or external change\r\n * @param e\r\n */\r\n @Method() async changeScroll(e: ViewPortScrollEvent, silent = false) {\r\n if (silent) {\r\n if (e.coordinate && this.verticalScroll) {\r\n switch (e.dimension) {\r\n // for mobile devices to skip negative scroll loop. only on vertical scroll\r\n case 'rgRow':\r\n this.verticalScroll.style.transform = `translateY(${-1 * e.coordinate}px)`;\r\n break;\r\n }\r\n }\r\n return;\r\n }\r\n if (e.delta) {\r\n switch (e.dimension) {\r\n case 'rgCol':\r\n e.coordinate = this.horizontalScroll.scrollLeft + e.delta;\r\n break;\r\n case 'rgRow':\r\n e.coordinate = (this.verticalScroll?.scrollTop ?? 0) + e.delta;\r\n break;\r\n }\r\n this.setScroll(e);\r\n }\r\n return e;\r\n }\r\n\r\n /**\r\n * Dispatch this event to trigger vertical mouse wheel from plugins\r\n */\r\n @Listen('mousewheel-vertical') mousewheelVertical({\r\n detail: e,\r\n }: CustomEvent<LocalScrollEvent>) {\r\n this.verticalMouseWheel(e);\r\n }\r\n /**\r\n * Dispatch this event to trigger horizontal mouse wheel from plugins\r\n */\r\n @Listen('mousewheel-horizontal') mousewheelHorizontal({\r\n detail: e,\r\n }: CustomEvent<LocalScrollEvent>) {\r\n this.horizontalMouseWheel(e);\r\n }\r\n /**\r\n * Allows to use outside listener\r\n */\r\n @Listen('scroll-coordinate') scrollApply({\r\n detail: { type, coordinate },\r\n }: CustomEvent<ScrollCoordinateEvent>) {\r\n this.applyOnScroll(type, coordinate, true);\r\n }\r\n\r\n connectedCallback() {\r\n /**\r\n * Bind scroll functions for farther usage\r\n */\r\n // allow mousewheel for all devices including mobile\r\n this.verticalMouseWheel = this.onVerticalMouseWheel.bind(\r\n this,\r\n 'rgRow',\r\n 'deltaY',\r\n );\r\n this.horizontalMouseWheel = this.onHorizontalMouseWheel.bind(\r\n this,\r\n 'rgCol',\r\n 'deltaX',\r\n );\r\n this.localScrollTimer = new LocalScrollTimer(\r\n 'ontouchstart' in document.documentElement ? 0 : 10,\r\n );\r\n /**\r\n * Create local scroll service\r\n */\r\n this.localScrollService = new LocalScrollService({\r\n // to improve safari smoothnes on scroll\r\n // skipAnimationFrame: isSafariDesktop(),\r\n runScroll: e => this.scrollViewport.emit(e),\r\n applyScroll: e => {\r\n this.localScrollTimer.setCoordinate(e);\r\n switch (e.dimension) {\r\n case 'rgCol':\r\n // this will trigger on scroll event\r\n this.horizontalScroll.scrollLeft = e.coordinate;\r\n break;\r\n case 'rgRow':\r\n if (this.verticalScroll) {\r\n // this will trigger on scroll event\r\n this.verticalScroll.scrollTop = e.coordinate;\r\n // for mobile devices to skip negative scroll loop. only on vertical scroll\r\n if (this.verticalScroll.style.transform) {\r\n this.verticalScroll.style.transform = '';\r\n }\r\n }\r\n break;\r\n }\r\n },\r\n });\r\n }\r\n\r\n componentDidLoad() {\r\n // track viewport resize\r\n this.resizeService = new GridResizeService(\r\n this.horizontalScroll,\r\n (entry) => {\r\n const els: Partial<\r\n Record<\r\n DimensionType,\r\n {\r\n size: number;\r\n contentSize: number;\r\n scroll: number;\r\n noScroll: boolean;\r\n }\r\n >\r\n > = {};\r\n\r\n let calculatedHeight = entry.height || 0;\r\n if (calculatedHeight) {\r\n calculatedHeight -=\r\n (this.header?.clientHeight ?? 0) +\r\n (this.footer?.clientHeight ?? 0);\r\n }\r\n els.rgRow = {\r\n size: calculatedHeight,\r\n contentSize: this.contentHeight,\r\n scroll: this.verticalScroll?.scrollTop ?? 0,\r\n noScroll: false,\r\n };\r\n const calculatedWidth = entry.width || 0;\r\n els.rgCol = {\r\n size: calculatedWidth,\r\n contentSize: this.contentWidth,\r\n scroll: this.horizontalScroll.scrollLeft,\r\n noScroll: this.colType !== 'rgCol',\r\n };\r\n // Process changes in order: width first, then height\r\n const dimensions: DimensionType[] = ['rgCol', 'rgRow'];\r\n for (const dimension of dimensions) {\r\n const item = els[dimension];\r\n if (!item) continue;\r\n this.resizeViewport.emit({\r\n dimension,\r\n size: item.size,\r\n rowHeader: this.rowHeader,\r\n });\r\n if (item.noScroll) {\r\n continue;\r\n }\r\n this.localScrollService?.scroll(item.scroll ?? 0, dimension, true);\r\n // track scroll visibility on outer element change\r\n this.setScrollVisibility(dimension, item.size, item.contentSize);\r\n }\r\n },\r\n [this.footer, this.header],\r\n );\r\n }\r\n\r\n /**\r\n * Check if scroll present or not per type\r\n * Trigger this method on inner content size change or on outer element size change\r\n * If inner content bigger then outer size then scroll is present and mousewheel binding required\r\n * @param type - dimension type 'rgRow/y' or 'rgCol/x'\r\n * @param size - outer content size\r\n * @param innerContentSize - inner content size\r\n */\r\n setScrollVisibility(\r\n type: DimensionType,\r\n size: number,\r\n innerContentSize: number,\r\n ) {\r\n // test if scroll present\r\n const hasScroll = size < innerContentSize;\r\n let el: HTMLElement | undefined;\r\n // event reference for binding\r\n switch (type) {\r\n case 'rgCol':\r\n el = this.horizontalScroll;\r\n break;\r\n case 'rgRow':\r\n el = this.verticalScroll;\r\n break;\r\n }\r\n // based on scroll visibility assign or remove class and event\r\n if (hasScroll) {\r\n el?.classList.add(`scroll-${type}`);\r\n } else {\r\n el?.classList.remove(`scroll-${type}`);\r\n }\r\n this.scrollchange.emit({ type, hasScroll });\r\n }\r\n\r\n disconnectedCallback() {\r\n this.resizeService?.destroy();\r\n }\r\n\r\n async componentDidRender() {\r\n this.localScrollService.setParams(\r\n {\r\n contentSize: this.contentHeight,\r\n clientSize: this.verticalScroll?.clientHeight ?? 0,\r\n virtualSize: 0,\r\n },\r\n 'rgRow',\r\n );\r\n\r\n this.localScrollService.setParams(\r\n {\r\n contentSize: this.contentWidth,\r\n clientSize: this.horizontalScroll.clientWidth,\r\n virtualSize: 0,\r\n },\r\n 'rgCol',\r\n );\r\n this.setScrollVisibility(\r\n 'rgRow',\r\n this.verticalScroll?.clientHeight ?? 0,\r\n this.contentHeight,\r\n );\r\n this.setScrollVisibility(\r\n 'rgCol',\r\n this.horizontalScroll.clientWidth,\r\n this.contentWidth,\r\n );\r\n }\r\n\r\n render() {\r\n return (\r\n <Host\r\n onWheel={this.horizontalMouseWheel}\r\n onScroll={(e: UIEvent) => this.applyScroll('rgCol', e)}\r\n >\r\n <div\r\n class=\"inner-content-table\"\r\n style={{ width: `${this.contentWidth}px` }}\r\n >\r\n <div class=\"header-wrapper\" ref={e => (this.header = e)}>\r\n <slot name={HEADER_SLOT} />\r\n </div>\r\n <div\r\n class=\"vertical-inner\"\r\n ref={el => (this.verticalScroll = el)}\r\n onWheel={this.verticalMouseWheel}\r\n onScroll={(e: MouseEvent) => this.applyScroll('rgRow', e)}\r\n >\r\n <div\r\n class=\"content-wrapper\"\r\n style={{ height: `${this.contentHeight}px` }}\r\n >\r\n <slot name={CONTENT_SLOT} />\r\n </div>\r\n </div>\r\n <div class=\"footer-wrapper\" ref={e => (this.footer = e)}>\r\n <slot name={FOOTER_SLOT} />\r\n </div>\r\n </div>\r\n </Host>\r\n );\r\n }\r\n /**\r\n * Extra layer for scroll event monitoring, where MouseWheel event is not passing\r\n * We need to trigger scroll event in case there is no mousewheel event\r\n */\r\n @Method() async applyScroll(type: DimensionType, e: UIEvent) {\r\n if (!(e.target instanceof HTMLElement)) {\r\n return;\r\n }\r\n let scroll = 0;\r\n switch (type) {\r\n case 'rgCol':\r\n scroll = e.target.scrollLeft;\r\n break;\r\n case 'rgRow':\r\n scroll = e.target.scrollTop;\r\n break;\r\n }\r\n\r\n // for mobile devices to skip negative scroll loop\r\n if (scroll < 0) {\r\n this.silentScroll.emit({ dimension: type, coordinate: scroll });\r\n return;\r\n }\r\n this.applyOnScroll(type, scroll);\r\n }\r\n\r\n /**\r\n * Applies change on scroll event only if mousewheel event happened some time ago\r\n */\r\n private applyOnScroll(\r\n type: DimensionType,\r\n coordinate: number,\r\n outside = false,\r\n ) {\r\n const lastScrollUpdate = () => {\r\n this.localScrollService?.scroll(\r\n coordinate,\r\n type,\r\n undefined,\r\n undefined,\r\n outside,\r\n );\r\n };\r\n // apply after throttling\r\n if (this.localScrollTimer.isReady(type, coordinate)) {\r\n lastScrollUpdate();\r\n } else {\r\n this.localScrollTimer.throttleLastScrollUpdate(type, coordinate, () => lastScrollUpdate());\r\n }\r\n }\r\n\r\n /**\r\n * On vertical mousewheel event\r\n * @param type\r\n * @param delta\r\n * @param e\r\n */\r\n private onVerticalMouseWheel(\r\n type: DimensionType,\r\n delta: Delta,\r\n e: LocalScrollEvent,\r\n ) {\r\n const scrollTop = this.verticalScroll?.scrollTop ?? 0;\r\n const clientHeight = this.verticalScroll?.clientHeight ?? 0;\r\n const scrollHeight = this.verticalScroll?.scrollHeight ?? 0;\r\n\r\n // Detect if the user has reached the bottom\r\n const atBottom = scrollTop + clientHeight >= scrollHeight && e.deltaY > 0;\r\n const atTop = scrollTop === 0 && e.deltaY < 0;\r\n if (!atBottom && !atTop) {\r\n e.preventDefault?.();\r\n }\r\n const pos = scrollTop + e[delta];\r\n this.localScrollService?.scroll(pos, type, undefined, e[delta]);\r\n this.localScrollTimer.latestScrollUpdate(type);\r\n }\r\n\r\n /**\r\n * On horizontal mousewheel event\r\n * @param type\r\n * @param delta\r\n * @param e\r\n */\r\n private onHorizontalMouseWheel(\r\n type: DimensionType,\r\n delta: Delta,\r\n e: LocalScrollEvent,\r\n ) {\r\n if (!e.deltaX) {\r\n return;\r\n }\r\n const { scrollLeft, scrollWidth, clientWidth } = this.horizontalScroll;\r\n\r\n // Detect if the user has reached the right end\r\n const atRight = scrollLeft + clientWidth >= scrollWidth && e.deltaX > 0;\r\n\r\n // Detect if the user has reached the left end\r\n const atLeft = scrollLeft === 0 && e.deltaX < 0;\r\n if (!atRight && !atLeft) {\r\n e.preventDefault?.();\r\n }\r\n const pos = scrollLeft + e[delta];\r\n this.localScrollService?.scroll(pos, type, undefined, e[delta]);\r\n this.localScrollTimer.latestScrollUpdate(type);\r\n }\r\n}\r\n","import {\r\n Component,\r\n Element,\r\n Event,\r\n EventEmitter,\r\n Host,\r\n Prop,\r\n type VNode,\r\n h,\r\n} from '@stencil/core';\r\n\r\n/**\r\n * VNode to html converter for stencil components.\r\n * Transform VNode to html string.\r\n */\r\n/**\r\n * @internal\r\n */\r\n@Component({\r\n tag: 'vnode-html',\r\n})\r\nexport class VNodeToHtml {\r\n @Prop() redraw: (() => VNode[]) | null | undefined = null;\r\n @Event() html: EventEmitter<{ html: string; vnodes: (VNode[]) | null }>;\r\n @Element() el: HTMLElement;\r\n\r\n private vnodes: VNode[] | null = [];\r\n\r\n componentDidRender() {\r\n this.html.emit({\r\n html: this.el.innerHTML,\r\n vnodes: this.vnodes,\r\n });\r\n }\r\n\r\n render() {\r\n this.vnodes = this.redraw?.() ?? null;\r\n return (\r\n <Host\r\n style={{ visibility: 'hidden', position: 'absolute' }}\r\n >\r\n {this.vnodes}\r\n </Host>\r\n );\r\n }\r\n}\r\n"],"version":3}
|
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-BAoInZ4V.js';
|
|
5
|
+
import { d as debounce } from './debounce-DTUQ1fY7.js';
|
|
6
|
+
import { i as isFilterBtn, e as AndOrButton, d as TrashButton } from './filter.button-CjABZQgg.js';
|
|
7
|
+
|
|
8
|
+
(function closest() {
|
|
9
|
+
if (!Element.prototype.matches) {
|
|
10
|
+
Element.prototype.matches =
|
|
11
|
+
Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;
|
|
12
|
+
}
|
|
13
|
+
if (!Element.prototype.closest) {
|
|
14
|
+
Element.prototype.closest = function (s) {
|
|
15
|
+
let el = this;
|
|
16
|
+
do {
|
|
17
|
+
if (Element.prototype.matches.call(el, s)) {
|
|
18
|
+
return el;
|
|
19
|
+
}
|
|
20
|
+
el = el.parentElement || el.parentNode;
|
|
21
|
+
} while (el !== null && el.nodeType === 1);
|
|
22
|
+
return null;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
})();
|
|
26
|
+
|
|
27
|
+
const filterStyleCss = "revogr-filter-panel{position:absolute;display:block;top:0;left:0;z-index:100;max-height:calc(100% - 80px);min-width:250px;overflow:auto;opacity:1;transform:none;background-color:var(--revo-grid-filter-panel-bg, #fff);border:1px solid var(--revo-grid-filter-panel-border, #cecece);transform-origin:62px 0px;box-shadow:0 5px 18px -2px var(--revo-grid-filter-panel-shadow, rgba(0, 0, 0, 0.15));padding:10px;border-radius:8px;min-width:220px;text-align:left}revogr-filter-panel .filter-holder>div{display:flex;flex-direction:column}revogr-filter-panel label{font-size:13px;display:block;padding:8px 0}revogr-filter-panel select{width:100%}revogr-filter-panel input[type=text]{border:0;min-height:34px;margin:5px 0;background:var(--revo-grid-filter-panel-input-bg, #f3f3f3);border-radius:5px;padding:0 10px;box-sizing:border-box;width:100%}revogr-filter-panel button{margin-top:10px;margin-right:5px}revogr-filter-panel .filter-actions{text-align:right;margin-right:-5px}.rgHeaderCell:hover .rv-filter{transition:opacity 267ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, transform 178ms cubic-bezier(0.4, 0, 0.2, 1) 0ms}.rgHeaderCell:hover .rv-filter,.rgHeaderCell .rv-filter.active{opacity:1}.rgHeaderCell .rv-filter{height:24px;width:24px;background:none;border:0;opacity:0;visibility:visible;cursor:pointer;border-radius:4px}.rgHeaderCell .rv-filter.active{color:#10224a}.rgHeaderCell .rv-filter .filter-img{color:gray;width:11px}.select-css{display:block;font-family:sans-serif;line-height:1.3;padding:0.6em 1.4em 0.5em 0.8em;width:100%;max-width:100%;box-sizing:border-box;margin:0;border:1px solid var(--revo-grid-filter-panel-select-border, #d9d9d9);box-shadow:transparent;border-radius:0.5em;appearance:none;background-color:var(--revo-grid-filter-panel-input-bg, #f3f3f3);background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23007CB2%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E\");background-repeat:no-repeat, repeat;background-position:right 0.7em top 50%, 0 0;background-size:0.65em auto, 100%;}.select-css::-ms-expand{display:none}.select-css:hover{border-color:var(--revo-grid-filter-panel-select-border, #d9d9d9)}.select-css:focus{border-color:var(--revo-grid-filter-panel-select-border-hover, #d9d9d9);box-shadow:0 0 1px 3px rgba(59, 153, 252, 0.7);box-shadow:0 0 0 3px -moz-mac-focusring;outline:none}.select-css option{font-weight:normal}.select-css:disabled,.select-css[aria-disabled=true]{color:gray;background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22graytext%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E\"), linear-gradient(to bottom, #ffffff 0%, #ffffff 100%)}.select-css:disabled:hover,.select-css[aria-disabled=true]{border-color:var(--revo-grid-filter-panel-select-border, #d9d9d9)}.multi-filter-list{margin-top:5px;margin-bottom:5px}.multi-filter-list div{white-space:nowrap}.multi-filter-list .multi-filter-list-action{display:flex;justify-content:space-between;align-items:center}.multi-filter-list .and-or-button{margin:0 0 0 10px;min-width:58px;cursor:pointer}.multi-filter-list .trash-button{margin:0 0 -2px 6px;cursor:pointer;width:22px;height:100%;font-size:16px}.multi-filter-list .trash-button .trash-img{width:1em}.add-filter-divider{display:block;margin:0 -10px 10px -10px;border-bottom:1px solid var(--revo-grid-filter-panel-divider, #d9d9d9);height:10px}.select-input{display:flex;justify-content:space-between;align-items:center}";
|
|
28
|
+
|
|
29
|
+
const defaultType = 'none';
|
|
30
|
+
const FILTER_LIST_CLASS = 'multi-filter-list';
|
|
31
|
+
const FILTER_LIST_CLASS_ACTION = 'multi-filter-list-action';
|
|
32
|
+
const FILTER_ID = 'add-filter';
|
|
33
|
+
const FilterPanel = class {
|
|
34
|
+
constructor(hostRef) {
|
|
35
|
+
registerInstance(this, hostRef);
|
|
36
|
+
this.filterChange = createEvent(this, "filterChange", 7);
|
|
37
|
+
this.resetChange = createEvent(this, "resetChange", 7);
|
|
38
|
+
this.filterCaptionsInternal = {
|
|
39
|
+
title: 'Filter by',
|
|
40
|
+
ok: 'Close',
|
|
41
|
+
save: 'Save',
|
|
42
|
+
// drops the filter
|
|
43
|
+
reset: 'Reset',
|
|
44
|
+
cancel: 'Cancel',
|
|
45
|
+
add: 'Add condition',
|
|
46
|
+
placeholder: 'Enter value...',
|
|
47
|
+
and: 'and',
|
|
48
|
+
or: 'or',
|
|
49
|
+
};
|
|
50
|
+
this.isFilterIdSet = false;
|
|
51
|
+
this.filterId = 0;
|
|
52
|
+
this.currentFilterId = -1;
|
|
53
|
+
this.currentFilterType = defaultType;
|
|
54
|
+
this.filterItems = {};
|
|
55
|
+
this.filterNames = {};
|
|
56
|
+
this.filterEntities = {};
|
|
57
|
+
/**
|
|
58
|
+
* Disables dynamic filtering. A way to apply filters on Save only
|
|
59
|
+
*/
|
|
60
|
+
this.disableDynamicFiltering = false;
|
|
61
|
+
/**
|
|
62
|
+
* If true, closes the filter panel when clicking outside
|
|
63
|
+
*/
|
|
64
|
+
this.closeOnOutsideClick = true;
|
|
65
|
+
this.debouncedApplyFilter = debounce(() => {
|
|
66
|
+
this.filterChange.emit(this.filterItems);
|
|
67
|
+
}, 400);
|
|
68
|
+
}
|
|
69
|
+
onMouseDown(e) {
|
|
70
|
+
// click on anything then select drops values to default
|
|
71
|
+
if (!this.changes) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const path = e.composedPath();
|
|
75
|
+
const select = document.getElementById(FILTER_ID);
|
|
76
|
+
if (select instanceof HTMLSelectElement) {
|
|
77
|
+
// click on select should be skipped
|
|
78
|
+
if (path.includes(select)) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
select.value = defaultType;
|
|
82
|
+
}
|
|
83
|
+
this.currentFilterType = defaultType;
|
|
84
|
+
if (this.changes) {
|
|
85
|
+
this.changes.type = defaultType;
|
|
86
|
+
}
|
|
87
|
+
this.currentFilterId = -1;
|
|
88
|
+
const isOutside = !path.includes(this.element);
|
|
89
|
+
if (e.target instanceof HTMLElement &&
|
|
90
|
+
isOutside &&
|
|
91
|
+
!isFilterBtn(e.target) &&
|
|
92
|
+
this.closeOnOutsideClick) {
|
|
93
|
+
this.changes = undefined;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async show(newEntity) {
|
|
97
|
+
this.changes = newEntity;
|
|
98
|
+
this.filterItems = (newEntity === null || newEntity === void 0 ? void 0 : newEntity.filterItems) || {};
|
|
99
|
+
if (this.changes) {
|
|
100
|
+
this.changes.type = this.changes.type || defaultType;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
async getChanges() {
|
|
104
|
+
return this.changes;
|
|
105
|
+
}
|
|
106
|
+
componentWillRender() {
|
|
107
|
+
if (!this.isFilterIdSet) {
|
|
108
|
+
this.isFilterIdSet = true;
|
|
109
|
+
const filterItems = Object.keys(this.filterItems);
|
|
110
|
+
for (const prop of filterItems) {
|
|
111
|
+
// we set the proper filterId so there won't be any conflict when removing filters
|
|
112
|
+
this.filterId += this.filterItems[prop].length;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
getFilterItemsList() {
|
|
117
|
+
var _a, _b;
|
|
118
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
119
|
+
if (typeof prop === 'undefined')
|
|
120
|
+
return '';
|
|
121
|
+
const propFilters = (_b = this.filterItems[prop]) !== null && _b !== void 0 ? _b : [];
|
|
122
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
123
|
+
return (h("div", { key: this.filterId }, propFilters.map((filter, index) => {
|
|
124
|
+
let andOrButton;
|
|
125
|
+
if (filter.hidden) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
// hide toggle button if there is only one filter and the last one
|
|
129
|
+
if (index !== this.filterItems[prop].length - 1) {
|
|
130
|
+
andOrButton = (h("div", { onClick: () => this.toggleFilterAndOr(filter.id) }, h(AndOrButton, { text: filter.relation === 'and' ? capts.and : capts.or })));
|
|
131
|
+
}
|
|
132
|
+
return (h("div", { key: filter.id, class: FILTER_LIST_CLASS }, h("div", { class: { 'select-input': true } }, h("select", { class: "select-css select-filter", onChange: e => this.onFilterTypeChange(e, prop, index) }, this.renderSelectOptions(this.filterItems[prop][index].type, true)), h("div", { class: FILTER_LIST_CLASS_ACTION }, andOrButton), h("div", { onClick: () => this.onRemoveFilter(filter.id) }, h(TrashButton, null))), h("div", null, this.renderExtra(prop, index))));
|
|
133
|
+
}), propFilters.filter(f => !f.hidden).length > 0 ? h("div", { class: "add-filter-divider" }) : ''));
|
|
134
|
+
}
|
|
135
|
+
autoCorrect(el) {
|
|
136
|
+
var _a, _b;
|
|
137
|
+
if (!el) {
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
const revoGrid = el.closest('revo-grid');
|
|
141
|
+
if (!revoGrid) {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const pos = el.getBoundingClientRect();
|
|
145
|
+
const gridPos = revoGrid.getBoundingClientRect();
|
|
146
|
+
const maxLeft = gridPos.right - pos.width;
|
|
147
|
+
if (pos.left > maxLeft && el.offsetLeft) {
|
|
148
|
+
el.style.left = `${maxLeft - ((_b = (_a = el.parentElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect().left) !== null && _b !== void 0 ? _b : 0)}px`;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
onFilterTypeChange(e, prop, index) {
|
|
152
|
+
if (!(e.target instanceof HTMLSelectElement)) {
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
this.filterItems[prop][index].type = e.target.value;
|
|
156
|
+
// this re-renders the input to know if we need extra input
|
|
157
|
+
this.filterId++;
|
|
158
|
+
// adding setTimeout will wait for the next tick DOM update then focus on input
|
|
159
|
+
setTimeout(() => {
|
|
160
|
+
const input = document.getElementById('filter-input-' + this.filterItems[prop][index].id);
|
|
161
|
+
if (input instanceof HTMLInputElement) {
|
|
162
|
+
input.focus();
|
|
163
|
+
}
|
|
164
|
+
}, 0);
|
|
165
|
+
if (!this.disableDynamicFiltering) {
|
|
166
|
+
this.debouncedApplyFilter();
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
onAddNewFilter(e) {
|
|
170
|
+
const el = e.target;
|
|
171
|
+
this.currentFilterType = el.value;
|
|
172
|
+
this.addNewFilterToProp();
|
|
173
|
+
// reset value after adding new filter
|
|
174
|
+
const select = document.getElementById('add-filter');
|
|
175
|
+
if (select) {
|
|
176
|
+
select.value = defaultType;
|
|
177
|
+
this.currentFilterType = defaultType;
|
|
178
|
+
}
|
|
179
|
+
if (!this.disableDynamicFiltering) {
|
|
180
|
+
this.debouncedApplyFilter();
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
addNewFilterToProp() {
|
|
184
|
+
var _a;
|
|
185
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
186
|
+
if (!(prop || prop === 0))
|
|
187
|
+
return;
|
|
188
|
+
if (!this.filterItems[prop]) {
|
|
189
|
+
this.filterItems[prop] = [];
|
|
190
|
+
}
|
|
191
|
+
if (this.currentFilterType === 'none')
|
|
192
|
+
return;
|
|
193
|
+
this.filterId++;
|
|
194
|
+
this.currentFilterId = this.filterId;
|
|
195
|
+
this.filterItems[prop].push({
|
|
196
|
+
id: this.currentFilterId,
|
|
197
|
+
type: this.currentFilterType,
|
|
198
|
+
value: '',
|
|
199
|
+
relation: 'and',
|
|
200
|
+
});
|
|
201
|
+
// adding setTimeout will wait for the next tick DOM update then focus on input
|
|
202
|
+
setTimeout(() => {
|
|
203
|
+
const input = document.getElementById('filter-input-' + this.currentFilterId);
|
|
204
|
+
if (input)
|
|
205
|
+
input.focus();
|
|
206
|
+
}, 0);
|
|
207
|
+
}
|
|
208
|
+
onSave() {
|
|
209
|
+
this.filterChange.emit(this.filterItems);
|
|
210
|
+
}
|
|
211
|
+
onCancel() {
|
|
212
|
+
this.changes = undefined;
|
|
213
|
+
}
|
|
214
|
+
onReset() {
|
|
215
|
+
var _a;
|
|
216
|
+
this.assertChanges();
|
|
217
|
+
this.resetChange.emit((_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop);
|
|
218
|
+
// this updates the DOM which is used by getFilterItemsList() key
|
|
219
|
+
this.filterId++;
|
|
220
|
+
}
|
|
221
|
+
onRemoveFilter(id) {
|
|
222
|
+
var _a;
|
|
223
|
+
this.assertChanges();
|
|
224
|
+
// this is for reactivity issues for getFilterItemsList()
|
|
225
|
+
this.filterId++;
|
|
226
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
227
|
+
const items = this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
228
|
+
if (!items)
|
|
229
|
+
return;
|
|
230
|
+
const index = items.findIndex(d => d.id === id);
|
|
231
|
+
if (index === -1)
|
|
232
|
+
return;
|
|
233
|
+
items.splice(index, 1);
|
|
234
|
+
// let's remove the prop if no more filters so the filter icon will be removed
|
|
235
|
+
if (items.length === 0)
|
|
236
|
+
delete this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
237
|
+
if (!this.disableDynamicFiltering) {
|
|
238
|
+
this.debouncedApplyFilter();
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
toggleFilterAndOr(id) {
|
|
242
|
+
var _a;
|
|
243
|
+
this.assertChanges();
|
|
244
|
+
// this is for reactivity issues for getFilterItemsList()
|
|
245
|
+
this.filterId++;
|
|
246
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
247
|
+
const items = this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
248
|
+
if (!items)
|
|
249
|
+
return;
|
|
250
|
+
const index = items.findIndex(d => d.id === id);
|
|
251
|
+
if (index === -1)
|
|
252
|
+
return;
|
|
253
|
+
items[index].relation = items[index].relation === 'and' ? 'or' : 'and';
|
|
254
|
+
if (!this.disableDynamicFiltering) {
|
|
255
|
+
this.debouncedApplyFilter();
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
assertChanges() {
|
|
259
|
+
if (!this.changes) {
|
|
260
|
+
throw new Error('Changes required per edit');
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
renderSelectOptions(type, isDefaultTypeRemoved = false) {
|
|
264
|
+
if (!this.changes) {
|
|
265
|
+
return;
|
|
266
|
+
}
|
|
267
|
+
const options = [];
|
|
268
|
+
const prop = this.changes.prop;
|
|
269
|
+
const hidden = new Set();
|
|
270
|
+
Object.entries(this.filterItems).forEach(([_, values]) => {
|
|
271
|
+
values.forEach((filter) => {
|
|
272
|
+
if (filter.hidden) {
|
|
273
|
+
hidden.add(filter.type);
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
});
|
|
277
|
+
if (!isDefaultTypeRemoved) {
|
|
278
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
279
|
+
options.push(h("option", { selected: this.currentFilterType === defaultType, value: defaultType }, prop && this.filterItems[prop] && this.filterItems[prop].length > 0
|
|
280
|
+
? capts.add
|
|
281
|
+
: this.filterNames[defaultType]));
|
|
282
|
+
}
|
|
283
|
+
for (let gIndex in this.changes.filterTypes) {
|
|
284
|
+
const group = this.changes.filterTypes[gIndex].filter(k => !hidden.has(k));
|
|
285
|
+
if (group.length) {
|
|
286
|
+
options.push(...group.map(k => (h("option", { value: k, selected: type === k }, this.filterNames[k]))));
|
|
287
|
+
options.push(h("option", { disabled: true }));
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
return options;
|
|
291
|
+
}
|
|
292
|
+
renderExtra(prop, index) {
|
|
293
|
+
const currentFilter = this.filterItems[prop];
|
|
294
|
+
if (!currentFilter)
|
|
295
|
+
return '';
|
|
296
|
+
const applyFilter = (value) => {
|
|
297
|
+
this.filterItems[prop][index].value = value;
|
|
298
|
+
if (!this.disableDynamicFiltering) {
|
|
299
|
+
this.debouncedApplyFilter();
|
|
300
|
+
}
|
|
301
|
+
};
|
|
302
|
+
const focusNext = () => {
|
|
303
|
+
const select = document.getElementById('add-filter');
|
|
304
|
+
if (select) {
|
|
305
|
+
select.value = defaultType;
|
|
306
|
+
this.currentFilterType = defaultType;
|
|
307
|
+
this.addNewFilterToProp();
|
|
308
|
+
select.focus();
|
|
309
|
+
}
|
|
310
|
+
};
|
|
311
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
312
|
+
const extra = this.filterEntities[currentFilter[index].type].extra;
|
|
313
|
+
if (typeof extra === 'function') {
|
|
314
|
+
return extra(h, {
|
|
315
|
+
value: currentFilter[index].value,
|
|
316
|
+
filter: currentFilter[index],
|
|
317
|
+
prop,
|
|
318
|
+
index,
|
|
319
|
+
placeholder: capts.placeholder,
|
|
320
|
+
onInput: (value) => {
|
|
321
|
+
applyFilter(value);
|
|
322
|
+
},
|
|
323
|
+
onFocus: () => {
|
|
324
|
+
focusNext();
|
|
325
|
+
}
|
|
326
|
+
});
|
|
327
|
+
}
|
|
328
|
+
if (extra !== 'input' && extra !== 'datepicker') {
|
|
329
|
+
return '';
|
|
330
|
+
}
|
|
331
|
+
return (h("input", { id: `filter-input-${currentFilter[index].id}`, placeholder: capts.placeholder, type: extra === 'datepicker' ? 'date' : 'text', value: currentFilter[index].value, onInput: (e) => {
|
|
332
|
+
if (e.target instanceof HTMLInputElement) {
|
|
333
|
+
applyFilter(e.target.value);
|
|
334
|
+
}
|
|
335
|
+
}, onKeyDown: e => {
|
|
336
|
+
if (e.key.toLowerCase() === 'enter') {
|
|
337
|
+
const select = document.getElementById('add-filter');
|
|
338
|
+
if (select) {
|
|
339
|
+
focusNext();
|
|
340
|
+
}
|
|
341
|
+
return;
|
|
342
|
+
}
|
|
343
|
+
// keep event local, don't escalate farther to dom
|
|
344
|
+
e.stopPropagation();
|
|
345
|
+
} }));
|
|
346
|
+
}
|
|
347
|
+
render() {
|
|
348
|
+
var _a, _b, _c;
|
|
349
|
+
if (!this.changes) {
|
|
350
|
+
return h(Host, { style: { display: 'none' } });
|
|
351
|
+
}
|
|
352
|
+
const style = {
|
|
353
|
+
display: 'block',
|
|
354
|
+
left: `${this.changes.x}px`,
|
|
355
|
+
top: `${this.changes.y}px`,
|
|
356
|
+
};
|
|
357
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
358
|
+
return (h(Host, { style: style, ref: el => {
|
|
359
|
+
var _a;
|
|
360
|
+
((_a = this.changes) === null || _a === void 0 ? void 0 : _a.autoCorrect) !== false && this.autoCorrect(el);
|
|
361
|
+
} }, h("slot", { slot: "header" }), ((_b = (_a = this.changes).extraContent) === null || _b === void 0 ? void 0 : _b.call(_a, this.changes)) || '', ((_c = this.changes) === null || _c === void 0 ? void 0 : _c.hideDefaultFilters) !== true && ([
|
|
362
|
+
h("label", null, capts.title),
|
|
363
|
+
h("div", { class: "filter-holder" }, this.getFilterItemsList()),
|
|
364
|
+
h("div", { class: "add-filter" }, h("select", { id: FILTER_ID, class: "select-css", onChange: e => this.onAddNewFilter(e) }, this.renderSelectOptions(this.currentFilterType)))
|
|
365
|
+
]), h("slot", null), h("div", { class: "filter-actions" }, this.disableDynamicFiltering && [
|
|
366
|
+
h("button", { id: "revo-button-save", "aria-label": "save", class: "revo-button green", onClick: () => this.onSave() }, capts.save),
|
|
367
|
+
h("button", { id: "revo-button-ok", "aria-label": "ok", class: "revo-button green", onClick: () => this.onCancel() }, capts.cancel),
|
|
368
|
+
], !this.disableDynamicFiltering && [
|
|
369
|
+
h("button", { id: "revo-button-ok", "aria-label": "ok", class: "revo-button green", onClick: () => this.onCancel() }, capts.ok),
|
|
370
|
+
h("button", { id: "revo-button-reset", "aria-label": "reset", class: "revo-button outline", onClick: () => this.onReset() }, capts.reset),
|
|
371
|
+
]), h("slot", { slot: "footer" })));
|
|
372
|
+
}
|
|
373
|
+
get element() { return getElement(this); }
|
|
374
|
+
};
|
|
375
|
+
FilterPanel.style = filterStyleCss;
|
|
376
|
+
|
|
377
|
+
export { FilterPanel as revogr_filter_panel };
|
|
378
|
+
//# sourceMappingURL=revogr-filter-panel.entry.js.map
|
|
379
|
+
|
|
380
|
+
//# sourceMappingURL=revogr-filter-panel.entry.js.map
|