@revolist/revogrid 4.22.1 → 4.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (120) hide show
  1. package/dist/cjs/{cell-renderer-BQdEGQXP.js → cell-renderer-DWJ9Px9f.js} +9 -3
  2. package/dist/cjs/{column.drag.plugin-RDjQhKCH.js → column.drag.plugin-CaEBDG-Q.js} +391 -256
  3. package/dist/cjs/{column.service-DXYMehqK.js → column.service-f612L4ql.js} +1 -1
  4. package/dist/cjs/{dimension.helpers-CiiNnlLa.js → dimension.helpers-B9HgANnM.js} +14 -145
  5. package/dist/cjs/{edit.utils-CecCfA4E.js → edit.utils-pKeiYFLJ.js} +1 -1
  6. package/dist/cjs/{header-cell-renderer-DGyBrK8I.js → header-cell-renderer-4yq9_WbM.js} +1 -1
  7. package/dist/cjs/index-DxaSE5uZ.js +136 -0
  8. package/dist/cjs/index.cjs.js +37 -32
  9. package/dist/cjs/revo-grid.cjs.entry.js +35 -15
  10. package/dist/cjs/revogr-attribution_7.cjs.entry.js +43 -25
  11. package/dist/cjs/revogr-clipboard_3.cjs.entry.js +10 -8
  12. package/dist/cjs/revogr-data_4.cjs.entry.js +26 -17
  13. package/dist/cjs/revogr-filter-panel.cjs.entry.js +2 -1
  14. package/dist/cjs/{text-editor-DnLZW1a-.js → text-editor-B4W-m-r-.js} +3 -3
  15. package/dist/cjs/{throttle-CfgQFkfR.js → throttle-BCwEuJJq.js} +59 -24
  16. package/dist/cjs/viewport.helpers-BND76K2j.js +140 -0
  17. package/dist/cjs/{viewport.store-q6YdR9mg.js → viewport.store-BlKQ4x9H.js} +16 -16
  18. package/dist/collection/components/data/revogr-data.js +5 -3
  19. package/dist/collection/components/header/header-group-renderer.js +1 -1
  20. package/dist/collection/components/header/header-renderer.js +1 -1
  21. package/dist/collection/components/header/revogr-header-style.css +13 -3
  22. package/dist/collection/components/header/revogr-header.js +5 -2
  23. package/dist/collection/components/order/order-row.service.js +6 -5
  24. package/dist/collection/components/overlay/keyboard.service.js +23 -1
  25. package/dist/collection/components/overlay/selection.utils.js +8 -6
  26. package/dist/collection/components/revoGrid/revo-grid.js +6 -5
  27. package/dist/collection/components/revoGrid/viewport.service.js +2 -1
  28. package/dist/collection/components/scroll/revogr-viewport-scroll.js +10 -6
  29. package/dist/collection/components/scrollable/revogr-scroll-virtual.js +4 -10
  30. package/dist/collection/plugins/filter/filter.panel.js +2 -1
  31. package/dist/collection/plugins/filter/filter.plugin.js +11 -4
  32. package/dist/collection/plugins/groupingRow/grouping.row.plugin.js +25 -1
  33. package/dist/collection/plugins/moveColumn/column.drag.plugin.js +4 -4
  34. package/dist/collection/plugins/sorting/sorting.func.js +173 -15
  35. package/dist/collection/plugins/sorting/sorting.plugin.js +167 -84
  36. package/dist/collection/plugins/sorting/sorting.sign.js +7 -1
  37. package/dist/collection/serve/controller.js +98 -37
  38. package/dist/collection/serve/data.js +273 -144
  39. package/dist/collection/services/dimension.provider.js +16 -1
  40. package/dist/collection/services/local.scroll.service.js +59 -24
  41. package/dist/collection/services/scroll.dimension.helpers.js +83 -0
  42. package/dist/collection/services/selection.store.connector.js +4 -1
  43. package/dist/collection/store/dimension/dimension.recalculate.plugin.js +22 -9
  44. package/dist/collection/store/dimension/dimension.store.js +4 -2
  45. package/dist/collection/store/vp/viewport.helpers.js +9 -0
  46. package/dist/collection/store/vp/viewport.store.js +5 -16
  47. package/dist/collection/utils/store.utils.js +3 -3
  48. package/dist/{revo-grid/cell-renderer-CALsEsnh.js → esm/cell-renderer-8UiGd-s7.js} +9 -3
  49. package/dist/esm/{column.drag.plugin-Dy5ztusn.js → column.drag.plugin-BsfhsfmB.js} +388 -255
  50. package/dist/esm/{column.service-CCvAi5l4.js → column.service-DbpulTog.js} +1 -1
  51. package/dist/{revo-grid/debounce-BfO9dz9v.js → esm/debounce-PCRWZliA.js} +1 -1
  52. package/dist/{revo-grid/dimension.helpers-DmIvjIa7.js → esm/dimension.helpers-CGKwSvw6.js} +7 -128
  53. package/dist/esm/{edit.utils-DYN6XZh8.js → edit.utils-Dnnbd0xG.js} +1 -1
  54. package/dist/{revo-grid/header-cell-renderer-DU8wKAbg.js → esm/header-cell-renderer-DGI2FAD8.js} +1 -1
  55. package/dist/esm/index-Db3qZoW5.js +127 -0
  56. package/dist/esm/index.js +11 -10
  57. package/dist/esm/revo-grid.entry.js +34 -14
  58. package/dist/esm/revogr-attribution_7.entry.js +42 -24
  59. package/dist/esm/revogr-clipboard_3.entry.js +11 -9
  60. package/dist/esm/revogr-data_4.entry.js +27 -18
  61. package/dist/esm/revogr-filter-panel.entry.js +3 -2
  62. package/dist/esm/{text-editor-DpCnd6Fq.js → text-editor-C3RUSwH5.js} +2 -2
  63. package/dist/esm/{throttle-ERvyruXb.js → throttle-CaUDyxyU.js} +60 -25
  64. package/dist/esm/viewport.helpers-CoCAvmZs.js +133 -0
  65. package/dist/{revo-grid/viewport.store-CFjDW-3l.js → esm/viewport.store-COAfzAyu.js} +15 -17
  66. package/dist/{esm/cell-renderer-CALsEsnh.js → revo-grid/cell-renderer-8UiGd-s7.js} +9 -3
  67. package/dist/revo-grid/{column.drag.plugin-Dy5ztusn.js → column.drag.plugin-BsfhsfmB.js} +388 -255
  68. package/dist/revo-grid/{column.service-CCvAi5l4.js → column.service-DbpulTog.js} +1 -1
  69. package/dist/{esm/debounce-BfO9dz9v.js → revo-grid/debounce-PCRWZliA.js} +1 -1
  70. package/dist/{esm/dimension.helpers-DmIvjIa7.js → revo-grid/dimension.helpers-CGKwSvw6.js} +7 -128
  71. package/dist/revo-grid/{edit.utils-DYN6XZh8.js → edit.utils-Dnnbd0xG.js} +1 -1
  72. package/dist/{esm/header-cell-renderer-DU8wKAbg.js → revo-grid/header-cell-renderer-DGI2FAD8.js} +1 -1
  73. package/dist/revo-grid/index-Db3qZoW5.js +127 -0
  74. package/dist/revo-grid/index.esm.js +11 -10
  75. package/dist/revo-grid/revo-grid.entry.js +34 -14
  76. package/dist/revo-grid/revogr-attribution_7.entry.js +42 -24
  77. package/dist/revo-grid/revogr-clipboard_3.entry.js +11 -9
  78. package/dist/revo-grid/revogr-data_4.entry.js +27 -18
  79. package/dist/revo-grid/revogr-filter-panel.entry.js +3 -2
  80. package/dist/revo-grid/{text-editor-DpCnd6Fq.js → text-editor-C3RUSwH5.js} +2 -2
  81. package/dist/revo-grid/{throttle-ERvyruXb.js → throttle-CaUDyxyU.js} +60 -25
  82. package/dist/revo-grid/viewport.helpers-CoCAvmZs.js +133 -0
  83. package/dist/{esm/viewport.store-CFjDW-3l.js → revo-grid/viewport.store-COAfzAyu.js} +15 -17
  84. package/dist/types/components/header/header-group-renderer.d.ts +1 -0
  85. package/dist/types/components/header/header-renderer.d.ts +1 -0
  86. package/dist/types/components/overlay/keyboard.service.d.ts +5 -0
  87. package/dist/types/plugins/groupingRow/grouping.row.plugin.d.ts +8 -0
  88. package/dist/types/plugins/sorting/sorting.func.d.ts +25 -2
  89. package/dist/types/plugins/sorting/sorting.plugin.d.ts +84 -9
  90. package/dist/types/plugins/sorting/sorting.sign.d.ts +5 -1
  91. package/dist/types/plugins/sorting/sorting.types.d.ts +46 -1
  92. package/dist/types/services/local.scroll.service.d.ts +10 -2
  93. package/dist/types/services/scroll.dimension.helpers.d.ts +20 -0
  94. package/dist/types/store/vp/viewport.helpers.d.ts +2 -0
  95. package/dist/types/types/interfaces.d.ts +11 -0
  96. package/hydrate/index.js +649 -365
  97. package/hydrate/index.mjs +649 -365
  98. package/package.json +1 -1
  99. package/standalone/column.service.js +1 -1
  100. package/standalone/data.store.js +1 -1
  101. package/standalone/debounce.js +1 -1
  102. package/standalone/dimension.helpers.js +1 -1
  103. package/standalone/index.js +1 -1
  104. package/standalone/local.scroll.timer.js +1 -1
  105. package/standalone/revo-grid.js +1 -1
  106. package/standalone/revogr-data2.js +1 -1
  107. package/standalone/revogr-filter-panel.js +1 -1
  108. package/standalone/revogr-header2.js +1 -1
  109. package/standalone/revogr-order-editor2.js +1 -1
  110. package/standalone/revogr-overlay-selection2.js +1 -1
  111. package/standalone/revogr-row-headers.js +1 -1
  112. package/standalone/revogr-row-headers2.js +1 -1
  113. package/standalone/revogr-scroll-virtual2.js +1 -1
  114. package/standalone/revogr-viewport-scroll2.js +1 -1
  115. package/standalone/selection.utils.js +1 -1
  116. package/standalone/throttle.js +1 -1
  117. package/standalone/toNumber.js +1 -1
  118. package/dist/cjs/viewport.helpers-BAovztDd.js +0 -58
  119. package/dist/esm/viewport.helpers-VXhsJZtn.js +0 -52
  120. package/dist/revo-grid/viewport.helpers-VXhsJZtn.js +0 -52
