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,411 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
|
|
5
|
+
import { d as debounce } from './debounce.js';
|
|
6
|
+
import { i as isFilterBtn, e as AndOrButton, d as TrashButton } from './filter.button.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 = /*@__PURE__*/ proxyCustomElement(class FilterPanel extends HTMLElement {
|
|
34
|
+
constructor() {
|
|
35
|
+
super();
|
|
36
|
+
this.__registerHost();
|
|
37
|
+
this.filterChange = createEvent(this, "filterChange", 7);
|
|
38
|
+
this.resetChange = createEvent(this, "resetChange", 7);
|
|
39
|
+
this.filterCaptionsInternal = {
|
|
40
|
+
title: 'Filter by',
|
|
41
|
+
ok: 'Close',
|
|
42
|
+
save: 'Save',
|
|
43
|
+
// drops the filter
|
|
44
|
+
reset: 'Reset',
|
|
45
|
+
cancel: 'Cancel',
|
|
46
|
+
add: 'Add condition',
|
|
47
|
+
placeholder: 'Enter value...',
|
|
48
|
+
and: 'and',
|
|
49
|
+
or: 'or',
|
|
50
|
+
};
|
|
51
|
+
this.isFilterIdSet = false;
|
|
52
|
+
this.filterId = 0;
|
|
53
|
+
this.currentFilterId = -1;
|
|
54
|
+
this.currentFilterType = defaultType;
|
|
55
|
+
this.filterItems = {};
|
|
56
|
+
this.filterNames = {};
|
|
57
|
+
this.filterEntities = {};
|
|
58
|
+
/**
|
|
59
|
+
* Disables dynamic filtering. A way to apply filters on Save only
|
|
60
|
+
*/
|
|
61
|
+
this.disableDynamicFiltering = false;
|
|
62
|
+
/**
|
|
63
|
+
* If true, closes the filter panel when clicking outside
|
|
64
|
+
*/
|
|
65
|
+
this.closeOnOutsideClick = true;
|
|
66
|
+
this.debouncedApplyFilter = debounce(() => {
|
|
67
|
+
this.filterChange.emit(this.filterItems);
|
|
68
|
+
}, 400);
|
|
69
|
+
}
|
|
70
|
+
onMouseDown(e) {
|
|
71
|
+
// click on anything then select drops values to default
|
|
72
|
+
if (!this.changes) {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const path = e.composedPath();
|
|
76
|
+
const select = document.getElementById(FILTER_ID);
|
|
77
|
+
if (select instanceof HTMLSelectElement) {
|
|
78
|
+
// click on select should be skipped
|
|
79
|
+
if (path.includes(select)) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
select.value = defaultType;
|
|
83
|
+
}
|
|
84
|
+
this.currentFilterType = defaultType;
|
|
85
|
+
if (this.changes) {
|
|
86
|
+
this.changes.type = defaultType;
|
|
87
|
+
}
|
|
88
|
+
this.currentFilterId = -1;
|
|
89
|
+
const isOutside = !path.includes(this.element);
|
|
90
|
+
if (e.target instanceof HTMLElement &&
|
|
91
|
+
isOutside &&
|
|
92
|
+
!isFilterBtn(e.target) &&
|
|
93
|
+
this.closeOnOutsideClick) {
|
|
94
|
+
this.changes = undefined;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
async show(newEntity) {
|
|
98
|
+
this.changes = newEntity;
|
|
99
|
+
this.filterItems = (newEntity === null || newEntity === void 0 ? void 0 : newEntity.filterItems) || {};
|
|
100
|
+
if (this.changes) {
|
|
101
|
+
this.changes.type = this.changes.type || defaultType;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
async getChanges() {
|
|
105
|
+
return this.changes;
|
|
106
|
+
}
|
|
107
|
+
componentWillRender() {
|
|
108
|
+
if (!this.isFilterIdSet) {
|
|
109
|
+
this.isFilterIdSet = true;
|
|
110
|
+
const filterItems = Object.keys(this.filterItems);
|
|
111
|
+
for (const prop of filterItems) {
|
|
112
|
+
// we set the proper filterId so there won't be any conflict when removing filters
|
|
113
|
+
this.filterId += this.filterItems[prop].length;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
getFilterItemsList() {
|
|
118
|
+
var _a, _b;
|
|
119
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
120
|
+
if (typeof prop === 'undefined')
|
|
121
|
+
return '';
|
|
122
|
+
const propFilters = (_b = this.filterItems[prop]) !== null && _b !== void 0 ? _b : [];
|
|
123
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
124
|
+
return (h("div", { key: this.filterId }, propFilters.map((filter, index) => {
|
|
125
|
+
let andOrButton;
|
|
126
|
+
if (filter.hidden) {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
// hide toggle button if there is only one filter and the last one
|
|
130
|
+
if (index !== this.filterItems[prop].length - 1) {
|
|
131
|
+
andOrButton = (h("div", { onClick: () => this.toggleFilterAndOr(filter.id) }, h(AndOrButton, { text: filter.relation === 'and' ? capts.and : capts.or })));
|
|
132
|
+
}
|
|
133
|
+
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))));
|
|
134
|
+
}), propFilters.filter(f => !f.hidden).length > 0 ? h("div", { class: "add-filter-divider" }) : ''));
|
|
135
|
+
}
|
|
136
|
+
autoCorrect(el) {
|
|
137
|
+
var _a, _b;
|
|
138
|
+
if (!el) {
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
const revoGrid = el.closest('revo-grid');
|
|
142
|
+
if (!revoGrid) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const pos = el.getBoundingClientRect();
|
|
146
|
+
const gridPos = revoGrid.getBoundingClientRect();
|
|
147
|
+
const maxLeft = gridPos.right - pos.width;
|
|
148
|
+
if (pos.left > maxLeft && el.offsetLeft) {
|
|
149
|
+
el.style.left = `${maxLeft - ((_b = (_a = el.parentElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect().left) !== null && _b !== void 0 ? _b : 0)}px`;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
onFilterTypeChange(e, prop, index) {
|
|
153
|
+
if (!(e.target instanceof HTMLSelectElement)) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
this.filterItems[prop][index].type = e.target.value;
|
|
157
|
+
// this re-renders the input to know if we need extra input
|
|
158
|
+
this.filterId++;
|
|
159
|
+
// adding setTimeout will wait for the next tick DOM update then focus on input
|
|
160
|
+
setTimeout(() => {
|
|
161
|
+
const input = document.getElementById('filter-input-' + this.filterItems[prop][index].id);
|
|
162
|
+
if (input instanceof HTMLInputElement) {
|
|
163
|
+
input.focus();
|
|
164
|
+
}
|
|
165
|
+
}, 0);
|
|
166
|
+
if (!this.disableDynamicFiltering) {
|
|
167
|
+
this.debouncedApplyFilter();
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
onAddNewFilter(e) {
|
|
171
|
+
const el = e.target;
|
|
172
|
+
this.currentFilterType = el.value;
|
|
173
|
+
this.addNewFilterToProp();
|
|
174
|
+
// reset value after adding new filter
|
|
175
|
+
const select = document.getElementById('add-filter');
|
|
176
|
+
if (select) {
|
|
177
|
+
select.value = defaultType;
|
|
178
|
+
this.currentFilterType = defaultType;
|
|
179
|
+
}
|
|
180
|
+
if (!this.disableDynamicFiltering) {
|
|
181
|
+
this.debouncedApplyFilter();
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
addNewFilterToProp() {
|
|
185
|
+
var _a;
|
|
186
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
187
|
+
if (!(prop || prop === 0))
|
|
188
|
+
return;
|
|
189
|
+
if (!this.filterItems[prop]) {
|
|
190
|
+
this.filterItems[prop] = [];
|
|
191
|
+
}
|
|
192
|
+
if (this.currentFilterType === 'none')
|
|
193
|
+
return;
|
|
194
|
+
this.filterId++;
|
|
195
|
+
this.currentFilterId = this.filterId;
|
|
196
|
+
this.filterItems[prop].push({
|
|
197
|
+
id: this.currentFilterId,
|
|
198
|
+
type: this.currentFilterType,
|
|
199
|
+
value: '',
|
|
200
|
+
relation: 'and',
|
|
201
|
+
});
|
|
202
|
+
// adding setTimeout will wait for the next tick DOM update then focus on input
|
|
203
|
+
setTimeout(() => {
|
|
204
|
+
const input = document.getElementById('filter-input-' + this.currentFilterId);
|
|
205
|
+
if (input)
|
|
206
|
+
input.focus();
|
|
207
|
+
}, 0);
|
|
208
|
+
}
|
|
209
|
+
onSave() {
|
|
210
|
+
this.filterChange.emit(this.filterItems);
|
|
211
|
+
}
|
|
212
|
+
onCancel() {
|
|
213
|
+
this.changes = undefined;
|
|
214
|
+
}
|
|
215
|
+
onReset() {
|
|
216
|
+
var _a;
|
|
217
|
+
this.assertChanges();
|
|
218
|
+
this.resetChange.emit((_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop);
|
|
219
|
+
// this updates the DOM which is used by getFilterItemsList() key
|
|
220
|
+
this.filterId++;
|
|
221
|
+
}
|
|
222
|
+
onRemoveFilter(id) {
|
|
223
|
+
var _a;
|
|
224
|
+
this.assertChanges();
|
|
225
|
+
// this is for reactivity issues for getFilterItemsList()
|
|
226
|
+
this.filterId++;
|
|
227
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
228
|
+
const items = this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
229
|
+
if (!items)
|
|
230
|
+
return;
|
|
231
|
+
const index = items.findIndex(d => d.id === id);
|
|
232
|
+
if (index === -1)
|
|
233
|
+
return;
|
|
234
|
+
items.splice(index, 1);
|
|
235
|
+
// let's remove the prop if no more filters so the filter icon will be removed
|
|
236
|
+
if (items.length === 0)
|
|
237
|
+
delete this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
238
|
+
if (!this.disableDynamicFiltering) {
|
|
239
|
+
this.debouncedApplyFilter();
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
toggleFilterAndOr(id) {
|
|
243
|
+
var _a;
|
|
244
|
+
this.assertChanges();
|
|
245
|
+
// this is for reactivity issues for getFilterItemsList()
|
|
246
|
+
this.filterId++;
|
|
247
|
+
const prop = (_a = this.changes) === null || _a === void 0 ? void 0 : _a.prop;
|
|
248
|
+
const items = this.filterItems[prop !== null && prop !== void 0 ? prop : ''];
|
|
249
|
+
if (!items)
|
|
250
|
+
return;
|
|
251
|
+
const index = items.findIndex(d => d.id === id);
|
|
252
|
+
if (index === -1)
|
|
253
|
+
return;
|
|
254
|
+
items[index].relation = items[index].relation === 'and' ? 'or' : 'and';
|
|
255
|
+
if (!this.disableDynamicFiltering) {
|
|
256
|
+
this.debouncedApplyFilter();
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
assertChanges() {
|
|
260
|
+
if (!this.changes) {
|
|
261
|
+
throw new Error('Changes required per edit');
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
renderSelectOptions(type, isDefaultTypeRemoved = false) {
|
|
265
|
+
if (!this.changes) {
|
|
266
|
+
return;
|
|
267
|
+
}
|
|
268
|
+
const options = [];
|
|
269
|
+
const prop = this.changes.prop;
|
|
270
|
+
const hidden = new Set();
|
|
271
|
+
Object.entries(this.filterItems).forEach(([_, values]) => {
|
|
272
|
+
values.forEach((filter) => {
|
|
273
|
+
if (filter.hidden) {
|
|
274
|
+
hidden.add(filter.type);
|
|
275
|
+
}
|
|
276
|
+
});
|
|
277
|
+
});
|
|
278
|
+
if (!isDefaultTypeRemoved) {
|
|
279
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
280
|
+
options.push(h("option", { selected: this.currentFilterType === defaultType, value: defaultType }, prop && this.filterItems[prop] && this.filterItems[prop].length > 0
|
|
281
|
+
? capts.add
|
|
282
|
+
: this.filterNames[defaultType]));
|
|
283
|
+
}
|
|
284
|
+
for (let gIndex in this.changes.filterTypes) {
|
|
285
|
+
const group = this.changes.filterTypes[gIndex].filter(k => !hidden.has(k));
|
|
286
|
+
if (group.length) {
|
|
287
|
+
options.push(...group.map(k => (h("option", { value: k, selected: type === k }, this.filterNames[k]))));
|
|
288
|
+
options.push(h("option", { disabled: true }));
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
return options;
|
|
292
|
+
}
|
|
293
|
+
renderExtra(prop, index) {
|
|
294
|
+
const currentFilter = this.filterItems[prop];
|
|
295
|
+
if (!currentFilter)
|
|
296
|
+
return '';
|
|
297
|
+
const applyFilter = (value) => {
|
|
298
|
+
this.filterItems[prop][index].value = value;
|
|
299
|
+
if (!this.disableDynamicFiltering) {
|
|
300
|
+
this.debouncedApplyFilter();
|
|
301
|
+
}
|
|
302
|
+
};
|
|
303
|
+
const focusNext = () => {
|
|
304
|
+
const select = document.getElementById('add-filter');
|
|
305
|
+
if (select) {
|
|
306
|
+
select.value = defaultType;
|
|
307
|
+
this.currentFilterType = defaultType;
|
|
308
|
+
this.addNewFilterToProp();
|
|
309
|
+
select.focus();
|
|
310
|
+
}
|
|
311
|
+
};
|
|
312
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
313
|
+
const extra = this.filterEntities[currentFilter[index].type].extra;
|
|
314
|
+
if (typeof extra === 'function') {
|
|
315
|
+
return extra(h, {
|
|
316
|
+
value: currentFilter[index].value,
|
|
317
|
+
filter: currentFilter[index],
|
|
318
|
+
prop,
|
|
319
|
+
index,
|
|
320
|
+
placeholder: capts.placeholder,
|
|
321
|
+
onInput: (value) => {
|
|
322
|
+
applyFilter(value);
|
|
323
|
+
},
|
|
324
|
+
onFocus: () => {
|
|
325
|
+
focusNext();
|
|
326
|
+
}
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
if (extra !== 'input' && extra !== 'datepicker') {
|
|
330
|
+
return '';
|
|
331
|
+
}
|
|
332
|
+
return (h("input", { id: `filter-input-${currentFilter[index].id}`, placeholder: capts.placeholder, type: extra === 'datepicker' ? 'date' : 'text', value: currentFilter[index].value, onInput: (e) => {
|
|
333
|
+
if (e.target instanceof HTMLInputElement) {
|
|
334
|
+
applyFilter(e.target.value);
|
|
335
|
+
}
|
|
336
|
+
}, onKeyDown: e => {
|
|
337
|
+
if (e.key.toLowerCase() === 'enter') {
|
|
338
|
+
const select = document.getElementById('add-filter');
|
|
339
|
+
if (select) {
|
|
340
|
+
focusNext();
|
|
341
|
+
}
|
|
342
|
+
return;
|
|
343
|
+
}
|
|
344
|
+
// keep event local, don't escalate farther to dom
|
|
345
|
+
e.stopPropagation();
|
|
346
|
+
} }));
|
|
347
|
+
}
|
|
348
|
+
render() {
|
|
349
|
+
var _a, _b, _c;
|
|
350
|
+
if (!this.changes) {
|
|
351
|
+
return h(Host, { style: { display: 'none' } });
|
|
352
|
+
}
|
|
353
|
+
const style = {
|
|
354
|
+
display: 'block',
|
|
355
|
+
left: `${this.changes.x}px`,
|
|
356
|
+
top: `${this.changes.y}px`,
|
|
357
|
+
};
|
|
358
|
+
const capts = Object.assign(this.filterCaptionsInternal, this.filterCaptions);
|
|
359
|
+
return (h(Host, { style: style, ref: el => {
|
|
360
|
+
var _a;
|
|
361
|
+
((_a = this.changes) === null || _a === void 0 ? void 0 : _a.autoCorrect) !== false && this.autoCorrect(el);
|
|
362
|
+
} }, 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 && ([
|
|
363
|
+
h("label", null, capts.title),
|
|
364
|
+
h("div", { class: "filter-holder" }, this.getFilterItemsList()),
|
|
365
|
+
h("div", { class: "add-filter" }, h("select", { id: FILTER_ID, class: "select-css", onChange: e => this.onAddNewFilter(e) }, this.renderSelectOptions(this.currentFilterType)))
|
|
366
|
+
]), h("slot", null), h("div", { class: "filter-actions" }, this.disableDynamicFiltering && [
|
|
367
|
+
h("button", { id: "revo-button-save", "aria-label": "save", class: "revo-button green", onClick: () => this.onSave() }, capts.save),
|
|
368
|
+
h("button", { id: "revo-button-ok", "aria-label": "ok", class: "revo-button green", onClick: () => this.onCancel() }, capts.cancel),
|
|
369
|
+
], !this.disableDynamicFiltering && [
|
|
370
|
+
h("button", { id: "revo-button-ok", "aria-label": "ok", class: "revo-button green", onClick: () => this.onCancel() }, capts.ok),
|
|
371
|
+
h("button", { id: "revo-button-reset", "aria-label": "reset", class: "revo-button outline", onClick: () => this.onReset() }, capts.reset),
|
|
372
|
+
]), h("slot", { slot: "footer" })));
|
|
373
|
+
}
|
|
374
|
+
get element() { return this; }
|
|
375
|
+
static get style() { return filterStyleCss; }
|
|
376
|
+
}, [260, "revogr-filter-panel", {
|
|
377
|
+
"filterNames": [16, "filter-names"],
|
|
378
|
+
"filterEntities": [16, "filter-entities"],
|
|
379
|
+
"filterCaptions": [16, "filter-captions"],
|
|
380
|
+
"disableDynamicFiltering": [4, "disable-dynamic-filtering"],
|
|
381
|
+
"closeOnOutsideClick": [4, "close-on-outside-click"],
|
|
382
|
+
"isFilterIdSet": [32],
|
|
383
|
+
"filterId": [32],
|
|
384
|
+
"currentFilterId": [32],
|
|
385
|
+
"currentFilterType": [32],
|
|
386
|
+
"changes": [32],
|
|
387
|
+
"filterItems": [32],
|
|
388
|
+
"show": [64],
|
|
389
|
+
"getChanges": [64]
|
|
390
|
+
}, [[5, "mousedown", "onMouseDown"]]]);
|
|
391
|
+
function defineCustomElement$1() {
|
|
392
|
+
if (typeof customElements === "undefined") {
|
|
393
|
+
return;
|
|
394
|
+
}
|
|
395
|
+
const components = ["revogr-filter-panel"];
|
|
396
|
+
components.forEach(tagName => { switch (tagName) {
|
|
397
|
+
case "revogr-filter-panel":
|
|
398
|
+
if (!customElements.get(tagName)) {
|
|
399
|
+
customElements.define(tagName, FilterPanel);
|
|
400
|
+
}
|
|
401
|
+
break;
|
|
402
|
+
} });
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
const RevogrFilterPanel = FilterPanel;
|
|
406
|
+
const defineCustomElement = defineCustomElement$1;
|
|
407
|
+
|
|
408
|
+
export { RevogrFilterPanel, defineCustomElement };
|
|
409
|
+
//# sourceMappingURL=revogr-filter-panel.js.map
|
|
410
|
+
|
|
411
|
+
//# sourceMappingURL=revogr-filter-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"revogr-filter-panel.js","mappings":"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","names":["__stencil_proxyCustomElement"],"sources":["src/utils/closest.polifill.ts","src/plugins/filter/filter.style.scss?tag=revogr-filter-panel","src/plugins/filter/filter.panel.tsx"],"sourcesContent":["(function closest() {\r\n if (!Element.prototype.matches) {\r\n Element.prototype.matches =\r\n ((Element.prototype as unknown) as { msMatchesSelector: (selectors: string) => boolean }).msMatchesSelector || Element.prototype.webkitMatchesSelector;\r\n }\r\n\r\n if (!Element.prototype.closest) {\r\n Element.prototype.closest = function (s: string) {\r\n let el: HTMLElement | Element | (Node & ParentNode) | null = this;\r\n\r\n do {\r\n if (Element.prototype.matches.call(el, s)) {\r\n return el;\r\n }\r\n el = el.parentElement || el.parentNode;\r\n } while (el !== null && el.nodeType === 1);\r\n return null;\r\n };\r\n }\r\n})();\r\n","revogr-filter-panel {\r\n position: absolute;\r\n display: block;\r\n top: 0;\r\n left: 0;\r\n z-index: 100;\r\n max-height: calc(100% - 80px);\r\n min-width: 250px;\r\n overflow: auto;\r\n\r\n opacity: 1;\r\n transform: none;\r\n background-color: var(--revo-grid-filter-panel-bg, #fff);\r\n border: 1px solid var(--revo-grid-filter-panel-border, #cecece);\r\n transform-origin: 62px 0px;\r\n box-shadow: 0 5px 18px -2px var(--revo-grid-filter-panel-shadow, rgba(0, 0, 0, 0.15));\r\n padding: 10px;\r\n border-radius: 8px;\r\n\r\n min-width: 220px;\r\n text-align: left;\r\n\r\n .filter-holder > div {\r\n display: flex;\r\n flex-direction: column;\r\n }\r\n\r\n label {\r\n font-size: 13px;\r\n display: block;\r\n padding: 8px 0;\r\n }\r\n\r\n select {\r\n width: 100%;\r\n }\r\n\r\n input[type='text'] {\r\n border: 0;\r\n min-height: 34px;\r\n margin: 5px 0;\r\n background: var(--revo-grid-filter-panel-input-bg, #f3f3f3);\r\n border-radius: 5px;\r\n padding: 0 10px;\r\n box-sizing: border-box;\r\n width: 100%;\r\n }\r\n\r\n button {\r\n margin-top: 10px;\r\n margin-right: 5px;\r\n }\r\n\r\n .filter-actions {\r\n text-align: right;\r\n margin-right: -5px;\r\n }\r\n}\r\n\r\n.rgHeaderCell {\r\n &:hover .rv-filter {\r\n transition:\r\n opacity 267ms cubic-bezier(0.4, 0, 0.2, 1) 0ms,\r\n transform 178ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;\r\n }\r\n &:hover .rv-filter,\r\n .rv-filter.active {\r\n opacity: 1;\r\n }\r\n\r\n .rv-filter {\r\n $btn-size: 24px;\r\n height: $btn-size;\r\n width: $btn-size;\r\n background: none;\r\n border: 0;\r\n opacity: 0;\r\n visibility: visible;\r\n cursor: pointer;\r\n border-radius: 4px;\r\n\r\n &.active {\r\n color: #10224a;\r\n }\r\n\r\n .filter-img {\r\n $img-size: 11px;\r\n color: gray;\r\n width: $img-size;\r\n }\r\n }\r\n}\r\n\r\n.select-css {\r\n $gradient: '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';\r\n\r\n display: block;\r\n font-family: sans-serif;\r\n line-height: 1.3;\r\n padding: 0.6em 1.4em 0.5em 0.8em;\r\n width: 100%;\r\n max-width: 100%; /* useful when width is set to anything other than 100% */\r\n box-sizing: border-box;\r\n margin: 0;\r\n border: 1px solid var(--revo-grid-filter-panel-select-border, #d9d9d9);\r\n box-shadow: transparent;\r\n border-radius: 0.5em;\r\n appearance: none;\r\n background-color: var(--revo-grid-filter-panel-input-bg, #f3f3f3);\r\n background-image: url($gradient);\r\n background-repeat: no-repeat, repeat;\r\n /* arrow icon position (1em from the right, 50% vertical) , then gradient position*/\r\n background-position:\r\n right 0.7em top 50%,\r\n 0 0;\r\n /* icon size, then gradient */\r\n background-size:\r\n 0.65em auto,\r\n 100%;\r\n\r\n /* Hide arrow icon in IE browsers */\r\n &::-ms-expand {\r\n display: none;\r\n }\r\n /* Hover style */\r\n &:hover {\r\n border-color: var(--revo-grid-filter-panel-select-border, #d9d9d9);\r\n }\r\n /* Focus style */\r\n &:focus {\r\n border-color: var(--revo-grid-filter-panel-select-border-hover, #d9d9d9);\r\n box-shadow: 0 0 1px 3px rgba(59, 153, 252, 0.7);\r\n box-shadow: 0 0 0 3px -moz-mac-focusring;\r\n outline: none;\r\n }\r\n\r\n /* Set options to normal weight */\r\n option {\r\n font-weight: normal;\r\n }\r\n\r\n /* Disabled styles */\r\n &:disabled,\r\n &[aria-disabled='true'] {\r\n color: gray;\r\n 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'),\r\n linear-gradient(to bottom, #ffffff 0%, #ffffff 100%);\r\n }\r\n\r\n &:disabled:hover,\r\n &[aria-disabled='true'] {\r\n border-color: var(--revo-grid-filter-panel-select-border, #d9d9d9);\r\n }\r\n}\r\n\r\n.multi-filter-list {\r\n margin-top: 5px;\r\n margin-bottom: 5px;\r\n\r\n div {\r\n white-space: nowrap;\r\n }\r\n\r\n .multi-filter-list-action {\r\n display: flex;\r\n\r\n justify-content: space-between;\r\n align-items: center;\r\n }\r\n\r\n .and-or-button {\r\n margin: 0 0 0 10px;\r\n min-width: 58px;\r\n cursor: pointer;\r\n }\r\n .trash-button {\r\n $btn-remove-size: 22px;\r\n margin: 0 0 -2px 6px;\r\n cursor: pointer;\r\n\r\n width: $btn-remove-size;\r\n height: 100%;\r\n font-size: 16px;\r\n\r\n .trash-img {\r\n width: 1em;\r\n }\r\n }\r\n}\r\n\r\n.add-filter-divider {\r\n display: block;\r\n margin: 0 -10px 10px -10px;\r\n\r\n border-bottom: 1px solid var(--revo-grid-filter-panel-divider, #d9d9d9);\r\n height: 10px;\r\n}\r\n\r\n.select-input {\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n}\r\n","// filter.panel.tsx\r\n\r\nimport {\r\n h,\r\n Component,\r\n Event,\r\n EventEmitter,\r\n Host,\r\n Listen,\r\n Method,\r\n Prop,\r\n State,\r\n type VNode,\r\n Element,\r\n} from '@stencil/core';\r\nimport debounce from 'lodash/debounce';\r\n\r\nimport { AndOrButton, isFilterBtn, TrashButton } from './filter.button';\r\nimport '../../utils/closest.polifill';\r\nimport {\r\n FilterCaptions,\r\n LogicFunction,\r\n MultiFilterItem,\r\n ShowData,\r\n} from './filter.types';\r\nimport type { ColumnProp } from '@type';\r\nimport { FilterType } from './filter.indexed';\r\n\r\nconst defaultType: FilterType = 'none';\r\n\r\nconst FILTER_LIST_CLASS = 'multi-filter-list';\r\nconst FILTER_LIST_CLASS_ACTION = 'multi-filter-list-action';\r\nconst FILTER_ID = 'add-filter';\r\n\r\n/**\r\n * Filter panel for editing filters\r\n */\r\n/**\r\n * @internal\r\n */\r\n@Component({\r\n tag: 'revogr-filter-panel',\r\n styleUrl: 'filter.style.scss',\r\n})\r\nexport class FilterPanel {\r\n private filterCaptionsInternal: FilterCaptions = {\r\n title: 'Filter by',\r\n ok: 'Close',\r\n save: 'Save',\r\n // drops the filter\r\n reset: 'Reset',\r\n cancel: 'Cancel',\r\n add: 'Add condition',\r\n placeholder: 'Enter value...',\r\n and: 'and',\r\n or: 'or',\r\n };\r\n\r\n @Element() element!: HTMLElement;\r\n @State() isFilterIdSet = false;\r\n @State() filterId = 0;\r\n @State() currentFilterId = -1;\r\n @State() currentFilterType: FilterType = defaultType;\r\n @State() changes: ShowData | undefined;\r\n @State() filterItems: MultiFilterItem = {};\r\n @Prop() filterNames: Record<string, string> = {};\r\n @Prop() filterEntities: Record<string, LogicFunction> = {};\r\n @Prop() filterCaptions: Partial<FilterCaptions> | undefined;\r\n /**\r\n * Disables dynamic filtering. A way to apply filters on Save only\r\n */\r\n @Prop() disableDynamicFiltering = false;\r\n /**\r\n * If true, closes the filter panel when clicking outside\r\n */\r\n @Prop() closeOnOutsideClick = true;\r\n @Event() filterChange: EventEmitter<MultiFilterItem>;\r\n @Event() resetChange: EventEmitter<ColumnProp>;\r\n\r\n @Listen('mousedown', { target: 'document' }) onMouseDown(e: MouseEvent) {\r\n // click on anything then select drops values to default\r\n if (!this.changes) {\r\n return;\r\n }\r\n const path = e.composedPath();\r\n const select = document.getElementById(FILTER_ID);\r\n if (select instanceof HTMLSelectElement) {\r\n // click on select should be skipped\r\n if (path.includes(select)) {\r\n return;\r\n }\r\n select.value = defaultType;\r\n }\r\n this.currentFilterType = defaultType;\r\n if (this.changes) {\r\n this.changes.type = defaultType;\r\n }\r\n this.currentFilterId = -1;\r\n\r\n const isOutside = !path.includes(this.element);\r\n\r\n if (\r\n e.target instanceof HTMLElement &&\r\n isOutside &&\r\n !isFilterBtn(e.target) &&\r\n this.closeOnOutsideClick\r\n ) {\r\n this.changes = undefined;\r\n }\r\n }\r\n\r\n @Method() async show(newEntity?: ShowData) {\r\n this.changes = newEntity;\r\n this.filterItems = newEntity?.filterItems || {};\r\n if (this.changes) {\r\n this.changes.type = this.changes.type || defaultType;\r\n }\r\n }\r\n\r\n @Method() async getChanges() {\r\n return this.changes;\r\n }\r\n\r\n componentWillRender() {\r\n if (!this.isFilterIdSet) {\r\n this.isFilterIdSet = true;\r\n const filterItems = Object.keys(this.filterItems);\r\n for (const prop of filterItems) {\r\n // we set the proper filterId so there won't be any conflict when removing filters\r\n this.filterId += this.filterItems[prop].length;\r\n }\r\n }\r\n }\r\n\r\n getFilterItemsList() {\r\n const prop = this.changes?.prop;\r\n if (typeof prop === 'undefined') return '';\r\n\r\n const propFilters = this.filterItems[prop] ?? [];\r\n const capts = Object.assign(\r\n this.filterCaptionsInternal,\r\n this.filterCaptions,\r\n );\r\n return (\r\n <div key={this.filterId}>\r\n {propFilters.map((filter, index) => {\r\n let andOrButton;\r\n if (filter.hidden) {\r\n return;\r\n }\r\n\r\n // hide toggle button if there is only one filter and the last one\r\n if (index !== this.filterItems[prop].length - 1) {\r\n andOrButton = (\r\n <div onClick={() => this.toggleFilterAndOr(filter.id)}>\r\n <AndOrButton\r\n text={filter.relation === 'and' ? capts.and : capts.or}\r\n />\r\n </div>\r\n );\r\n }\r\n\r\n return (\r\n <div key={filter.id} class={FILTER_LIST_CLASS}>\r\n <div class={{ 'select-input': true }}>\r\n <select\r\n class=\"select-css select-filter\"\r\n onChange={e => this.onFilterTypeChange(e, prop, index)}\r\n >\r\n {this.renderSelectOptions(\r\n this.filterItems[prop][index].type,\r\n true,\r\n )}\r\n </select>\r\n <div class={FILTER_LIST_CLASS_ACTION}>{andOrButton}</div>\r\n <div onClick={() => this.onRemoveFilter(filter.id)}>\r\n <TrashButton />\r\n </div>\r\n </div>\r\n <div>{this.renderExtra(prop, index)}</div>\r\n </div>\r\n );\r\n })}\r\n\r\n {propFilters.filter(f => !f.hidden).length > 0 ? <div class=\"add-filter-divider\" /> : ''}\r\n </div>\r\n );\r\n }\r\n\r\n private autoCorrect(el?: HTMLElement | null) {\r\n if (!el) {\r\n return;\r\n }\r\n\r\n const revoGrid = el.closest('revo-grid');\r\n if (!revoGrid) {\r\n return;\r\n }\r\n\r\n const pos = el.getBoundingClientRect();\r\n const gridPos = revoGrid.getBoundingClientRect();\r\n const maxLeft = gridPos.right - pos.width;\r\n\r\n if (pos.left > maxLeft && el.offsetLeft) {\r\n el.style.left = `${maxLeft - (el.parentElement?.getBoundingClientRect().left ?? 0)}px`;\r\n }\r\n }\r\n\r\n private onFilterTypeChange(e: Event, prop: ColumnProp, index: number) {\r\n if (!(e.target instanceof HTMLSelectElement)) {\r\n return;\r\n }\r\n this.filterItems[prop][index].type = e.target.value as FilterType;\r\n\r\n // this re-renders the input to know if we need extra input\r\n this.filterId++;\r\n\r\n // adding setTimeout will wait for the next tick DOM update then focus on input\r\n setTimeout(() => {\r\n const input = document.getElementById(\r\n 'filter-input-' + this.filterItems[prop][index].id,\r\n );\r\n if (input instanceof HTMLInputElement) {\r\n input.focus();\r\n }\r\n }, 0);\r\n\r\n if (!this.disableDynamicFiltering) {\r\n this.debouncedApplyFilter();\r\n }\r\n }\r\n\r\n private debouncedApplyFilter = debounce(() => {\r\n this.filterChange.emit(this.filterItems);\r\n }, 400);\r\n\r\n private onAddNewFilter(e: Event) {\r\n const el = e.target as HTMLSelectElement;\r\n this.currentFilterType = el.value as FilterType;\r\n this.addNewFilterToProp();\r\n\r\n // reset value after adding new filter\r\n const select = document.getElementById('add-filter') as HTMLSelectElement;\r\n if (select) {\r\n select.value = defaultType;\r\n this.currentFilterType = defaultType;\r\n }\r\n\r\n if (!this.disableDynamicFiltering) {\r\n this.debouncedApplyFilter();\r\n }\r\n }\r\n\r\n private addNewFilterToProp() {\r\n const prop = this.changes?.prop;\r\n if (!(prop || prop === 0)) return;\r\n\r\n if (!this.filterItems[prop]) {\r\n this.filterItems[prop] = [];\r\n }\r\n\r\n if (this.currentFilterType === 'none') return;\r\n\r\n this.filterId++;\r\n this.currentFilterId = this.filterId;\r\n\r\n this.filterItems[prop].push({\r\n id: this.currentFilterId,\r\n type: this.currentFilterType,\r\n value: '',\r\n relation: 'and',\r\n });\r\n\r\n // adding setTimeout will wait for the next tick DOM update then focus on input\r\n setTimeout(() => {\r\n const input = document.getElementById(\r\n 'filter-input-' + this.currentFilterId,\r\n ) as HTMLInputElement;\r\n if (input) input.focus();\r\n }, 0);\r\n }\r\n\r\n private onSave() {\r\n this.filterChange.emit(this.filterItems);\r\n }\r\n\r\n private onCancel() {\r\n this.changes = undefined;\r\n }\r\n\r\n private onReset() {\r\n this.assertChanges();\r\n\r\n this.resetChange.emit(this.changes?.prop);\r\n\r\n // this updates the DOM which is used by getFilterItemsList() key\r\n this.filterId++;\r\n }\r\n\r\n private onRemoveFilter(id: number) {\r\n this.assertChanges();\r\n\r\n // this is for reactivity issues for getFilterItemsList()\r\n this.filterId++;\r\n\r\n const prop = this.changes?.prop;\r\n\r\n const items = this.filterItems[prop ?? ''];\r\n if (!items) return;\r\n\r\n const index = items.findIndex(d => d.id === id);\r\n if (index === -1) return;\r\n items.splice(index, 1);\r\n\r\n // let's remove the prop if no more filters so the filter icon will be removed\r\n if (items.length === 0) delete this.filterItems[prop ?? ''];\r\n\r\n if (!this.disableDynamicFiltering) {\r\n this.debouncedApplyFilter();\r\n }\r\n }\r\n\r\n private toggleFilterAndOr(id: number) {\r\n this.assertChanges();\r\n\r\n // this is for reactivity issues for getFilterItemsList()\r\n this.filterId++;\r\n\r\n const prop = this.changes?.prop;\r\n\r\n const items = this.filterItems[prop ?? ''];\r\n if (!items) return;\r\n\r\n const index = items.findIndex(d => d.id === id);\r\n if (index === -1) return;\r\n\r\n items[index].relation = items[index].relation === 'and' ? 'or' : 'and';\r\n if (!this.disableDynamicFiltering) {\r\n this.debouncedApplyFilter();\r\n }\r\n }\r\n\r\n private assertChanges() {\r\n if (!this.changes) {\r\n throw new Error('Changes required per edit');\r\n }\r\n }\r\n\r\n renderSelectOptions(type: FilterType, isDefaultTypeRemoved = false) {\r\n if (!this.changes) {\r\n return;\r\n }\r\n const options: VNode[] = [];\r\n const prop = this.changes.prop;\r\n\r\n const hidden = new Set<string>();\r\n Object.entries(this.filterItems).forEach(([_, values]) => {\r\n values.forEach((filter) => {\r\n if (filter.hidden) {\r\n hidden.add(filter.type);\r\n }\r\n })\r\n });\r\n\r\n if (!isDefaultTypeRemoved) {\r\n const capts = Object.assign(\r\n this.filterCaptionsInternal,\r\n this.filterCaptions,\r\n );\r\n\r\n options.push(\r\n <option\r\n selected={this.currentFilterType === defaultType}\r\n value={defaultType}\r\n >\r\n {prop && this.filterItems[prop] && this.filterItems[prop].length > 0\r\n ? capts.add\r\n : this.filterNames[defaultType]}\r\n </option>,\r\n );\r\n }\r\n\r\n for (let gIndex in this.changes.filterTypes) {\r\n const group = this.changes.filterTypes[gIndex].filter(k => !hidden.has(k));\r\n if (group.length) {\r\n options.push(\r\n ...group.map(k => (\r\n <option value={k} selected={type === k}>\r\n {this.filterNames[k]}\r\n </option>\r\n )),\r\n );\r\n options.push(<option disabled></option>);\r\n }\r\n }\r\n return options;\r\n }\r\n\r\n renderExtra(prop: ColumnProp, index: number) {\r\n const currentFilter = this.filterItems[prop];\r\n\r\n if (!currentFilter) return '';\r\n\r\n const applyFilter = (value?: any) => {\r\n this.filterItems[prop][index].value = value;\r\n if (!this.disableDynamicFiltering) {\r\n this.debouncedApplyFilter();\r\n }\r\n };\r\n\r\n const focusNext = () => {\r\n const select = document.getElementById('add-filter') as HTMLSelectElement;\r\n if (select) {\r\n select.value = defaultType;\r\n this.currentFilterType = defaultType;\r\n this.addNewFilterToProp();\r\n select.focus();\r\n }\r\n };\r\n\r\n const capts = Object.assign(\r\n this.filterCaptionsInternal,\r\n this.filterCaptions,\r\n );\r\n const extra = this.filterEntities[currentFilter[index].type].extra;\r\n if (typeof extra === 'function') {\r\n return extra(h, {\r\n value: currentFilter[index].value,\r\n filter: currentFilter[index],\r\n prop,\r\n index,\r\n placeholder: capts.placeholder,\r\n onInput: (value: any) => {\r\n applyFilter(value);\r\n },\r\n onFocus: () => {\r\n focusNext();\r\n }\r\n });\r\n }\r\n if (extra !== 'input' && extra !== 'datepicker') {\r\n return '';\r\n }\r\n return (\r\n <input\r\n id={`filter-input-${currentFilter[index].id}`}\r\n placeholder={capts.placeholder}\r\n type={extra === 'datepicker' ? 'date' : 'text'}\r\n value={currentFilter[index].value}\r\n onInput={(e) => {\r\n if (e.target instanceof HTMLInputElement) {\r\n applyFilter(e.target.value);\r\n }\r\n }}\r\n onKeyDown={e => {\r\n if (e.key.toLowerCase() === 'enter') {\r\n const select = document.getElementById('add-filter') as HTMLSelectElement;\r\n if (select) {\r\n focusNext();\r\n }\r\n return;\r\n }\r\n // keep event local, don't escalate farther to dom\r\n e.stopPropagation();\r\n }}\r\n />\r\n );\r\n }\r\n\r\n render() {\r\n if (!this.changes) {\r\n return <Host style={{ display: 'none' }}></Host>;\r\n }\r\n const style = {\r\n display: 'block',\r\n left: `${this.changes.x}px`,\r\n top: `${this.changes.y}px`,\r\n };\r\n\r\n const capts = Object.assign(\r\n this.filterCaptionsInternal,\r\n this.filterCaptions,\r\n );\r\n\r\n return (\r\n <Host\r\n style={style}\r\n ref={el => {\r\n this.changes?.autoCorrect !== false && this.autoCorrect(el);\r\n }}\r\n >\r\n <slot slot=\"header\" />\r\n { this.changes.extraContent?.(this.changes) || '' }\r\n\r\n { this.changes?.hideDefaultFilters !== true && (\r\n [\r\n <label>{capts.title}</label>,\r\n <div class=\"filter-holder\">{this.getFilterItemsList()}</div>,\r\n <div class=\"add-filter\">\r\n <select\r\n id={FILTER_ID}\r\n class=\"select-css\"\r\n onChange={e => this.onAddNewFilter(e)}\r\n >\r\n {this.renderSelectOptions(this.currentFilterType)}\r\n </select>\r\n </div>\r\n ]\r\n )}\r\n\r\n <slot />\r\n <div class=\"filter-actions\">\r\n {this.disableDynamicFiltering && [\r\n <button\r\n id=\"revo-button-save\"\r\n aria-label=\"save\"\r\n class=\"revo-button green\"\r\n onClick={() => this.onSave()}\r\n >\r\n {capts.save}\r\n </button>,\r\n <button\r\n id=\"revo-button-ok\"\r\n aria-label=\"ok\"\r\n class=\"revo-button green\"\r\n onClick={() => this.onCancel()}\r\n >\r\n {capts.cancel}\r\n </button>,\r\n ]}\r\n {!this.disableDynamicFiltering && [\r\n <button\r\n id=\"revo-button-ok\"\r\n aria-label=\"ok\"\r\n class=\"revo-button green\"\r\n onClick={() => this.onCancel()}\r\n >\r\n {capts.ok}\r\n </button>,\r\n\r\n <button\r\n id=\"revo-button-reset\"\r\n aria-label=\"reset\"\r\n class=\"revo-button outline\"\r\n onClick={() => this.onReset()}\r\n >\r\n {capts.reset}\r\n </button>,\r\n ]}\r\n </div>\r\n <slot slot=\"footer\" />\r\n </Host>\r\n );\r\n }\r\n}\r\n"],"version":3}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Components, JSX } from "../dist/types/components";
|
|
2
|
+
|
|
3
|
+
interface RevogrFocus extends Components.RevogrFocus, HTMLElement {}
|
|
4
|
+
export const RevogrFocus: {
|
|
5
|
+
prototype: RevogrFocus;
|
|
6
|
+
new (): RevogrFocus;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Used to define this component and all nested components recursively.
|
|
10
|
+
*/
|
|
11
|
+
export const defineCustomElement: () => void;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { R as RevogrFocus$1, d as defineCustomElement$1 } from './revogr-focus2.js';
|
|
5
|
+
|
|
6
|
+
const RevogrFocus = RevogrFocus$1;
|
|
7
|
+
const defineCustomElement = defineCustomElement$1;
|
|
8
|
+
|
|
9
|
+
export { RevogrFocus, defineCustomElement };
|
|
10
|
+
//# sourceMappingURL=revogr-focus.js.map
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=revogr-focus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"revogr-focus.js","mappings":";;;;;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
|
|
5
|
+
import { F as FOCUS_CLASS } from './consts.js';
|
|
6
|
+
import { a as getCell, s as styleByCellProps } from './selection.utils.js';
|
|
7
|
+
import { b as getSourceItem } from './data.store.js';
|
|
8
|
+
import './platform.js';
|
|
9
|
+
|
|
10
|
+
const revogrFocusStyleCss = "revogr-focus.focused-cell{box-shadow:-1px 0 0 #0d63e8 inset, 1px 0 0 #0d63e8 inset, 0 -1px 0 #0d63e8 inset, 0 1px 0 #0d63e8 inset;position:absolute;pointer-events:none;z-index:9;display:block !important}";
|
|
11
|
+
|
|
12
|
+
const RevogrFocus = /*@__PURE__*/ proxyCustomElement(class RevogrFocus extends HTMLElement {
|
|
13
|
+
constructor() {
|
|
14
|
+
super();
|
|
15
|
+
this.__registerHost();
|
|
16
|
+
this.beforeFocusRender = createEvent(this, "beforefocusrender", 7);
|
|
17
|
+
this.beforeScrollIntoView = createEvent(this, "beforescrollintoview", 7);
|
|
18
|
+
this.afterFocus = createEvent(this, "afterfocus", 7);
|
|
19
|
+
/**
|
|
20
|
+
* Focus template custom function. Can be used to render custom focus layer.
|
|
21
|
+
*/
|
|
22
|
+
this.focusTemplate = null;
|
|
23
|
+
this.activeFocus = null;
|
|
24
|
+
}
|
|
25
|
+
componentDidRender() {
|
|
26
|
+
var _a, _b;
|
|
27
|
+
const currentFocus = this.selectionStore.get('focus');
|
|
28
|
+
if (((_a = this.activeFocus) === null || _a === void 0 ? void 0 : _a.x) === (currentFocus === null || currentFocus === void 0 ? void 0 : currentFocus.x) &&
|
|
29
|
+
((_b = this.activeFocus) === null || _b === void 0 ? void 0 : _b.y) === (currentFocus === null || currentFocus === void 0 ? void 0 : currentFocus.y)) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
this.activeFocus = currentFocus;
|
|
33
|
+
if (currentFocus && this.el) {
|
|
34
|
+
const beforeScrollIn = this.beforeScrollIntoView.emit({ el: this.el });
|
|
35
|
+
if (!beforeScrollIn.defaultPrevented) {
|
|
36
|
+
this.el.scrollIntoView({
|
|
37
|
+
block: 'nearest',
|
|
38
|
+
inline: 'nearest',
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
const model = getSourceItem(this.dataStore, currentFocus.y);
|
|
42
|
+
const column = getSourceItem(this.colData, currentFocus.x);
|
|
43
|
+
this.afterFocus.emit({
|
|
44
|
+
model,
|
|
45
|
+
column,
|
|
46
|
+
rowType: this.rowType,
|
|
47
|
+
colType: this.colType,
|
|
48
|
+
rowIndex: currentFocus.y,
|
|
49
|
+
colIndex: currentFocus.x,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
render() {
|
|
54
|
+
var _a;
|
|
55
|
+
const editCell = this.selectionStore.get('edit');
|
|
56
|
+
if (editCell) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const focusCell = this.selectionStore.get('focus');
|
|
60
|
+
if (!focusCell) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const event = this.beforeFocusRender.emit({
|
|
64
|
+
range: Object.assign(Object.assign({}, focusCell), { x1: focusCell.x, y1: focusCell.y }),
|
|
65
|
+
rowType: this.rowType,
|
|
66
|
+
colType: this.colType,
|
|
67
|
+
rowDimension: Object.assign({}, this.dimensionRow.state),
|
|
68
|
+
colDimension: Object.assign({}, this.dimensionCol.state),
|
|
69
|
+
});
|
|
70
|
+
if (event.defaultPrevented) {
|
|
71
|
+
return h("slot", null);
|
|
72
|
+
}
|
|
73
|
+
const { detail } = event;
|
|
74
|
+
const cell = getCell(detail.range, event.detail.rowDimension, event.detail.colDimension);
|
|
75
|
+
const styles = styleByCellProps(cell);
|
|
76
|
+
const extra = (_a = this.focusTemplate) === null || _a === void 0 ? void 0 : _a.call(this, h, detail);
|
|
77
|
+
const props = {
|
|
78
|
+
class: { [FOCUS_CLASS]: true },
|
|
79
|
+
style: styles,
|
|
80
|
+
};
|
|
81
|
+
return (h(Host, Object.assign({}, props), h("slot", null), extra));
|
|
82
|
+
}
|
|
83
|
+
get el() { return this; }
|
|
84
|
+
static get style() { return revogrFocusStyleCss; }
|
|
85
|
+
}, [260, "revogr-focus", {
|
|
86
|
+
"colType": [1, "col-type"],
|
|
87
|
+
"rowType": [1, "row-type"],
|
|
88
|
+
"selectionStore": [16, "selection-store"],
|
|
89
|
+
"dimensionRow": [16, "dimension-row"],
|
|
90
|
+
"dimensionCol": [16, "dimension-col"],
|
|
91
|
+
"dataStore": [16, "data-store"],
|
|
92
|
+
"colData": [16, "col-data"],
|
|
93
|
+
"focusTemplate": [16, "focus-template"]
|
|
94
|
+
}]);
|
|
95
|
+
function defineCustomElement() {
|
|
96
|
+
if (typeof customElements === "undefined") {
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const components = ["revogr-focus"];
|
|
100
|
+
components.forEach(tagName => { switch (tagName) {
|
|
101
|
+
case "revogr-focus":
|
|
102
|
+
if (!customElements.get(tagName)) {
|
|
103
|
+
customElements.define(tagName, RevogrFocus);
|
|
104
|
+
}
|
|
105
|
+
break;
|
|
106
|
+
} });
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
export { RevogrFocus as R, defineCustomElement as d };
|
|
110
|
+
//# sourceMappingURL=revogr-focus2.js.map
|
|
111
|
+
|
|
112
|
+
//# sourceMappingURL=revogr-focus2.js.map
|