@revolist/revogrid 4.9.21 → 4.9.23
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/dist/cjs/{column.drag.plugin-9841e68f.js → column.drag.plugin-eb1db875.js} +48 -53
- package/dist/cjs/column.drag.plugin-eb1db875.js.map +1 -0
- package/dist/cjs/{column.service-2471e4f3.js → column.service-6089b047.js} +9 -19
- package/dist/cjs/column.service-6089b047.js.map +1 -0
- package/dist/{esm/debounce-e8e9464a.js → cjs/debounce-ec7a04b4.js} +36 -78
- package/dist/cjs/debounce-ec7a04b4.js.map +1 -0
- package/dist/cjs/{edit.utils-eef92df0.js → edit.utils-093fe9cd.js} +2 -2
- package/dist/cjs/{edit.utils-eef92df0.js.map → edit.utils-093fe9cd.js.map} +1 -1
- package/dist/cjs/{header-cell-renderer-751067c0.js → header-cell-renderer-2d56e8f5.js} +2 -2
- package/dist/cjs/{header-cell-renderer-751067c0.js.map → header-cell-renderer-2d56e8f5.js.map} +1 -1
- package/dist/cjs/{index-8bceed03.js → index-a9ee8eef.js} +289 -853
- package/dist/cjs/index-a9ee8eef.js.map +1 -0
- package/dist/cjs/index.cjs.js +8 -8
- package/dist/cjs/{key.utils-f548f37c.js → key.utils-1438f2ac.js} +2 -2
- package/dist/cjs/{key.utils-f548f37c.js.map → key.utils-1438f2ac.js.map} +1 -1
- package/dist/cjs/revo-grid.cjs.entry.js +41 -72
- package/dist/cjs/revo-grid.cjs.entry.js.map +1 -1
- package/dist/cjs/revogr-attribution_6.cjs.entry.js +9 -9
- package/dist/cjs/revogr-attribution_6.cjs.entry.js.map +1 -1
- package/dist/cjs/revogr-clipboard_3.cjs.entry.js +6 -6
- package/dist/cjs/revogr-clipboard_3.cjs.entry.js.map +1 -1
- package/dist/cjs/revogr-data_4.cjs.entry.js +21 -44
- package/dist/cjs/revogr-data_4.cjs.entry.js.map +1 -1
- package/dist/cjs/revogr-filter-panel.cjs.entry.js +2 -2
- package/dist/cjs/revogr-filter-panel.cjs.entry.js.map +1 -1
- package/dist/cjs/{row-header-utils-5d0d3fab.js → row-header-utils-eb5949b3.js} +7 -9
- package/dist/cjs/row-header-utils-eb5949b3.js.map +1 -0
- package/dist/cjs/{text-editor-f066d388.js → text-editor-ea3badef.js} +3 -3
- package/dist/cjs/{text-editor-f066d388.js.map → text-editor-ea3badef.js.map} +1 -1
- package/dist/cjs/{throttle-216690f1.js → throttle-6fecba1e.js} +6 -11
- package/dist/cjs/throttle-6fecba1e.js.map +1 -0
- package/dist/collection/components/revoGrid/revo-grid.js +9 -13
- package/dist/collection/components/revoGrid/revo-grid.js.map +1 -1
- package/dist/collection/services/dimension.provider.js +4 -3
- package/dist/collection/services/dimension.provider.js.map +1 -1
- package/dist/collection/store/dimension/dimension.store.js +19 -6
- package/dist/collection/store/dimension/dimension.store.js.map +1 -1
- package/dist/collection/store/vp/viewport.store.js +5 -7
- package/dist/collection/store/vp/viewport.store.js.map +1 -1
- package/dist/esm/{column.drag.plugin-c9787a50.js → column.drag.plugin-cb25a5e1.js} +45 -50
- package/dist/esm/column.drag.plugin-cb25a5e1.js.map +1 -0
- package/dist/esm/{column.service-a6682d9d.js → column.service-407956dd.js} +6 -16
- package/dist/esm/column.service-407956dd.js.map +1 -0
- package/dist/{cjs/debounce-cb5f4e35.js → esm/debounce-7b511afc.js} +26 -88
- package/dist/esm/debounce-7b511afc.js.map +1 -0
- package/dist/esm/{edit.utils-c358c970.js → edit.utils-1eeabeab.js} +2 -2
- package/dist/esm/{edit.utils-c358c970.js.map → edit.utils-1eeabeab.js.map} +1 -1
- package/dist/esm/{header-cell-renderer-52d9d6ba.js → header-cell-renderer-da468bd2.js} +2 -2
- package/dist/esm/{header-cell-renderer-52d9d6ba.js.map → header-cell-renderer-da468bd2.js.map} +1 -1
- package/dist/esm/{index-6c437a0d.js → index-b6586f9b.js} +269 -833
- package/dist/esm/index-b6586f9b.js.map +1 -0
- package/dist/esm/index.js +8 -8
- package/dist/esm/{key.utils-5a827d12.js → key.utils-562c749e.js} +2 -2
- package/dist/esm/{key.utils-5a827d12.js.map → key.utils-562c749e.js.map} +1 -1
- package/dist/esm/revo-grid.entry.js +37 -68
- package/dist/esm/revo-grid.entry.js.map +1 -1
- package/dist/esm/revogr-attribution_6.entry.js +9 -9
- package/dist/esm/revogr-attribution_6.entry.js.map +1 -1
- package/dist/esm/revogr-clipboard_3.entry.js +6 -6
- package/dist/esm/revogr-clipboard_3.entry.js.map +1 -1
- package/dist/esm/revogr-data_4.entry.js +17 -40
- package/dist/esm/revogr-data_4.entry.js.map +1 -1
- package/dist/esm/revogr-filter-panel.entry.js +2 -2
- package/dist/esm/revogr-filter-panel.entry.js.map +1 -1
- package/dist/esm/{row-header-utils-f5b04d1a.js → row-header-utils-e043f744.js} +7 -9
- package/dist/esm/row-header-utils-e043f744.js.map +1 -0
- package/dist/esm/{text-editor-79a617b5.js → text-editor-654f5d53.js} +3 -3
- package/dist/esm/{text-editor-79a617b5.js.map → text-editor-654f5d53.js.map} +1 -1
- package/dist/esm/{throttle-b94844de.js → throttle-bb3169c7.js} +4 -9
- package/dist/esm/throttle-bb3169c7.js.map +1 -0
- package/dist/revo-grid/column.drag.plugin-cb25a5e1.js +5 -0
- package/dist/revo-grid/column.drag.plugin-cb25a5e1.js.map +1 -0
- package/dist/revo-grid/column.service-407956dd.js +5 -0
- package/dist/revo-grid/column.service-407956dd.js.map +1 -0
- package/dist/revo-grid/debounce-7b511afc.js +5 -0
- package/dist/revo-grid/debounce-7b511afc.js.map +1 -0
- package/dist/revo-grid/{edit.utils-c358c970.js → edit.utils-1eeabeab.js} +2 -2
- package/dist/revo-grid/{header-cell-renderer-52d9d6ba.js → header-cell-renderer-da468bd2.js} +2 -2
- package/dist/revo-grid/index-b6586f9b.js +5 -0
- package/dist/revo-grid/index-b6586f9b.js.map +1 -0
- package/dist/revo-grid/index.esm.js +1 -1
- package/dist/revo-grid/{key.utils-5a827d12.js → key.utils-562c749e.js} +2 -2
- package/dist/revo-grid/revo-grid.entry.js +1 -1
- package/dist/revo-grid/revo-grid.entry.js.map +1 -1
- package/dist/revo-grid/revogr-attribution_6.entry.js +1 -1
- package/dist/revo-grid/revogr-clipboard_3.entry.js +1 -1
- package/dist/revo-grid/revogr-data_4.entry.js +1 -1
- package/dist/revo-grid/revogr-data_4.entry.js.map +1 -1
- package/dist/revo-grid/revogr-filter-panel.entry.js +1 -1
- package/dist/revo-grid/row-header-utils-e043f744.js +5 -0
- package/dist/revo-grid/row-header-utils-e043f744.js.map +1 -0
- package/dist/revo-grid/{text-editor-79a617b5.js → text-editor-654f5d53.js} +2 -2
- package/dist/revo-grid/throttle-bb3169c7.js +5 -0
- package/dist/revo-grid/throttle-bb3169c7.js.map +1 -0
- package/dist/types/store/dimension/dimension.store.d.ts +2 -1
- package/dist/types/store/vp/viewport.store.d.ts +0 -1
- package/hydrate/index.js +412 -1103
- package/hydrate/index.mjs +412 -1103
- package/package.json +3 -3
- package/standalone/column.service.js +5 -16
- package/standalone/column.service.js.map +1 -1
- package/standalone/debounce.js +7 -16
- package/standalone/debounce.js.map +1 -1
- package/standalone/dimension.helpers.js +15 -45
- package/standalone/dimension.helpers.js.map +1 -1
- package/standalone/index.js +0 -2
- package/standalone/index.js.map +1 -1
- package/standalone/index2.js +0 -2
- package/standalone/index2.js.map +1 -1
- package/standalone/reduce.js +1319 -474
- package/standalone/reduce.js.map +1 -1
- package/standalone/revo-grid.js +74 -111
- package/standalone/revo-grid.js.map +1 -1
- package/standalone/revogr-data2.js +0 -2
- package/standalone/revogr-data2.js.map +1 -1
- package/standalone/revogr-filter-panel.js +2 -2
- package/standalone/revogr-filter-panel.js.map +1 -1
- package/standalone/revogr-focus2.js +0 -2
- package/standalone/revogr-focus2.js.map +1 -1
- package/standalone/revogr-header2.js +12 -37
- package/standalone/revogr-header2.js.map +1 -1
- package/standalone/revogr-order-editor2.js +2 -4
- package/standalone/revogr-order-editor2.js.map +1 -1
- package/standalone/revogr-overlay-selection2.js +2 -4
- package/standalone/revogr-overlay-selection2.js.map +1 -1
- package/standalone/revogr-row-headers2.js +5 -9
- package/standalone/revogr-row-headers2.js.map +1 -1
- package/standalone/revogr-temp-range2.js +2 -2
- package/standalone/revogr-temp-range2.js.map +1 -1
- package/standalone/revogr-viewport-scroll2.js +2 -2
- package/standalone/revogr-viewport-scroll2.js.map +1 -1
- package/standalone/selection.utils.js +0 -2
- package/standalone/selection.utils.js.map +1 -1
- package/standalone/throttle.js +3 -8
- package/standalone/throttle.js.map +1 -1
- package/standalone/toNumber.js +165 -22
- package/standalone/toNumber.js.map +1 -1
- package/dist/cjs/column.drag.plugin-9841e68f.js.map +0 -1
- package/dist/cjs/column.service-2471e4f3.js.map +0 -1
- package/dist/cjs/debounce-cb5f4e35.js.map +0 -1
- package/dist/cjs/index-8bceed03.js.map +0 -1
- package/dist/cjs/row-header-utils-5d0d3fab.js.map +0 -1
- package/dist/cjs/throttle-216690f1.js.map +0 -1
- package/dist/esm/column.drag.plugin-c9787a50.js.map +0 -1
- package/dist/esm/column.service-a6682d9d.js.map +0 -1
- package/dist/esm/debounce-e8e9464a.js.map +0 -1
- package/dist/esm/index-6c437a0d.js.map +0 -1
- package/dist/esm/row-header-utils-f5b04d1a.js.map +0 -1
- package/dist/esm/throttle-b94844de.js.map +0 -1
- package/dist/revo-grid/column.drag.plugin-c9787a50.js +0 -5
- package/dist/revo-grid/column.drag.plugin-c9787a50.js.map +0 -1
- package/dist/revo-grid/column.service-a6682d9d.js +0 -5
- package/dist/revo-grid/column.service-a6682d9d.js.map +0 -1
- package/dist/revo-grid/debounce-e8e9464a.js +0 -5
- package/dist/revo-grid/debounce-e8e9464a.js.map +0 -1
- package/dist/revo-grid/index-6c437a0d.js +0 -5
- package/dist/revo-grid/index-6c437a0d.js.map +0 -1
- package/dist/revo-grid/row-header-utils-f5b04d1a.js +0 -5
- package/dist/revo-grid/row-header-utils-f5b04d1a.js.map +0 -1
- package/dist/revo-grid/throttle-b94844de.js +0 -5
- package/dist/revo-grid/throttle-b94844de.js.map +0 -1
- package/standalone/_stringToPath.js +0 -1389
- package/standalone/_stringToPath.js.map +0 -1
- package/standalone/isObjectLike.js +0 -195
- package/standalone/isObjectLike.js.map +0 -1
- /package/dist/revo-grid/{edit.utils-c358c970.js.map → edit.utils-1eeabeab.js.map} +0 -0
- /package/dist/revo-grid/{header-cell-renderer-52d9d6ba.js.map → header-cell-renderer-da468bd2.js.map} +0 -0
- /package/dist/revo-grid/{key.utils-5a827d12.js.map → key.utils-562c749e.js.map} +0 -0
- /package/dist/revo-grid/{text-editor-79a617b5.js.map → text-editor-654f5d53.js.map} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Built by Revolist OU ❤️
|
|
3
3
|
*/
|
|
4
|
-
import { i as getItemByPosition, V as createStore, v as setStore } from './index-
|
|
4
|
+
import { i as getItemByPosition, V as createStore, v as setStore } from './index-b6586f9b.js';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* Update items based on new scroll position
|
|
@@ -283,10 +283,6 @@ class ViewportStore {
|
|
|
283
283
|
// last coordinate for store position restore
|
|
284
284
|
this.lastKnownScroll = 0;
|
|
285
285
|
this.store = createStore(initialState());
|
|
286
|
-
// drop items on real size change, require a new item set
|
|
287
|
-
this.store.onChange('realCount', () => this.clearItems());
|
|
288
|
-
// drop items on virtual size change, require a new item set
|
|
289
|
-
this.store.onChange('virtualSize', () => this.clearItems());
|
|
290
286
|
}
|
|
291
287
|
/**
|
|
292
288
|
* Render viewport based on coordinate
|
|
@@ -388,11 +384,13 @@ class ViewportStore {
|
|
|
388
384
|
};
|
|
389
385
|
}
|
|
390
386
|
setViewport(data) {
|
|
387
|
+
// drop items on virtual size change, require a new item set
|
|
388
|
+
// drop items on real size change, require a new item set
|
|
389
|
+
if (typeof data.realCount === 'number' || typeof data.virtualSize === 'number') {
|
|
390
|
+
data = Object.assign(Object.assign({}, data), { items: data.items || [] });
|
|
391
|
+
}
|
|
391
392
|
setStore(this.store, data);
|
|
392
393
|
}
|
|
393
|
-
clearItems() {
|
|
394
|
-
this.store.set('items', []);
|
|
395
|
-
}
|
|
396
394
|
}
|
|
397
395
|
|
|
398
396
|
const LETTER_BLOCK_SIZE = 10;
|
|
@@ -403,4 +401,4 @@ const calculateRowHeaderSize = (itemsLength, rowHeaderColumn, minWidth = 50) =>
|
|
|
403
401
|
|
|
404
402
|
export { ViewportStore as V, addMissingItems as a, getItems as b, isActiveRangeOutsideLastItem as c, getFirstItem as d, getLastItem as e, calculateRowHeaderSize as f, getUpdatedItemsByPosition as g, isActiveRange as i, recombineByOffset as r, setItemSizes as s, updateMissingAndRange as u };
|
|
405
403
|
|
|
406
|
-
//# sourceMappingURL=row-header-utils-
|
|
404
|
+
//# sourceMappingURL=row-header-utils-e043f744.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"row-header-utils-e043f744.js","mappings":"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","names":[],"sources":["src/store/vp/viewport.helpers.ts","src/store/vp/viewport.store.ts","src/utils/row-header-utils.ts"],"sourcesContent":["import {\n DimensionSettingsState,\n PositionItem,\n ViewSettingSizeProp,\n ViewportStateItems,\n VirtualPositionItem,\n Range,\n} from '@type';\n\nimport { getItemByPosition } from '../dimension/dimension.helpers';\n\nexport type DimensionDataViewport = Pick<\n DimensionSettingsState,\n | 'indexes'\n | 'positionIndexes'\n | 'positionIndexToItem'\n | 'sizes'\n | 'originItemSize'\n | 'realSize'\n>;\n\nexport type ItemsToUpdate = Pick<ViewportStateItems, 'items' | 'start' | 'end'>;\n/**\n * Update items based on new scroll position\n * If viewport wasn't changed fully simple recombination of positions\n * Otherwise rebuild viewport items\n */\nexport function getUpdatedItemsByPosition<T extends ItemsToUpdate>(\n pos: number, // coordinate\n items: T,\n realCount: number,\n virtualSize: number,\n dimension: DimensionDataViewport,\n): ItemsToUpdate {\n const activeItem: PositionItem = getItemByPosition(dimension, pos);\n const firstItem = getFirstItem(items);\n let toUpdate: ItemsToUpdate | undefined;\n // do simple position recombination if items already present in viewport\n if (firstItem) {\n let changedOffsetStart = activeItem.itemIndex - (firstItem.itemIndex || 0);\n // if item changed\n if (changedOffsetStart) {\n // simple recombination\n toUpdate = recombineByOffset(Math.abs(changedOffsetStart), {\n positiveDirection: changedOffsetStart > -1,\n ...dimension,\n ...items,\n });\n }\n }\n\n const maxSizeVirtualSize = getMaxVirtualSize(\n virtualSize,\n dimension.realSize,\n activeItem,\n );\n // if partial recombination add items if revo-viewport has some space left\n if (toUpdate) {\n const extra = addMissingItems(\n activeItem,\n realCount,\n maxSizeVirtualSize,\n toUpdate,\n dimension,\n );\n if (extra.length) {\n updateMissingAndRange(toUpdate.items, extra, toUpdate);\n }\n }\n\n // new collection if no items after replacement full replacement\n if (!toUpdate) {\n const items = getItems({\n firstItemStart: activeItem.start,\n firstItemIndex: activeItem.itemIndex,\n origSize: dimension.originItemSize,\n maxSize: maxSizeVirtualSize,\n maxCount: realCount,\n sizes: dimension.sizes,\n });\n\n // range now comes from 0 to length - 1\n toUpdate = {\n items,\n start: 0,\n end: items.length - 1,\n };\n }\n return toUpdate;\n}\n\n// virtual size can differ based on scroll position if some big items are present\n// scroll can be in the middle of item and virtual size will be larger\n// so we need to exclude this part from virtual size hence it's already passed\nfunction getMaxVirtualSize(\n virtualSize: number,\n realSize: number,\n activeItem: PositionItem,\n) {\n return Math.min(virtualSize + (activeItem.end - activeItem.start), realSize);\n}\n\nexport function updateMissingAndRange(\n items: VirtualPositionItem[],\n missing: VirtualPositionItem[],\n range: Range,\n) {\n items.splice(range.end + 1, 0, ...missing);\n // update range if start larger after recombination\n if (\n range.start >= range.end &&\n !(range.start === range.end && range.start === 0)\n ) {\n range.start += missing.length;\n }\n range.end += missing.length;\n}\n\n/**\n * If partial replacement\n * this function adds items if viewport has some space left\n */\nexport function addMissingItems<T extends ItemsToUpdate>(\n firstItem: PositionItem,\n realCount: number,\n virtualSize: number,\n existingCollection: T,\n dimension: Pick<DimensionSettingsState, 'sizes' | 'originItemSize'>,\n): VirtualPositionItem[] {\n const lastItem: VirtualPositionItem = getLastItem(existingCollection);\n const items = getItems({\n sizes: dimension.sizes,\n firstItemStart: lastItem.end,\n firstItemIndex: lastItem.itemIndex + 1,\n origSize: dimension.originItemSize,\n maxSize: virtualSize - (lastItem.end - firstItem.start),\n maxCount: realCount,\n });\n return items;\n}\n\n/**\n * Get wiewport items parameters\n * caching position and calculating items count in viewport\n */\nexport function getItems(\n opt: {\n firstItemIndex: number;\n firstItemStart: number;\n origSize: number;\n maxSize: number; // virtual size\n maxCount: number; // real item count, where the last item\n sizes?: ViewSettingSizeProp;\n },\n currentSize = 0,\n) {\n const items: VirtualPositionItem[] = [];\n\n let index = opt.firstItemIndex;\n let size = currentSize;\n\n // max size or max count\n while (size <= opt.maxSize && index < opt.maxCount) {\n const newSize = getItemSize(index, opt.sizes, opt.origSize);\n items.push({\n start: opt.firstItemStart + size,\n end: opt.firstItemStart + size + newSize,\n itemIndex: index,\n size: newSize,\n });\n size += newSize;\n index++;\n }\n return items;\n}\n\n/**\n * Do batch items recombination\n * If items not overlapped with existing viewport returns null\n */\ntype RecombindDimensionData = Pick<\n DimensionSettingsState,\n 'sizes' | 'realSize' | 'originItemSize'\n>;\ntype RecombineOffsetData = {\n positiveDirection: boolean;\n} & ItemsToUpdate &\n RecombindDimensionData;\nexport function recombineByOffset(\n offset: number,\n data: RecombineOffsetData,\n): ItemsToUpdate | undefined {\n const newItems = [...data.items];\n const itemsCount = newItems.length;\n let newRange = {\n start: data.start,\n end: data.end,\n };\n\n // if offset out of revo-viewport, makes sense whole redraw\n if (offset > itemsCount) {\n return undefined;\n }\n\n // is direction of scroll positive\n if (data.positiveDirection) {\n // push item to the end\n let lastItem: VirtualPositionItem = getLastItem(data);\n\n let i = newRange.start;\n const length = i + offset;\n for (; i < length; i++) {\n const newIndex = lastItem.itemIndex + 1;\n const size = getItemSize(\n newIndex,\n data.sizes,\n data.originItemSize,\n );\n\n // if item overlapped limit break a loop\n if (lastItem.end + size > data.realSize) {\n break;\n }\n\n // new item index to recombine\n let newEnd = i % itemsCount;\n\n // item should always present, we do not create new item, we recombine them\n if (!newItems[newEnd]) {\n throw new Error('incorrect index');\n }\n\n // do recombination\n newItems[newEnd] = lastItem = {\n start: lastItem.end,\n end: lastItem.end + size,\n itemIndex: newIndex,\n size: size,\n };\n // update range\n newRange.start++;\n newRange.end = newEnd;\n }\n\n // direction is negative\n } else {\n // push item to the start\n let firstItem = getFirstItem(data);\n\n const end = newRange.end;\n for (let i = 0; i < offset; i++) {\n const newIndex = (firstItem?.itemIndex ?? 0) - 1;\n const size = getItemSize(\n newIndex,\n data.sizes,\n data.originItemSize,\n );\n\n // new item index to recombine\n let newStart = end - i;\n newStart = (newStart < 0 ? itemsCount + newStart : newStart) % itemsCount;\n\n // item should always present, we do not create new item, we recombine them\n if (!newItems[newStart]) {\n console.error('incorrect index');\n break;\n }\n\n // do recombination\n const firstItemStart = firstItem?.start ?? 0;\n newItems[newStart] = firstItem = {\n start: firstItemStart - size,\n end: firstItemStart,\n itemIndex: newIndex,\n size: size,\n };\n // update range\n newRange.start = newStart;\n newRange.end--;\n }\n }\n const range = {\n start:\n (newRange.start < 0 ? itemsCount + newRange.start : newRange.start) %\n itemsCount,\n end:\n (newRange.end < 0 ? itemsCount + newRange.end : newRange.end) %\n itemsCount,\n };\n return {\n items: newItems,\n ...range,\n };\n}\n\nfunction getItemSize(\n index: number,\n sizes?: ViewSettingSizeProp,\n origSize = 0,\n): number {\n if (sizes && sizes[index]) {\n return sizes[index];\n }\n return origSize;\n}\n\n/**\n * Verify if position is in range of the PositionItem, start and end are included\n */\nexport function isActiveRange(\n pos: number,\n realSize: number,\n first?: PositionItem,\n last?: PositionItem,\n): boolean {\n if (!first || !last) {\n return false;\n }\n // if position is in range of first item\n // or position is after first item and last item is the last item in real size\n return (\n (pos >= first.start && pos <= first.end) ||\n (pos > first.end && last.end === realSize)\n );\n}\n\nexport function isActiveRangeOutsideLastItem(\n pos: number,\n virtualSize: number,\n firstItem?: PositionItem,\n lastItem?: PositionItem,\n) {\n // if no first item, means no items in viewport\n if (!firstItem) {\n return false;\n }\n return virtualSize + pos > (lastItem?.end ?? 0);\n}\n\nexport function getFirstItem(\n s: ItemsToUpdate,\n) {\n return s.items[s.start];\n}\n\nexport function getLastItem(s: ItemsToUpdate): VirtualPositionItem {\n return s.items[s.end];\n}\n\n/**\n * Set items sizes from start index to end\n * @param vpItems\n * @param start\n * @param size\n * @param lastCoordinate\n * @returns\n */\nexport function setItemSizes(\n vpItems: VirtualPositionItem[],\n initialIndex: number,\n size: number,\n lastCoordinate: number,\n) {\n const items = [...vpItems];\n const count = items.length;\n\n let pos = lastCoordinate;\n let i = 0;\n let start = initialIndex;\n\n // viewport not inited\n if (!count) {\n return [];\n }\n // loop through array from initial item after recombination\n while (i < count) {\n const item = items[start];\n item.start = pos;\n item.size = size;\n item.end = item.start + size;\n pos = item.end;\n // loop by start index\n start++;\n i++;\n\n // if start index out of array, reset it\n if (start === count) {\n start = 0;\n }\n }\n return items;\n}\n","import {\n DimensionDataViewport,\n addMissingItems,\n getFirstItem,\n getLastItem,\n getUpdatedItemsByPosition,\n isActiveRange,\n setItemSizes,\n updateMissingAndRange,\n isActiveRangeOutsideLastItem,\n ItemsToUpdate,\n} from './viewport.helpers';\nimport { createStore } from '@stencil/store';\nimport { type Observable, setStore } from '../../utils/store.utils';\nimport type {\n VirtualPositionItem,\n ViewportState,\n MultiDimensionType,\n} from '@type';\n\n/**\n * Viewport store\n * Used for virtualization (process of rendering only visible part of data)\n * Redraws viewport based on position and dimension\n */\nfunction initialState(): ViewportState {\n return {\n // virtual item information per rendered item\n items: [],\n // virtual dom item order to render\n start: 0,\n end: 0,\n\n // size of viewport in px\n virtualSize: 0,\n\n // total number of items\n realCount: 0,\n };\n}\n\n/**\n * Viewport store class\n */\nexport class ViewportStore {\n readonly store: Observable<ViewportState>;\n\n // last coordinate for store position restore\n private lastKnownScroll = 0;\n\n get lastCoordinate() {\n return this.lastKnownScroll;\n }\n set lastCoordinate(value: number) {\n this.lastKnownScroll = value;\n }\n constructor(readonly type: MultiDimensionType) {\n this.store = createStore(initialState());\n }\n\n /**\n * Render viewport based on coordinate\n * It's the main method for draw\n * Use force if you want to re-render viewport\n */\n setViewPortCoordinate(\n position: number,\n dimension: DimensionDataViewport,\n force = false,\n ) {\n const viewportSize = this.store.get('virtualSize');\n // no visible data to calculate\n if (!viewportSize) {\n return;\n }\n\n const frameOffset = 1;\n const singleOffsetInPx = dimension.originItemSize * frameOffset;\n // add offset to virtual size from both sides\n const outsize = singleOffsetInPx * 2;\n // math virtual size is based on visible area + 2 items outside of visible area\n const virtualSize = viewportSize + outsize;\n\n // expected no scroll if real size less than virtual size, position is 0\n let maxCoordinate = 0;\n // if there is nodes outside of viewport, max coordinate has to be adjusted\n if (dimension.realSize > viewportSize) {\n // max coordinate is real size minus virtual/rendered space\n maxCoordinate = dimension.realSize - viewportSize - singleOffsetInPx;\n }\n\n let pos = position;\n // limit position to max and min coordinates\n if (pos < 0) {\n pos = 0;\n } else if (pos > maxCoordinate) {\n pos = maxCoordinate;\n }\n\n // store last coordinate for further restore on redraw\n this.lastCoordinate = pos;\n\n // actual position is less than first item start based on offset\n pos -= singleOffsetInPx;\n pos = pos < 0 ? 0 : pos < maxCoordinate ? pos : maxCoordinate;\n\n let allItems: ItemsToUpdate;\n // if force clear all items and start from 0\n if (force) {\n allItems = {\n items: [],\n start: 0,\n end: 0,\n };\n } else {\n allItems = this.getItems();\n }\n\n const firstItem: VirtualPositionItem | undefined = getFirstItem(allItems);\n const lastItem: VirtualPositionItem | undefined = getLastItem(allItems);\n\n let toUpdate: Partial<ViewportState> = {};\n\n // left position changed\n // verify if new position is in range of previously rendered first item\n if (!isActiveRange(pos, dimension.realSize, firstItem, lastItem)) {\n toUpdate = {\n ...toUpdate,\n ...getUpdatedItemsByPosition(\n pos,\n allItems,\n this.store.get('realCount'),\n virtualSize,\n dimension,\n ),\n };\n this.setViewport({ ...toUpdate });\n // verify is render area is outside of last item\n } else if (\n isActiveRangeOutsideLastItem(pos, virtualSize, firstItem, lastItem)\n ) {\n const items = [...allItems.items];\n // check is any item missing for fulfill content\n const missing = addMissingItems(\n firstItem,\n this.store.get('realCount'),\n virtualSize + pos - firstItem.start,\n allItems,\n {\n sizes: dimension.sizes,\n originItemSize: dimension.originItemSize,\n },\n );\n\n // update missing items\n if (missing.length) {\n const range = {\n start: this.store.get('start'),\n end: this.store.get('end'),\n };\n updateMissingAndRange(items, missing, range);\n toUpdate = {\n ...toUpdate,\n items: [...items],\n ...range,\n };\n this.setViewport({ ...toUpdate });\n }\n }\n }\n\n /**\n * Set sizes for existing items\n */\n setOriginalSizes(size: number) {\n const items = this.store.get('items');\n const count = items.length;\n // viewport not inited\n if (!count) {\n return;\n }\n\n setStore(this.store, {\n items: setItemSizes(\n items,\n this.store.get('start'),\n size,\n this.lastCoordinate,\n ),\n });\n }\n\n getItems(): ItemsToUpdate {\n return {\n items: this.store.get('items'),\n start: this.store.get('start'),\n end: this.store.get('end'),\n };\n }\n\n setViewport(data: Partial<ViewportState>) {\n // drop items on virtual size change, require a new item set\n // drop items on real size change, require a new item set\n if (typeof data.realCount === 'number' || typeof data.virtualSize === 'number') {\n data = { ...data, items: data.items || [] };\n }\n setStore(this.store, data);\n }\n}\n","import { RowHeaders } from '..';\n\nconst LETTER_BLOCK_SIZE = 10;\nexport const calculateRowHeaderSize = (\n itemsLength: number,\n rowHeaderColumn?: RowHeaders,\n minWidth = 50,\n) => {\n return (\n rowHeaderColumn?.size ||\n Math.max((itemsLength.toString().length + 1) * LETTER_BLOCK_SIZE, minWidth)\n );\n};\n"],"version":3}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Built by Revolist OU ❤️
|
|
3
3
|
*/
|
|
4
|
-
import { f as isEnterKeyValue, d as isTab } from './key.utils-
|
|
5
|
-
import { q as timeout } from './index-
|
|
4
|
+
import { f as isEnterKeyValue, d as isTab } from './key.utils-562c749e.js';
|
|
5
|
+
import { q as timeout } from './index-b6586f9b.js';
|
|
6
6
|
|
|
7
7
|
class TextEditor {
|
|
8
8
|
constructor(column, saveCallback) {
|
|
@@ -77,4 +77,4 @@ class TextEditor {
|
|
|
77
77
|
|
|
78
78
|
export { TextEditor as T };
|
|
79
79
|
|
|
80
|
-
//# sourceMappingURL=text-editor-
|
|
80
|
+
//# sourceMappingURL=text-editor-654f5d53.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"file":"text-editor-
|
|
1
|
+
{"file":"text-editor-654f5d53.js","mappings":";;;;;;MAoBa,UAAU;IAMrB,YACS,MAAqB,EACpB,YAA2B;QAD5B,WAAM,GAAN,MAAM,CAAe;QACpB,iBAAY,GAAZ,YAAY,CAAe;QAPrC,cAAS,GAA4B,IAAI,CAAC;QAE1C,YAAO,GAAmB,IAAI,CAAC;QAC/B,aAAQ,GAAc,SAAS,CAAC;KAK5B;;;;IAKJ,MAAM,kBAAkB;;QACtB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,MAAM,OAAO,EAAE,CAAC;YAChB,MAAA,IAAI,CAAC,SAAS,0CAAE,KAAK,EAAE,CAAC;SACzB;KACF;IAED,SAAS,CAAC,CAAgB;QACxB,MAAM,OAAO,GAAG,eAAe,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACvC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAE9B,IACE,CAAC,QAAQ,IAAI,OAAO;YACpB,CAAC,CAAC,MAAM;YACR,IAAI,CAAC,YAAY;YACjB,CAAC,CAAC,CAAC,WAAW,EACd;;YAEA,IAAI,CAAC,gBAAgB,EAAE,CAAC;;YAExB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAC;SAC9C;KACF;;;;IAKD,gBAAgB;;QACd,MAAA,IAAI,CAAC,SAAS,0CAAE,IAAI,EAAE,CAAC;KACxB;;;;IAKD,QAAQ;;QACN,OAAO,MAAA,IAAI,CAAC,SAAS,0CAAE,KAAK,CAAC;KAC9B;;;;;;;;;;IAWD,MAAM,CAAC,CAAuB,EAAE,eAAoB;;QAClD,OAAO,CAAC,CAAC,OAAO,EAAE;YAChB,IAAI,EAAE,MAAM;YACZ,YAAY,EAAE,OAAO;;YAErB,KAAK,EAAE,MAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,GAAG,mCAAI,EAAE;;YAE/B,GAAG,EAAE,CAAC,EAA2B;gBAC/B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;aACrB;;YAED,SAAS,EAAE,CAAC,CAAgB,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;SACnD,CAAC,CAAC;KACJ;;;;;","names":[],"sources":["src/components/editors/text-editor.ts"],"sourcesContent":["import { VNode, h as createElement } from '@stencil/core';\nimport { isEnterKeyValue, isTab } from '../../utils/key.utils';\nimport { timeout } from '../../utils';\nimport { ColumnRegular } from '@type';\nimport { EditCell, EditorBase, SaveData } from '@type';\n\n/**\n * Represents a cell editor in a grid.\n *\n * It's a good place to start with your own editor.\n * It manages the editing of cells by handling events, saving data, rendering the editor UI, and managing the lifecycle of the editor instance.\n */\n\n/**\n * Callback triggered on cell editor save\n * Closes editor when called\n * @param preventFocus - if true editor will not be closed and next cell will not be focused\n */\nexport type SaveCallback = (value: SaveData | undefined, preventFocus: boolean) => void;\n\nexport class TextEditor implements EditorBase {\n editInput: HTMLInputElement | null = null;\n\n element: Element | null = null;\n editCell?: EditCell = undefined;\n\n constructor(\n public column: ColumnRegular,\n private saveCallback?: SaveCallback,\n ) {}\n\n /**\n * Callback triggered on cell editor render\n */\n async componentDidRender(): Promise<void> {\n if (this.editInput) {\n await timeout();\n this.editInput?.focus();\n }\n }\n\n onKeyDown(e: KeyboardEvent) {\n const isEnter = isEnterKeyValue(e.key);\n const isKeyTab = isTab(e.key);\n\n if (\n (isKeyTab || isEnter) &&\n e.target &&\n this.saveCallback &&\n !e.isComposing\n ) {\n // blur is needed to avoid autoscroll\n this.beforeDisconnect();\n // request callback which will close cell after all\n this.saveCallback(this.getValue(), isKeyTab);\n }\n }\n\n /**\n * IMPORTANT: Prevent scroll glitches when editor is closed and focus is on current input element.\n */\n beforeDisconnect() {\n this.editInput?.blur();\n }\n\n /**\n * Get value from input\n */\n getValue() {\n return this.editInput?.value;\n }\n\n /**\n * Render method for Editor plugin.\n * Renders input element with passed data from cell.\n *\n * @required @method\n * @param {Function} h - h function from stencil render.\n * @param {Object} _additionalData - additional data from plugin.\n * @returns {VNode} - input element.\n */\n render(h: typeof createElement, _additionalData: any): VNode | VNode[] {\n return h('input', {\n type: 'text',\n enterKeyHint: 'enter',\n // set input value from cell data\n value: this.editCell?.val ?? '',\n // save input element as ref for further usage\n ref: (el: HTMLInputElement | null) => {\n this.editInput = el;\n },\n // listen to keydown event on input element\n onKeyDown: (e: KeyboardEvent) => this.onKeyDown(e),\n });\n }\n}\n"],"version":3}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Built by Revolist OU ❤️
|
|
3
3
|
*/
|
|
4
|
-
import { o as scaleValue } from './index-
|
|
5
|
-
import { d as
|
|
4
|
+
import { o as scaleValue } from './index-b6586f9b.js';
|
|
5
|
+
import { d as debounce, i as isObject } from './debounce-7b511afc.js';
|
|
6
6
|
|
|
7
7
|
const initialParams = {
|
|
8
8
|
contentSize: 0,
|
|
@@ -160,9 +160,6 @@ class LocalScrollTimer {
|
|
|
160
160
|
}
|
|
161
161
|
}
|
|
162
162
|
|
|
163
|
-
var debounce = debounce_1,
|
|
164
|
-
isObject = isObject_1;
|
|
165
|
-
|
|
166
163
|
/** Error message constants. */
|
|
167
164
|
var FUNC_ERROR_TEXT = 'Expected a function';
|
|
168
165
|
|
|
@@ -228,8 +225,6 @@ function throttle(func, wait, options) {
|
|
|
228
225
|
});
|
|
229
226
|
}
|
|
230
227
|
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
export { LocalScrollTimer as L, LocalScrollService as a, getContentSize as g, throttle_1 as t };
|
|
228
|
+
export { LocalScrollTimer as L, LocalScrollService as a, getContentSize as g, throttle as t };
|
|
234
229
|
|
|
235
|
-
//# sourceMappingURL=throttle-
|
|
230
|
+
//# sourceMappingURL=throttle-bb3169c7.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"throttle-bb3169c7.js","mappings":"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","names":[],"sources":["src/services/local.scroll.service.ts","src/services/local.scroll.timer.ts","node_modules/lodash/throttle.js"],"sourcesContent":["import type { DimensionType, ViewPortScrollEvent } from '@type';\nimport { scaleValue } from '../utils';\n\ninterface Config {\n skipAnimationFrame?: boolean;\n // scroll event inited and direction cached\n // scrollingService.proxyScroll get tiggered\n // setScroll event called from scrollingService\n runScroll(e: ViewPortScrollEvent): void;\n // all operation finished, apply scroll values\n applyScroll(e: ViewPortScrollEvent): void;\n}\n\ntype Params = {\n contentSize: number;\n virtualContentSize?: number;\n clientSize: number;\n virtualSize: number;\n maxSize?: number;\n};\n\nconst initialParams: Params = {\n contentSize: 0,\n clientSize: 0,\n virtualSize: 0,\n maxSize: 0,\n};\nconst NO_COORDINATE = -1;\n\n/**\n * Based on content size, client size and virtual size\n * return full size\n */\nexport function getContentSize(\n contentSize: number,\n clientSize: number,\n virtualSize = 0,\n): number {\n return contentSize + (virtualSize ? clientSize - virtualSize : 0);\n}\n\nexport default class LocalScrollService {\n private preventArtificialScroll: Record<DimensionType, (() => void) | null> = {\n rgRow: null,\n rgCol: null,\n };\n // to check if scroll changed\n private previousScroll: Record<DimensionType, number> = {\n rgRow: NO_COORDINATE,\n rgCol: NO_COORDINATE,\n };\n private params: Record<DimensionType, Params> = {\n rgRow: { ...initialParams },\n rgCol: { ...initialParams },\n };\n\n constructor(private cfg: Config) {}\n\n setParams(params: Params, dimension: DimensionType) {\n const virtualContentSize = getContentSize(\n params.contentSize,\n params.clientSize,\n params.virtualSize,\n );\n this.params[dimension] = {\n ...params,\n maxSize: virtualContentSize - params.clientSize,\n virtualContentSize,\n };\n }\n\n // apply scroll values after scroll done\n async setScroll(e: ViewPortScrollEvent) {\n this.cancelScroll(e.dimension);\n\n // start frame animation\n const frameAnimation = new Promise<void>((resolve, reject) => {\n // for example safari desktop has issues with animation frame\n if (this.cfg.skipAnimationFrame) {\n return resolve();\n }\n const animationId = window.requestAnimationFrame(() => {\n resolve();\n });\n this.preventArtificialScroll[e.dimension] = reject.bind(\n null,\n animationId,\n );\n });\n\n try {\n await frameAnimation;\n const params = this.getParams(e.dimension);\n e.coordinate = Math.ceil(e.coordinate);\n this.previousScroll[e.dimension] = this.wrapCoordinate(\n e.coordinate,\n params,\n );\n this.preventArtificialScroll[e.dimension] = null;\n this.cfg.applyScroll({\n ...e,\n coordinate: params.virtualSize\n ? this.convert(e.coordinate, params, false)\n : e.coordinate,\n });\n } catch (id) {\n window.cancelAnimationFrame(id);\n }\n }\n\n /**\n * On scroll event started\n */\n scroll(\n coordinate: number,\n dimension: DimensionType,\n force = false,\n delta?: number,\n outside = false,\n ) {\n // cancel all previous scrolls for same dimension\n this.cancelScroll(dimension);\n\n // drop if no change\n if (!force && this.previousScroll[dimension] === coordinate) {\n this.previousScroll[dimension] = NO_COORDINATE;\n return;\n }\n\n const param = this.getParams(dimension);\n // let component know about scroll event started\n this.cfg.runScroll({\n dimension: dimension,\n coordinate: param.virtualSize\n ? this.convert(coordinate, param)\n : coordinate,\n delta,\n outside,\n });\n }\n\n private getParams(dimension: DimensionType): Params {\n return this.params[dimension];\n }\n\n // check if scroll outside of region to avoid looping\n private wrapCoordinate(c: number, param: Params): number {\n if (c < 0) {\n return NO_COORDINATE;\n }\n\n if (typeof param.maxSize === 'number' && c > param.maxSize) {\n return param.maxSize;\n }\n return c;\n }\n\n // prevent already started scroll, performance optimization\n private cancelScroll(dimension: DimensionType) {\n this.preventArtificialScroll[dimension]?.();\n this.preventArtificialScroll[dimension] = null;\n }\n\n /* convert virtual to real and back, scale range */\n private convert(pos: number, param: Params, toReal = true): number {\n const minRange = param.clientSize;\n const from: [number, number] = [0, (param.virtualContentSize ?? minRange) - minRange];\n const to: [number, number] = [0, param.contentSize - param.virtualSize];\n if (toReal) {\n return scaleValue(pos, from, to);\n }\n return scaleValue(pos, to, from);\n }\n}\n","import type { DimensionType } from '@type';\n/**\n * Apply changes only if mousewheel event happened some time ago (scrollThrottling)\n */\nexport class LocalScrollTimer {\n /**\n * Last mw event time for trigger scroll function below\n * If mousewheel function was ignored we still need to trigger render\n */\n private mouseWheelScrollTimestamp: Record<DimensionType, number> = {\n rgCol: 0,\n rgRow: 0,\n };\n private lastKnownScrollCoordinate: Record<DimensionType, number> = {\n rgCol: 0,\n rgRow: 0,\n };\n\n constructor(private scrollThrottling = 10) {}\n\n setCoordinate(e: { dimension: DimensionType; coordinate: number }) {\n this.lastKnownScrollCoordinate[e.dimension] = e.coordinate;\n }\n\n /**\n * Remember last mw event time\n */\n latestScrollUpdate(dimension: DimensionType) {\n this.mouseWheelScrollTimestamp[dimension] = new Date().getTime();\n }\n\n /**\n * Check if scroll is ready to accept new value\n */\n isReady(type: DimensionType, coordinate: number) {\n const change = new Date().getTime() - this.mouseWheelScrollTimestamp[type];\n // apply after throttling\n return (\n change > this.scrollThrottling &&\n coordinate !== this.lastKnownScrollCoordinate[type]\n );\n }\n}\n","import debounce from './debounce.js';\nimport isObject from './isObject.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n}\n\nexport default throttle;\n"],"version":3}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by Revolist OU ❤️
|
|
3
|
+
*/
|
|
4
|
+
import{V as t,W as i,v as s,h as e,X as n,b as o,n as r,Y as c,Z as h,q as l,i as a}from"./index-b6586f9b.js";import{e as u,m as f,o as d,d as p,h as m}from"./column.service-407956dd.js";import{f as v}from"./row-header-utils-e043f744.js";import{h as g}from"./index-a61f225b.js";import{F as b,i as y}from"./filter.button-37373672.js";import{d as w}from"./debounce-7b511afc.js";import{d as O,O as j}from"./header-cell-renderer-da468bd2.js";const S=t=>{let i={};const s=(s,e)=>{const n=Object.assign({},s);i={};for(const[t,s]of Object.entries(e)){const e=t;if(s&&n[e]){i[e]=n[e];delete n[e]}}t.setDimensionSize(n)};return{set(e,n){switch(e){case"trimmed":const e=n;const o=t.store.get("sizes");s(Object.assign(Object.assign({},o),i),e);break}}}};const E=t=>({set(i){switch(i){case"count":case"sizes":case"originItemSize":let i=0;const s=t.store.get("count");for(let e=0;e<s;e++){i+=t.store.get("sizes")[e]||t.store.get("originItemSize")}t.setStore({realSize:i});break}}});function x(){return{indexes:[],count:0,trimmed:{},sizes:{},positionIndexToItem:{},indexToItem:{},positionIndexes:[]}}function C(){return Object.assign(Object.assign({},x()),{realSize:0,originItemSize:0})}class z{constructor(i){this.type=i;this.store=t(C());this.store.use(S(this));this.store.use(E(this))}getCurrentState(){const t=C();const s=Object.keys(t);return i(s,((t,i)=>{const s=this.store.get(i);t[i]=s;return t}),t)}dispose(){s(this.store,C())}setStore(t){s(this.store,t)}drop(){s(this.store,x())}setDimensionSize(t){const i=e(this.store.get("originItemSize"),t);s(this.store,i)}}const P=["rowPinStart","rgRow","rowPinEnd"];const k=["colPinStart","rgCol","colPinEnd"];function q(t){return P.indexOf(t)>-1}class I{constructor(t,i){this.revogrid=t;this.providers=i;this.h=g;this.subscriptions={}}addEventListener(t,i){this.revogrid.addEventListener(t,i);this.subscriptions[t]=i}watch(t,i,{immediate:s}={immediate:false}){const e=Object.getOwnPropertyDescriptor(this.revogrid,t)||Object.getOwnPropertyDescriptor(this.revogrid.constructor.prototype,t);Object.defineProperty(this.revogrid,t,{set(t){var s;const n=i(t);if(n===false){return}return(s=e===null||e===void 0?void 0:e.set)===null||s===void 0?void 0:s.call(this,t)},get(){var t;return(t=e===null||e===void 0?void 0:e.get)===null||t===void 0?void 0:t.call(this)}});if(s){i(e===null||e===void 0?void 0:e.value)}}removeEventListener(t){this.revogrid.removeEventListener(t,this.subscriptions[t]);delete this.subscriptions[t]}emit(t,i){const s=new CustomEvent(t,{detail:i,cancelable:true});this.revogrid.dispatchEvent(s);return s}clearSubscriptions(){for(let t in this.subscriptions){this.removeEventListener(t)}}destroy(){this.clearSubscriptions()}}const N=7;var F;(function(t){t["headerClickAutosize"]="headerClickAutoSize";t["autoSizeOnTextOverlap"]="autoSizeOnTextOverlap";t["autoSizeAll"]="autoSizeAll"})(F||(F={}));class M extends I{constructor(t,i,s){super(t,i);this.providers=i;this.config=s;this.autoSizeColumns=null;this.dataResolve=null;this.dataReject=null;this.letterBlockSize=(s===null||s===void 0?void 0:s.letterBlockSize)||N;if(s===null||s===void 0?void 0:s.preciseSize){this.precsizeCalculationArea=this.initiatePresizeElement();t.appendChild(this.precsizeCalculationArea)}const e=({detail:{source:t}})=>{this.setSource(t)};const n=({detail:t})=>{this.afteredit(t)};const o=({detail:t})=>{this.afterEditAll(t)};const r=({detail:{columns:t}})=>{this.columnSet(t)};const c=({detail:t})=>{const i=u(t.column);const s=this.getColumnSize(t.index,i);if(s){this.providers.dimension.setCustomSizes(i,{[t.index]:s},true)}};this.addEventListener("beforecolumnsset",r);switch(s===null||s===void 0?void 0:s.mode){case F.autoSizeOnTextOverlap:this.addEventListener("aftersourceset",e);this.addEventListener("afteredit",n);break;case F.autoSizeAll:this.addEventListener("aftersourceset",e);this.addEventListener("afteredit",o);break;default:this.addEventListener("headerdblclick",c);break}}async setSource(t){let i=this.autoSizeColumns;if(this.dataReject){this.dataReject();this.clearPromise()}if(!i){const t=new Promise(((t,i)=>{this.dataResolve=t;this.dataReject=i}));try{i=await t}catch(t){return}}n(i,((s,e)=>{const o={};n(i[e],(i=>{i.size=o[i.index]=t.reduce(((t,s)=>Math.max(t,this.getLength(s[i.prop]))),this.getLength(i.name||""))}));this.providers.dimension.setCustomSizes(e,o,true)}))}getLength(t){var i;const s=15;if(!t){return 0}try{const e=t.toString();if((i=this.config)===null||i===void 0?void 0:i.preciseSize){this.precsizeCalculationArea.innerText=e;return this.precsizeCalculationArea.scrollWidth+s*2}return e.length*this.letterBlockSize+s*2}catch(t){return 0}}afteredit(t){let s;if(this.isRangeEdit(t)){s=t.data}else{s={0:{[t.prop]:t.val}}}n(this.autoSizeColumns,((t,e)=>{const o={};n(t,(t=>{var e;const n=i(s,((i,s)=>{if(typeof s[t.prop]==="undefined"){return i}return Math.max(i||0,this.getLength(s[t.prop]))}),undefined);if(n&&((e=t.size)!==null&&e!==void 0?e:0)<n){t.size=o[t.index]=n}}));this.providers.dimension.setCustomSizes(e,o,true)}))}afterEditAll(t){const i={};if(this.isRangeEdit(t)){n(t.data,(t=>n(t,((t,s)=>i[s]=true))))}else{i[t.prop]=true}n(this.autoSizeColumns,((t,s)=>{const e={};n(t,(t=>{if(i[t.prop]){const i=this.getColumnSize(t.index,s);if(i){e[t.index]=i}}}));this.providers.dimension.setCustomSizes(s,e,true)}))}getColumnSize(t,s){var e,n;const r=(n=(e=this.autoSizeColumns)===null||e===void 0?void 0:e[s])===null||n===void 0?void 0:n[t];if(!r){return 0}return i(this.providers.data.stores,((t,s)=>{const e=i(s.store.get("items"),((t,i,e)=>{const n=o(s.store,e);return Math.max(t||0,this.getLength(n===null||n===void 0?void 0:n[r.prop]))}),0);return Math.max(t,e)}),r.size||0)}columnSet(t){var i;for(let s of k){const e=s;const n=t[e];for(let t in n){if(n[t].autoSize||((i=this.config)===null||i===void 0?void 0:i.allColumns)){if(!this.autoSizeColumns){this.autoSizeColumns={}}if(!this.autoSizeColumns[e]){this.autoSizeColumns[e]={}}this.autoSizeColumns[e][t]=Object.assign(Object.assign({},n[t]),{index:parseInt(t,10)})}}}if(this.dataResolve){this.dataResolve(this.autoSizeColumns||{});this.clearPromise()}}clearPromise(){this.dataResolve=null;this.dataReject=null}isRangeEdit(t){return!!t.data}initiatePresizeElement(){var t;const i={position:"absolute",fontSize:"14px",height:"0",width:"0",whiteSpace:"nowrap",top:"0",overflowX:"scroll"};const s=document.createElement("div");for(let e in i){s.style[e]=(t=i[e])!==null&&t!==void 0?t:""}s.classList.add("revo-test-container");return s}destroy(){var t;super.destroy();(t=this.precsizeCalculationArea)===null||t===void 0?void 0:t.remove()}}class D extends I{constructor(t,i){super(t,i);this.providers=i;this.stretchedColumn=null;this.scrollSize=r(document);const s=({detail:{columns:t}})=>this.applyStretch(t);this.addEventListener("beforecolumnapplied",s)}setScroll({type:t,hasScroll:i}){var s;if(t==="rgRow"&&this.stretchedColumn&&((s=this.stretchedColumn)===null||s===void 0?void 0:s.initialSize)===this.stretchedColumn.size){if(i){this.stretchedColumn.size-=this.scrollSize;this.apply();this.dropChanges()}}}activateChanges(){const t=({detail:t})=>this.setScroll(t);this.addEventListener("scrollchange",t)}dropChanges(){this.stretchedColumn=null;this.removeEventListener("scrollchange")}apply(){if(!this.stretchedColumn){return}const t="rgCol";const i=this.providers.dimension.stores[t].store.get("sizes");this.providers.dimension.setCustomSizes(t,Object.assign(Object.assign({},i),{[this.stretchedColumn.index]:this.stretchedColumn.size}),true)}applyStretch(t){this.dropChanges();let i=this.revogrid.clientWidth-1;n(t,((t,s)=>{const e=this.providers.dimension.stores[s].store.get("realSize");i-=e}));if(this.revogrid.rowHeaders){const t=this.providers.data.stores.rgRow.store.get("source").length;const s=this.revogrid.rowHeaders;const e=v(t,typeof s==="object"?s:undefined);if(e){i-=e}}if(i>0){const s=t.rgCol.length-1;const e=t.rgCol[s];const n=(e===null||e===void 0?void 0:e.size)||this.revogrid.colSize||0;const o=i+n-1;if(e&&!e.autoSize&&n<o){this.stretchedColumn={initialSize:o,index:s,size:o};this.apply();this.activateChanges()}}}}function $(t){return!!t.applyStretch}function R(t,i,s){if(t===t){if(s!==undefined){t=t<=s?t:s}if(i!==undefined){t=t>=i?t:i}}return t}var A=4294967295;function B(t){return t?R(c(t),0,A):0}function T(t,i,s,e){var n=t.length;s=c(s);if(s<0){s=-s>n?0:n+s}e=e===undefined||e>n?n:c(e);if(e<0){e+=n}e=s>e?0:B(e);while(s<e){t[s++]=i}return t}function J(t,i,s,e){var n=t==null?0:t.length;if(!n){return[]}if(s&&typeof s!="number"&&h(t,i,s)){s=0;e=n}return T(t,i,s,e)}const H={mime:"text/csv",fileKind:"csv",bom:true,columnDelimiter:",",rowDelimiter:"\r\n",encoding:""};const L=String.fromCharCode(13);const X=String.fromCharCode(10);const G=String.fromCharCode(34);const K=String.fromCharCode(65279);const U=new RegExp('"',"g");class V{constructor(t={}){this.options=Object.assign(Object.assign({},H),t)}doExport({data:t,headers:i,props:s}){let e=this.options.bom?K:"";if((i===null||i===void 0?void 0:i.length)>0){i.forEach((t=>{if(!t.length){return}e+=this.prepareHeader(t,this.options.columnDelimiter);e+=this.options.rowDelimiter}))}t.forEach(((t,i)=>{if(i>0){e+=this.options.rowDelimiter}if(f(t)){e+=this.parseCell(d(t),this.options.columnDelimiter);return}e+=s.map((i=>this.parseCell(t[i],this.options.columnDelimiter))).join(this.options.columnDelimiter)}));return e}prepareHeader(t,i){let s="";const e=t.map((t=>this.parseCell(t,i,true)));s+=e.join(i);return s}parseCell(t,i,s=false){let e=t;if(typeof t!=="string"){e=JSON.stringify(t)}const n=[L,G,X,i];if(typeof e==="undefined"){return""}if(e!==""&&(s||n.some((t=>e.indexOf(t)>=0)))){return`"${e.replace(U,'""')}"`}return e}}var W;(function(t){t["csv"]="csv"})(W||(W={}));class Y extends I{async exportString(t={},i=W.csv){const s=await this.beforeexport();if(!s){return null}return this.formatter(i,t).doExport(s)}async exportBlob(t={},i=W.csv){return await this.getBlob(this.formatter(i,t))}async exportFile(t={},i=W.csv){const s=this.formatter(i,t);const e=window.URL||window.webkitURL;const n=document.createElement("a");const{filename:o,fileKind:r}=s.options;const c=`${o}.${r}`;const h=await this.getBlob(s);const a=h?e.createObjectURL(h):"";n.style.display="none";n.setAttribute("href",a);n.setAttribute("download",c);this.revogrid.appendChild(n);n.dispatchEvent(new MouseEvent("click"));this.revogrid.removeChild(n);await l(120);e.revokeObjectURL(a)}async getBlob(t){const i=`${t.options.mime};charset=${t.options.encoding}`;if(typeof Blob!=="undefined"){const s=await this.beforeexport();if(!s){return null}return new Blob([t.doExport(s)],{type:i})}return null}async beforeexport(){let t=await this.getData();const i=this.emit("beforeexport",{data:t});if(i.defaultPrevented){return null}return i.detail.data}async getData(){const t=await this.getSource();const i=[];const s=[];k.forEach(((t,e)=>{s.push(this.getColPerSource(t).then((t=>i[e]=t)))}));await Promise.all(s);const e={headers:[],props:[]};for(let t of i){t.headers.forEach(((t,i)=>{if(!e.headers[i]){e.headers[i]=[]}e.headers[i].push(...t)}));e.props.push(...t.props)}return Object.assign({data:t},e)}async getColPerSource(t){const i=await this.revogrid.getColumnStore(t);const s=i.get("source");const e=i.get("items");const n=i.get("groupingDepth");const o=i.get("groups");const r=[];const c=[];const h=e.reduce(((t,i,e)=>{const n=s[i].prop;r.push(s[i].name||"");c.push(n);t[n]=e;return t}),{});const l=this.getGroupHeaders(n,o,e,h);l.push(r);return{headers:l,props:c}}getGroupHeaders(t,i,s,e){const n=[];const o=J(new Array(s.length),"");for(let s=0;s<t;s++){const t=[...o];n.push(t);if(!i[s]){continue}const r=i[s];r.forEach((i=>{const s=this.findGroupStartIndex(i.ids,e);if(typeof s==="number"){t[s]=i.name}}))}return n}findGroupStartIndex(t,i){let s;t.forEach((t=>{const e=i[t];if(typeof e==="number"){if(typeof s!=="number"||s>e){s=e}}}));return s}async getSource(){const t=[];const i=[];P.forEach((s=>{const e=[];t.push(e);const n=this.revogrid.getVisibleSource(s).then((t=>e.push(...t)));i.push(n)}));await Promise.all(i);return t.reduce(((t,i)=>{t.push(...i);return t}),[])}formatter(t,i={}){switch(t){case W.csv:return new V(i);default:throw new Error("Unknown format")}}}const Z=(t,i)=>{if(typeof t==="undefined"||t===null&&!i){return true}if(typeof t!=="string"){t=JSON.stringify(t)}const s=i===null||i===void 0?void 0:i.toString().toLocaleLowerCase();if((s===null||s===void 0?void 0:s.length)===0){return true}return t.toLocaleLowerCase()===s};const Q=(t,i)=>!Z(t,i);Q.extra="input";Z.extra="input";const _=function(t,i){let s;if(typeof t==="number"&&typeof i!=="undefined"&&i!==null){s=parseFloat(i===null||i===void 0?void 0:i.toString());return t>s}return false};_.extra="input";const tt=function(t,i){return Z(t,i)||_(t,i)};tt.extra="input";const it=function(t,i){let s;if(typeof t==="number"&&typeof i!=="undefined"&&i!==null){s=parseFloat(i.toString());return t<s}else{return false}};it.extra="input";const st=function(t,i){return Z(t,i)||it(t,i)};st.extra="input";const et=t=>!(t===""||t===null||t===void 0);const nt=t=>!et(t);const ot=(t,i)=>{if(!t){return false}if(!i){return true}if(typeof t!=="string"){t=JSON.stringify(t)}if(typeof i!=="string"){i=JSON.stringify(i)}return t.toLocaleLowerCase().indexOf(i.toLocaleLowerCase())===0};ot.extra="input";const rt=(t,i)=>{if(!i){return true}if(!t){return false}if(i){if(typeof t!=="string"){t=JSON.stringify(t)}return t.toLocaleLowerCase().indexOf(i.toString().toLowerCase())>-1}return true};const ct=(t,i)=>!rt(t,i);ct.extra="input";rt.extra="input";const ht={none:()=>true,empty:nt,notEmpty:et,eq:Z,notEq:Q,begins:ot,contains:rt,notContains:ct,eqN:Z,neqN:Q,gt:_,gte:tt,lt:it,lte:st};const lt={string:["notEmpty","empty","eq","notEq","begins","contains","notContains"],number:["notEmpty","empty","eqN","neqN","gt","gte","lt","lte"]};const at={none:"None",empty:"Not set",notEmpty:"Set",eq:"Equal",notEq:"Not equal",begins:"Begins with",contains:"Contains",notContains:"Does not contain",eqN:"=",neqN:"!=",gt:">",gte:">=",lt:"<",lte:"<="};const ut="filter";const ft="filterconfigchanged";class dt extends I{constructor(t,i,s){var e;super(t,i);this.revogrid=t;this.filterCollection={};this.multiFilterItems={};this.filterByType=Object.assign({},lt);this.filterNameIndexByType=Object.assign({},at);this.filterFunctionsIndexedByType=Object.assign({},ht);this.filterProp=b;if(s){this.initConfig(s)}const n=async()=>{const t=Object.keys(this.filterCollection);if(t.length>0){t.forEach(((t,i)=>{if(!this.multiFilterItems[t]){this.multiFilterItems[t]=[{id:i,type:this.filterCollection[t].type,value:this.filterCollection[t].value,relation:"and"}]}}))}await this.runFiltering()};this.addEventListener("headerclick",(t=>this.headerclick(t)));this.addEventListener(ft,(({detail:t})=>{if(!t){this.clearFiltering();return}if(typeof t==="object"){this.initConfig(t)}n()}));this.addEventListener("aftersourceset",n);this.addEventListener("filter",(({detail:t})=>this.onFilterChange(t)));const o=this.revogrid.registerVNode.filter((t=>t.t!=="revogr-filter-panel"));this.revogrid.registerVNode=[...o,g("revogr-filter-panel",{filterItems:this.multiFilterItems,filterNames:this.filterNameIndexByType,filterEntities:this.filterFunctionsIndexedByType,filterCaptions:(e=s===null||s===void 0?void 0:s.localization)===null||e===void 0?void 0:e.captions,onFilterChange:t=>this.onFilterChange(t.detail),disableDynamicFiltering:s===null||s===void 0?void 0:s.disableDynamicFiltering,ref:t=>this.pop=t})]}initConfig(t){if(t.multiFilterItems){this.multiFilterItems=Object.assign({},t.multiFilterItems)}if(t.customFilters){for(let i in t.customFilters){const s=t.customFilters[i];if(!this.filterByType[s.columnFilterType]){this.filterByType[s.columnFilterType]=[]}this.filterByType[s.columnFilterType].push(i);this.filterFunctionsIndexedByType[i]=s.func;this.filterNameIndexByType[i]=s.name}}if(t.filterProp){this.filterProp=t.filterProp}const s=t.include;if(s){const t={};for(let i in this.filterByType){const e=this.filterByType[i].filter((t=>s.indexOf(t)>-1));if(e.length){t[i]=e}}if(Object.keys(t).length>0){this.filterByType=t}}if(t.collection){this.filterCollection=i(t.collection,((t,i,s)=>{if(this.filterFunctionsIndexedByType[i.type]){t[s]=i}else{console.warn(`${i.type} type is not found.`)}return t}),{})}if(t.localization){if(t.localization.filterNames){Object.entries(t.localization.filterNames).forEach((([t,i])=>{if(this.filterNameIndexByType[t]!=void 0){this.filterNameIndexByType[t]=i}}))}}}async headerclick(t){var i,s,e;const n=(i=t.detail.originalEvent)===null||i===void 0?void 0:i.target;if(!y(n)){return}t.preventDefault();const o=await((s=this.pop)===null||s===void 0?void 0:s.getChanges());if(o&&(o===null||o===void 0?void 0:o.prop)===t.detail.prop){(e=this.pop)===null||e===void 0?void 0:e.show();return}if(!this.pop){return}const r=this.revogrid.getBoundingClientRect();const c=n.getBoundingClientRect();const h=t.detail.prop;this.pop.show(Object.assign(Object.assign({},this.filterCollection[h]),{x:c.x-r.x,y:c.y-r.y+c.height,autoCorrect:true,prop:h,filterTypes:this.getColumnFilter(t.detail.filter)}))}getColumnFilter(t){let i="string";if(!t){return{[i]:this.filterByType[i]}}if(this.isValidType(t)){i=t}else if(typeof t==="object"&&t.length){return t.reduce(((t,i)=>{if(this.isValidType(i)){t[i]=this.filterByType[i]}return t}),{})}return{[i]:this.filterByType[i]}}isValidType(t){return!!(typeof t==="string"&&this.filterByType[t])}async onFilterChange(t){this.multiFilterItems=t;this.runFiltering()}async doFiltering(t,i,s,e){const n=[];const o={};s.forEach((t=>{const i=Object.assign({},t);const s=e[i.prop];o[i.prop]=i;if(i[this.filterProp]&&!s){delete i[this.filterProp];n.push(i)}if(!i[this.filterProp]&&s){n.push(i);i[this.filterProp]=true}}));const r=this.getRowFilter(i,e,o);const{defaultPrevented:c,detail:h}=this.emit("beforefiltertrimmed",{collection:t,itemsToFilter:r,source:i,filterItems:e});if(c){return}const l=await this.revogrid.addTrimmed(h.itemsToFilter,ut);if(l.defaultPrevented){return}this.providers.column.updateColumns(n);this.emit("afterfilterapply")}async clearFiltering(){this.multiFilterItems={};await this.runFiltering()}async runFiltering(){const t={};const i=Object.keys(this.multiFilterItems);for(const s of i){if(this.multiFilterItems[s].length>0){const i=this.multiFilterItems[s][0];t[s]={filter:this.filterFunctionsIndexedByType[i.type],type:i.type,value:i.value}}}this.filterCollection=t;const{source:s,columns:e}=await this.getData();const{defaultPrevented:n,detail:o}=this.emit("beforefilterapply",{collection:this.filterCollection,source:s,columns:e,filterItems:this.multiFilterItems});if(n){return}this.doFiltering(o.collection,o.source,o.columns,o.filterItems)}async getData(){return{source:await this.revogrid.getSource(),columns:await this.revogrid.getColumns()}}getRowFilter(t,i,s){const e=Object.keys(i);const n={};let o=0;let r=[];t.forEach(((t,c)=>{for(const h of e){const e=i[h];o=0;r=[];for(const[i,n]of e.entries()){const c=this.filterFunctionsIndexedByType[n.type];const l=s[h];const a=l?p(t,s[h]):t[h];if(n.relation==="or"){r=[];if(c(a,n.value)){continue}o++}else{r.push(!c(a,n.value));const t=e[i+1];if(!t||t.relation!=="and"){if(r.indexOf(true)===-1){r=[];continue}o+=r.length;r=[]}}}if(o===e.length){n[c]=true}}}));return n}}const pt="column-drag-start";class mt{constructor(){this.offset=0}renderAutoscroll(t,i){if(!i){return}this.autoscrollEl=document.createElement("div");this.autoscrollEl.classList.add("drag-auto-scroll-y");i.appendChild(this.autoscrollEl)}autoscroll(t,i,s="translateX"){if(!this.autoscrollEl){return}const e=10;const n=Math.min(t+e,i-3);this.autoscrollEl.style.transform=`${s}(${n}px)`;this.autoscrollEl.scrollIntoView({block:"nearest",inline:"nearest"})}start(t,{dataEl:i,gridRect:s,scrollEl:e,gridEl:n},o="left"){n.classList.add(pt);const r=e.getBoundingClientRect();if(r){this.offset=r[o]-s[o]}this.renderAutoscroll(t,i)}stop(t){var i;t.classList.remove(pt);if(this.element){this.element.hidden=true}this.offset=0;(i=this.autoscrollEl)===null||i===void 0?void 0:i.remove();this.autoscrollEl=undefined}showHandler(t,i,s="translateX"){if(!this.element){return}if(this.offset){t=Math.max(t,this.offset)}t=Math.min(t,i);this.element.style.transform=`${s}(${t}px)`;this.element.hidden=false}render(){const t=this.element=document.createElement("div");t.classList.add("drag-position-y");t.hidden=true;return t}}const vt=j;const gt="columndragmousemove";const bt="columndragend";const yt="beforecolumndragend";const wt="columndragstart";class Ot extends I{constructor(t,i){super(t,i);this.revogrid=t;this.providers=i;this.moveFunc=w((t=>this.doMove(t)),5);this.staticDragData=null;this.dragData=null;this.localSubscriptions={};this.orderUi=new mt;t.appendChild(this.orderUi.render());t.classList.add("column-draggable");this.localSubscriptions["mouseleave"]={target:document,callback:t=>this.onMouseOut(t)};this.localSubscriptions["mouseup"]={target:document,callback:t=>this.onMouseUp(t)};this.localSubscriptions["mousemove"]={target:document,callback:t=>this.move(t)};this.addEventListener(vt,(({detail:t})=>this.dragStart(t)))}dragStart({event:t,data:i}){if(t.defaultPrevented){return}const{defaultPrevented:s}=O(this.revogrid,wt,i);if(s){return}this.clearOrder();const{mouseleave:e,mouseup:n,mousemove:o}=this.localSubscriptions;e.target.addEventListener("mouseleave",e.callback);n.target.addEventListener("mouseup",n.callback);const r=t.target.closest("revogr-header");const c=t.target.closest("revogr-viewport-scroll");if(!r||!c){return}if(m(i)||i.providers.type==="rowHeaders"){return}const h=this.getDimension(i.pin||"rgCol");const l=this.revogrid.getBoundingClientRect();const u=r.getBoundingClientRect();const f=a(h,jt(t.x,l.left,u.left-l.left));this.staticDragData={startPos:t.x,startItem:f,data:i,dataEl:r,scrollEl:c,gridEl:this.revogrid,cols:h};this.dragData=this.getData(this.staticDragData);o.target.addEventListener("mousemove",o.callback);this.orderUi.start(t,Object.assign(Object.assign({},this.dragData),this.staticDragData))}doMove(t){if(!this.staticDragData){return}const i=this.dragData=this.getData(this.staticDragData);if(!i){return}const s=this.staticDragData.startPos;if(Math.abs(s-t.x)>10){const s=jt(t.x,this.dragData.gridRect.left,this.dragData.scrollOffset);const e=a(this.staticDragData.cols,s);this.orderUi.autoscroll(s,i.elRect.width);this.orderUi.showHandler(e.end+i.scrollOffset,i.gridRect.width)}}move(t){O(this.revogrid,gt,t);this.moveFunc(t)}onMouseOut(t){this.clearOrder()}onMouseUp(t){if(this.dragData&&this.staticDragData){let i=jt(t.x,this.dragData.gridRect.left,this.dragData.scrollOffset);if(i<0){i=0}const s=a(this.staticDragData.cols,i);const e=this.providers.column.stores[this.dragData.type].store;const n=[...e.get("items")];const{defaultPrevented:o}=O(this.revogrid,yt,Object.assign(Object.assign({},this.staticDragData),{startPosition:this.staticDragData.startItem,newPosition:s,newItem:e.get("source")[n[this.staticDragData.startItem.itemIndex]]}));if(!o){const t=n.splice(this.staticDragData.startItem.itemIndex,1);n.splice(s.itemIndex,0,...t);e.set("items",n)}O(this.revogrid,bt,this.dragData)}this.clearOrder()}clearLocalSubscriptions(){n(this.localSubscriptions,(({target:t,callback:i},s)=>t.removeEventListener(s,i)))}clearOrder(){this.staticDragData=null;this.dragData=null;this.clearLocalSubscriptions();this.orderUi.stop(this.revogrid)}clearSubscriptions(){super.clearSubscriptions();this.clearLocalSubscriptions()}getData({gridEl:t,dataEl:i,data:s}){const e=t.getBoundingClientRect();const n=i.getBoundingClientRect();const o=n.left-e.left;return{elRect:n,gridRect:e,type:s.pin||"rgCol",scrollOffset:o}}getDimension(t){return this.providers.dimension.stores[t].getCurrentState()}}function jt(t,i,s){return t-i-s}export{M as A,I as B,Ot as C,z as D,Y as E,ut as F,D as S,$ as a,ft as b,k as c,dt as d,jt as g,q as i,P as r};
|
|
5
|
+
//# sourceMappingURL=column.drag.plugin-cb25a5e1.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["trimmedPlugin","store","trimmedSize","setTrimmed","sizes","trimmed","newSize","Object","assign","index","v","entries","i","setDimensionSize","set","key","val","trim","get","recalculateRealSizePlugin","storeService","k","realSize","count","setStore","initialBase","indexes","positionIndexToItem","indexToItem","positionIndexes","initialState","originItemSize","DimensionStore","constructor","type","this","createStore","use","getCurrentState","state","keys","reduce","r","data","dispose","drop","dimensionData","calculateDimensionData","rowTypes","columnTypes","isRowType","indexOf","BasePlugin","revogrid","providers","h","subscriptions","addEventListener","eventName","callback","watch","prop","immediate","nativeValueDesc","getOwnPropertyDescriptor","prototype","defineProperty","keepDefault","_a","call","value","removeEventListener","emit","detail","event","CustomEvent","cancelable","dispatchEvent","clearSubscriptions","destroy","LETTER_BLOCK_SIZE","ColumnAutoSizeMode","AutoSizeColumnPlugin","config","super","autoSizeColumns","dataResolve","dataReject","letterBlockSize","preciseSize","precsizeCalculationArea","initiatePresizeElement","appendChild","aftersourceset","source","setSource","afteredit","afterEditAll","beforecolumnsset","columns","columnSet","headerDblClick","getColumnType","column","size","getColumnSize","dimension","setCustomSizes","mode","autoSizeOnTextOverlap","autoSizeAll","autoSize","clearPromise","request","Promise","resolve","reject","e","each","_v","rgCol","prev","rgRow","Math","max","getLength","name","len","padding","str","toString","innerText","scrollWidth","length","isRangeEdit","undefined","props","p","_b","stores","s","perStore","_row","item","getSourceItem","t","cols","allColumns","parseInt","styleForFontTest","position","fontSize","height","width","whiteSpace","top","overflowX","el","document","createElement","style","classList","add","remove","StretchColumn","stretchedColumn","scrollSize","getScrollbarSize","beforecolumnapplied","applyStretch","setScroll","hasScroll","initialSize","apply","dropChanges","activateChanges","sizeDifference","clientWidth","_","rowHeaders","itemsLength","header","rowHeaderSize","calculateRowHeaderSize","last","colSize","isStretchPlugin","plugin","baseClamp","number","lower","upper","MAX_ARRAY_LENGTH","toLength","toInteger","baseFill","array","start","end","fill","isIterateeCall","INITIAL","mime","fileKind","bom","columnDelimiter","rowDelimiter","encoding","CARRIAGE_RETURN","String","fromCharCode","LINE_FEED","DOUBLE_QT","NO_BREAK_SPACE","escapeRegex","RegExp","ExportCsv","options","doExport","headers","result","forEach","prepareHeader","isGrouping","parseCell","getGroupingName","map","join","columnHeaders","newColumnHeaders","force","escape","JSON","stringify","toEscape","some","replace","ExportTypes","ExportFilePlugin","exportString","csv","beforeexport","formatter","exportBlob","getBlob","exportFile","URL","window","webkitURL","a","filename","blob","url","createObjectURL","display","setAttribute","MouseEvent","removeChild","timeout","revokeObjectURL","Blob","getData","defaultPrevented","getSource","colSource","colPromises","push","getColPerSource","then","all","getColumnStore","virtualIndexes","depth","groups","colNames","colProps","visibleItems","virtualIndex","rows","getGroupHeaders","items","template","Array","d","levelGroups","group","minIndex","findGroupStartIndex","ids","min","id","current","promisesData","dataPart","promise","getVisibleSource","Error","eq","extra","filterVal","toLocaleLowerCase","notEq","gtThan","conditionValue","parseFloat","gtThanEq","gt","lt","lsEq","notSet","beginsWith","contains","toLowerCase","notContains","filterCoreFunctionsIndexedByType","none","empty","notEmpty","begins","eqN","neqN","gte","lte","filterTypes","string","filterNames","FILTER_TRIMMED_TYPE","FILTER_CONFIG_CHANGED_EVENT","FilterPlugin","filterCollection","multiFilterItems","filterByType","filterNameIndexByType","filterFunctionsIndexedByType","filterProp","FILTER_PROP","initConfig","async","filterCollectionProps","relation","runFiltering","headerclick","clearFiltering","onFilterChange","existingNodes","registerVNode","filter","n","$tag$","filterItems","filterEntities","filterCaptions","localization","captions","disableDynamicFiltering","ref","pop","customFilters","customFilterType","cFilter","columnFilterType","func","cfgInlcude","include","filters","newTypes","f","collection","console","warn","originalEvent","target","isFilterBtn","preventDefault","changes","getChanges","_c","show","gridPos","getBoundingClientRect","buttonPos","x","y","autoCorrect","getColumnFilter","filterType","isValidType","multiType","doFiltering","columnsToUpdate","columnByProp","hasFilter","itemsToTrim","getRowFilter","itemsToFilter","isAddedEvent","addTrimmed","updateColumns","filterProps","firstFilterItem","getColumns","propKeys","propFilterSatisfiedCount","lastFilterResults","model","rowIndex","propFilters","filterIndex","filterData","filterFunc","getCellDataParsed","nextFilterData","COLUMN_DRAG_CLASS","ColumnOrderHandler","offset","renderAutoscroll","parent","autoscrollEl","autoscroll","pos","dataContainerSize","direction","helperOffset","maxScroll","transform","scrollIntoView","block","inline","dataEl","gridRect","scrollEl","gridEl","dir","scrollContainerRect","stop","element","hidden","showHandler","render","COLUMN_CLICK","ON_COLUMN_CLICK","MOVE","DRAG_END","BEFORE_DRAG_END","DRAG_START","ColumnPlugin","moveFunc","debounce","doMove","staticDragData","dragData","localSubscriptions","orderUi","onMouseOut","onMouseUp","move","dragStart","dispatch","clearOrder","mouseleave","mouseup","mousemove","closest","isColGrouping","getDimension","pin","elRect","startItem","getItemByPosition","getLeftRelative","left","startPos","abs","scrollOffset","relativePos","newPosition","stopDrag","startPosition","newItem","itemIndex","toMove","splice","clearLocalSubscriptions","absoluteX"],"sources":["src/store/dimension/dimension.store.ts","src/store/index.ts","src/plugins/base.plugin.ts","src/plugins/column.auto-size.plugin.ts","src/plugins/column.stretch.plugin.ts","node_modules/lodash/_baseClamp.js","node_modules/lodash/toLength.js","node_modules/lodash/_baseFill.js","node_modules/lodash/fill.js","src/plugins/export/csv.ts","src/plugins/export/export.plugin.ts","src/plugins/filter/conditions/equal.ts","src/plugins/filter/conditions/number/greaterThan.ts","src/plugins/filter/conditions/number/greaterThanOrEqual.ts","src/plugins/filter/conditions/number/lessThan.ts","src/plugins/filter/conditions/number/lessThanOrEqual.ts","src/plugins/filter/conditions/set.ts","src/plugins/filter/conditions/string/beginswith.ts","src/plugins/filter/conditions/string/contains.ts","src/plugins/filter/filter.indexed.ts","src/plugins/filter/filter.plugin.tsx","src/plugins/moveColumn/order-column.handler.tsx","src/plugins/moveColumn/column.drag.plugin.ts"],"sourcesContent":["/**\n * Storing pre-calculated\n * Dimension information and sizes\n */\nimport reduce from 'lodash/reduce';\nimport { createStore } from '@stencil/store';\n\nimport { setStore, Observable, PluginSubscribe } from '../../utils/store.utils';\nimport { calculateDimensionData } from './dimension.helpers';\nimport {\n DimensionCalc,\n DimensionSettingsState,\n ViewSettingSizeProp,\n MultiDimensionType,\n} from '@type';\n\nexport type DimensionStoreCollection = {\n [T in MultiDimensionType]: DimensionStore;\n};\n\ntype Item = keyof DimensionSettingsState;\n\nconst trimmedPlugin = (\n store: DimensionStore,\n): PluginSubscribe<DimensionSettingsState> => {\n let trimmedSize: DimensionSettingsState['sizes'] = {};\n\n const setTrimmed = (\n sizes: DimensionSettingsState['sizes'],\n trimmed: DimensionSettingsState['trimmed'],\n ) => {\n const newSize: DimensionSettingsState['sizes'] = { ...sizes };\n trimmedSize = {};\n for (const [index, v] of Object.entries(trimmed)) {\n const i = index as keyof DimensionSettingsState['sizes'];\n if (v && newSize[i]) {\n trimmedSize[i] = newSize[i];\n delete newSize[i];\n }\n }\n store.setDimensionSize(newSize);\n };\n return {\n set(key, val) {\n switch (key) {\n case 'trimmed':\n const trim = val as DimensionSettingsState['trimmed'];\n const sizes = store.store.get('sizes');\n // recover trimmed, apply new trim\n setTrimmed({ ...sizes, ...trimmedSize }, trim);\n break;\n }\n },\n };\n};\n\n/**\n * Plugin which recalculates realSize on changes of sizes, originItemSize and count\n */\nconst recalculateRealSizePlugin = (\n storeService: DimensionStore,\n): PluginSubscribe<DimensionSettingsState> => {\n /**\n * Recalculates realSize if size, origin size or count changes\n */\n return {\n /**\n * Reacts on changes of count, sizes and originItemSize\n */\n set(k) {\n switch (k) {\n case 'count':\n case 'sizes':\n case 'originItemSize':\n // recalculate realSize\n let realSize = 0;\n const count = storeService.store.get('count');\n for (let i = 0; i < count; i++) {\n realSize +=\n storeService.store.get('sizes')[i] ||\n storeService.store.get('originItemSize');\n }\n storeService.setStore({ realSize });\n break;\n }\n },\n };\n};\n\nfunction initialBase(): DimensionCalc {\n return {\n indexes: [],\n count: 0,\n\n // plugin support\n trimmed: {},\n\n // size operations, this provider stores only changed sizes, not all of them\n // same as indexes but for sizes and positions\n // item index to size\n sizes: {},\n // order in indexes[] to coordinate\n positionIndexToItem: {},\n // initial element to coordinate ^\n indexToItem: {},\n positionIndexes: [],\n };\n}\n\nfunction initialState(): DimensionSettingsState {\n return {\n ...initialBase(),\n // size which all items can take\n realSize: 0,\n\n // initial item size if it wasn't changed\n originItemSize: 0,\n };\n}\n\nexport class DimensionStore {\n readonly store: Observable<DimensionSettingsState>;\n constructor(public readonly type: MultiDimensionType) {\n this.store = createStore(initialState());\n this.store.use(trimmedPlugin(this));\n this.store.use(recalculateRealSizePlugin(this));\n }\n\n getCurrentState(): DimensionSettingsState {\n const state = initialState();\n const keys = Object.keys(state);\n return reduce(\n keys,\n (r: DimensionSettingsState, k: Item) => {\n const data = this.store.get(k);\n r[k] = data as never;\n return r;\n },\n state,\n );\n }\n\n dispose() {\n setStore(this.store, initialState());\n }\n\n setStore<T extends Record<string, any>>(data: Partial<T>) {\n setStore(this.store, data);\n }\n\n drop() {\n setStore(this.store, initialBase());\n }\n\n /**\n * Set custom dimension sizes and overwrite old\n * Generates new indexes based on sizes\n * @param sizes - sizes to set\n */\n setDimensionSize(sizes: ViewSettingSizeProp) {\n const dimensionData = calculateDimensionData(\n this.store.get('originItemSize'),\n sizes,\n );\n setStore(this.store, dimensionData);\n }\n}\n","import type { DimensionCols, DimensionRows } from '@type';\n\nexport * from './dataSource';\nexport * from './dimension';\nexport * from './selection';\nexport * from './vp';\n\nexport const rowTypes: DimensionRows[] = ['rowPinStart', 'rgRow', 'rowPinEnd'];\nexport const columnTypes: DimensionCols[] = [\n 'colPinStart',\n 'rgCol',\n 'colPinEnd',\n];\n\nexport function isRowType(type: DimensionRows | any): type is DimensionRows {\n return rowTypes.indexOf(type) > -1;\n}\n","import { h } from '@stencil/core';\nimport { PluginProviders, PluginBaseComponent } from '..';\n\ntype WatchConfig = { immediate: boolean };\n\n/**\n * Base layer for plugins\n * Provide minimal starting core for plugins to work\n * Extend this class to create plugin\n */\nexport class BasePlugin implements PluginBaseComponent {\n readonly h = h;\n readonly subscriptions: Record<string, (...args: any[]) => void> = {};\n constructor(public revogrid: HTMLRevoGridElement, public providers: PluginProviders) {}\n /**\n *\n * @param eventName - event name to subscribe to in revo-grid component (e.g. 'beforeheaderclick')\n * @param callback - callback function for event\n */\n addEventListener<T = any>(\n eventName: string,\n callback: (e: CustomEvent<T>) => void,\n ) {\n this.revogrid.addEventListener(eventName, callback);\n this.subscriptions[eventName] = callback;\n }\n\n /**\n * Subscribe to property change in revo-grid component\n * You can return false in callback to prevent default value set\n *\n * @param prop - property name\n * @param callback - callback function\n * @param immediate - trigger callback immediately with current value\n */\n watch<T extends any>(\n prop: string,\n callback: (arg: T) => boolean | void,\n { immediate }: Partial<WatchConfig> = { immediate: false },\n ) {\n const nativeValueDesc =\n Object.getOwnPropertyDescriptor(this.revogrid, prop) ||\n Object.getOwnPropertyDescriptor(this.revogrid.constructor.prototype, prop);\n\n // Overwrite property descriptor for this instance\n Object.defineProperty(this.revogrid, prop, {\n set(val: T) {\n const keepDefault = callback(val);\n if (keepDefault === false) {\n return;\n }\n // Continue with native behavior\n return nativeValueDesc?.set?.call(this, val);\n },\n get() {\n // Continue with native behavior\n return nativeValueDesc?.get?.call(this);\n },\n });\n if (immediate) {\n callback(nativeValueDesc?.value);\n }\n }\n\n /**\n * Remove event listener\n * @param eventName\n */\n removeEventListener(eventName: string) {\n this.revogrid.removeEventListener(eventName, this.subscriptions[eventName]);\n delete this.subscriptions[eventName];\n }\n\n /**\n * Emit event from revo-grid component\n * Event can be cancelled by calling event.preventDefault() in callback\n */\n emit<T = any>(eventName: string, detail?: T) {\n const event = new CustomEvent<T>(eventName, { detail, cancelable: true });\n this.revogrid.dispatchEvent(event);\n return event;\n }\n\n /**\n * Clear all subscriptions\n */\n clearSubscriptions() {\n for (let type in this.subscriptions) {\n this.removeEventListener(type);\n }\n }\n\n /**\n * Destroy plugin and clear all subscriptions\n */\n destroy() {\n this.clearSubscriptions();\n }\n}\n\nexport type GridPlugin = (typeof BasePlugin);\n","/**\n * Plugin module for revo-grid grid system\n * Add support for automatic column resize\n */\nimport each from 'lodash/each';\nimport reduce from 'lodash/reduce';\n\nimport { BasePlugin } from './base.plugin';\nimport { getSourceItem, columnTypes } from '@store';\nimport {\n DimensionCols,\n DimensionRows,\n ColumnRegular,\n DataType,\n InitialHeaderClick,\n ViewSettingSizeProp,\n BeforeSaveDataDetails,\n BeforeRangeSaveDataDetails,\n PluginProviders,\n} from '@type';\nimport { ColumnCollection, getColumnType } from '../utils/column.utils';\n\ninterface Column extends ColumnRegular {\n index: number;\n}\n\ntype AutoSizeColumns = Record<DimensionCols, ColumnRecords>;\ntype ColumnRecords = Record<any, Column>;\ntype SourceSetEvent = { type: DimensionRows; source: DataType[] };\ntype EditEvent = BeforeSaveDataDetails | BeforeRangeSaveDataDetails;\ntype Resolve = (cols: Partial<AutoSizeColumns>) => void;\ntype Reject = () => void;\n\nexport type AutoSizeColumnConfig = {\n // ui behavior mode\n mode?: ColumnAutoSizeMode;\n /**\n * autoSize for all columns\n * if allColumnes true all columns treated as autoSize, worse for performance\n * false by default\n */\n allColumns?: boolean;\n /**\n * assumption per characted size\n * by default defined as 8, can be changed in this config\n */\n letterBlockSize?: number;\n /** make size calculation exact\n * by default it based on assumption each character takes some space defined in letterBlockSize */\n preciseSize?: boolean;\n};\n\nconst LETTER_BLOCK_SIZE = 7;\n\nenum ColumnAutoSizeMode {\n // increases column width on header click according the largest text value\n headerClickAutosize = 'headerClickAutoSize',\n // increases column width on data set and text edit, decreases performance\n autoSizeOnTextOverlap = 'autoSizeOnTextOverlap',\n // increases and decreases column width based on all items sizes, worst for performance\n autoSizeAll = 'autoSizeAll',\n}\n\nexport default class AutoSizeColumnPlugin extends BasePlugin {\n autoSizeColumns: Partial<AutoSizeColumns> | null = null;\n readonly letterBlockSize: number;\n\n /** for config option when @preciseSize enabled */\n readonly precsizeCalculationArea: HTMLElement;\n\n /** for edge case when no columns defined before data */\n dataResolve: Resolve | null = null;\n dataReject: Reject | null = null;\n\n constructor(\n revogrid: HTMLRevoGridElement,\n public providers: PluginProviders,\n public config?: AutoSizeColumnConfig,\n ) {\n super(revogrid, providers);\n this.letterBlockSize = config?.letterBlockSize || LETTER_BLOCK_SIZE;\n\n // create test container to check text width\n if (config?.preciseSize) {\n this.precsizeCalculationArea = this.initiatePresizeElement();\n revogrid.appendChild(this.precsizeCalculationArea);\n }\n\n const aftersourceset = ({\n detail: { source },\n }: CustomEvent<SourceSetEvent>) => {\n this.setSource(source);\n };\n const afteredit = ({ detail }: CustomEvent<EditEvent>) => {\n this.afteredit(detail);\n };\n const afterEditAll = ({ detail }: CustomEvent<EditEvent>) => {\n this.afterEditAll(detail);\n };\n const beforecolumnsset = ({\n detail: { columns },\n }: CustomEvent<ColumnCollection>) => {\n this.columnSet(columns);\n };\n const headerDblClick = ({ detail }: CustomEvent<InitialHeaderClick>) => {\n const type = getColumnType(detail.column);\n const size = this.getColumnSize(detail.index, type);\n if (size) {\n this.providers.dimension.setCustomSizes(\n type,\n {\n [detail.index]: size,\n },\n true,\n );\n }\n };\n this.addEventListener('beforecolumnsset', beforecolumnsset);\n switch (config?.mode) {\n case ColumnAutoSizeMode.autoSizeOnTextOverlap:\n this.addEventListener('aftersourceset', aftersourceset);\n this.addEventListener('afteredit', afteredit);\n break;\n case ColumnAutoSizeMode.autoSizeAll:\n this.addEventListener('aftersourceset', aftersourceset);\n this.addEventListener('afteredit', afterEditAll);\n break;\n default:\n this.addEventListener('headerdblclick', headerDblClick);\n break;\n }\n }\n\n async setSource(source: DataType[]): Promise<void> {\n let autoSize = this.autoSizeColumns;\n if (this.dataReject) {\n this.dataReject();\n this.clearPromise();\n }\n\n /** If data set first and no column provided await until get one */\n if (!autoSize) {\n const request = new Promise((resolve: Resolve, reject: Reject) => {\n this.dataResolve = resolve;\n this.dataReject = reject;\n });\n try {\n autoSize = await request;\n } catch (e) {\n return;\n }\n }\n\n // calculate sizes\n each(autoSize, (_v, type: DimensionCols) => {\n const sizes: ViewSettingSizeProp = {};\n each(autoSize[type], rgCol => {\n // calculate size\n rgCol.size = sizes[rgCol.index] = source.reduce(\n (prev, rgRow) => Math.max(prev, this.getLength(rgRow[rgCol.prop])),\n this.getLength(rgCol.name || ''),\n );\n });\n this.providers.dimension.setCustomSizes(type, sizes, true);\n });\n }\n\n getLength(len?: any): number {\n const padding = 15;\n if (!len) {\n return 0;\n }\n try {\n const str = len.toString();\n\n /**if exact calculation required proxy with html element, slow operation */\n if (this.config?.preciseSize) {\n this.precsizeCalculationArea.innerText = str;\n return this.precsizeCalculationArea.scrollWidth + padding * 2;\n }\n return str.length * this.letterBlockSize + padding * 2;\n } catch (e) {\n return 0;\n }\n }\n\n afteredit(e: EditEvent) {\n let data: Record<string, DataType>;\n if (this.isRangeEdit(e)) {\n data = e.data;\n } else {\n data = { 0: { [e.prop]: e.val } };\n }\n each(this.autoSizeColumns, (columns, type: DimensionCols) => {\n const sizes: ViewSettingSizeProp = {};\n\n each(columns, rgCol => {\n // calculate size\n const size = reduce(\n data,\n (prev: number | undefined, rgRow) => {\n if (typeof rgRow[rgCol.prop] === 'undefined') {\n return prev;\n }\n return Math.max(prev || 0, this.getLength(rgRow[rgCol.prop]));\n },\n undefined,\n );\n\n if (size && (rgCol.size ?? 0) < size) {\n rgCol.size = sizes[rgCol.index] = size;\n }\n });\n\n this.providers.dimension.setCustomSizes(type, sizes, true);\n });\n }\n\n afterEditAll(e: EditEvent) {\n const props: Record<any, true> = {};\n if (this.isRangeEdit(e)) {\n each(e.data, r => each(r, (_v, p) => (props[p] = true)));\n } else {\n props[e.prop] = true;\n }\n each(this.autoSizeColumns, (columns, type: DimensionCols) => {\n const sizes: ViewSettingSizeProp = {};\n\n each(columns, rgCol => {\n if (props[rgCol.prop]) {\n const size = this.getColumnSize(rgCol.index, type);\n if (size) {\n sizes[rgCol.index] = size;\n }\n }\n });\n this.providers.dimension.setCustomSizes(type, sizes, true);\n });\n }\n\n getColumnSize(index: number, type: DimensionCols): number {\n const rgCol = this.autoSizeColumns?.[type]?.[index];\n if (!rgCol) {\n return 0;\n }\n return reduce(\n this.providers.data.stores,\n (r, s) => {\n const perStore = reduce(\n s.store.get('items'),\n (prev, _row, i) => {\n const item = getSourceItem(s.store, i);\n return Math.max(prev || 0, this.getLength(item?.[rgCol.prop]));\n },\n 0,\n );\n return Math.max(r, perStore);\n },\n rgCol.size || 0,\n );\n }\n\n columnSet(columns: Record<DimensionCols, ColumnRegular[]>) {\n for (let t of columnTypes) {\n const type = t as DimensionCols;\n const cols = columns[type];\n\n for (let i in cols) {\n if (cols[i].autoSize || this.config?.allColumns) {\n if (!this.autoSizeColumns) {\n this.autoSizeColumns = {};\n }\n if (!this.autoSizeColumns[type]) {\n this.autoSizeColumns[type] = {};\n }\n this.autoSizeColumns[type][i] = {\n ...cols[i],\n index: parseInt(i, 10),\n };\n }\n }\n }\n\n if (this.dataResolve) {\n this.dataResolve(this.autoSizeColumns || {});\n this.clearPromise();\n }\n }\n\n clearPromise() {\n this.dataResolve = null;\n this.dataReject = null;\n }\n\n isRangeEdit(e: EditEvent): e is BeforeRangeSaveDataDetails {\n return !!(e as BeforeRangeSaveDataDetails).data;\n }\n\n initiatePresizeElement(): HTMLElement {\n const styleForFontTest: Partial<CSSStyleDeclaration> = {\n position: 'absolute',\n fontSize: '14px',\n height: '0',\n width: '0',\n whiteSpace: 'nowrap',\n top: '0',\n overflowX: 'scroll',\n };\n\n const el = document.createElement('div');\n for (let s in styleForFontTest) {\n el.style[s] = styleForFontTest[s] ?? '';\n }\n el.classList.add('revo-test-container');\n return el;\n }\n\n destroy() {\n super.destroy();\n this.precsizeCalculationArea?.remove();\n }\n}\n","import each from 'lodash/each';\nimport { calculateRowHeaderSize } from '../utils/row-header-utils';\nimport { getScrollbarSize } from '../utils';\nimport { BasePlugin } from './base.plugin';\nimport { DimensionCols, DimensionType, PluginBaseComponent, PluginProviders, ColumnRegular } from '@type';\nimport { ColumnCollection } from '../utils/column.utils';\n\n/**\n * This plugin serves to recalculate columns initially\n * Base on empty space if there is any\n * Currently plugin supports only increasing last column\n */\ntype ScrollChange = {\n type: DimensionType;\n hasScroll: boolean;\n};\ntype StretchedData = {\n initialSize: number;\n size: number;\n index: number;\n};\n\nexport default class StretchColumn extends BasePlugin {\n private stretchedColumn: StretchedData | null = null;\n private readonly scrollSize;\n constructor(\n revogrid: HTMLRevoGridElement,\n public providers: PluginProviders,\n ) {\n super(revogrid, providers);\n\n // calculate scroll bar size for current user session\n this.scrollSize = getScrollbarSize(document);\n\n // subscribe to column changes\n const beforecolumnapplied = ({\n detail: { columns },\n }: CustomEvent<ColumnCollection>) => this.applyStretch(columns);\n this.addEventListener('beforecolumnapplied', beforecolumnapplied);\n }\n\n private setScroll({ type, hasScroll }: ScrollChange) {\n if (\n type === 'rgRow' &&\n this.stretchedColumn &&\n this.stretchedColumn?.initialSize === this.stretchedColumn.size\n ) {\n if (hasScroll) {\n this.stretchedColumn.size -= this.scrollSize;\n this.apply();\n this.dropChanges();\n }\n }\n }\n\n private activateChanges() {\n const setScroll = ({ detail }: CustomEvent<ScrollChange>) =>\n this.setScroll(detail);\n this.addEventListener('scrollchange', setScroll);\n }\n\n private dropChanges() {\n this.stretchedColumn = null;\n this.removeEventListener('scrollchange');\n }\n\n private apply() {\n if (!this.stretchedColumn) {\n return;\n }\n const type: DimensionCols = 'rgCol';\n const sizes = this.providers.dimension.stores[type].store.get('sizes');\n this.providers.dimension.setCustomSizes(\n type,\n {\n ...sizes,\n [this.stretchedColumn.index]: this.stretchedColumn.size,\n },\n true,\n );\n }\n\n /**\n * Apply stretch changes\n */\n applyStretch(columns: Record<DimensionCols, ColumnRegular[]>) {\n // unsubscribe from all events\n this.dropChanges();\n // calculate grid size\n let sizeDifference = this.revogrid.clientWidth - 1;\n each(columns, (_, type: DimensionCols) => {\n const realSize =\n this.providers.dimension.stores[type].store.get('realSize');\n sizeDifference -= realSize;\n });\n if (this.revogrid.rowHeaders) {\n const itemsLength =\n this.providers.data.stores.rgRow.store.get('source').length;\n const header = this.revogrid.rowHeaders;\n const rowHeaderSize = calculateRowHeaderSize(\n itemsLength,\n typeof header === 'object' ? header : undefined,\n );\n if (rowHeaderSize) {\n sizeDifference -= rowHeaderSize;\n }\n }\n if (sizeDifference > 0) {\n // currently plugin accepts last column only\n const index = columns.rgCol.length - 1;\n const last = columns.rgCol[index];\n /**\n * has column\n * no auto size applied\n * size for column shouldn't be defined\n */\n const colSize = last?.size || this.revogrid.colSize || 0;\n const size = sizeDifference + colSize - 1;\n\n if (last && !last.autoSize && colSize < size) {\n this.stretchedColumn = {\n initialSize: size,\n index,\n size,\n };\n this.apply();\n this.activateChanges();\n }\n }\n }\n}\n\n/**\n * Check plugin type is Stretch\n */\nexport function isStretchPlugin(\n plugin: PluginBaseComponent | StretchColumn,\n): plugin is StretchColumn {\n return !!(plugin as StretchColumn).applyStretch;\n}\n","/**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\nfunction baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n}\n\nexport default baseClamp;\n","import baseClamp from './_baseClamp.js';\nimport toInteger from './toInteger.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\nfunction toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n}\n\nexport default toLength;\n","import toInteger from './toInteger.js';\nimport toLength from './toLength.js';\n\n/**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\nfunction baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n}\n\nexport default baseFill;\n","import baseFill from './_baseFill.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\nfunction fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n}\n\nexport default fill;\n","import { getGroupingName, isGrouping } from '../groupingRow/grouping.service';\nimport { CSVFormat, DataInput, Formatter } from './types';\n\nconst INITIAL: CSVFormat = {\n mime: 'text/csv',\n fileKind: 'csv',\n // BOM signature\n bom: true,\n columnDelimiter: ',',\n rowDelimiter: '\\r\\n',\n encoding: '',\n};\n\nexport type CSVFormatter = (options: Partial<CSVFormat>, data: DataInput) => string;\n\n// The ASCII character code 13 is called a Carriage Return or CR.\nconst CARRIAGE_RETURN = String.fromCharCode(13);\n// Chr(13) followed by a Chr(10) that compose a proper CRLF.\nconst LINE_FEED = String.fromCharCode(10);\nconst DOUBLE_QT = String.fromCharCode(34);\nconst NO_BREAK_SPACE = String.fromCharCode(0xfeff);\nconst escapeRegex = new RegExp('\"', 'g');\n\nexport default class ExportCsv implements Formatter {\n readonly options: Readonly<CSVFormat>;\n constructor(options: Partial<CSVFormat> = {}) {\n this.options = { ...INITIAL, ...options };\n }\n\n doExport({ data, headers, props }: DataInput) {\n let result = this.options.bom ? NO_BREAK_SPACE : '';\n\n // any header\n if (headers?.length > 0) {\n headers.forEach(header => {\n // ignore empty\n if (!header.length) {\n return;\n }\n result += this.prepareHeader(header, this.options.columnDelimiter);\n result += this.options.rowDelimiter;\n });\n }\n\n data.forEach((rgRow, index) => {\n if (index > 0) {\n result += this.options.rowDelimiter;\n }\n // support grouping\n if (isGrouping(rgRow)) {\n result += this.parseCell(getGroupingName(rgRow), this.options.columnDelimiter);\n return;\n }\n result += props.map(p => this.parseCell(rgRow[p], this.options.columnDelimiter)).join(this.options.columnDelimiter);\n });\n\n return result;\n }\n\n private prepareHeader(columnHeaders: string[], columnDelimiter: string) {\n let result = '';\n const newColumnHeaders = columnHeaders.map(v => this.parseCell(v, columnDelimiter, true));\n result += newColumnHeaders.join(columnDelimiter);\n return result;\n }\n\n private parseCell(value: any, columnDelimiter: string, force = false) {\n let escape = value;\n if (typeof value !== 'string') {\n escape = JSON.stringify(value);\n }\n const toEscape = [CARRIAGE_RETURN, DOUBLE_QT, LINE_FEED, columnDelimiter];\n if (typeof escape === 'undefined') {\n return '';\n }\n if (escape !== '' && (force || toEscape.some(i => escape.indexOf(i) >= 0))) {\n return `\"${escape.replace(escapeRegex, '\"\"')}\"`;\n }\n\n return escape;\n }\n}\n","import fill from 'lodash/fill';\nimport { columnTypes, rowTypes, Group, Groups } from '@store';\n\nimport { timeout } from '../../utils';\nimport { BasePlugin } from '../base.plugin';\nimport ExportCsv from './csv';\nimport { ColSource, CSVFormat, DataInput, Formatter } from './types';\nimport { DimensionCols, ColumnProp, DataType } from '@type';\n\nenum ExportTypes {\n csv = 'csv',\n}\n\nexport type ExportFormat = Partial<CSVFormat>;\n\nexport default class ExportFilePlugin extends BasePlugin {\n /** Exports string */\n async exportString(options: ExportFormat = {}, t: ExportTypes = ExportTypes.csv) {\n const data = await this.beforeexport();\n if (!data) {\n return null;\n }\n return this.formatter(t, options).doExport(data);\n }\n\n /** Exports Blob */\n async exportBlob(options: ExportFormat = {}, t: ExportTypes = ExportTypes.csv) {\n return await this.getBlob(this.formatter(t, options));\n }\n\n /** Export file */\n async exportFile(options: ExportFormat = {}, t: ExportTypes = ExportTypes.csv) {\n const formatter = this.formatter(t, options);\n\n // url\n const URL = window.URL || window.webkitURL;\n\n const a = document.createElement('a');\n const { filename, fileKind } = formatter.options;\n const name = `${filename}.${fileKind}`;\n\n const blob = await this.getBlob(formatter);\n const url = blob ? URL.createObjectURL(blob) : '';\n\n a.style.display = 'none';\n a.setAttribute('href', url);\n a.setAttribute('download', name);\n this.revogrid.appendChild(a);\n a.dispatchEvent(new MouseEvent('click'));\n this.revogrid.removeChild(a);\n\n // delay for revoke, correct for some browsers\n await timeout(120);\n URL.revokeObjectURL(url);\n }\n\n /** Blob object */\n async getBlob(formatter: Formatter) {\n const type = `${formatter.options.mime};charset=${formatter.options.encoding}`;\n if (typeof Blob !== 'undefined') {\n const data = await this.beforeexport();\n if (!data) {\n return null;\n }\n return new Blob([formatter.doExport(data)], { type });\n }\n return null;\n }\n\n // before event\n private async beforeexport() {\n let data = await this.getData();\n const event: CustomEvent<{ data: DataInput }> = this.emit('beforeexport', { data });\n if (event.defaultPrevented) {\n return null;\n }\n return event.detail.data;\n }\n\n private async getData(): Promise<DataInput> {\n const data = await this.getSource();\n const colSource: ColSource[] = [];\n const colPromises: Promise<ColSource>[] = [];\n columnTypes.forEach((t, i) => {\n colPromises.push(this.getColPerSource(t).then(s => (colSource[i] = s)));\n });\n await Promise.all(colPromises);\n const columns: ColSource = {\n headers: [],\n props: [],\n };\n for (let source of colSource) {\n source.headers.forEach((h, i) => {\n if (!columns.headers[i]) {\n columns.headers[i] = [];\n }\n columns.headers[i].push(...h);\n });\n columns.props.push(...source.props);\n }\n return {\n data,\n ...columns,\n };\n }\n\n private async getColPerSource(t: DimensionCols) {\n const store = await this.revogrid.getColumnStore(t);\n const source = store.get('source');\n const virtualIndexes = store.get('items');\n const depth = store.get('groupingDepth');\n const groups = store.get('groups');\n const colNames: string[] = [];\n const colProps: ColumnProp[] = [];\n const visibleItems = virtualIndexes.reduce((r: Record<string, number>, v: number, virtualIndex: number) => {\n const prop = source[v].prop;\n colNames.push(source[v].name || '');\n colProps.push(prop);\n r[prop] = virtualIndex;\n return r;\n }, {});\n const rows: string[][] = this.getGroupHeaders(depth, groups, virtualIndexes, visibleItems);\n rows.push(colNames);\n return {\n headers: rows,\n props: colProps,\n };\n }\n\n private getGroupHeaders(depth: number, groups: Groups, items: number[], visibleItems: Record<string, number>) {\n const rows: string[][] = [];\n const template = fill(new Array(items.length), '');\n for (let d = 0; d < depth; d++) {\n const rgRow = [...template];\n rows.push(rgRow);\n if (!groups[d]) {\n continue;\n }\n const levelGroups = groups[d];\n\n // add names of groups\n levelGroups.forEach((group: Group) => {\n const minIndex = this.findGroupStartIndex(group.ids, visibleItems);\n if (typeof minIndex === 'number') {\n rgRow[minIndex] = group.name;\n }\n });\n }\n return rows;\n }\n\n private findGroupStartIndex(ids: (string | number)[], visibleItems: Record<string, number>): number | undefined {\n let min: number | undefined;\n ids.forEach(id => {\n const current = visibleItems[id];\n if (typeof current === 'number') {\n if (typeof min !== 'number' || min > current) {\n min = current;\n }\n }\n });\n return min;\n }\n\n private async getSource() {\n const data: DataType[][] = [];\n const promisesData: Promise<number>[] = [];\n rowTypes.forEach(t => {\n const dataPart: DataType[] = [];\n data.push(dataPart);\n const promise = this.revogrid.getVisibleSource(t).then((d: DataType[]) => dataPart.push(...d));\n promisesData.push(promise);\n });\n await Promise.all(promisesData);\n return data.reduce((r, v) => {\n r.push(...v);\n return r;\n }, []);\n }\n\n // get correct class for future multiple types support\n private formatter(type: ExportTypes, options: ExportFormat = {}) {\n switch (type) {\n case ExportTypes.csv:\n return new ExportCsv(options);\n default:\n throw new Error('Unknown format');\n }\n }\n}\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam, ExtraField } from '../filter.types';\n\nconst eq: LogicFunction = (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) => {\n if (typeof value === 'undefined' || (value === null && !extra)) {\n return true;\n }\n if (typeof value !== 'string') {\n value = JSON.stringify(value);\n }\n\n const filterVal = extra?.toString().toLocaleLowerCase();\n if (filterVal?.length === 0) {\n return true;\n }\n \n return value.toLocaleLowerCase() === filterVal;\n};\n\nexport const notEq: LogicFunction = (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) => !eq(value, extra);\nnotEq.extra = 'input' as ExtraField;\neq.extra = 'input' as ExtraField;\nexport default eq;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\n\nconst gtThan: LogicFunction = function (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) {\n let conditionValue: number;\n\n if (typeof value === 'number' && typeof extra !== 'undefined' && extra !== null) {\n conditionValue = parseFloat(extra?.toString());\n return value > conditionValue;\n }\n return false;\n};\n\ngtThan.extra = 'input';\nexport default gtThan;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\nimport eq from '../equal';\nimport gt from './greaterThan';\n\nconst gtThanEq: LogicFunction = function (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) {\n return eq(value, extra) || gt(value, extra);\n};\n\ngtThanEq.extra = 'input';\nexport default gtThanEq;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\n\nconst lt: LogicFunction = function (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) {\n let conditionValue: number;\n if (typeof value === 'number' && typeof extra !== 'undefined' && extra !== null) {\n conditionValue = parseFloat(extra.toString());\n return value < conditionValue;\n } else {\n return false;\n }\n};\n\nlt.extra = 'input';\nexport default lt;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\nimport eq from '../equal';\nimport lt from './lessThan';\n\nconst lsEq: LogicFunction = function (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) {\n return eq(value, extra) || lt(value, extra);\n};\n\nlsEq.extra = 'input';\nexport default lsEq;\n","import { LogicFunction, LogicFunctionParam } from '../filter.types';\n\nconst set: LogicFunction = (value: LogicFunctionParam) => !(value === '' || value === null || value === void 0);\nexport const notSet: LogicFunction = (value: LogicFunctionParam) => !set(value);\nexport default set;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\n\nconst beginsWith: LogicFunction = (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) => {\n if (!value) {\n return false;\n }\n if (!extra) {\n return true;\n }\n if (typeof value !== 'string') {\n value = JSON.stringify(value);\n }\n if (typeof extra !== 'string') {\n extra = JSON.stringify(extra);\n }\n return value.toLocaleLowerCase().indexOf(extra.toLocaleLowerCase()) === 0;\n};\n\nbeginsWith.extra = 'input';\nexport default beginsWith;\n","import { LogicFunction, LogicFunctionExtraParam, LogicFunctionParam } from '../../filter.types';\n\nconst contains: LogicFunction = (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) => {\n if (!extra) {\n return true;\n }\n if (!value) {\n return false;\n }\n if (extra) {\n if (typeof value !== 'string') {\n value = JSON.stringify(value);\n }\n return value.toLocaleLowerCase().indexOf(extra.toString().toLowerCase()) > -1;\n }\n return true;\n};\n\nexport const notContains: LogicFunction = (value: LogicFunctionParam, extra?: LogicFunctionExtraParam) => {\n return !contains(value, extra);\n};\nnotContains.extra = 'input';\ncontains.extra = 'input';\nexport default contains;\n","import eq, { notEq } from './conditions/equal';\nimport gtThan from './conditions/number/greaterThan';\nimport gtThanEq from './conditions/number/greaterThanOrEqual';\nimport lt from './conditions/number/lessThan';\nimport lsEq from './conditions/number/lessThanOrEqual';\nimport set, { notSet } from './conditions/set';\nimport beginsWith from './conditions/string/beginswith';\nimport contains, { notContains } from './conditions/string/contains';\nimport { LogicFunction } from './filter.types';\n\n\nexport const filterCoreFunctionsIndexedByType: Record<FilterType, LogicFunction> = {\n none: () => true,\n empty: notSet,\n notEmpty: set,\n eq: eq,\n notEq: notEq,\n begins: beginsWith,\n contains: contains,\n notContains: notContains,\n\n eqN: eq,\n neqN: notEq,\n gt: gtThan,\n gte: gtThanEq,\n lt: lt,\n lte: lsEq,\n};\n\nexport const filterTypes: Record<string, FilterType[]> = {\n string: ['notEmpty', 'empty', 'eq', 'notEq', 'begins', 'contains', 'notContains'],\n number: ['notEmpty', 'empty', 'eqN', 'neqN', 'gt', 'gte', 'lt', 'lte'],\n};\n\nexport const filterNames = {\n none: 'None',\n empty: 'Not set',\n notEmpty: 'Set',\n\n eq: 'Equal',\n notEq: 'Not equal',\n begins: 'Begins with',\n contains: 'Contains',\n notContains: 'Does not contain',\n\n eqN: '=',\n neqN: '!=',\n gt: '>',\n gte: '>=',\n lt: '<',\n lte: '<=',\n};\n\nexport type FilterType = keyof typeof filterNames;\n","import { h } from '@stencil/core';\nimport reduce from 'lodash/reduce';\n\nimport { BasePlugin } from '../base.plugin';\nimport { FILTER_PROP, isFilterBtn } from './filter.button';\nimport {\n filterCoreFunctionsIndexedByType,\n filterNames,\n filterTypes,\n} from './filter.indexed';\nimport {\n ColumnFilterConfig,\n FilterCollection,\n LogicFunction,\n MultiFilterItem,\n} from './filter.types';\nimport { ColumnRegular, DataType, PluginProviders } from '@type';\nimport { getCellDataParsed } from 'src/utils';\n\n/**\n * @typedef ColumnFilterConfig\n * @type {object}\n * @property {FilterCollection|undefined} collection - preserved filter data\n * @property {string[]|undefined} include - filters to be included, if defined everything else out of scope will be ignored\n * @property {Record<string, CustomFilter>|undefined} customFilters - hash map of {FilterType:CustomFilter}.\n * @property {FilterLocalization|undefined} localization - translation for filter popup captions.\n * @property {MultiFilterItem|undefined} multiFilterItems - data for multi filtering.\n * @property {boolean|undefined} disableDynamicFiltering - disables dynamic filtering.\n * A way to define your own filter types per column\n */\n/**\n * @internal\n */\n\nexport const FILTER_TRIMMED_TYPE = 'filter';\nexport const FILTER_CONFIG_CHANGED_EVENT = 'filterconfigchanged';\n\nexport class FilterPlugin extends BasePlugin {\n pop?: HTMLRevogrFilterPanelElement;\n filterCollection: FilterCollection = {};\n multiFilterItems: MultiFilterItem = {};\n\n filterByType: Record<string, string[]> =\n { ...filterTypes };\n filterNameIndexByType: Record<string, string> = {\n ...filterNames,\n };\n filterFunctionsIndexedByType: Record<string, LogicFunction> = {\n ...filterCoreFunctionsIndexedByType,\n };\n\n filterProp = FILTER_PROP;\n\n constructor(\n public revogrid: HTMLRevoGridElement,\n providers: PluginProviders,\n config?: ColumnFilterConfig,\n ) {\n super(revogrid, providers);\n if (config) {\n this.initConfig(config);\n }\n\n const aftersourceset = async () => {\n const filterCollectionProps = Object.keys(this.filterCollection);\n if (filterCollectionProps.length > 0) {\n // handle old way of filtering by reworking FilterCollection to new MultiFilterItem\n filterCollectionProps.forEach((prop, index) => {\n if (!this.multiFilterItems[prop]) {\n this.multiFilterItems[prop] = [\n {\n id: index,\n type: this.filterCollection[prop].type,\n value: this.filterCollection[prop].value,\n relation: 'and',\n },\n ];\n }\n });\n }\n await this.runFiltering();\n };\n this.addEventListener(\n 'headerclick',\n (e: CustomEvent<HTMLRevoGridElementEventMap['headerclick']>) =>\n this.headerclick(e),\n );\n this.addEventListener(\n FILTER_CONFIG_CHANGED_EVENT,\n ({ detail }: CustomEvent<ColumnFilterConfig | boolean>) => {\n if (!detail) {\n this.clearFiltering();\n return;\n }\n if (typeof detail === 'object') {\n this.initConfig(detail);\n }\n aftersourceset();\n },\n );\n this.addEventListener('aftersourceset', aftersourceset);\n this.addEventListener('filter', ({ detail }: CustomEvent) =>\n this.onFilterChange(detail),\n );\n\n const existingNodes = this.revogrid.registerVNode.filter(\n n => n.$tag$ !== 'revogr-filter-panel',\n );\n this.revogrid.registerVNode = [\n ...existingNodes,\n <revogr-filter-panel\n filterItems={this.multiFilterItems}\n filterNames={this.filterNameIndexByType}\n filterEntities={this.filterFunctionsIndexedByType}\n filterCaptions={config?.localization?.captions}\n onFilterChange={e => this.onFilterChange(e.detail)}\n disableDynamicFiltering={config?.disableDynamicFiltering}\n ref={e => (this.pop = e)}\n />,\n ];\n }\n\n initConfig(config: ColumnFilterConfig) {\n if (config.multiFilterItems) {\n this.multiFilterItems = { ...config.multiFilterItems };\n }\n // Add custom filters\n if (config.customFilters) {\n for (let customFilterType in config.customFilters) {\n const cFilter = config.customFilters[customFilterType];\n if (!this.filterByType[cFilter.columnFilterType]) {\n this.filterByType[cFilter.columnFilterType] = [];\n }\n this.filterByType[cFilter.columnFilterType].push(customFilterType);\n this.filterFunctionsIndexedByType[customFilterType] = cFilter.func;\n this.filterNameIndexByType[customFilterType] = cFilter.name;\n }\n }\n\n // Add filterProp if provided in config\n if (config.filterProp) {\n this.filterProp = config.filterProp;\n }\n\n /**\n * which filters has to be included/excluded\n * convinient way to exclude system filters\n */\n const cfgInlcude = config.include;\n if (cfgInlcude) {\n const filters: Record<string, string[]> = {};\n\n for (let t in this.filterByType) {\n // validate filters, if appropriate function present\n const newTypes = this.filterByType[t].filter(\n f => cfgInlcude.indexOf(f) > -1,\n );\n if (newTypes.length) {\n filters[t] = newTypes;\n }\n }\n // if any valid filters provided show them\n if (Object.keys(filters).length > 0) {\n this.filterByType = filters;\n }\n }\n\n if (config.collection) {\n this.filterCollection = reduce(\n config.collection,\n (result: FilterCollection, item, prop) => {\n if (this.filterFunctionsIndexedByType[item.type]) {\n result[prop] = item;\n } else {\n console.warn(`${item.type} type is not found.`);\n }\n return result;\n },\n {},\n );\n }\n\n if (config.localization) {\n if (config.localization.filterNames) {\n Object.entries(config.localization.filterNames).forEach(([k, v]) => {\n if (this.filterNameIndexByType[k] != void 0) {\n this.filterNameIndexByType[k] = v;\n }\n });\n }\n }\n }\n\n async headerclick(e: CustomEvent<ColumnRegular>) {\n const el = e.detail.originalEvent?.target as HTMLElement;\n if (!isFilterBtn(el)) {\n return;\n }\n e.preventDefault();\n\n // close if same\n const changes = await this.pop?.getChanges();\n if (changes && changes?.prop === e.detail.prop) {\n this.pop?.show();\n return;\n }\n\n if (!this.pop) {\n return;\n }\n\n // filter button clicked, open filter dialog\n const gridPos = this.revogrid.getBoundingClientRect();\n const buttonPos = el.getBoundingClientRect();\n const prop = e.detail.prop;\n\n this.pop.show({\n ...this.filterCollection[prop],\n x: buttonPos.x - gridPos.x,\n y: buttonPos.y - gridPos.y + buttonPos.height,\n autoCorrect: true,\n prop,\n filterTypes: this.getColumnFilter(e.detail.filter),\n });\n }\n\n getColumnFilter(\n type?: boolean | string | string[],\n ): Record<string, string[]> {\n let filterType = 'string';\n if (!type) {\n return { [filterType]: this.filterByType[filterType] };\n }\n\n // if custom column filter\n if (this.isValidType(type)) {\n filterType = type;\n\n // if multiple filters applied\n } else if (typeof type === 'object' && type.length) {\n return type.reduce((r: Record<string, string[]>, multiType) => {\n if (this.isValidType(multiType)) {\n r[multiType] = this.filterByType[multiType];\n }\n return r;\n }, {});\n }\n return { [filterType]: this.filterByType[filterType] };\n }\n\n isValidType(type: any): type is string {\n return !!(typeof type === 'string' && this.filterByType[type]);\n }\n\n /**\n * Called on internal component change\n */\n async onFilterChange(filterItems: MultiFilterItem) {\n // store the filter items\n this.multiFilterItems = filterItems;\n\n // run the filtering when the items change\n this.runFiltering();\n }\n\n /**\n * Triggers grid filtering\n */\n async doFiltering(\n collection: FilterCollection,\n source: DataType[],\n columns: ColumnRegular[],\n filterItems: MultiFilterItem,\n ) {\n const columnsToUpdate: ColumnRegular[] = [];\n\n /**\n * Loop through the columns and update the columns that need to be updated with the `hasFilter` property.\n */\n const columnByProp: Record<string, ColumnRegular> = {};\n columns.forEach(rgCol => {\n const column = { ...rgCol };\n const hasFilter = filterItems[column.prop];\n columnByProp[column.prop] = column;\n\n /**\n * If the column has a filter and it's not already marked as filtered, update the column.\n */\n if (column[this.filterProp] && !hasFilter) {\n delete column[this.filterProp];\n columnsToUpdate.push(column);\n }\n\n /**\n * If the column does not have a filter and it's marked as filtered, update the column.\n */\n\n if (!column[this.filterProp] && hasFilter) {\n columnsToUpdate.push(column);\n column[this.filterProp] = true;\n }\n });\n const itemsToTrim = this.getRowFilter(source, filterItems, columnByProp);\n // check is filter event prevented\n const { defaultPrevented, detail } = this.emit('beforefiltertrimmed', {\n collection,\n itemsToFilter: itemsToTrim,\n source,\n filterItems,\n });\n if (defaultPrevented) {\n return;\n }\n\n // check is trimmed event prevented\n const isAddedEvent = await this.revogrid.addTrimmed(\n detail.itemsToFilter,\n FILTER_TRIMMED_TYPE,\n );\n if (isAddedEvent.defaultPrevented) {\n return;\n }\n\n // applies the hasFilter to the columns to show filter icon\n this.providers.column.updateColumns(columnsToUpdate);\n this.emit('afterfilterapply');\n }\n\n async clearFiltering() {\n this.multiFilterItems = {};\n await this.runFiltering();\n }\n\n async runFiltering() {\n const collection: FilterCollection = {};\n\n // handle old filterCollection to return the first filter only (if any) from multiFilterItems\n const filterProps = Object.keys(this.multiFilterItems);\n\n for (const prop of filterProps) {\n // check if we have any filter for a column\n if (this.multiFilterItems[prop].length > 0) {\n const firstFilterItem = this.multiFilterItems[prop][0];\n collection[prop] = {\n filter: this.filterFunctionsIndexedByType[firstFilterItem.type],\n type: firstFilterItem.type,\n value: firstFilterItem.value,\n };\n }\n }\n\n this.filterCollection = collection;\n\n const { source, columns } = await this.getData();\n const { defaultPrevented, detail } = this.emit('beforefilterapply', {\n collection: this.filterCollection,\n source,\n columns,\n filterItems: this.multiFilterItems,\n });\n if (defaultPrevented) {\n return;\n }\n this.doFiltering(\n detail.collection,\n detail.source,\n detail.columns,\n detail.filterItems,\n );\n }\n\n async getData() {\n return {\n source: await this.revogrid.getSource(),\n columns: await this.revogrid.getColumns(),\n };\n }\n\n /**\n * Get trimmed rows based on filter\n */\n getRowFilter(\n rows: DataType[],\n filterItems: MultiFilterItem,\n columnByProp: Record<string, ColumnRegular>\n ): Record<number, boolean> {\n const propKeys = Object.keys(filterItems);\n\n const trimmed: Record<number, boolean> = {};\n let propFilterSatisfiedCount = 0;\n let lastFilterResults: boolean[] = [];\n\n // each rows\n rows.forEach((model, rowIndex) => {\n // check filter by column properties\n for (const prop of propKeys) {\n const propFilters = filterItems[prop];\n\n // reset the count of satisfied filters\n propFilterSatisfiedCount = 0;\n // reset the array of last filter results\n lastFilterResults = [];\n\n // testing each filter for a prop\n for (const [filterIndex, filterData] of propFilters.entries()) {\n // the filter LogicFunction based on the type\n const filterFunc = this.filterFunctionsIndexedByType[filterData.type];\n\n // THE MAGIC OF FILTERING IS HERE\n const column = columnByProp[prop];\n // If there is no column but user wants to filter by a property\n const value = column ? getCellDataParsed(model, columnByProp[prop]) : model[prop];\n // OR relation\n if (filterData.relation === 'or') {\n // reset the array of last filter results\n lastFilterResults = [];\n // if the filter is satisfied, continue to the next filter\n if (filterFunc(value, filterData.value)) {\n continue;\n }\n // if the filter is not satisfied, count it\n propFilterSatisfiedCount++;\n\n // AND relation\n } else {\n // 'and' relation will need to know the next filter\n // so we save this current filter to include it in the next filter\n lastFilterResults.push(!filterFunc(value, filterData.value));\n\n // check first if we have a filter on the next index to pair it with this current filter\n const nextFilterData = propFilters[filterIndex + 1];\n // stop the sequence if there is no next filter or if the next filter is not an 'and' relation\n if (!nextFilterData || nextFilterData.relation !== 'and') {\n // let's just continue since for sure propFilterSatisfiedCount cannot be satisfied\n if (lastFilterResults.indexOf(true) === -1) {\n // reset the array of last filter results\n lastFilterResults = [];\n continue;\n }\n\n // we need to add all of the lastFilterResults since we need to satisfy all\n propFilterSatisfiedCount += lastFilterResults.length;\n // reset the array of last filter results\n lastFilterResults = [];\n }\n }\n } // end of propFilters forEach\n\n // add to the list of removed/trimmed rows of filter condition is satisfied\n if (propFilterSatisfiedCount === propFilters.length) {\n trimmed[rowIndex] = true;\n }\n } // end of for-of propKeys\n });\n return trimmed;\n }\n}\n","const COLUMN_DRAG_CLASS = 'column-drag-start';\n\nexport class ColumnOrderHandler {\n private element?: HTMLDivElement;\n private autoscrollEl?: HTMLElement;\n private offset = 0;\n\n renderAutoscroll(_: MouseEvent, parent: HTMLElement | null) {\n if (!parent) {\n return;\n }\n this.autoscrollEl = document.createElement('div');\n this.autoscrollEl.classList.add('drag-auto-scroll-y');\n parent.appendChild(this.autoscrollEl);\n }\n\n autoscroll(pos: number, dataContainerSize: number, direction = 'translateX') {\n if (!this.autoscrollEl) {\n return;\n }\n const helperOffset = 10;\n // calculate current y position inside of the grid active holder\n // 3 - size of element + border\n const maxScroll = Math.min(pos + helperOffset, dataContainerSize - 3);\n\n this.autoscrollEl.style.transform = `${direction}(${maxScroll}px)`;\n this.autoscrollEl.scrollIntoView({\n block: 'nearest',\n inline: 'nearest',\n });\n }\n\n start(e: MouseEvent, { dataEl, gridRect, scrollEl, gridEl }: {\n dataEl: HTMLElement;\n gridRect: DOMRect;\n scrollEl: Element;\n gridEl: Element;\n }, dir: 'top' | 'left' = 'left') {\n gridEl.classList.add(COLUMN_DRAG_CLASS);\n const scrollContainerRect = scrollEl.getBoundingClientRect();\n if (scrollContainerRect) {\n this.offset = scrollContainerRect[dir] - gridRect[dir];\n }\n this.renderAutoscroll(e, dataEl);\n }\n\n stop(gridEl: Element) {\n gridEl.classList.remove(COLUMN_DRAG_CLASS);\n if (this.element) {\n this.element.hidden = true;\n }\n this.offset = 0;\n this.autoscrollEl?.remove();\n this.autoscrollEl = undefined;\n }\n\n showHandler(pos: number, size: number, direction = 'translateX') {\n if (!this.element) {\n return;\n }\n // do not allow overcross top of the scrollable area, header excluded\n if (this.offset) {\n pos = Math.max(pos, this.offset);\n }\n // can not be bigger then grid end\n pos = Math.min(pos, size);\n this.element.style.transform = `${direction}(${pos}px)`;\n this.element.hidden = false;\n }\n\n render() {\n const el = this.element = document.createElement('div');\n el.classList.add('drag-position-y');\n el.hidden = true;\n return el;\n }\n}\n","/**\n * Plugin for column manual move\n */\nimport debounce from 'lodash/debounce';\nimport each from 'lodash/each';\nimport { getItemByPosition } from '@store';\nimport { BasePlugin } from '../base.plugin';\nimport { ColumnOrderHandler } from './order-column.handler';\nimport { dispatch } from '../dispatcher';\nimport { ColumnPropProp, ColumnRegular, DimensionSettingsState, PositionItem, DimensionCols, MultiDimensionType, PluginProviders } from '@type';\nimport { ON_COLUMN_CLICK } from '../../components/header/header-cell-renderer';\nimport { isColGrouping } from '../../utils/column.utils';\n\nconst COLUMN_CLICK = ON_COLUMN_CLICK;\nconst MOVE = 'columndragmousemove';\nconst DRAG_END = 'columndragend';\nconst BEFORE_DRAG_END = 'beforecolumndragend';\n\n// use this event subscription to drop D&D for particular columns\nconst DRAG_START = 'columndragstart';\n\nexport type DragStartEventDetails = {\n event: MouseEvent;\n data: ColumnPropProp;\n};\n\ntype StaticData = {\n startPos: number;\n startItem: PositionItem;\n data: ColumnRegular;\n dataEl: HTMLElement;\n scrollEl: Element;\n gridEl: HTMLElement;\n cols: DimensionSettingsState;\n};\n\ntype LocalSubscriptions = Record<string, LocalSubscription>;\ntype LocalSubscription = {\n target: Element | Document;\n callback(...params: any[]): void;\n};\nexport type ColumnDragEventData = {\n elRect: DOMRect;\n gridRect: DOMRect;\n scrollOffset: number;\n type: DimensionCols;\n};\nexport default class ColumnPlugin extends BasePlugin {\n private moveFunc = debounce((e: MouseEvent) => this.doMove(e), 5);\n private staticDragData: StaticData | null = null;\n private dragData: ColumnDragEventData | null = null;\n private readonly orderUi: ColumnOrderHandler;\n protected readonly localSubscriptions: LocalSubscriptions = {};\n constructor(public revogrid: HTMLRevoGridElement, public providers: PluginProviders) {\n super(revogrid, providers);\n this.orderUi = new ColumnOrderHandler();\n revogrid.appendChild(this.orderUi.render());\n revogrid.classList.add('column-draggable');\n\n // Register events\n this.localSubscriptions['mouseleave'] = {\n target: document,\n callback: (e: MouseEvent) => this.onMouseOut(e),\n };\n this.localSubscriptions['mouseup'] = {\n target: document,\n callback: (e: MouseEvent) => this.onMouseUp(e),\n };\n\n this.localSubscriptions['mousemove'] = {\n target: document,\n callback: (e: MouseEvent) => this.move(e),\n };\n\n this.addEventListener(COLUMN_CLICK, ({ detail }) => this.dragStart(detail));\n }\n\n dragStart({ event, data }: DragStartEventDetails) {\n if (event.defaultPrevented) {\n return;\n }\n const { defaultPrevented } = dispatch(this.revogrid, DRAG_START, data);\n // check if allowed to drag particulat column\n if (defaultPrevented) {\n return;\n }\n this.clearOrder();\n const { mouseleave, mouseup, mousemove } = this.localSubscriptions;\n mouseleave.target.addEventListener('mouseleave', mouseleave.callback);\n mouseup.target.addEventListener('mouseup', mouseup.callback);\n\n const dataEl = (event.target as HTMLElement).closest('revogr-header');\n const scrollEl = (event.target as HTMLElement).closest('revogr-viewport-scroll');\n if (!dataEl || !scrollEl) {\n return;\n }\n\n // no grouping drag and no row header column drag\n if (isColGrouping(data) || data.providers.type === 'rowHeaders') {\n return;\n }\n\n const cols = this.getDimension(data.pin || 'rgCol');\n const gridRect = this.revogrid.getBoundingClientRect();\n const elRect = dataEl.getBoundingClientRect();\n const startItem = getItemByPosition(\n cols,\n getLeftRelative(event.x, gridRect.left, elRect.left - gridRect.left));\n \n this.staticDragData = {\n startPos: event.x,\n startItem,\n data,\n dataEl,\n scrollEl,\n gridEl: this.revogrid,\n cols,\n };\n this.dragData = this.getData(this.staticDragData);\n mousemove.target.addEventListener('mousemove', mousemove.callback);\n this.orderUi.start(event, {\n ...this.dragData,\n ...this.staticDragData,\n });\n }\n\n doMove(e: MouseEvent) {\n if (!this.staticDragData) {\n return;\n }\n\n const dragData = (this.dragData = this.getData(this.staticDragData));\n if (!dragData) {\n return;\n }\n const start = this.staticDragData.startPos;\n if (Math.abs(start - e.x) > 10) {\n const x = getLeftRelative(e.x, this.dragData.gridRect.left, this.dragData.scrollOffset);\n const rgCol = getItemByPosition(this.staticDragData.cols, x);\n this.orderUi.autoscroll(x, dragData.elRect.width);\n this.orderUi.showHandler(\n rgCol.end + dragData.scrollOffset,\n dragData.gridRect.width\n );\n }\n }\n\n move(e: MouseEvent) {\n dispatch(this.revogrid, MOVE, e);\n // then do move\n this.moveFunc(e);\n }\n onMouseOut(_: MouseEvent) {\n this.clearOrder();\n }\n onMouseUp(e: MouseEvent) {\n // apply new positions\n if (this.dragData && this.staticDragData) {\n let relativePos = getLeftRelative(e.x, this.dragData.gridRect.left, this.dragData.scrollOffset);\n if (relativePos < 0) {\n relativePos = 0;\n }\n const newPosition = getItemByPosition(this.staticDragData.cols, relativePos);\n\n const store = this.providers.column.stores[this.dragData.type].store;\n const items = [...store.get('items')];\n\n // prevent position change if needed\n const { defaultPrevented: stopDrag } = dispatch(this.revogrid, BEFORE_DRAG_END, {\n ...this.staticDragData,\n startPosition: this.staticDragData.startItem,\n newPosition,\n newItem: store.get('source')[items[this.staticDragData.startItem.itemIndex]]\n });\n if (!stopDrag) {\n // todo: if move item out of group remove item from group\n const toMove = items.splice(this.staticDragData.startItem.itemIndex, 1);\n items.splice(newPosition.itemIndex, 0, ...toMove);\n store.set('items', items);\n }\n dispatch(this.revogrid, DRAG_END, this.dragData);\n }\n this.clearOrder();\n }\n\n private clearLocalSubscriptions() {\n each(this.localSubscriptions, ({ target, callback }, key) => target.removeEventListener(key, callback));\n }\n\n clearOrder() {\n this.staticDragData = null;\n this.dragData = null;\n this.clearLocalSubscriptions();\n this.orderUi.stop(this.revogrid);\n }\n /**\n * Clearing subscription\n */\n clearSubscriptions() {\n super.clearSubscriptions();\n this.clearLocalSubscriptions();\n }\n\n private getData({\n gridEl,\n dataEl,\n data,\n }: StaticData): ColumnDragEventData {\n const gridRect = gridEl.getBoundingClientRect();\n const elRect = dataEl.getBoundingClientRect();\n const scrollOffset = elRect.left - gridRect.left;\n return {\n elRect,\n gridRect,\n type: data.pin || 'rgCol',\n scrollOffset,\n };\n }\n private getDimension(type: MultiDimensionType) {\n return this.providers.dimension.stores[type].getCurrentState();\n }\n}\n\nexport function getLeftRelative(\n absoluteX: number,\n gridPos: number,\n offset: number\n): number {\n return absoluteX - gridPos - offset;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Built by Revolist OU ❤️
|
|
3
|
+
*/
|
|
4
|
+
import{V as t,v as e,W as n,_ as s,O as i,Z as o,Y as r,a as l,C as c,y as u,b as f}from"./index-b6586f9b.js";import"./index-a61f225b.js";function a(){return{range:null,tempRange:null,tempRangeType:null,focus:null,edit:null,lastCell:null,nextFocus:null}}class h{constructor(){this.unsubscribe=[];this.store=t(a());this.store.on("set",((t,e)=>{if(t==="tempRange"&&!e){this.store.set("tempRangeType",null)}}))}onChange(t,e){this.unsubscribe.push(this.store.onChange(t,e))}clearFocus(){e(this.store,{focus:null,range:null,edit:null,tempRange:null})}setFocus(t,n){if(!n){e(this.store,{focus:t})}else{e(this.store,{focus:t,range:m(t,n),edit:null,tempRange:null})}}setNextFocus(t){e(this.store,{nextFocus:t})}setTempArea(t){e(this.store,{tempRange:t===null||t===void 0?void 0:t.area,tempRangeType:t===null||t===void 0?void 0:t.type,edit:null})}clearTemp(){e(this.store,{tempRange:null})}setRangeArea(t){e(this.store,{range:t,edit:null,tempRange:null})}setRange(t,e){const n=m(t,e);this.setRangeArea(n)}setLastCell(t){e(this.store,{lastCell:t})}setEdit(t){const n=this.store.get("focus");if(n&&typeof t==="string"){e(this.store,{edit:{x:n.x,y:n.y,val:t}});return}e(this.store,{edit:null})}dispose(){this.unsubscribe.forEach((t=>t()));this.store.dispose()}}const d=-1;class p{constructor(){this.dirty=false;this.stores={};this.columnStores={};this.rowStores={};this.storesByType={};this.storesXToType={};this.storesYToType={};this.sections=[]}get focusedStore(){var t;for(let e in this.stores){for(let n in this.stores[e]){const s=(t=this.stores[e][n])===null||t===void 0?void 0:t.store.get("focus");if(s){return{entity:this.stores[e][n],cell:s,position:{x:parseInt(n,10),y:parseInt(e,10)}}}}}return null}get edit(){var t;return(t=this.focusedStore)===null||t===void 0?void 0:t.entity.store.get("edit")}get focused(){var t;return(t=this.focusedStore)===null||t===void 0?void 0:t.entity.store.get("focus")}get selectedRange(){var t;return(t=this.focusedStore)===null||t===void 0?void 0:t.entity.store.get("range")}registerSection(t){if(!t){this.sections.length=0;this.dirty=true;return}if(this.sections.indexOf(t)===-1){this.sections.push(t)}}beforeUpdate(){if(this.dirty){for(let t in this.stores){for(let e in this.stores[t]){this.stores[t][e].dispose()}}this.dirty=false}}registerColumn(t,e){if(v(t)){return new h}if(this.columnStores[t]){return this.columnStores[t]}this.columnStores[t]=new h;this.storesByType[e]=t;this.storesXToType[t]=e;return this.columnStores[t]}registerRow(t,e){if(v(t)){return new h}if(this.rowStores[t]){return this.rowStores[t]}this.rowStores[t]=new h;this.storesByType[e]=t;this.storesYToType[t]=e;return this.rowStores[t]}register({x:t,y:e}){var n,s;if(v(t)||v(e)){return new h}if(!this.stores[e]){this.stores[e]={}}if(this.stores[e][t]){return this.stores[e][t]}this.stores[e][t]=new h;(n=this.stores[e][t])===null||n===void 0?void 0:n.onChange("range",(n=>{this.columnStores[t].setRangeArea(n);this.rowStores[e].setRangeArea(n)}));(s=this.stores[e][t])===null||s===void 0?void 0:s.store.on("dispose",(()=>this.destroy(t,e)));return this.stores[e][t]}destroy(t,e){var n,s;(n=this.columnStores[t])===null||n===void 0?void 0:n.dispose();(s=this.rowStores[e])===null||s===void 0?void 0:s.dispose();delete this.rowStores[e];delete this.columnStores[t];if(this.storesXToType[t]){const e=this.storesXToType[t];delete this.storesXToType[t];delete this.storesByType[e]}if(this.storesYToType[e]){const t=this.storesYToType[e];delete this.storesYToType[e];delete this.storesByType[t]}if(this.stores[e]){delete this.stores[e][t]}if(!Object.keys(this.stores[e]||{}).length){delete this.stores[e]}}setEditByCell(t,e){this.focusByCell(t,e,e);this.setEdit("")}beforeNextFocusCell(t){var e;if(!this.focusedStore){return}const n=this.focusedStore.entity.store.get("lastCell");const s=n&&this.getNextStore(t,this.focusedStore.position,n);(e=s===null||s===void 0?void 0:s.store)===null||e===void 0?void 0:e.setNextFocus(Object.assign(Object.assign({},t),s.item))}focusByCell(t,e,n){const s=this.stores[t.y][t.x];this.focus(s,{focus:e,end:n})}focus(t,{focus:e,end:n}){const s=this.getCurrentStorePointer(t);if(!s){return null}const i=t.store.get("lastCell");const o=i&&this.getNextStore(e,s,i);if(o===null||o===void 0?void 0:o.store){const t=Object.assign(Object.assign({},e),o.item);this.focus(o.store,{focus:t,end:t});return null}if(i){e=y(e,i);n=y(n,i)}t.setFocus(e,n);return e}getCurrentStorePointer(t){let e;for(let n in this.stores){for(let s in this.stores[n]){const i=this.stores[n][s];if(i!==t){i.clearFocus()}else{e={x:parseInt(s,10),y:parseInt(n,10)}}}}return e}getNextStore(t,e,n){const s=g(t,n);let i;if(s){Object.entries(s).forEach((([t,n])=>{let o;switch(t){case"x":o=this.getXStores(e.y);break;case"y":o=this.getYStores(e.x);break}if(n>=0){i=o[++e[t]]}else{i=o[--e[t]];const r=i===null||i===void 0?void 0:i.store.get("lastCell");if(r){s[t]=r[t]+n}}}))}return{store:i,item:s}}clearAll(){var t;for(let e in this.stores){for(let n in this.stores[e]){(t=this.stores[e][n])===null||t===void 0?void 0:t.clearFocus()}}}setEdit(t){if(!this.focusedStore){return}this.focusedStore.entity.setEdit(t)}selectAll(){for(let t in this.stores){for(let e in this.stores[t]){const n=this.stores[t][e];if(!n){continue}const s=n.store.get("lastCell");if(s){n.setRange({x:0,y:0},{x:s.x-1,y:s.y-1})}}}}getXStores(t){return this.stores[t]}getYStores(t){const e={};for(let n in this.stores){e[n]=this.stores[n][t]}return e}}function v(t){return t===d}function g(t,e){const n={};let s=["x","y"];for(let e of s){if(t[e]<0){n[e]=t[e];return n}}for(let i of s){if(t[i]>=e[i]){n[i]=t[i]-e[i];return n}}return null}function y(t,e){const n=Object.assign({},t);const s=["x","y"];for(const i of s){if(t[i]<0){n[i]=0}else if(t[i]>=e[i]){n[i]=e[i]-1}}return n}function m(t,e){return t&&e?{x:Math.min(t.x,e.x),y:Math.min(t.y,e.y),x1:Math.max(t.x,e.x),y1:Math.max(t.y,e.y)}:null}function x(t){return t.x===t.x1&&t.y===t.y1}function b(t){if(typeof t==="undefined"||t===null){return""}return t}function O(t,e){const n=e.cellParser?e.cellParser(t,e):t[e.prop];return b(n)}function j(t){if(t.pin){return t.pin}return"rgCol"}function C(t){const e={};for(const[n,s]of t.entries()){if(s.size){e[n]=s.size}}return e}function R(t){return!!t.children}function w(t,e=0,s){const i={columns:{rgCol:[],colPinStart:[],colPinEnd:[]},columnByProp:{},columnGrouping:{rgCol:[],colPinStart:[],colPinEnd:[]},maxLevel:e,sort:{}};return n(t,((t,n)=>{if(R(n)){return I(t,n,w(n.children,e+1,s),e)}const i=Object.assign(Object.assign({},n.columnType&&s&&s[n.columnType]),n);if(!i.pin){t.columns.rgCol.push(i)}else{t.columns[i.pin].push(i)}if(i.order){t.sort[i.prop]=i}if(!t.columnByProp[i.prop]){t.columnByProp[i.prop]=[]}t.columnByProp[i.prop].push(i);i.beforeSetup&&i.beforeSetup(i);return t}),i)}function I(t,e,n,i=0){const o=Object.assign(Object.assign({},e),{level:i,ids:[]});for(let e in n.columns){const i=e;const r=t.columns[i];const l=n.columns[i];if(s(r)&&s(l)){r.push(...l);if(l.length){t.columnGrouping[i].push(Object.assign(Object.assign({},o),{ids:l.map((t=>t.prop))}))}}}for(let e in n.columnGrouping){const s=e;const i=n.columnGrouping[s];t.columnGrouping[s].push(...i)}t.maxLevel=Math.max(t.maxLevel,n.maxLevel);t.sort=Object.assign(Object.assign({},t.sort),n.sort);return t}function S(t,e){for(const n of t){if(R(n)){const t=S(n.children,e);if(t){return t}}else if(n.prop===e){return n}}return undefined}function T(t,e){return S(t,e)}const A=`${i}-depth`;const M=`${i}-name`;const P=`${i}-id`;const E=`${i}-value`;const D=`${i}-column`;const $=`${i}-expanded`;const F=`${i}-original-index`;const G=`group-expand`;const N=`groupexpandclick`;const k="rgRow";function B(t,e){return t[e]||null}function J(t,e,{prevExpanded:n,expandedAll:s,getGroupValue:i=B}){const o=new Map;t.forEach(((t,n)=>{const s=e.map((e=>i(t,e)));const r=s.pop();let l=o;s.forEach((t=>{if(!l.has(t)){l.set(t,new Map)}l=l.get(t)}));if(!l.has(r)){l.set(r,[])}const c=l.get(r);c.push(Object.assign(Object.assign({},t),{[F]:n}))}));let r=-1;const l=e.length;const c={};const u={};const f={};const a=[];function h(t,e,i){const o=e.length;t.forEach(((t,l)=>{const d=[...e,l];const p=d.join(",");const v=i&&(!!s||!!(n===null||n===void 0?void 0:n[p]));a.push({[M]:l,[A]:o,[P]:JSON.stringify(d),[E]:p,[$]:v});r+=1;if(!v&&o){c[r]=true}if(Array.isArray(t)){t.forEach((t=>{r+=1;if(!v){c[r]=true}u[t[F]]=r;const e=d.map(((t,e)=>d.slice(0,e+1).join(",")));e.forEach((t=>{if(!f[t]){f[t]=[]}f[t].push(r)}))}));a.push(...t)}else{h(t,d,v)}}))}h(o,[],true);return{sourceWithGroups:a,depth:l,trimmed:c,oldNewIndexMap:u,childrenByGroup:f}}function L(t){return t&&t[M]}function V(t){return typeof(t===null||t===void 0?void 0:t[M])!=="undefined"}function W(t){return t&&typeof t[D]!=="undefined"}function Y(t,e){const n=t.length;let s=0;for(;s<n;s++){if(t[s]!==e[s]){return s}}return s}function q(t){const e=JSON.parse(t);if(!Array.isArray(e)){return null}return e}function z(t,e,n){const s=q(n[P]);if(!s){return false}const i=Y(t,s);return e[A]<i}function U(t,e,n){var s=-1,i=t.length;if(e<0){e=-e>i?0:i+e}n=n>i?i:n;if(n<0){n+=i}i=e>n?0:n-e>>>0;e>>>=0;var o=Array(i);while(++s<i){o[s]=t[s+e]}return o}function X(t,e,n){var s=t==null?0:t.length;if(!s){return[]}if(n&&typeof n!="number"&&o(t,e,n)){e=0;n=s}else{e=e==null?0:r(e);n=n===undefined?s:r(n)}return U(t,e,n)}class Z{get columns(){return l(this.source)}constructor(t,e){this.dataStore=t;this.source=e;this.unsubscribe=[];this.hasGrouping=false;this.unsubscribe.push(e.onChange("source",(t=>this.checkGrouping(t))));this.checkGrouping(e.get("source"));this.type=e.get("type")}checkGrouping(t){for(let e of t){if(W(e)){this.hasGrouping=true;return}this.hasGrouping=false}}isReadOnly(t,e){var n;const s=(n=this.columns[e])===null||n===void 0?void 0:n.readonly;if(typeof s==="function"){const n=this.rowDataModel(t,e);return s(n)}return!!s}mergeProperties(t,e,n,s,i){const o=Object.assign({},n);o.class=Object.assign(Object.assign({},typeof o.class==="string"?{[o.class]:true}:o.class),{[c]:true,[u]:this.isReadOnly(t,e)});const r=i===null||i===void 0?void 0:i(s);if(!r){return o}return K(o,r)}getRowClass(t,e){const n=f(this.dataStore,t)||{};return n[e]||""}getCellData(t,e){const n=this.rowDataModel(t,e);return b(n.model[n.prop])}getSaveData(t,e,n){const s=this.rowDataModel(t,e);if(typeof n==="undefined"){n=b(s.model[s.prop])}return{prop:s.prop,rowIndex:t,colIndex:e,val:n,model:s.model,colType:this.type,type:this.dataStore.get("type")}}getCellEditor(t,e,n){var s;const i=(s=this.columns[e])===null||s===void 0?void 0:s.editor;if(!i){return undefined}if(typeof i==="string"){return n[i]}return i}rowDataModel(t,e){const n=this.columns[e];const s=n===null||n===void 0?void 0:n.prop;const i=f(this.dataStore,t)||{};const o=i[s];const r=this.dataStore.get("type");return{prop:s,model:i,data:this.dataStore.get("source"),column:n,rowIndex:t,colIndex:e,colType:this.type,type:r,value:o}}getRangeData(t,e){var n;const s={};const i=t.oldRange.x1-t.oldRange.x+1;const o=t.oldRange.y1-t.oldRange.y+1;const r={};for(let l=t.newRange.y,c=0;l<t.newRange.y1+1;l++,c++){const u=t.oldRange.y+c%o;const a=f(this.dataStore,u)||{};for(let o=t.newRange.x,c=0;o<t.newRange.x1+1;o++,c++){if(l>=t.oldRange.y&&l<=t.oldRange.y1&&o>=t.oldRange.x&&o<=t.oldRange.x1){continue}if(!this.columns[o]){continue}const f=(n=this.columns[o])===null||n===void 0?void 0:n.prop;const h=t.oldRange.x+c%i;const d=e[h].prop;if(!this.isReadOnly(l,o)){if(!s[l]){s[l]={}}s[l][f]=a[d];if(!r[l]){r[l]={}}r[l][f]={colIndex:h,colProp:d,rowIndex:u}}}}return{changed:s,mapping:r}}getTransformedDataToApply(t,e){const n={};const s=e.length;const i=this.columns.length;const o=this.dataStore.get("items").length;let r=t.y;let l=0;for(let c=0;r<o&&c<s;r++,c++){const o=e[c%s];const u=(o===null||o===void 0?void 0:o.length)||0;let f=t.x;for(let t=0;f<i&&t<u;f++,t++){const e=this.columns[f].prop;const s=t%i;if(!this.isReadOnly(r,f)){if(!n[r]){n[r]={}}n[r][e]=o[s]}}l=Math.max(l,f-1)}const c=m(t,{y:r-1,x:l});return{changed:n,range:c}}getRangeStaticData(t,e){const n={};for(let s=t.y,i=0;s<t.y1+1;s++,i++){for(let i=t.x,o=0;i<t.x1+1;i++,o++){if(!this.columns[i]){continue}const t=this.columns[i].prop;if(!this.isReadOnly(s,i)){if(!n[s]){n[s]={}}n[s][t]=e}}}return n}getRangeTransformedToProps(t,e){var n;const s=[];const i=this.dataStore.get("type");for(let o=t.y,r=0;o<t.y1+1;o++,r++){for(let r=t.x,l=0;r<t.x1+1;r++,l++){const t=(n=this.columns[r])===null||n===void 0?void 0:n.prop;s.push({prop:t,rowIndex:o,colIndex:r,model:f(e,o),type:i,colType:this.type})}}return s}copyRangeArray(t,e){const n=[...this.columns];const s=X(n,t.x,t.x1+1).map((t=>t.prop));const i=[];const o={};for(let n=t.y;n<=t.y1;n++){const t=[];o[n]={};for(let i of s){const s=f(e,n);if(!s){continue}const r=s[i];t.push(r);o[n][i]=r}i.push(t)}return{data:i,mapping:o}}destroy(){this.unsubscribe.forEach((t=>t()))}}function _(t,e){if(typeof t==="function"){return t(e)}return!!t}function H(t={},e={}){if(typeof t==="string"){t={[t]:true}}if(typeof e==="string"){e={[e]:true}}return Object.assign(Object.assign({},t),e)}function K(t,e){if(e.className){e.class=H(e.class,e.className);delete e.className}let n=Object.assign(Object.assign({},e),t);if(e.class){n.class=H(n.class,e.class)}if(e.style){n.style=Object.assign(Object.assign({},e.style),n.style)}return n}export{G as A,M as B,Z as C,_ as D,d as E,$ as G,E as P,h as S,x as a,b,y as c,O as d,j as e,C as f,m as g,R as h,v as i,w as j,I as k,T as l,V as m,g as n,L as o,K as p,q,z as r,A as s,P as t,k as u,D as v,N as w,J as x,W as y,p as z};
|
|
5
|
+
//# sourceMappingURL=column.service-407956dd.js.map
|