@@ -1,6 +1,6 @@
1
1
  import { BasePlugin } from '../base.plugin';
2
2
  import type { ColumnRegular, DimensionRows, PluginProviders } from "../../types/index";
3
- import type { SortingConfig, SortingOrder, SortingOrderFunction } from './sorting.types';
3
+ import type { SortingColumnMap, SortingColumnOrder, SortingConfig, SortingOrder, SortingOrderFunction } from './sorting.types';
4
4
  export * from './sorting.types';
5
5
  export * from './sorting.func';
6
6
  export * from './sorting.sign';
@@ -15,34 +15,109 @@ export * from './sorting.sign';
15
15
  */
16
16
  export declare class SortingPlugin extends BasePlugin {
17
17
  revogrid: HTMLRevoGridElement;
18
+ /**
19
+ * Current sorting order per column property.
20
+ */
18
21
  sorting?: SortingOrder;
22
+ /**
23
+ * Comparator functions indexed by column property.
24
+ *
25
+ * Multiple columns can be sorted at the same time.
26
+ */
19
27
  sortingFunc?: SortingOrderFunction;
20
28
  /**
21
- * Delayed sorting promise
29
+ * Column metadata for the current sorting state.
30
+ *
31
+ * Used internally to optimize default sorting without changing comparator
32
+ * functions or their public API contract.
33
+ */
34
+ private sortingColumns?;
35
+ /**
36
+ * Active sorting priority in click/config insertion order.
37
+ *
38
+ * Required for numeric column props because object key iteration does not
39
+ * preserve insertion order for integer-like keys.
40
+ */
41
+ private sortingOrder?;
42
+ /**
43
+ * Delayed sorting promise registered in the grid render job queue.
22
44
  */
23
45
  sortingPromise: (() => void) | null;
24
46
  /**
25
- * We need to sort only so often
47
+ * Debounced sorting entry point.
48
+ *
49
+ * Sorting can be requested by column changes, source changes, and header
50
+ * clicks in quick succession, so the actual sort is delayed and coalesced.
26
51
  */
27
- postponeSort: import("lodash").DebouncedFunc<(order?: SortingOrder, comparison?: SortingOrderFunction, ignoreViewportUpdate?: boolean) => void>;
52
+ postponeSort: import("lodash").DebouncedFunc<(order?: SortingOrder, comparison?: SortingOrderFunction, sortingColumns?: SortingColumnMap, sortingOrder?: SortingColumnOrder, ignoreViewportUpdate?: boolean) => void>;
28
53
  constructor(revogrid: HTMLRevoGridElement, providers: PluginProviders, config?: SortingConfig);
29
54
  /**
30
- * Entry point for sorting, waits for all delays, registers jobs
55
+ * Creates mutable sorting maps from current state when additive sorting is requested.
56
+ */
57
+ private createSortingState;
58
+ /**
59
+ * Stores normalized sorting state, clearing inactive empty maps.
60
+ */
61
+ private setSortingState;
62
+ /**
63
+ * Adds or replaces a column in a sorting state.
64
+ */
65
+ private setColumnSorting;
66
+ /**
67
+ * Removes a column from a sorting state.
68
+ */
69
+ private clearColumnSorting;
70
+ /**
71
+ * Normalizes external sorting configuration into internal order,
72
+ * comparator, and column metadata maps.
73
+ */
74
+ private applySortingConfig;
75
+ /**
76
+ * Schedules sorting before the next render.
77
+ *
78
+ * @param order - Active sorting order by column property.
79
+ * @param sortingFunc - Comparator functions by column property.
80
+ * @param sortingColumns - Column metadata by property.
81
+ * @param sortingOrder - Active sorting priority in click/config insertion order.
82
+ * @param ignoreViewportUpdate - Skips dimension position recalculation when true.
31
83
  */
32
84
  startSorting(order?: SortingOrder, sortingFunc?: SortingOrderFunction, ignoreViewportUpdate?: boolean): void;
85
+ startSorting(order?: SortingOrder, sortingFunc?: SortingOrderFunction, sortingColumns?: SortingColumnMap, sortingOrder?: SortingColumnOrder, ignoreViewportUpdate?: boolean): void;
33
86
  /**
34
- * Apply sorting to data on header click
35
- * If additive - add to existing sorting, multiple columns can be sorted
87
+ * Applies sorting requested by a sortable header click.
88
+ *
89
+ * @param column - Column that initiated sorting.
90
+ * @param additive - If true, add/remove this column from the current multi-sort state.
36
91
  */
37
92
  headerclick(column: ColumnRegular, additive: boolean): void;
93
+ /**
94
+ * Applies sorting state produced by a header click.
95
+ */
96
+ private applyHeaderSorting;
97
+ /**
98
+ * Runs a scheduled sort and resolves the render-blocking sorting promise.
99
+ *
100
+ * @param order - Active sorting order by column property.
101
+ * @param comparison - Comparator functions by column property.
102
+ * @param sortingColumns - Column metadata by property.
103
+ * @param sortingOrder - Active sorting priority in click/config insertion order.
104
+ * @param ignoreViewportUpdate - Skips dimension position recalculation when true.
105
+ */
38
106
  runSorting(order?: SortingOrder, comparison?: SortingOrderFunction, ignoreViewportUpdate?: boolean): void;
107
+ runSorting(order?: SortingOrder, comparison?: SortingOrderFunction, sortingColumns?: SortingColumnMap, sortingOrder?: SortingColumnOrder, ignoreViewportUpdate?: boolean): void;
39
108
  /**
40
- * Sort items by sorting function
109
+ * Sorts row proxy indexes by sorting functions.
110
+ *
41
111
  * @requires proxyItems applied to row store
42
112
  * @requires source applied to row store
43
113
  *
44
114
  * @param sorting - per column sorting
45
- * @param data - this.stores['rgRow'].store.get('source')
115
+ * @param sortingFunc - Comparator functions by column property.
116
+ * @param sortingColumns - Column metadata by property.
117
+ * @param sortingOrder - Active sorting priority in click/config insertion order.
118
+ * @param types - Row stores to sort.
119
+ * @param ignoreViewportUpdate - Skips dimension position recalculation when true.
46
120
  */
47
121
  sort(sorting?: SortingOrder, sortingFunc?: SortingOrderFunction, types?: DimensionRows[], ignoreViewportUpdate?: boolean): void;
122
+ sort(sorting?: SortingOrder, sortingFunc?: SortingOrderFunction, sortingColumns?: SortingColumnMap, sortingOrder?: SortingColumnOrder, types?: DimensionRows[], ignoreViewportUpdate?: boolean): void;
48
123
  }
