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,125 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
/**
|
|
6
|
+
* Contains extra elements for stencil components.
|
|
7
|
+
* Performs rendering and updates for external components.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* In Plugins if you want to add extra elements to grid and use stenciljs vnodes reactivity:
|
|
11
|
+
* function paginationPanel(this: PaginationPlugin, config: { refresh: () => void }) {
|
|
12
|
+
* // use `config.refresh()` for component to re-render
|
|
13
|
+
* return h('div')
|
|
14
|
+
* }
|
|
15
|
+
*
|
|
16
|
+
* revogrid.registerVNode = [
|
|
17
|
+
* ...existingNodes,
|
|
18
|
+
* paginationPanel.bind(this)
|
|
19
|
+
* ];
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* @internal
|
|
24
|
+
*/
|
|
25
|
+
export class RevoGridExtra {
|
|
26
|
+
constructor() {
|
|
27
|
+
/**
|
|
28
|
+
* Nodes to render
|
|
29
|
+
*/
|
|
30
|
+
this.nodes = [];
|
|
31
|
+
/**
|
|
32
|
+
* Force component to re-render
|
|
33
|
+
*/
|
|
34
|
+
this.update = 1;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Refreshes the extra component. Useful if you want to manually
|
|
38
|
+
* force the component to re-render.
|
|
39
|
+
*/
|
|
40
|
+
async refresh() {
|
|
41
|
+
this.update *= -1;
|
|
42
|
+
}
|
|
43
|
+
render() {
|
|
44
|
+
var _a;
|
|
45
|
+
return (_a = this.nodes) === null || _a === void 0 ? void 0 : _a.map(node => {
|
|
46
|
+
// Check if node is a function or a stencil component
|
|
47
|
+
// If function wrap it in a stencil component with the refresh function
|
|
48
|
+
if (typeof node === 'function') {
|
|
49
|
+
const config = {};
|
|
50
|
+
const getNodes = () => [node({ refresh: () => { var _a; return (_a = config.refresh) === null || _a === void 0 ? void 0 : _a.call(config); } })];
|
|
51
|
+
return (h("revogr-extra", { nodes: getNodes(), ref: (el) => {
|
|
52
|
+
if (el) {
|
|
53
|
+
// Update exclusively for current node
|
|
54
|
+
config.refresh = () => {
|
|
55
|
+
el.nodes = getNodes();
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
} }));
|
|
59
|
+
}
|
|
60
|
+
return node;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
static get is() { return "revogr-extra"; }
|
|
64
|
+
static get properties() {
|
|
65
|
+
return {
|
|
66
|
+
"nodes": {
|
|
67
|
+
"type": "unknown",
|
|
68
|
+
"attribute": "nodes",
|
|
69
|
+
"mutable": false,
|
|
70
|
+
"complexType": {
|
|
71
|
+
"original": "(\r\n | VNode\r\n | ((c: ExtraNodeFuncConfig) => VNode)\r\n )[]",
|
|
72
|
+
"resolved": "(VNode | ((c: ExtraNodeFuncConfig) => VNode))[]",
|
|
73
|
+
"references": {
|
|
74
|
+
"VNode": {
|
|
75
|
+
"location": "import",
|
|
76
|
+
"path": "@stencil/core",
|
|
77
|
+
"id": "node_modules::VNode"
|
|
78
|
+
},
|
|
79
|
+
"ExtraNodeFuncConfig": {
|
|
80
|
+
"location": "import",
|
|
81
|
+
"path": "@type",
|
|
82
|
+
"id": "src/types/index.ts::ExtraNodeFuncConfig"
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
"required": false,
|
|
87
|
+
"optional": false,
|
|
88
|
+
"docs": {
|
|
89
|
+
"tags": [],
|
|
90
|
+
"text": "Nodes to render"
|
|
91
|
+
},
|
|
92
|
+
"getter": false,
|
|
93
|
+
"setter": false,
|
|
94
|
+
"defaultValue": "[]"
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
static get states() {
|
|
99
|
+
return {
|
|
100
|
+
"update": {}
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
static get methods() {
|
|
104
|
+
return {
|
|
105
|
+
"refresh": {
|
|
106
|
+
"complexType": {
|
|
107
|
+
"signature": "() => Promise<void>",
|
|
108
|
+
"parameters": [],
|
|
109
|
+
"references": {
|
|
110
|
+
"Promise": {
|
|
111
|
+
"location": "global",
|
|
112
|
+
"id": "global::Promise"
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
"return": "Promise<void>"
|
|
116
|
+
},
|
|
117
|
+
"docs": {
|
|
118
|
+
"text": "Refreshes the extra component. Useful if you want to manually\r\nforce the component to re-render.",
|
|
119
|
+
"tags": []
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=revogr-extra.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"revogr-extra.js","sourceRoot":"","sources":["../../../src/components/extra/revogr-extra.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAGzE;;;;;;;;;;;;;;;;;;;GAmBG;AAIH,MAAM,OAAO,aAAa;IAH1B;QAIE;;WAEG;QACK,UAAK,GAGP,EAAE,CAAC;QACT;;WAEG;QACM,WAAM,GAAG,CAAC,CAAC;KAmCrB;IAjCC;;;OAGG;IACO,KAAK,CAAC,OAAO;QACrB,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;IACpB,CAAC;IAED,MAAM;;QACJ,OAAO,MAAA,IAAI,CAAC,KAAK,0CAAE,GAAG,CAAC,IAAI,CAAC,EAAE;YAC5B,qDAAqD;YACrD,uEAAuE;YACvE,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC/B,MAAM,MAAM,GAAiC,EAAE,CAAC;gBAChD,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,WAAC,OAAA,MAAA,MAAM,CAAC,OAAO,sDAAI,CAAA,EAAA,EAAE,CAAC,CAAC,CAAC;gBAErE,OAAO,CACL,oBACE,KAAK,EAAE,QAAQ,EAAE,EACjB,GAAG,EAAE,CAAC,EAA2B,EAAE,EAAE;wBACnC,IAAI,EAAE,EAAE,CAAC;4BACP,sCAAsC;4BACtC,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE;gCACpB,EAAE,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAC;4BACxB,CAAC,CAAC;wBACJ,CAAC;oBACH,CAAC,GACD,CACH,CAAC;YACJ,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { h, Component, Method, Prop, State, VNode } from '@stencil/core';\r\nimport type { ExtraNodeFuncConfig } from '@type';\r\n\r\n/**\r\n * Contains extra elements for stencil components.\r\n * Performs rendering and updates for external components.\r\n * \r\n * @example\r\n * In Plugins if you want to add extra elements to grid and use stenciljs vnodes reactivity:\r\n * function paginationPanel(this: PaginationPlugin, config: { refresh: () => void }) {\r\n * // use `config.refresh()` for component to re-render\r\n * return h('div')\r\n * }\r\n * \r\n * revogrid.registerVNode = [\r\n * ...existingNodes,\r\n * paginationPanel.bind(this)\r\n * ];\r\n\r\n\r\n/**\r\n * @internal\r\n */\r\n@Component({\r\n tag: 'revogr-extra',\r\n})\r\nexport class RevoGridExtra {\r\n /**\r\n * Nodes to render\r\n */\r\n @Prop() nodes: (\r\n | VNode\r\n | ((c: ExtraNodeFuncConfig) => VNode)\r\n )[] = [];\r\n /**\r\n * Force component to re-render\r\n */\r\n @State() update = 1;\r\n\r\n /**\r\n * Refreshes the extra component. Useful if you want to manually\r\n * force the component to re-render.\r\n */\r\n @Method() async refresh() {\r\n this.update *= -1;\r\n }\r\n\r\n render() {\r\n return this.nodes?.map(node => {\r\n // Check if node is a function or a stencil component\r\n // If function wrap it in a stencil component with the refresh function\r\n if (typeof node === 'function') {\r\n const config: Partial<ExtraNodeFuncConfig> = {};\r\n const getNodes = () => [node({ refresh: () => config.refresh?.() })];\r\n\r\n return (\r\n <revogr-extra\r\n nodes={getNodes()}\r\n ref={(el?: HTMLRevogrExtraElement) => {\r\n if (el) {\r\n // Update exclusively for current node\r\n config.refresh = () => {\r\n el.nodes = getNodes();\r\n };\r\n }\r\n }}\r\n />\r\n );\r\n }\r\n return node;\r\n });\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { dispatch } from "../../plugins/dispatcher";
|
|
6
|
+
import { doPropMerge } from "../data/column.service";
|
|
7
|
+
import { ResizableElement, } from "./resizable.element";
|
|
8
|
+
export const ON_COLUMN_CLICK = 'columnclick';
|
|
9
|
+
export const HeaderCellRenderer = ({ data, props, additionalData }, children) => {
|
|
10
|
+
let colTemplate = (data === null || data === void 0 ? void 0 : data.name) || '';
|
|
11
|
+
let cellProps = props;
|
|
12
|
+
if (data === null || data === void 0 ? void 0 : data.columnTemplate) {
|
|
13
|
+
colTemplate = data.columnTemplate(h, data, additionalData);
|
|
14
|
+
}
|
|
15
|
+
if (data === null || data === void 0 ? void 0 : data.columnProperties) {
|
|
16
|
+
const extra = data.columnProperties(data);
|
|
17
|
+
if (extra) {
|
|
18
|
+
cellProps = doPropMerge(props, extra);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
const resizeProps = Object.assign(Object.assign({}, cellProps), { onMouseDown(e) {
|
|
22
|
+
dispatch(e.currentTarget, ON_COLUMN_CLICK, {
|
|
23
|
+
data,
|
|
24
|
+
event: e,
|
|
25
|
+
});
|
|
26
|
+
} });
|
|
27
|
+
return (h(ResizableElement, Object.assign({}, resizeProps), !!(data === null || data === void 0 ? void 0 : data.rowDrag) && (h("div", { onMouseDown: (e) => {
|
|
28
|
+
dispatch(e.currentTarget, ON_COLUMN_CLICK, {
|
|
29
|
+
data,
|
|
30
|
+
event: e,
|
|
31
|
+
});
|
|
32
|
+
}, class: "header-cell-drag" }, h("svg", { xmlns: "http://www.w3.org/2000/svg", width: "18", height: "18", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", "stroke-width": "1.3", "stroke-linecap": "round", "stroke-linejoin": "round" }, h("circle", { cx: "9", cy: "12", r: "1" }), h("circle", { cx: "9", cy: "5", r: "1" }), h("circle", { cx: "9", cy: "19", r: "1" }), h("circle", { cx: "15", cy: "12", r: "1" }), h("circle", { cx: "15", cy: "5", r: "1" }), h("circle", { cx: "15", cy: "19", r: "1" })))), h("div", { class: "header-content" }, colTemplate), children));
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=header-cell-renderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"header-cell-renderer.js","sourceRoot":"","sources":["../../../src/components/header/header-cell-renderer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA4B,CAAC,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EACL,gBAAgB,GAEjB,MAAM,qBAAqB,CAAC;AAG7B,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAAC;AAE7C,MAAM,CAAC,MAAM,kBAAkB,GAI1B,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE,QAAQ,EAAE,EAAE;IACjD,IAAI,WAAW,GAAyB,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,KAAI,EAAE,CAAC;IACzD,IAAI,SAAS,GAAG,KAAK,CAAC;IACtB,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,cAAc,EAAE,CAAC;QACzB,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC;IAC7D,CAAC;IACD,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,gBAAgB,EAAE,CAAC;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC1C,IAAI,KAAK,EAAE,CAAC;YACV,SAAS,GAAG,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IACD,MAAM,WAAW,mCACZ,SAAS,KACZ,WAAW,CAAC,CAAa;YACvB,QAAQ,CAAC,CAAC,CAAC,aAAa,EAAE,eAAe,EAAE;gBACzC,IAAI;gBACJ,KAAK,EAAE,CAAC;aACT,CAAC,CAAC;QACL,CAAC,GACF,CAAC;IAEF,OAAO,CACL,EAAC,gBAAgB,oBAAK,WAAW;QAC9B,CAAC,CAAC,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,CAAA,IAAI,CAClB,WACE,WAAW,EAAE,CAAC,CAAa,EAAE,EAAE;gBAC7B,QAAQ,CAAC,CAAC,CAAC,aAA4B,EAAE,eAAe,EAAE;oBACxD,IAAI;oBACJ,KAAK,EAAE,CAAC;iBACT,CAAC,CAAC;YACL,CAAC,EACD,KAAK,EAAC,kBAAkB;YAExB,WACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,cAAc,kBACR,KAAK,oBACH,OAAO,qBACN,OAAO;gBAEvB,cAAQ,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG;gBAC/B,cAAQ,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,GAAG,EAAC,CAAC,EAAC,GAAG,GAAG;gBAC9B,cAAQ,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG;gBAC/B,cAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG;gBAChC,cAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,GAAG,EAAC,CAAC,EAAC,GAAG,GAAG;gBAC/B,cAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG,CAC5B,CACF,CACP;QACD,WAAK,KAAK,EAAC,gBAAgB,IAAE,WAAW,CAAO;QAC9C,QAAQ,CACQ,CACpB,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { type FunctionalComponent, h } from '@stencil/core';\r\nimport { dispatch } from '../../plugins/dispatcher';\r\nimport { doPropMerge } from '../data/column.service';\r\nimport {\r\n ResizableElement,\r\n ResizableElementHTMLAttributes,\r\n} from './resizable.element';\r\nimport { ColumnTemplateProp } from '@type';\r\n\r\nexport const ON_COLUMN_CLICK = 'columnclick';\r\n\r\nexport const HeaderCellRenderer: FunctionalComponent<{\r\n props: ResizableElementHTMLAttributes;\r\n additionalData: any;\r\n data?: ColumnTemplateProp;\r\n}> = ({ data, props, additionalData }, children) => {\r\n let colTemplate: ReturnType<typeof h> = data?.name || '';\r\n let cellProps = props;\r\n if (data?.columnTemplate) {\r\n colTemplate = data.columnTemplate(h, data, additionalData);\r\n }\r\n if (data?.columnProperties) {\r\n const extra = data.columnProperties(data);\r\n if (extra) {\r\n cellProps = doPropMerge(props, extra);\r\n }\r\n }\r\n const resizeProps = {\r\n ...cellProps,\r\n onMouseDown(e: MouseEvent) {\r\n dispatch(e.currentTarget, ON_COLUMN_CLICK, {\r\n data,\r\n event: e,\r\n });\r\n },\r\n };\r\n\r\n return (\r\n <ResizableElement {...resizeProps}>\r\n {!!data?.rowDrag && (\r\n <div\r\n onMouseDown={(e: MouseEvent) => {\r\n dispatch(e.currentTarget as HTMLElement, ON_COLUMN_CLICK, {\r\n data,\r\n event: e,\r\n });\r\n }}\r\n class=\"header-cell-drag\"\r\n >\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"18\"\r\n height=\"18\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n stroke-width=\"1.3\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n >\r\n <circle cx=\"9\" cy=\"12\" r=\"1\" />\r\n <circle cx=\"9\" cy=\"5\" r=\"1\" />\r\n <circle cx=\"9\" cy=\"19\" r=\"1\" />\r\n <circle cx=\"15\" cy=\"12\" r=\"1\" />\r\n <circle cx=\"15\" cy=\"5\" r=\"1\" />\r\n <circle cx=\"15\" cy=\"19\" r=\"1\" />\r\n </svg>\r\n </div>\r\n )}\r\n <div class=\"header-content\">{colTemplate}</div>\r\n {children}\r\n </ResizableElement>\r\n );\r\n};\r\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { HEADER_CLASS, MIN_COL_SIZE } from "../../utils/consts";
|
|
6
|
+
import { HeaderCellRenderer } from "./header-cell-renderer";
|
|
7
|
+
const HeaderGroupRenderer = (p) => {
|
|
8
|
+
const groupProps = {
|
|
9
|
+
canResize: p.canResize,
|
|
10
|
+
minWidth: p.group.indexes.length * MIN_COL_SIZE,
|
|
11
|
+
maxWidth: 0,
|
|
12
|
+
active: p.active || ['r'],
|
|
13
|
+
class: {
|
|
14
|
+
[HEADER_CLASS]: true,
|
|
15
|
+
},
|
|
16
|
+
style: {
|
|
17
|
+
transform: `translateX(${p.start}px)`,
|
|
18
|
+
width: `${p.end - p.start}px`,
|
|
19
|
+
},
|
|
20
|
+
onResize: p.onResize,
|
|
21
|
+
};
|
|
22
|
+
return (h(HeaderCellRenderer, { data: Object.assign(Object.assign({}, p.group), { prop: '', providers: p.providers, index: p.start }), props: groupProps, additionalData: p.additionalData }));
|
|
23
|
+
};
|
|
24
|
+
export default HeaderGroupRenderer;
|
|
25
|
+
//# sourceMappingURL=header-group-renderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"header-group-renderer.js","sourceRoot":"","sources":["../../../src/components/header/header-group-renderer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAIlC,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAY5D,MAAM,mBAAmB,GAAG,CAAC,CAA2B,EAAwB,EAAE;IAChF,MAAM,UAAU,GAAqC;QACnD,SAAS,EAAE,CAAC,CAAC,SAAS;QACtB,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,YAAY;QAC/C,QAAQ,EAAE,CAAC;QAEX,MAAM,EAAE,CAAC,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC;QACzB,KAAK,EAAE;YACL,CAAC,YAAY,CAAC,EAAE,IAAI;SACrB;QACD,KAAK,EAAE;YACL,SAAS,EAAE,cAAc,CAAC,CAAC,KAAK,KAAK;YACrC,KAAK,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,IAAI;SAC9B;QACD,QAAQ,EAAE,CAAC,CAAC,QAAQ;KACrB,CAAC;IACF,OAAO,CACL,EAAC,kBAAkB,IACjB,IAAI,kCACC,CAAC,CAAC,KAAK,KACV,IAAI,EAAE,EAAE,EACR,SAAS,EAAE,CAAC,CAAC,SAAS,EACtB,KAAK,EAAE,CAAC,CAAC,KAAK,KAEhB,KAAK,EAAE,UAAU,EACjB,cAAc,EAAE,CAAC,CAAC,cAAc,GAChC,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,mBAAmB,CAAC","sourcesContent":["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"]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { FilterButton } from "../../plugins/filter/filter.button";
|
|
6
|
+
import { SortingSign } from "../../plugins/sorting/sorting.sign";
|
|
7
|
+
import { DATA_COL, FOCUS_CLASS, HEADER_CLASS, HEADER_SORTABLE_CLASS, MIN_COL_SIZE, } from "../../utils/consts";
|
|
8
|
+
import { HeaderCellRenderer } from "./header-cell-renderer";
|
|
9
|
+
const HeaderRenderer = (p) => {
|
|
10
|
+
var _a, _b, _c, _d, _e;
|
|
11
|
+
const cellClass = {
|
|
12
|
+
[HEADER_CLASS]: true,
|
|
13
|
+
[HEADER_SORTABLE_CLASS]: !!((_a = p.data) === null || _a === void 0 ? void 0 : _a.sortable),
|
|
14
|
+
};
|
|
15
|
+
if ((_b = p.data) === null || _b === void 0 ? void 0 : _b.order) {
|
|
16
|
+
cellClass[p.data.order] = true;
|
|
17
|
+
}
|
|
18
|
+
const dataProps = {
|
|
19
|
+
[DATA_COL]: p.column.itemIndex,
|
|
20
|
+
canResize: p.canResize,
|
|
21
|
+
minWidth: ((_c = p.data) === null || _c === void 0 ? void 0 : _c.minSize) || MIN_COL_SIZE,
|
|
22
|
+
maxWidth: (_d = p.data) === null || _d === void 0 ? void 0 : _d.maxSize,
|
|
23
|
+
active: p.active || ['r'],
|
|
24
|
+
class: cellClass,
|
|
25
|
+
style: {
|
|
26
|
+
width: `${p.column.size}px`,
|
|
27
|
+
transform: `translateX(${p.column.start}px)`,
|
|
28
|
+
},
|
|
29
|
+
onResize: p.onResize,
|
|
30
|
+
onDblClick(originalEvent) {
|
|
31
|
+
var _a;
|
|
32
|
+
(_a = p.onDblClick) === null || _a === void 0 ? void 0 : _a.call(p, {
|
|
33
|
+
column: p.data,
|
|
34
|
+
index: p.column.itemIndex,
|
|
35
|
+
originalEvent,
|
|
36
|
+
providers: p.data.providers,
|
|
37
|
+
});
|
|
38
|
+
},
|
|
39
|
+
onClick(originalEvent) {
|
|
40
|
+
if (originalEvent.defaultPrevented || !p.onClick) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
p.onClick({
|
|
44
|
+
column: p.data,
|
|
45
|
+
index: p.column.itemIndex,
|
|
46
|
+
originalEvent,
|
|
47
|
+
providers: p.data.providers,
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
};
|
|
51
|
+
if (p.range) {
|
|
52
|
+
if (p.column.itemIndex >= p.range.x && p.column.itemIndex <= p.range.x1) {
|
|
53
|
+
if (typeof dataProps.class === 'object') {
|
|
54
|
+
dataProps.class[FOCUS_CLASS] = true;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return (h(HeaderCellRenderer, { data: p.data, props: dataProps, additionalData: p.additionalData }, h(SortingSign, { column: p.data }), p.canFilter && ((_e = p.data) === null || _e === void 0 ? void 0 : _e.filter) !== false ? (h(FilterButton, { column: p.data })) : ('')));
|
|
59
|
+
};
|
|
60
|
+
export default HeaderRenderer;
|
|
61
|
+
//# sourceMappingURL=header-renderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"header-renderer.js","sourceRoot":"","sources":["../../../src/components/header/header-renderer.tsx"],"names":[],"mappings":"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","sourcesContent":["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"]}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
export var ResizeEvents;
|
|
5
|
+
(function (ResizeEvents) {
|
|
6
|
+
ResizeEvents["start"] = "resize:start";
|
|
7
|
+
ResizeEvents["move"] = "resize:move";
|
|
8
|
+
ResizeEvents["end"] = "resize:end";
|
|
9
|
+
})(ResizeEvents || (ResizeEvents = {}));
|
|
10
|
+
const RESIZE_MASK = {
|
|
11
|
+
'resizable-r': { bit: 0b0001, cursor: 'ew-resize' },
|
|
12
|
+
'resizable-rb': { bit: 0b0011, cursor: 'se-resize' },
|
|
13
|
+
'resizable-b': { bit: 0b0010, cursor: 's-resize' },
|
|
14
|
+
'resizable-lb': { bit: 0b0110, cursor: 'sw-resize' },
|
|
15
|
+
'resizable-l': { bit: 0b0100, cursor: 'w-resize' },
|
|
16
|
+
'resizable-lt': { bit: 0b1100, cursor: 'nw-resize' },
|
|
17
|
+
'resizable-t': { bit: 0b1000, cursor: 'n-resize' },
|
|
18
|
+
'resizable-rt': { bit: 0b1001, cursor: 'ne-resize' },
|
|
19
|
+
};
|
|
20
|
+
const DISABLE_MASK = {
|
|
21
|
+
l: 0b0001,
|
|
22
|
+
t: 0b0010,
|
|
23
|
+
w: 0b0100,
|
|
24
|
+
h: 0b1000,
|
|
25
|
+
};
|
|
26
|
+
const defaultProps = (props) => {
|
|
27
|
+
return Object.assign(Object.assign({}, props), { fitParent: props.fitParent || false, active: props.active || [], disableAttributes: props.disableAttributes || [], minWidth: props.minWidth || 0, minHeight: props.minHeight || 0 });
|
|
28
|
+
};
|
|
29
|
+
export class ResizeDirective {
|
|
30
|
+
constructor(initialProps, $event) {
|
|
31
|
+
var _a, _b;
|
|
32
|
+
this.initialProps = initialProps;
|
|
33
|
+
this.$event = $event;
|
|
34
|
+
this.mouseX = 0;
|
|
35
|
+
this.mouseY = 0;
|
|
36
|
+
this.width = 0;
|
|
37
|
+
this.height = 0;
|
|
38
|
+
this.changeX = 0;
|
|
39
|
+
this.changeY = 0;
|
|
40
|
+
this.disableCalcMap = 0b1111;
|
|
41
|
+
this.props = defaultProps(initialProps);
|
|
42
|
+
this.mouseMoveFunc = this.handleMove.bind(this);
|
|
43
|
+
this.mouseUpFunc = this.handleUp.bind(this);
|
|
44
|
+
this.minW = this.props.minWidth;
|
|
45
|
+
this.minH = this.props.minHeight;
|
|
46
|
+
this.maxW = (_a = this.props.maxWidth) !== null && _a !== void 0 ? _a : 0;
|
|
47
|
+
this.maxH = (_b = this.props.maxHeight) !== null && _b !== void 0 ? _b : 0;
|
|
48
|
+
this.parent = { width: 0, height: 0 };
|
|
49
|
+
this.resizeState = 0;
|
|
50
|
+
}
|
|
51
|
+
set($el) {
|
|
52
|
+
this.$el = $el;
|
|
53
|
+
this.props.disableAttributes.forEach(attr => {
|
|
54
|
+
switch (attr) {
|
|
55
|
+
case 'l':
|
|
56
|
+
this.disableCalcMap &= ~DISABLE_MASK.l;
|
|
57
|
+
break;
|
|
58
|
+
case 't':
|
|
59
|
+
this.disableCalcMap &= ~DISABLE_MASK.t;
|
|
60
|
+
break;
|
|
61
|
+
case 'w':
|
|
62
|
+
this.disableCalcMap &= ~DISABLE_MASK.w;
|
|
63
|
+
break;
|
|
64
|
+
case 'h':
|
|
65
|
+
this.disableCalcMap &= ~DISABLE_MASK.h;
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
emitEvent(eventName, additionalOptions) {
|
|
70
|
+
var _a;
|
|
71
|
+
if (!this.$event) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const isLeft = (_a = this.activeResizer) === null || _a === void 0 ? void 0 : _a.classList.contains('resizable-l');
|
|
75
|
+
this.$event(Object.assign({ eventName, width: this.width + this.changeX * (isLeft ? -1 : 1), height: this.height + this.changeY, changedX: this.changeX, changedY: this.changeY }, additionalOptions));
|
|
76
|
+
}
|
|
77
|
+
static isTouchEvent(e) {
|
|
78
|
+
var _a;
|
|
79
|
+
const event = e;
|
|
80
|
+
return ((_a = event.touches) === null || _a === void 0 ? void 0 : _a.length) >= 0;
|
|
81
|
+
}
|
|
82
|
+
handleMove(event) {
|
|
83
|
+
var _a;
|
|
84
|
+
if (!this.resizeState) {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
let eventY, eventX;
|
|
88
|
+
if (ResizeDirective.isTouchEvent(event)) {
|
|
89
|
+
eventY = event.touches[0].clientY;
|
|
90
|
+
eventX = event.touches[0].clientX;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
eventY = event.clientY;
|
|
94
|
+
eventX = event.clientX;
|
|
95
|
+
}
|
|
96
|
+
let isX = this.resizeState & RESIZE_MASK['resizable-r'].bit ||
|
|
97
|
+
this.resizeState & RESIZE_MASK['resizable-l'].bit;
|
|
98
|
+
let isY = this.resizeState & RESIZE_MASK['resizable-t'].bit ||
|
|
99
|
+
this.resizeState & RESIZE_MASK['resizable-b'].bit;
|
|
100
|
+
if (isY && this.disableCalcMap & DISABLE_MASK.h) {
|
|
101
|
+
let diffY = eventY - this.mouseY;
|
|
102
|
+
let changedY = this.changeY + diffY;
|
|
103
|
+
const newHeight = this.height + changedY;
|
|
104
|
+
// if overcrossed min height
|
|
105
|
+
if (newHeight < this.minH) {
|
|
106
|
+
changedY = -(this.height - this.minH);
|
|
107
|
+
}
|
|
108
|
+
// if overcrossed max heiht
|
|
109
|
+
if (this.maxH && newHeight > this.maxH) {
|
|
110
|
+
changedY = this.maxH - this.height;
|
|
111
|
+
}
|
|
112
|
+
this.changeY = changedY;
|
|
113
|
+
this.mouseY = eventY;
|
|
114
|
+
if (this.activeResizer) {
|
|
115
|
+
this.activeResizer.style.bottom = `${-this.changeY}px`;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
if (isX && this.disableCalcMap & DISABLE_MASK.w) {
|
|
119
|
+
const isLeft = (_a = this.activeResizer) === null || _a === void 0 ? void 0 : _a.classList.contains('resizable-l');
|
|
120
|
+
let diffX = eventX - this.mouseX;
|
|
121
|
+
let changedX = this.changeX + diffX;
|
|
122
|
+
const newWidth = this.width + changedX * (isLeft ? -1 : 1);
|
|
123
|
+
// if overcrossed min width
|
|
124
|
+
if (newWidth < this.minW) {
|
|
125
|
+
changedX = -(this.width - this.minW);
|
|
126
|
+
}
|
|
127
|
+
// if overcrossed max width
|
|
128
|
+
if (this.maxW && newWidth > this.maxW) {
|
|
129
|
+
changedX = this.maxW - this.width;
|
|
130
|
+
}
|
|
131
|
+
this.changeX = changedX;
|
|
132
|
+
this.mouseX = eventX;
|
|
133
|
+
if (this.activeResizer) {
|
|
134
|
+
if (!isLeft) {
|
|
135
|
+
this.activeResizer.style.right = `${-this.changeX}px`;
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
this.activeResizer.style.left = `${this.changeX}px`;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
this.emitEvent(ResizeEvents.move);
|
|
143
|
+
}
|
|
144
|
+
handleDown(event) {
|
|
145
|
+
if (event.defaultPrevented) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
// stop other events if resize in progress
|
|
149
|
+
event.preventDefault();
|
|
150
|
+
this.dropInitial();
|
|
151
|
+
for (let elClass in RESIZE_MASK) {
|
|
152
|
+
const target = event.target;
|
|
153
|
+
if (this.$el.contains(target) && (target === null || target === void 0 ? void 0 : target.classList.contains(elClass))) {
|
|
154
|
+
document.body.style.cursor = RESIZE_MASK[elClass].cursor;
|
|
155
|
+
if (ResizeDirective.isTouchEvent(event)) {
|
|
156
|
+
this.setInitials(event.touches[0], target);
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
event.preventDefault && event.preventDefault();
|
|
160
|
+
this.setInitials(event, target);
|
|
161
|
+
}
|
|
162
|
+
this.resizeState = RESIZE_MASK[elClass].bit;
|
|
163
|
+
const eventName = ResizeEvents.start;
|
|
164
|
+
this.emitEvent(eventName);
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
this.bindMove();
|
|
169
|
+
}
|
|
170
|
+
handleUp(e) {
|
|
171
|
+
e.preventDefault();
|
|
172
|
+
if (this.resizeState !== 0) {
|
|
173
|
+
this.resizeState = 0;
|
|
174
|
+
document.body.style.cursor = '';
|
|
175
|
+
const eventName = ResizeEvents.end;
|
|
176
|
+
this.emitEvent(eventName);
|
|
177
|
+
}
|
|
178
|
+
this.dropInitial();
|
|
179
|
+
this.unbindMove();
|
|
180
|
+
}
|
|
181
|
+
setInitials({ clientX, clientY }, target) {
|
|
182
|
+
var _a, _b, _c, _d;
|
|
183
|
+
const computedStyle = getComputedStyle(this.$el);
|
|
184
|
+
this.$el.classList.add('active');
|
|
185
|
+
this.activeResizer = target;
|
|
186
|
+
if (this.disableCalcMap & DISABLE_MASK.w) {
|
|
187
|
+
this.mouseX = clientX;
|
|
188
|
+
this.width = this.$el.clientWidth;
|
|
189
|
+
this.parent.width = (_b = (_a = this.$el.parentElement) === null || _a === void 0 ? void 0 : _a.clientWidth) !== null && _b !== void 0 ? _b : 0;
|
|
190
|
+
// min width
|
|
191
|
+
const minPaddingX = parseFloat(computedStyle.paddingLeft) +
|
|
192
|
+
parseFloat(computedStyle.paddingRight);
|
|
193
|
+
this.minW = Math.max(minPaddingX, this.initialProps.minWidth || 0);
|
|
194
|
+
// max width
|
|
195
|
+
if (this.initialProps.maxWidth) {
|
|
196
|
+
this.maxW = Math.max(this.width, this.initialProps.maxWidth);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
if (this.disableCalcMap & DISABLE_MASK.h) {
|
|
200
|
+
this.mouseY = clientY;
|
|
201
|
+
this.height = this.$el.clientHeight;
|
|
202
|
+
this.parent.height = (_d = (_c = this.$el.parentElement) === null || _c === void 0 ? void 0 : _c.clientHeight) !== null && _d !== void 0 ? _d : 0;
|
|
203
|
+
// min height
|
|
204
|
+
const minPaddingY = parseFloat(computedStyle.paddingTop) +
|
|
205
|
+
parseFloat(computedStyle.paddingBottom);
|
|
206
|
+
this.minH = Math.max(minPaddingY, this.initialProps.minHeight || 0);
|
|
207
|
+
// max height
|
|
208
|
+
if (this.initialProps.maxHeight) {
|
|
209
|
+
this.maxH = Math.max(this.height, this.initialProps.maxHeight);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
dropInitial() {
|
|
214
|
+
this.changeX = this.changeY = this.minW = this.minH;
|
|
215
|
+
this.width = this.height = 0;
|
|
216
|
+
if (this.activeResizer) {
|
|
217
|
+
this.activeResizer.removeAttribute('style');
|
|
218
|
+
}
|
|
219
|
+
this.$el.classList.remove('active');
|
|
220
|
+
this.activeResizer = undefined;
|
|
221
|
+
}
|
|
222
|
+
bindMove() {
|
|
223
|
+
document.documentElement.addEventListener('mouseup', this.mouseUpFunc, true);
|
|
224
|
+
document.documentElement.addEventListener('touchend', this.mouseUpFunc, true);
|
|
225
|
+
document.documentElement.addEventListener('mousemove', this.mouseMoveFunc, true);
|
|
226
|
+
document.documentElement.addEventListener('touchmove', this.mouseMoveFunc, true);
|
|
227
|
+
document.documentElement.addEventListener('mouseleave', this.mouseUpFunc);
|
|
228
|
+
}
|
|
229
|
+
unbindMove() {
|
|
230
|
+
document.documentElement.removeEventListener('mouseup', this.mouseUpFunc, true);
|
|
231
|
+
document.documentElement.removeEventListener('touchend', this.mouseUpFunc, true);
|
|
232
|
+
document.documentElement.removeEventListener('mousemove', this.mouseMoveFunc, true);
|
|
233
|
+
document.documentElement.removeEventListener('touchmove', this.mouseMoveFunc, true);
|
|
234
|
+
document.documentElement.removeEventListener('mouseleave', this.mouseUpFunc);
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
//# sourceMappingURL=resizable.directive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../src/components/header/resizable.directive.tsx"],"names":[],"mappings":"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","sourcesContent":["export type ResizeProps = {\r\n active: ('r' | 'rb' | 'b' | 'lb' | 'l' | 'lt' | 't' | 'rt')[]; // all\r\n fitParent: boolean; // false\r\n minWidth: number; // 0\r\n minHeight: number; // 0\r\n\r\n disableAttributes: ('l' | 't' | 'w' | 'h')[]; // []\r\n maxWidth?: number;\r\n maxHeight?: number;\r\n\r\n onResize?(e: ResizeEvent): void;\r\n};\r\n\r\nexport type ResizeEvent = {\r\n eventName: string;\r\n changedX?: number;\r\n changedY?: number;\r\n width?: number;\r\n height?: number;\r\n};\r\n\r\nexport enum ResizeEvents {\r\n start = 'resize:start',\r\n move = 'resize:move',\r\n end = 'resize:end',\r\n}\r\n\r\nconst RESIZE_MASK: { [key: string]: any } = {\r\n 'resizable-r': { bit: 0b0001, cursor: 'ew-resize' },\r\n 'resizable-rb': { bit: 0b0011, cursor: 'se-resize' },\r\n 'resizable-b': { bit: 0b0010, cursor: 's-resize' },\r\n 'resizable-lb': { bit: 0b0110, cursor: 'sw-resize' },\r\n 'resizable-l': { bit: 0b0100, cursor: 'w-resize' },\r\n 'resizable-lt': { bit: 0b1100, cursor: 'nw-resize' },\r\n 'resizable-t': { bit: 0b1000, cursor: 'n-resize' },\r\n 'resizable-rt': { bit: 0b1001, cursor: 'ne-resize' },\r\n};\r\n\r\nconst DISABLE_MASK = {\r\n l: 0b0001,\r\n t: 0b0010,\r\n w: 0b0100,\r\n h: 0b1000,\r\n};\r\n\r\nconst defaultProps = (props: Partial<ResizeProps>): ResizeProps => {\r\n return {\r\n ...props,\r\n fitParent: props.fitParent || false,\r\n active: props.active || [],\r\n disableAttributes: props.disableAttributes || [],\r\n minWidth: props.minWidth || 0,\r\n minHeight: props.minHeight || 0,\r\n };\r\n};\r\n\r\nexport class ResizeDirective {\r\n private $el: HTMLElement;\r\n private props: ResizeProps;\r\n private minW: number;\r\n private minH: number;\r\n private maxW: number;\r\n private maxH: number;\r\n\r\n private mouseX = 0;\r\n private mouseY = 0;\r\n\r\n private width = 0;\r\n private height = 0;\r\n\r\n private changeX = 0;\r\n private changeY = 0;\r\n\r\n private parent: { width: number; height: number };\r\n private resizeState: number;\r\n private activeResizer?: HTMLElement;\r\n private disableCalcMap = 0b1111;\r\n\r\n private mouseMoveFunc: () => void;\r\n private mouseUpFunc: () => void;\r\n\r\n constructor(\r\n private initialProps: Partial<ResizeProps>,\r\n private $event?: (e: ResizeEvent) => void,\r\n ) {\r\n this.props = defaultProps(initialProps);\r\n this.mouseMoveFunc = this.handleMove.bind(this);\r\n this.mouseUpFunc = this.handleUp.bind(this);\r\n\r\n this.minW = this.props.minWidth;\r\n this.minH = this.props.minHeight;\r\n this.maxW = this.props.maxWidth ?? 0;\r\n this.maxH = this.props.maxHeight ?? 0;\r\n this.parent = { width: 0, height: 0 };\r\n this.resizeState = 0;\r\n }\r\n\r\n set($el: HTMLElement) {\r\n this.$el = $el;\r\n this.props.disableAttributes.forEach(attr => {\r\n switch (attr) {\r\n case 'l':\r\n this.disableCalcMap &= ~DISABLE_MASK.l;\r\n break;\r\n case 't':\r\n this.disableCalcMap &= ~DISABLE_MASK.t;\r\n break;\r\n case 'w':\r\n this.disableCalcMap &= ~DISABLE_MASK.w;\r\n break;\r\n case 'h':\r\n this.disableCalcMap &= ~DISABLE_MASK.h;\r\n }\r\n });\r\n }\r\n emitEvent(eventName: string, additionalOptions?: any) {\r\n if (!this.$event) {\r\n return;\r\n }\r\n const isLeft = this.activeResizer?.classList.contains('resizable-l');\r\n this.$event({\r\n eventName,\r\n width: this.width + this.changeX * (isLeft ? -1 : 1),\r\n height: this.height + this.changeY,\r\n changedX: this.changeX,\r\n changedY: this.changeY,\r\n ...additionalOptions,\r\n });\r\n }\r\n\r\n private static isTouchEvent(e: MouseEvent | TouchEvent): e is TouchEvent {\r\n const event = e as TouchEvent;\r\n return event.touches?.length >= 0;\r\n }\r\n\r\n handleMove(event: MouseEvent | TouchEvent) {\r\n if (!this.resizeState) {\r\n return;\r\n }\r\n let eventY, eventX;\r\n if (ResizeDirective.isTouchEvent(event)) {\r\n eventY = event.touches[0].clientY;\r\n eventX = event.touches[0].clientX;\r\n } else {\r\n eventY = event.clientY;\r\n eventX = event.clientX;\r\n }\r\n let isX =\r\n this.resizeState & RESIZE_MASK['resizable-r'].bit ||\r\n this.resizeState & RESIZE_MASK['resizable-l'].bit;\r\n\r\n let isY =\r\n this.resizeState & RESIZE_MASK['resizable-t'].bit ||\r\n this.resizeState & RESIZE_MASK['resizable-b'].bit;\r\n\r\n if (isY && this.disableCalcMap & DISABLE_MASK.h) {\r\n let diffY = eventY - this.mouseY;\r\n let changedY = this.changeY + diffY;\r\n const newHeight = this.height + changedY;\r\n // if overcrossed min height\r\n if (newHeight < this.minH) {\r\n changedY = -(this.height - this.minH);\r\n }\r\n // if overcrossed max heiht\r\n if (this.maxH && newHeight > this.maxH) {\r\n changedY = this.maxH - this.height;\r\n }\r\n\r\n this.changeY = changedY;\r\n this.mouseY = eventY;\r\n\r\n if (this.activeResizer) {\r\n this.activeResizer.style.bottom = `${-this.changeY}px`;\r\n }\r\n }\r\n if (isX && this.disableCalcMap & DISABLE_MASK.w) {\r\n const isLeft = this.activeResizer?.classList.contains('resizable-l');\r\n let diffX = eventX - this.mouseX;\r\n let changedX = this.changeX + diffX;\r\n const newWidth = this.width + changedX * (isLeft ? -1 : 1);\r\n\r\n // if overcrossed min width\r\n if (newWidth < this.minW) {\r\n changedX = -(this.width - this.minW);\r\n }\r\n // if overcrossed max width\r\n if (this.maxW && newWidth > this.maxW) {\r\n changedX = this.maxW - this.width;\r\n }\r\n\r\n this.changeX = changedX;\r\n this.mouseX = eventX;\r\n\r\n if (this.activeResizer) {\r\n if (!isLeft) {\r\n this.activeResizer.style.right = `${-this.changeX}px`;\r\n } else {\r\n this.activeResizer.style.left = `${this.changeX}px`;\r\n }\r\n }\r\n }\r\n this.emitEvent(ResizeEvents.move);\r\n }\r\n\r\n handleDown(event: MouseEvent | TouchEvent) {\r\n if (event.defaultPrevented) {\r\n return;\r\n }\r\n // stop other events if resize in progress\r\n event.preventDefault();\r\n\r\n this.dropInitial();\r\n for (let elClass in RESIZE_MASK) {\r\n const target = event.target as HTMLElement | null;\r\n if (this.$el.contains(target) && target?.classList.contains(elClass)) {\r\n document.body.style.cursor = RESIZE_MASK[elClass].cursor;\r\n if (ResizeDirective.isTouchEvent(event)) {\r\n this.setInitials(event.touches[0], target);\r\n } else {\r\n event.preventDefault && event.preventDefault();\r\n this.setInitials(event, target);\r\n }\r\n this.resizeState = RESIZE_MASK[elClass].bit;\r\n const eventName = ResizeEvents.start;\r\n this.emitEvent(eventName);\r\n break;\r\n }\r\n }\r\n this.bindMove();\r\n }\r\n\r\n handleUp(e: MouseEvent) {\r\n e.preventDefault();\r\n if (this.resizeState !== 0) {\r\n this.resizeState = 0;\r\n document.body.style.cursor = '';\r\n const eventName = ResizeEvents.end;\r\n this.emitEvent(eventName);\r\n }\r\n this.dropInitial();\r\n this.unbindMove();\r\n }\r\n\r\n private setInitials(\r\n { clientX, clientY }: { clientX: number; clientY: number },\r\n target?: HTMLElement,\r\n ) {\r\n const computedStyle = getComputedStyle(this.$el);\r\n this.$el.classList.add('active');\r\n this.activeResizer = target;\r\n\r\n if (this.disableCalcMap & DISABLE_MASK.w) {\r\n this.mouseX = clientX;\r\n this.width = this.$el.clientWidth;\r\n this.parent.width = this.$el.parentElement?.clientWidth ?? 0;\r\n\r\n // min width\r\n const minPaddingX =\r\n parseFloat(computedStyle.paddingLeft) +\r\n parseFloat(computedStyle.paddingRight);\r\n this.minW = Math.max(minPaddingX, this.initialProps.minWidth || 0);\r\n\r\n // max width\r\n if (this.initialProps.maxWidth) {\r\n this.maxW = Math.max(this.width, this.initialProps.maxWidth);\r\n }\r\n }\r\n\r\n if (this.disableCalcMap & DISABLE_MASK.h) {\r\n this.mouseY = clientY;\r\n this.height = this.$el.clientHeight;\r\n this.parent.height = this.$el.parentElement?.clientHeight ?? 0;\r\n\r\n // min height\r\n const minPaddingY =\r\n parseFloat(computedStyle.paddingTop) +\r\n parseFloat(computedStyle.paddingBottom);\r\n this.minH = Math.max(minPaddingY, this.initialProps.minHeight || 0);\r\n // max height\r\n if (this.initialProps.maxHeight) {\r\n this.maxH = Math.max(this.height, this.initialProps.maxHeight);\r\n }\r\n }\r\n }\r\n\r\n private dropInitial() {\r\n this.changeX = this.changeY = this.minW = this.minH;\r\n this.width = this.height = 0;\r\n if (this.activeResizer) {\r\n this.activeResizer.removeAttribute('style');\r\n }\r\n this.$el.classList.remove('active');\r\n this.activeResizer = undefined;\r\n }\r\n\r\n private bindMove() {\r\n document.documentElement.addEventListener(\r\n 'mouseup',\r\n this.mouseUpFunc,\r\n true,\r\n );\r\n document.documentElement.addEventListener(\r\n 'touchend',\r\n this.mouseUpFunc,\r\n true,\r\n );\r\n document.documentElement.addEventListener(\r\n 'mousemove',\r\n this.mouseMoveFunc,\r\n true,\r\n );\r\n document.documentElement.addEventListener(\r\n 'touchmove',\r\n this.mouseMoveFunc,\r\n true,\r\n );\r\n document.documentElement.addEventListener('mouseleave', this.mouseUpFunc);\r\n }\r\n\r\n private unbindMove() {\r\n document.documentElement.removeEventListener(\r\n 'mouseup',\r\n this.mouseUpFunc,\r\n true,\r\n );\r\n document.documentElement.removeEventListener(\r\n 'touchend',\r\n this.mouseUpFunc,\r\n true,\r\n );\r\n document.documentElement.removeEventListener(\r\n 'mousemove',\r\n this.mouseMoveFunc,\r\n true,\r\n );\r\n document.documentElement.removeEventListener(\r\n 'touchmove',\r\n this.mouseMoveFunc,\r\n true,\r\n );\r\n document.documentElement.removeEventListener(\r\n 'mouseleave',\r\n this.mouseUpFunc,\r\n );\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by LevelSkill.Pro
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { ResizeDirective, ResizeEvents, } from "./resizable.directive";
|
|
6
|
+
export const ResizableElement = (props, children) => {
|
|
7
|
+
const resizeEls = [];
|
|
8
|
+
const directive = (props.canResize &&
|
|
9
|
+
new ResizeDirective(props, e => {
|
|
10
|
+
var _a;
|
|
11
|
+
if (e.eventName === ResizeEvents.end) {
|
|
12
|
+
(_a = props.onResize) === null || _a === void 0 ? void 0 : _a.call(props, e);
|
|
13
|
+
}
|
|
14
|
+
})) ||
|
|
15
|
+
null;
|
|
16
|
+
if (props.active) {
|
|
17
|
+
if (props.canResize) {
|
|
18
|
+
for (let p in props.active) {
|
|
19
|
+
resizeEls.push(h("div", { onClick: e => e.preventDefault(), onDblClick: e => {
|
|
20
|
+
var _a;
|
|
21
|
+
e.preventDefault();
|
|
22
|
+
(_a = props.onDblClick) === null || _a === void 0 ? void 0 : _a.call(props, e);
|
|
23
|
+
}, onMouseDown: (e) => directive === null || directive === void 0 ? void 0 : directive.handleDown(e), onTouchStart: (e) => directive === null || directive === void 0 ? void 0 : directive.handleDown(e), class: `resizable resizable-${props.active[p]}` }));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
for (let _p in props.active) {
|
|
28
|
+
resizeEls.push(h("div", { onClick: e => e.preventDefault(), onTouchStart: (e) => e.preventDefault(), onDblClick: e => {
|
|
29
|
+
var _a;
|
|
30
|
+
e.preventDefault();
|
|
31
|
+
(_a = props.onDblClick) === null || _a === void 0 ? void 0 : _a.call(props, e);
|
|
32
|
+
}, class: `no-resize` }));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return (h("div", Object.assign({}, props, { ref: e => e && (directive === null || directive === void 0 ? void 0 : directive.set(e)) }), children, resizeEls));
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=resizable.element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resizable.element.js","sourceRoot":"","sources":["../../../src/components/header/resizable.element.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA4B,CAAC,EAAc,MAAM,eAAe,CAAC;AACxE,OAAO,EAEL,eAAe,EACf,YAAY,GACb,MAAM,uBAAuB,CAAC;AAK/B,MAAM,CAAC,MAAM,gBAAgB,GAAwB,CACnD,KAAqC,EACrC,QAAiB,EACjB,EAAE;IACF,MAAM,SAAS,GAAY,EAAE,CAAC;IAC9B,MAAM,SAAS,GACb,CAAC,KAAK,CAAC,SAAS;QACd,IAAI,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE;;YAC7B,IAAI,CAAC,CAAC,SAAS,KAAK,YAAY,CAAC,GAAG,EAAE,CAAC;gBACrC,MAAA,KAAK,CAAC,QAAQ,sDAAG,CAAC,CAAC,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;QACL,IAAI,CAAC;IAEP,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;QACjB,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;YACpB,KAAK,IAAI,CAAC,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBAC3B,SAAS,CAAC,IAAI,CACZ,WACE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EAChC,UAAU,EAAE,CAAC,CAAC,EAAE;;wBACd,CAAC,CAAC,cAAc,EAAE,CAAC;wBACnB,MAAA,KAAK,CAAC,UAAU,sDAAG,CAAC,CAAC,CAAC;oBACxB,CAAC,EACD,WAAW,EAAE,CAAC,CAAa,EAAE,EAAE,CAAC,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,UAAU,CAAC,CAAC,CAAC,EACxD,YAAY,EAAE,CAAC,CAAa,EAAE,EAAE,CAAC,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,UAAU,CAAC,CAAC,CAAC,EACzD,KAAK,EAAE,uBAAuB,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAC/C,CACH,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,KAAK,IAAI,EAAE,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBAC5B,SAAS,CAAC,IAAI,CACZ,WACE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EAChC,YAAY,EAAE,CAAC,CAAa,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EACnD,UAAU,EAAE,CAAC,CAAC,EAAE;;wBACd,CAAC,CAAC,cAAc,EAAE,CAAC;wBACnB,MAAA,KAAK,CAAC,UAAU,sDAAG,CAAC,CAAC,CAAC;oBACxB,CAAC,EACD,KAAK,EAAE,WAAW,GAClB,CACH,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,CACL,2BAAS,KAAK,IAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,KAAI,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,GAAG,CAAC,CAAC,CAAC,CAAA;QAC7C,QAAQ;QACR,SAAS,CACN,CACP,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { type FunctionalComponent, h, type VNode } from '@stencil/core';\r\nimport {\r\n ResizeProps,\r\n ResizeDirective,\r\n ResizeEvents,\r\n} from './resizable.directive';\r\nimport type { CellProps } from '@type';\r\n\r\nexport type ResizableElementHTMLAttributes = Partial<ResizeProps> & CellProps;\r\n\r\nexport const ResizableElement: FunctionalComponent = (\r\n props: ResizableElementHTMLAttributes,\r\n children: VNode[],\r\n) => {\r\n const resizeEls: VNode[] = [];\r\n const directive =\r\n (props.canResize &&\r\n new ResizeDirective(props, e => {\r\n if (e.eventName === ResizeEvents.end) {\r\n props.onResize?.(e);\r\n }\r\n })) ||\r\n null;\r\n\r\n if (props.active) {\r\n if (props.canResize) {\r\n for (let p in props.active) {\r\n resizeEls.push(\r\n <div\r\n onClick={e => e.preventDefault()}\r\n onDblClick={e => {\r\n e.preventDefault();\r\n props.onDblClick?.(e);\r\n }}\r\n onMouseDown={(e: MouseEvent) => directive?.handleDown(e)}\r\n onTouchStart={(e: TouchEvent) => directive?.handleDown(e)}\r\n class={`resizable resizable-${props.active[p]}`}\r\n />,\r\n );\r\n }\r\n } else {\r\n for (let _p in props.active) {\r\n resizeEls.push(\r\n <div\r\n onClick={e => e.preventDefault()}\r\n onTouchStart={(e: TouchEvent) => e.preventDefault()}\r\n onDblClick={e => {\r\n e.preventDefault();\r\n props.onDblClick?.(e);\r\n }}\r\n class={`no-resize`}\r\n />,\r\n );\r\n }\r\n }\r\n }\r\n return (\r\n <div {...props} ref={e => e && directive?.set(e)}>\r\n {children}\r\n {resizeEls}\r\n </div>\r\n );\r\n};\r\n"]}
|