@@ -1,6 +1,10 @@
1
1
  import { ColumnRegular } from "../../types/index";
2
+ import type { SortingColumnRender } from './sorting.types';
2
3
  type Props = {
3
- column: ColumnRegular;
4
+ column: ColumnRegular & SortingColumnRender;
4
5
  };
6
+ /**
7
+ * Renders sorting direction and optional additive sorting rank.
8
+ */
5
9
  export declare const SortingSign: ({ column }: Props) => any;
6
10
  export {};
@@ -1,14 +1,59 @@
1
- import type { CellCompareFunc, ColumnProp, Order } from "../../types/index";
1
+ import type { CellCompareFunc, ColumnProp, ColumnRegular, Order } from "../../types/index";
2
+ /**
3
+ * Current sorting order per column property.
4
+ */
2
5
  export type SortingOrder = Record<ColumnProp, Order>;
6
+ /**
7
+ * Comparator functions indexed by column property.
8
+ *
9
+ * Undefined comparator entries are treated as inactive sorting entries.
10
+ */
3
11
  export type SortingOrderFunction = Record<ColumnProp, CellCompareFunc | undefined>;
12
+ /**
13
+ * Column metadata indexed by column property.
14
+ *
15
+ * This is an internal companion map for `SortingOrderFunction`. It lets the
16
+ * sorting helper detect the default comparer path without mutating
17
+ * `CellCompareFunc` instances or changing the public comparator contract.
18
+ */
19
+ export type SortingColumnMap = Record<ColumnProp, Partial<ColumnRegular> | undefined>;
20
+ /**
21
+ * Active sorting priority in click/config insertion order.
22
+ *
23
+ * This is stored separately from `SortingOrder` because JavaScript object keys
24
+ * that look like integers are enumerated in numeric order, not insertion order.
25
+ */
26
+ export type SortingColumnOrder = ColumnProp[];
27
+ /**
28
+ * Header metadata used to display additive sort priority.
29
+ */
30
+ export type SortingColumnRender = {
31
+ /**
32
+ * One-based additive sorting rank.
33
+ */
34
+ sortIndex?: number;
35
+ };
36
+ /**
37
+ * Sorting information emitted after columns are set.
38
+ */
4
39
  export type ColumnSetEvent = {
5
40
  order: SortingOrder;
6
41
  };
42
+ /**
43
+ * External sorting configuration.
44
+ */
7
45
  export type SortingConfig = {
46
+ /**
47
+ * Columns to sort by.
48
+ */
8
49
  columns?: {
9
50
  prop: ColumnProp;
10
51
  order: Order;
11
52
  cellCompare?: CellCompareFunc;
12
53
  }[];
54
+ /**
55
+ * If true, merge provided columns with the current sorting state.
56
+ * If false or omitted, replace current sorting state.
57
+ */
13
58
  additive?: boolean;
14
59
  };
@@ -1,4 +1,5 @@
1
1
  import type { DimensionType, ViewPortScrollEvent } from "../types/index";
2
+ import { type ScrollDimension } from './scroll.dimension.helpers';
2
3
  interface Config {
3
4
  skipAnimationFrame?: boolean;
4
5
  runScroll(e: ViewPortScrollEvent): void;
@@ -10,6 +11,8 @@ type Params = {
10
11
  clientSize: number;
11
12
  virtualSize: number;
12
13
  maxSize?: number;
14
+ maxScrollSize?: number;
15
+ scrollDimension?: ScrollDimension;
13
16
  };
14
17
  /**
15
18
  * Based on content size, client size and virtual size
@@ -20,17 +23,22 @@ export default class LocalScrollService {
20
23
  private cfg;
21
24
  private preventArtificialScroll;
22
25
  private previousScroll;
26
+ private previousLogicalScroll;
23
27
  private params;
24
28
  constructor(cfg: Config);
25
29
  setParams(params: Params, dimension: DimensionType): void;
26
30
  setScroll(e: ViewPortScrollEvent): Promise<void>;
31
+ setScrollByDelta(e: ViewPortScrollEvent, currentPhysicalCoordinate: number): Promise<ViewPortScrollEvent>;
27
32
  /**
28
33
  * On scroll event started
29
34
  */
30
35
  scroll(coordinate: number, dimension: DimensionType, force?: boolean, delta?: number, outside?: boolean): void;
31
36
  private getParams;
32
- private wrapCoordinate;
37
+ private wrapPhysicalCoordinate;
38
+ private wrapLogicalCoordinate;
33
39
  private cancelScroll;
34
- private convert;
40
+ private toLogicalScrollCoordinate;
41
+ private toPhysicalCoordinate;
42
+ private toLogicalCoordinate;
35
43
  }
36
44
  export {};
@@ -0,0 +1,20 @@
1
+ export type ScrollDimensionInput = {
2
+ contentSize: number;
3
+ clientSize: number;
4
+ virtualSize?: number;
5
+ maxScrollSize?: number;
6
+ };
7
+ export type ScrollDimension = {
8
+ contentSize: number;
9
+ clientSize: number;
10
+ viewportSize: number;
11
+ physicalContentSize: number;
12
+ logicalScrollSize: number;
13
+ physicalScrollSize: number;
14
+ isCompressed: boolean;
15
+ toLogicalCoordinate(coordinate: number): number;
16
+ toPhysicalCoordinate(coordinate: number): number;
17
+ getRenderOffset(coordinate: number): number;
18
+ };
19
+ export declare function getMaxScrollSize(doc?: Document | undefined): number;
20
+ export declare function getScrollDimension({ contentSize, clientSize, virtualSize, maxScrollSize, }: ScrollDimensionInput): ScrollDimension;
@@ -1,6 +1,8 @@
1
1
  import type { DimensionSettingsState, PositionItem, ViewSettingSizeProp, ViewportStateItems, VirtualPositionItem, Range } from "../../types/index";
2
2
  export type DimensionDataViewport = Pick<DimensionSettingsState, 'indexes' | 'positionIndexes' | 'positionIndexToItem' | 'sizes' | 'originItemSize' | 'realSize'>;
3
3
  export type ItemsToUpdate = Pick<ViewportStateItems, 'items' | 'start' | 'end'>;
4
+ export declare function getViewportMaxCoordinate(dimension: Pick<DimensionSettingsState, 'realSize' | 'originItemSize'>, viewportSize: number, frameOffset?: number): number;
5
+ export declare function clampViewportCoordinate(coordinate: number, dimension: Pick<DimensionSettingsState, 'realSize' | 'originItemSize'>, viewportSize: number, frameOffset?: number): number;
4
6
  /**
5
7
  * Update items based on new scroll position
6
8
  * If viewport wasn't changed fully simple recombination of positions
@@ -509,6 +509,12 @@ export interface ViewportState extends ViewportStateItems {
509
509
  * Until virtualization is not disabled.
510
510
  */
511
511
  clientSize: number;
512
+ /**
513
+ * Difference between logical coordinate and browser-safe rendered coordinate.
514
+ * Internal scroll virtualization offset used when content exceeds browser
515
+ * native scroll size limits.
516
+ */
517
+ renderOffset?: number;
512
518
  }
513
519
  /**
514
520
  * `ViewSettingSizeProp` is a record that maps column or row indexes to their
@@ -625,6 +631,11 @@ export interface DimensionSettingsState extends DimensionCalc {
625
631
  * Represents the origin item size of the dimension.
626
632
  */
627
633
  originItemSize: number;
634
+ /**
635
+ * Internal render offset applied when logical scroll space is compressed into
636
+ * a browser-safe physical scroll range.
637
+ */
638
+ renderOffset?: number;
628
639
  }
629
640
  /**
630
641
  * Represents the mapping of dimension types to their corresponding observable stores.