@polygrid/core 1.0.1 → 1.0.2

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 (274) hide show
  1. package/package.json +39 -12
  2. package/postcss.config.cjs +3 -0
  3. package/src/api/index.ts +15 -0
  4. package/src/api/set-columns.ts +8 -0
  5. package/src/api/set-data.ts +8 -0
  6. package/src/api/set-grid-id.ts +7 -0
  7. package/src/engine/const/pg-css-class.ts +24 -0
  8. package/src/engine/core/grid-dom.ts +26 -0
  9. package/src/engine/core/grid.ts +77 -0
  10. package/src/engine/core/interfaces/grid-options.ts +8 -0
  11. package/src/engine/core/methods/add-dom-listener.ts +14 -0
  12. package/src/engine/core/methods/consume-options.ts +32 -0
  13. package/src/engine/core/methods/index.ts +2 -0
  14. package/src/engine/core/methods/normalize-rows.ts +5 -0
  15. package/src/engine/debug.config.ts +3 -0
  16. package/src/engine/rx-lite/core/observable.ts +29 -0
  17. package/src/engine/rx-lite/core/subject.ts +21 -0
  18. package/src/engine/rx-lite/interfaces/observable-like.ts +6 -0
  19. package/src/engine/rx-lite/interfaces/pipe-fn.ts +18 -0
  20. package/src/engine/rx-lite/operators/combine-latest-any.ts +51 -0
  21. package/src/engine/rx-lite/operators/combine-latest.ts +30 -0
  22. package/src/engine/rx-lite/operators/distinct-until-array-changed.ts +22 -0
  23. package/src/engine/rx-lite/operators/distinct-until-changed.ts +20 -0
  24. package/src/engine/rx-lite/operators/filter.ts +11 -0
  25. package/src/engine/rx-lite/operators/map.ts +9 -0
  26. package/src/engine/rx-lite/operators/select-keyed.ts +31 -0
  27. package/src/engine/rx-lite/operators/select.ts +26 -0
  28. package/src/engine/rx-lite/operators/skip.ts +18 -0
  29. package/src/engine/rx-lite/operators/takeuntil.ts +18 -0
  30. package/src/engine/rx-lite/types/operator.ts +3 -0
  31. package/src/engine/services/column/column.ts +30 -0
  32. package/src/engine/services/column/index.ts +1 -0
  33. package/src/engine/services/column/interfaces/column.ts +6 -0
  34. package/src/engine/services/column/methods/index.ts +2 -0
  35. package/src/engine/services/column/methods/resolve-column-widths.ts +46 -0
  36. package/src/engine/services/column/methods/set-columns.ts +28 -0
  37. package/{types/engine/services/column/types/column-width-state.d.ts → src/engine/services/column/types/column-width-state.ts} +1 -2
  38. package/src/engine/services/data/data.ts +27 -0
  39. package/src/engine/services/data/index.ts +1 -0
  40. package/src/engine/services/data/methods/index.ts +1 -0
  41. package/src/engine/services/data/methods/set-rows.ts +18 -0
  42. package/src/engine/services/layout/index.ts +1 -0
  43. package/src/engine/services/layout/layout.ts +100 -0
  44. package/src/engine/services/layout/methods/add-scroll-event-listeners.ts +38 -0
  45. package/src/engine/services/layout/methods/adjust-viewport.ts +66 -0
  46. package/src/engine/services/layout/methods/apply-column-widths.ts +17 -0
  47. package/src/engine/services/layout/methods/compute-column-widths.ts +23 -0
  48. package/src/engine/services/layout/methods/compute-total-row-height.ts +16 -0
  49. package/src/engine/services/layout/methods/index.ts +12 -0
  50. package/src/engine/services/layout/methods/initialize-layout-pipeline.ts +39 -0
  51. package/src/engine/services/layout/methods/resize-body.ts +15 -0
  52. package/src/engine/services/layout/methods/resize-v-scrollbar.ts +15 -0
  53. package/src/engine/services/layout/methods/set-cell-width.ts +21 -0
  54. package/src/engine/services/layout/methods/set-grid-id.ts +14 -0
  55. package/src/engine/services/layout/methods/set-up-resize-observer.ts +25 -0
  56. package/src/engine/services/layout/methods/update-column-widths.ts +28 -0
  57. package/src/engine/services/renderer/index.ts +1 -0
  58. package/src/engine/services/renderer/methods/index.ts +1 -0
  59. package/src/engine/services/renderer/methods/re-render-cells.ts +31 -0
  60. package/src/engine/services/renderer/parts/body/body.ts +34 -0
  61. package/src/engine/services/renderer/parts/body/cell.ts +12 -0
  62. package/src/engine/services/renderer/parts/body/row.ts +26 -0
  63. package/src/engine/services/renderer/parts/footer/footer-cells.ts +15 -0
  64. package/src/engine/services/renderer/parts/footer/footer.ts +24 -0
  65. package/src/engine/services/renderer/parts/grid/grid.ts +21 -0
  66. package/src/engine/services/renderer/parts/header/header-cells.ts +15 -0
  67. package/src/engine/services/renderer/parts/header/header.ts +24 -0
  68. package/src/engine/services/renderer/parts/root/root.ts +22 -0
  69. package/src/engine/services/renderer/parts/scrollbars/h-scrollbar.ts +21 -0
  70. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.ts +8 -0
  71. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.ts +8 -0
  72. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.ts +8 -0
  73. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar.ts +34 -0
  74. package/src/engine/services/renderer/parts/viewport/viewport.ts +32 -0
  75. package/src/engine/services/renderer/renderer.ts +23 -0
  76. package/src/engine/services/row/index.ts +1 -0
  77. package/src/engine/services/row/interfaces/row.ts +4 -0
  78. package/src/engine/services/row/methods/index.ts +0 -0
  79. package/src/engine/services/row/row.ts +10 -0
  80. package/src/engine/services/services.ts +26 -0
  81. package/src/engine/store/interfaces/grid-state.ts +20 -0
  82. package/src/engine/store/methods/create-initial-state.ts +20 -0
  83. package/src/engine/store/methods/create-tracked-proxy.ts +60 -0
  84. package/src/engine/store/methods/debug.ts +29 -0
  85. package/src/engine/store/store.ts +85 -0
  86. package/src/engine/store/types/state-key.ts +3 -0
  87. package/src/engine/store/types/store-mutation.ts +5 -0
  88. package/src/index.ts +1 -0
  89. package/src/styles/body.css +13 -0
  90. package/src/styles/cell.css +15 -0
  91. package/src/styles/footer.css +30 -0
  92. package/src/styles/grid.css +5 -0
  93. package/src/styles/header.css +25 -0
  94. package/src/styles/index.css +9 -0
  95. package/src/styles/root.css +12 -0
  96. package/src/styles/row.css +12 -0
  97. package/src/styles/scrollbar.css +50 -0
  98. package/src/styles/viewport.css +6 -0
  99. package/src/styles.d.ts +1 -0
  100. package/tsconfig.json +23 -0
  101. package/polygrid.css +0 -1
  102. package/polygrid.es.js +0 -658
  103. package/polygrid.umd.js +0 -1
  104. package/types/api/index.d.ts +0 -9
  105. package/types/api/index.d.ts.map +0 -1
  106. package/types/api/set-columns.d.ts +0 -4
  107. package/types/api/set-columns.d.ts.map +0 -1
  108. package/types/api/set-data.d.ts +0 -3
  109. package/types/api/set-data.d.ts.map +0 -1
  110. package/types/api/set-grid-id.d.ts +0 -3
  111. package/types/api/set-grid-id.d.ts.map +0 -1
  112. package/types/engine/const/pg-css-class.d.ts +0 -25
  113. package/types/engine/const/pg-css-class.d.ts.map +0 -1
  114. package/types/engine/core/grid-dom.d.ts +0 -23
  115. package/types/engine/core/grid-dom.d.ts.map +0 -1
  116. package/types/engine/core/grid.d.ts +0 -19
  117. package/types/engine/core/grid.d.ts.map +0 -1
  118. package/types/engine/core/interfaces/grid-options.d.ts +0 -8
  119. package/types/engine/core/interfaces/grid-options.d.ts.map +0 -1
  120. package/types/engine/core/methods/add-dom-listener.d.ts +0 -3
  121. package/types/engine/core/methods/add-dom-listener.d.ts.map +0 -1
  122. package/types/engine/core/methods/consume-options.d.ts +0 -4
  123. package/types/engine/core/methods/consume-options.d.ts.map +0 -1
  124. package/types/engine/core/methods/index.d.ts +0 -3
  125. package/types/engine/core/methods/index.d.ts.map +0 -1
  126. package/types/engine/core/methods/normalize-rows.d.ts +0 -3
  127. package/types/engine/core/methods/normalize-rows.d.ts.map +0 -1
  128. package/types/engine/debug.config.d.ts +0 -4
  129. package/types/engine/debug.config.d.ts.map +0 -1
  130. package/types/engine/rx-lite/core/observable.d.ts +0 -9
  131. package/types/engine/rx-lite/core/observable.d.ts.map +0 -1
  132. package/types/engine/rx-lite/core/subject.d.ts +0 -9
  133. package/types/engine/rx-lite/core/subject.d.ts.map +0 -1
  134. package/types/engine/rx-lite/interfaces/observable-like.d.ts +0 -6
  135. package/types/engine/rx-lite/interfaces/observable-like.d.ts.map +0 -1
  136. package/types/engine/rx-lite/interfaces/pipe-fn.d.ts +0 -9
  137. package/types/engine/rx-lite/interfaces/pipe-fn.d.ts.map +0 -1
  138. package/types/engine/rx-lite/operators/combine-latest-any.d.ts +0 -7
  139. package/types/engine/rx-lite/operators/combine-latest-any.d.ts.map +0 -1
  140. package/types/engine/rx-lite/operators/combine-latest.d.ts +0 -7
  141. package/types/engine/rx-lite/operators/combine-latest.d.ts.map +0 -1
  142. package/types/engine/rx-lite/operators/distinct-until-array-changed.d.ts +0 -4
  143. package/types/engine/rx-lite/operators/distinct-until-array-changed.d.ts.map +0 -1
  144. package/types/engine/rx-lite/operators/distinct-until-changed.d.ts +0 -3
  145. package/types/engine/rx-lite/operators/distinct-until-changed.d.ts.map +0 -1
  146. package/types/engine/rx-lite/operators/filter.d.ts +0 -3
  147. package/types/engine/rx-lite/operators/filter.d.ts.map +0 -1
  148. package/types/engine/rx-lite/operators/map.d.ts +0 -3
  149. package/types/engine/rx-lite/operators/map.d.ts.map +0 -1
  150. package/types/engine/rx-lite/operators/select-keyed.d.ts +0 -5
  151. package/types/engine/rx-lite/operators/select-keyed.d.ts.map +0 -1
  152. package/types/engine/rx-lite/operators/select.d.ts +0 -5
  153. package/types/engine/rx-lite/operators/select.d.ts.map +0 -1
  154. package/types/engine/rx-lite/operators/skip.d.ts +0 -3
  155. package/types/engine/rx-lite/operators/skip.d.ts.map +0 -1
  156. package/types/engine/rx-lite/operators/takeuntil.d.ts +0 -4
  157. package/types/engine/rx-lite/operators/takeuntil.d.ts.map +0 -1
  158. package/types/engine/rx-lite/types/operator.d.ts +0 -3
  159. package/types/engine/rx-lite/types/operator.d.ts.map +0 -1
  160. package/types/engine/services/column/column.d.ts +0 -18
  161. package/types/engine/services/column/column.d.ts.map +0 -1
  162. package/types/engine/services/column/index.d.ts +0 -2
  163. package/types/engine/services/column/index.d.ts.map +0 -1
  164. package/types/engine/services/column/interfaces/column.d.ts +0 -7
  165. package/types/engine/services/column/interfaces/column.d.ts.map +0 -1
  166. package/types/engine/services/column/methods/index.d.ts +0 -3
  167. package/types/engine/services/column/methods/index.d.ts.map +0 -1
  168. package/types/engine/services/column/methods/resolve-column-widths.d.ts +0 -3
  169. package/types/engine/services/column/methods/resolve-column-widths.d.ts.map +0 -1
  170. package/types/engine/services/column/methods/set-columns.d.ts +0 -4
  171. package/types/engine/services/column/methods/set-columns.d.ts.map +0 -1
  172. package/types/engine/services/column/types/column-width-state.d.ts.map +0 -1
  173. package/types/engine/services/data/data.d.ts +0 -15
  174. package/types/engine/services/data/data.d.ts.map +0 -1
  175. package/types/engine/services/data/index.d.ts +0 -2
  176. package/types/engine/services/data/index.d.ts.map +0 -1
  177. package/types/engine/services/data/methods/index.d.ts +0 -2
  178. package/types/engine/services/data/methods/index.d.ts.map +0 -1
  179. package/types/engine/services/data/methods/set-rows.d.ts +0 -4
  180. package/types/engine/services/data/methods/set-rows.d.ts.map +0 -1
  181. package/types/engine/services/layout/index.d.ts +0 -2
  182. package/types/engine/services/layout/index.d.ts.map +0 -1
  183. package/types/engine/services/layout/layout.d.ts +0 -34
  184. package/types/engine/services/layout/layout.d.ts.map +0 -1
  185. package/types/engine/services/layout/methods/add-scroll-event-listeners.d.ts +0 -3
  186. package/types/engine/services/layout/methods/add-scroll-event-listeners.d.ts.map +0 -1
  187. package/types/engine/services/layout/methods/adjust-viewport.d.ts +0 -4
  188. package/types/engine/services/layout/methods/adjust-viewport.d.ts.map +0 -1
  189. package/types/engine/services/layout/methods/apply-column-widths.d.ts +0 -4
  190. package/types/engine/services/layout/methods/apply-column-widths.d.ts.map +0 -1
  191. package/types/engine/services/layout/methods/compute-column-widths.d.ts +0 -4
  192. package/types/engine/services/layout/methods/compute-column-widths.d.ts.map +0 -1
  193. package/types/engine/services/layout/methods/compute-total-row-height.d.ts +0 -4
  194. package/types/engine/services/layout/methods/compute-total-row-height.d.ts.map +0 -1
  195. package/types/engine/services/layout/methods/index.d.ts +0 -13
  196. package/types/engine/services/layout/methods/index.d.ts.map +0 -1
  197. package/types/engine/services/layout/methods/initialize-layout-pipeline.d.ts +0 -4
  198. package/types/engine/services/layout/methods/initialize-layout-pipeline.d.ts.map +0 -1
  199. package/types/engine/services/layout/methods/resize-body.d.ts +0 -4
  200. package/types/engine/services/layout/methods/resize-body.d.ts.map +0 -1
  201. package/types/engine/services/layout/methods/resize-v-scrollbar.d.ts +0 -4
  202. package/types/engine/services/layout/methods/resize-v-scrollbar.d.ts.map +0 -1
  203. package/types/engine/services/layout/methods/set-cell-width.d.ts +0 -2
  204. package/types/engine/services/layout/methods/set-cell-width.d.ts.map +0 -1
  205. package/types/engine/services/layout/methods/set-grid-id.d.ts +0 -4
  206. package/types/engine/services/layout/methods/set-grid-id.d.ts.map +0 -1
  207. package/types/engine/services/layout/methods/set-up-resize-observer.d.ts +0 -4
  208. package/types/engine/services/layout/methods/set-up-resize-observer.d.ts.map +0 -1
  209. package/types/engine/services/layout/methods/update-column-widths.d.ts +0 -4
  210. package/types/engine/services/layout/methods/update-column-widths.d.ts.map +0 -1
  211. package/types/engine/services/renderer/index.d.ts +0 -2
  212. package/types/engine/services/renderer/index.d.ts.map +0 -1
  213. package/types/engine/services/renderer/methods/index.d.ts +0 -2
  214. package/types/engine/services/renderer/methods/index.d.ts.map +0 -1
  215. package/types/engine/services/renderer/methods/re-render-cells.d.ts +0 -4
  216. package/types/engine/services/renderer/methods/re-render-cells.d.ts.map +0 -1
  217. package/types/engine/services/renderer/parts/body/body.d.ts +0 -4
  218. package/types/engine/services/renderer/parts/body/body.d.ts.map +0 -1
  219. package/types/engine/services/renderer/parts/body/cell.d.ts +0 -3
  220. package/types/engine/services/renderer/parts/body/cell.d.ts.map +0 -1
  221. package/types/engine/services/renderer/parts/body/row.d.ts +0 -4
  222. package/types/engine/services/renderer/parts/body/row.d.ts.map +0 -1
  223. package/types/engine/services/renderer/parts/footer/footer-cells.d.ts +0 -3
  224. package/types/engine/services/renderer/parts/footer/footer-cells.d.ts.map +0 -1
  225. package/types/engine/services/renderer/parts/footer/footer.d.ts +0 -4
  226. package/types/engine/services/renderer/parts/footer/footer.d.ts.map +0 -1
  227. package/types/engine/services/renderer/parts/grid/grid.d.ts +0 -4
  228. package/types/engine/services/renderer/parts/grid/grid.d.ts.map +0 -1
  229. package/types/engine/services/renderer/parts/header/header-cells.d.ts +0 -3
  230. package/types/engine/services/renderer/parts/header/header-cells.d.ts.map +0 -1
  231. package/types/engine/services/renderer/parts/header/header.d.ts +0 -4
  232. package/types/engine/services/renderer/parts/header/header.d.ts.map +0 -1
  233. package/types/engine/services/renderer/parts/root/root.d.ts +0 -4
  234. package/types/engine/services/renderer/parts/root/root.d.ts.map +0 -1
  235. package/types/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts +0 -3
  236. package/types/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts.map +0 -1
  237. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts +0 -2
  238. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts.map +0 -1
  239. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts +0 -2
  240. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts.map +0 -1
  241. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts +0 -2
  242. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts.map +0 -1
  243. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts +0 -3
  244. package/types/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts.map +0 -1
  245. package/types/engine/services/renderer/parts/viewport/viewport.d.ts +0 -4
  246. package/types/engine/services/renderer/parts/viewport/viewport.d.ts.map +0 -1
  247. package/types/engine/services/renderer/renderer.d.ts +0 -15
  248. package/types/engine/services/renderer/renderer.d.ts.map +0 -1
  249. package/types/engine/services/row/index.d.ts +0 -2
  250. package/types/engine/services/row/index.d.ts.map +0 -1
  251. package/types/engine/services/row/interfaces/row.d.ts +0 -5
  252. package/types/engine/services/row/interfaces/row.d.ts.map +0 -1
  253. package/types/engine/services/row/methods/index.d.ts +0 -2
  254. package/types/engine/services/row/methods/index.d.ts.map +0 -1
  255. package/types/engine/services/row/row.d.ts +0 -7
  256. package/types/engine/services/row/row.d.ts.map +0 -1
  257. package/types/engine/services/services.d.ts +0 -16
  258. package/types/engine/services/services.d.ts.map +0 -1
  259. package/types/engine/store/interfaces/grid-state.d.ts +0 -20
  260. package/types/engine/store/interfaces/grid-state.d.ts.map +0 -1
  261. package/types/engine/store/methods/create-initial-state.d.ts +0 -3
  262. package/types/engine/store/methods/create-initial-state.d.ts.map +0 -1
  263. package/types/engine/store/methods/create-tracked-proxy.d.ts +0 -3
  264. package/types/engine/store/methods/create-tracked-proxy.d.ts.map +0 -1
  265. package/types/engine/store/methods/debug.d.ts +0 -4
  266. package/types/engine/store/methods/debug.d.ts.map +0 -1
  267. package/types/engine/store/store.d.ts +0 -22
  268. package/types/engine/store/store.d.ts.map +0 -1
  269. package/types/engine/store/types/state-key.d.ts +0 -3
  270. package/types/engine/store/types/state-key.d.ts.map +0 -1
  271. package/types/engine/store/types/store-mutation.d.ts +0 -6
  272. package/types/engine/store/types/store-mutation.d.ts.map +0 -1
  273. package/types/index.d.ts +0 -4
  274. package/types/index.d.ts.map +0 -1
@@ -0,0 +1,30 @@
1
+ import type { PolyGrid } from "../../core/grid";
2
+ import type { GridDOM } from "../../core/grid-dom";
3
+ import type { ObservableLike } from "../../rx-lite/interfaces/observable-like";
4
+ import type { PolyGridStore } from "../../store/store";
5
+ import type { PolyGridColumn } from "./interfaces/column";
6
+ import * as methods from "./methods/index";
7
+
8
+ export class ColumnService {
9
+ store: PolyGridStore;
10
+ destroy$: ObservableLike<void>;
11
+ gridDom: GridDOM;
12
+ grid: PolyGrid;
13
+
14
+ columns$!: ObservableLike<PolyGridColumn[]>;
15
+
16
+ constructor(grid: PolyGrid) {
17
+ this.store = grid._store;
18
+ this.destroy$ = grid._destroy$;
19
+ this.gridDom = grid._gridDom;
20
+ this.grid = grid;
21
+ }
22
+
23
+ resolveColumnWidths = methods.resolveColumnWidths;
24
+ setColumns = methods.setColumns;
25
+
26
+ initApiSubscriptions() {
27
+ this.columns$ = this.store.selectKeyed("columns", (s) => s.columns);
28
+ methods.setColumns(this, this.destroy$);
29
+ }
30
+ }
@@ -0,0 +1 @@
1
+ export * from "./column";
@@ -0,0 +1,6 @@
1
+ export interface PolyGridColumn {
2
+ header: string;
3
+ field: string;
4
+ width?: number;
5
+ visible?: boolean;
6
+ }
@@ -0,0 +1,2 @@
1
+ export * from "./resolve-column-widths";
2
+ export * from "./set-columns";
@@ -0,0 +1,46 @@
1
+ import type { PolyGridColumn } from "../interfaces/column";
2
+ import type { ColumnWidthState } from "../types/column-width-state";
3
+
4
+ export function resolveColumnWidths(
5
+ columns: PolyGridColumn[],
6
+ gridWidth: number
7
+ ): number[] {
8
+ const explicit = columns.filter((c) => c.width != null);
9
+ const implicit = columns.filter((c) => c.width == null);
10
+
11
+ const totalExplicit = explicit.reduce(
12
+ (sum, c) => sum + (c.width as number),
13
+ 0
14
+ );
15
+
16
+ const state: ColumnWidthState =
17
+ explicit.length === columns.length
18
+ ? "ALL_SET"
19
+ : explicit.length === 0
20
+ ? "NOT_SET"
21
+ : "SOME_SET";
22
+
23
+ switch (state) {
24
+ case "ALL_SET":
25
+ if (totalExplicit >= gridWidth) {
26
+ return columns.map((c) => c.width as number);
27
+ } else {
28
+ const leftover = gridWidth - totalExplicit;
29
+ const bonus = leftover / columns.length;
30
+ return columns.map((c) => (c.width as number) + bonus);
31
+ }
32
+
33
+ case "SOME_SET":
34
+ if (totalExplicit >= gridWidth) {
35
+ return columns.map((c) => c.width ?? 0);
36
+ } else {
37
+ const leftover = gridWidth - totalExplicit;
38
+ const bonus = leftover / implicit.length;
39
+ return columns.map((c) => c.width ?? bonus);
40
+ }
41
+
42
+ case "NOT_SET":
43
+ const even = gridWidth / columns.length;
44
+ return columns.map(() => even);
45
+ }
46
+ }
@@ -0,0 +1,28 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import { updateColumnWidths } from "../../layout/methods";
4
+ import { reRenderCells } from "../../renderer/methods";
5
+ import type { ColumnService } from "../column";
6
+ import { resolveColumnWidths } from "./resolve-column-widths";
7
+
8
+ export function setColumns(
9
+ columnService: ColumnService,
10
+ destroy$: ObservableLike<void>
11
+ ) {
12
+ columnService.columns$.pipe(takeUntil(destroy$)).subscribe((columns) => {
13
+ const gridDom = columnService.gridDom;
14
+ // rerender cells
15
+ reRenderCells(gridDom, columnService.store);
16
+ // do everything else
17
+ const state = columnService.store.getState();
18
+ const cols = columns.filter((col) => col.visible ?? true);
19
+ const viewportWidth = state.viewportWidth;
20
+ const resolvedColWidths = resolveColumnWidths(cols, viewportWidth);
21
+ const totalColumnWidth = resolvedColWidths.reduce((a, b) => a + b, 0);
22
+ columnService.store.update((draft) => {
23
+ draft.resolvedColumnWidths = resolvedColWidths;
24
+ draft.totalColumnWidth = totalColumnWidth;
25
+ });
26
+ updateColumnWidths(gridDom, state, resolvedColWidths);
27
+ }, "SET-COLUMNS");
28
+ }
@@ -1,2 +1 @@
1
- export type ColumnWidthState = "ALL_SET" | "SOME_SET" | "NOT_SET";
2
- //# sourceMappingURL=column-width-state.d.ts.map
1
+ export type ColumnWidthState = "ALL_SET" | "SOME_SET" | "NOT_SET";
@@ -0,0 +1,27 @@
1
+ import type { PolyGrid } from "../../core/grid";
2
+ import type { GridDOM } from "../../core/grid-dom";
3
+ import type { ObservableLike } from "../../rx-lite/interfaces/observable-like";
4
+ import type { PolyGridStore } from "../../store/store";
5
+ import type { PolyGridRow } from "../row/interfaces/row";
6
+ import * as methods from "./methods/index";
7
+
8
+ export class DataService {
9
+ store: PolyGridStore;
10
+ destroy$: ObservableLike<void>;
11
+ gridDom: GridDOM;
12
+ grid: PolyGrid;
13
+
14
+ rows$!: ObservableLike<PolyGridRow[]>;
15
+
16
+ constructor(grid: PolyGrid) {
17
+ this.store = grid._store;
18
+ this.destroy$ = grid._destroy$;
19
+ this.gridDom = grid._gridDom;
20
+ this.grid = grid;
21
+ }
22
+
23
+ initApiSubscriptions() {
24
+ this.rows$ = this.store.selectKeyed("rows", (s) => s.rows);
25
+ methods.setRows(this, this.destroy$);
26
+ }
27
+ }
@@ -0,0 +1 @@
1
+ export * from "./data";
@@ -0,0 +1 @@
1
+ export * from "./set-rows";
@@ -0,0 +1,18 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import { updateColumnWidths } from "../../layout/methods";
4
+ import { reRenderCells } from "../../renderer/methods";
5
+ import type { DataService } from "../data";
6
+
7
+ export function setRows(
8
+ dataService: DataService,
9
+ destroy$: ObservableLike<void>
10
+ ) {
11
+ dataService.rows$.pipe(takeUntil(destroy$)).subscribe((rows) => {
12
+ const gridDom = dataService.gridDom;
13
+ const state = dataService.store.getState();
14
+ const resColWidths = state.resolvedColumnWidths;
15
+ reRenderCells(gridDom, dataService.store);
16
+ updateColumnWidths(gridDom, state, resColWidths);
17
+ }, "SET-DATA");
18
+ }
@@ -0,0 +1 @@
1
+ export * from "./layout";
@@ -0,0 +1,100 @@
1
+ import type { PolyGrid } from "../../core/grid";
2
+ import type { GridDOM } from "../../core/grid-dom";
3
+ import type { ObservableLike } from "../../rx-lite/interfaces/observable-like";
4
+ import { distinctUntilArrayChanged } from "../../rx-lite/operators/distinct-until-array-changed";
5
+ import { distinctUntilChanged } from "../../rx-lite/operators/distinct-until-changed";
6
+ import { filter } from "../../rx-lite/operators/filter";
7
+ import { map } from "../../rx-lite/operators/map";
8
+ import type { PolyGridStore } from "../../store/store";
9
+ import * as methods from "./methods/index";
10
+
11
+ export class LayoutService {
12
+ store: PolyGridStore;
13
+ destroy$: ObservableLike<void>;
14
+ gridDom: GridDOM;
15
+ grid: PolyGrid;
16
+
17
+ totalRowHeight$!: ObservableLike<number>;
18
+ viewportWidth$!: ObservableLike<number>;
19
+ resolvedColWidths$: ObservableLike<number[]>;
20
+ showVScrollbar$: ObservableLike<boolean>;
21
+ showHScrollbar$: ObservableLike<boolean>;
22
+ adjustedViewportWidth$: ObservableLike<[boolean, number]>;
23
+ adjustedViewportHeight$: ObservableLike<[boolean, number]>;
24
+ gridId$!: ObservableLike<string>;
25
+
26
+ constructor(grid: PolyGrid) {
27
+ this.store = grid._store;
28
+ this.destroy$ = grid._destroy$;
29
+ this.gridDom = grid._gridDom;
30
+ this.grid = grid;
31
+
32
+ this.totalRowHeight$ = this.store
33
+ .combineLatest([(s) => s.rows, (s) => s.rowHeight])
34
+ .pipe(
35
+ map(([rows, rowHeight]) => rows.length * rowHeight),
36
+ distinctUntilChanged()
37
+ );
38
+ this.viewportWidth$ = this.store
39
+ .select((s) => s.viewportWidth)
40
+ .pipe(distinctUntilChanged());
41
+ this.resolvedColWidths$ = this.store
42
+ .combineLatest([
43
+ (s) => s.resolvedColumnWidths,
44
+ (s) => s.viewportWidth,
45
+ (s) => s.rawViewportWidth,
46
+ ])
47
+ .pipe(
48
+ filter(
49
+ ([_, viewportWidth, rawViewportWidth]) =>
50
+ viewportWidth !== rawViewportWidth
51
+ ),
52
+ map(([resolvedColWidths]) => resolvedColWidths),
53
+ distinctUntilArrayChanged()
54
+ );
55
+ this.showVScrollbar$ = this.store
56
+ .combineLatest([(s) => s.totalRowHeight, (s) => s.rawViewportHeight])
57
+ .pipe(
58
+ map(
59
+ ([totalRowHeight, rawViewportHeight]) =>
60
+ totalRowHeight > rawViewportHeight
61
+ ),
62
+ distinctUntilChanged()
63
+ );
64
+ this.showHScrollbar$ = this.store
65
+ .combineLatest([(s) => s.totalColumnWidth, (s) => s.rawViewportWidth])
66
+ .pipe(
67
+ map(
68
+ ([totalColumnWidth, rawViewportWidth]) =>
69
+ totalColumnWidth > rawViewportWidth
70
+ ),
71
+ distinctUntilChanged()
72
+ );
73
+ this.adjustedViewportWidth$ = this.store.combineLatestAny([
74
+ this.showVScrollbar$,
75
+ (s) => s.rawViewportWidth,
76
+ ]);
77
+ this.adjustedViewportHeight$ = this.store.combineLatestAny([
78
+ this.showHScrollbar$,
79
+ (s) => s.rawViewportHeight,
80
+ ]);
81
+ }
82
+
83
+ resizeVScrollbar = methods.resizeVScrollbar;
84
+ resizeBody = methods.resizeBody;
85
+ computeTotalRowHeight = methods.computeTotalRowHeight;
86
+ addScrollEventListeners = methods.addScrollEventListeners;
87
+ computeColumnWidths = methods.computeColumnWidths;
88
+ setCellWidth = methods.setCellWidth;
89
+ applyColumnWidths = methods.applyColumnWidths;
90
+ adjustViewport = methods.adjustViewport;
91
+ initializeLayoutPipeline = methods.initializeLayoutPipeline;
92
+ setUpResizeObserver = methods.setUpResizeObserver;
93
+ setGridId = methods.setGridId;
94
+ updateColumnWidths = methods.updateColumnWidths;
95
+
96
+ initApiSubscriptions() {
97
+ this.gridId$ = this.store.selectKeyed("id", (s) => s.id);
98
+ methods.setGridId(this, this.destroy$);
99
+ }
100
+ }
@@ -0,0 +1,38 @@
1
+ import { addDomListener } from "../../../core/methods";
2
+ import type { LayoutService } from "../layout";
3
+
4
+ export function addScrollEventListeners(layoutService: LayoutService) {
5
+ const gridDom = layoutService.gridDom;
6
+ // vertical scroll bar scrolls body
7
+ addDomListener(gridDom, gridDom.vScrollInner, "scroll", () => {
8
+ const scrollTop = gridDom.vScrollInner.scrollTop;
9
+ if (gridDom.bodyViewport.scrollTop !== scrollTop) {
10
+ gridDom.bodyViewport.scrollTop = scrollTop;
11
+ }
12
+ });
13
+
14
+ // horizontal scroll bar scrolls header, footer, body
15
+ addDomListener(gridDom, gridDom.hScrollInner, "scroll", () => {
16
+ const scrollLeft = gridDom.hScrollInner.scrollLeft;
17
+ if (gridDom.bodyViewport.scrollLeft !== scrollLeft) {
18
+ gridDom.bodyViewport.scrollLeft = scrollLeft;
19
+ }
20
+ if (gridDom.headerViewport.scrollLeft !== scrollLeft) {
21
+ gridDom.headerViewport.scrollLeft = scrollLeft;
22
+ }
23
+ if (gridDom.footerViewport.scrollLeft !== scrollLeft) {
24
+ gridDom.footerViewport.scrollLeft = scrollLeft;
25
+ }
26
+ });
27
+
28
+ // wheel scrolls scrollbars
29
+ addDomListener(gridDom, gridDom.bodyViewport, "wheel", (e) => {
30
+ if (e.deltaY !== 0) {
31
+ gridDom.vScrollInner.scrollTop += e.deltaY;
32
+ }
33
+ if (e.deltaX !== 0) {
34
+ gridDom.hScrollInner.scrollLeft += e.deltaX;
35
+ }
36
+ e.preventDefault();
37
+ });
38
+ }
@@ -0,0 +1,66 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { distinctUntilChanged } from "../../../rx-lite/operators/distinct-until-changed";
3
+ import { filter } from "../../../rx-lite/operators/filter";
4
+ import { map } from "../../../rx-lite/operators/map";
5
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
6
+ import type { LayoutService } from "../layout";
7
+
8
+ export function adjustViewport(
9
+ layoutService: LayoutService,
10
+ destroy$: ObservableLike<void>
11
+ ) {
12
+ const gridDom = layoutService.gridDom;
13
+ layoutService.showVScrollbar$
14
+ .pipe(takeUntil(destroy$))
15
+ .subscribe((showVScrollbar) => {
16
+ layoutService.store.update((draft) => {
17
+ draft.showVScrollbar = showVScrollbar;
18
+ });
19
+ gridDom.vScrollbar.style.display = showVScrollbar ? "flex" : "none";
20
+ const lastRow = gridDom.body.querySelector(".pg-row:last-child");
21
+ lastRow?.classList.toggle("last-row", !showVScrollbar);
22
+ }, "SHOW-V-SCROLLBAR");
23
+ layoutService.showHScrollbar$
24
+ .pipe(takeUntil(destroy$))
25
+ .subscribe((showHScrollbar) => {
26
+ layoutService.store.update((draft) => {
27
+ draft.showHScrollbar = showHScrollbar;
28
+ });
29
+ gridDom.hScrollbar.style.display = showHScrollbar ? "block" : "none";
30
+ gridDom.vScrollBottomCorner.style.display = showHScrollbar
31
+ ? "block"
32
+ : "none";
33
+ }, "SHOW-H-SCROLLBAR");
34
+
35
+ layoutService.adjustedViewportWidth$
36
+ .pipe(
37
+ takeUntil(destroy$),
38
+ map(
39
+ ([showVScrollbar, rawViewportWidth]) =>
40
+ rawViewportWidth - (showVScrollbar ? 16 : 0)
41
+ ),
42
+ distinctUntilChanged(),
43
+ // ignore initial invalid values (rawViewportWidth = 0)
44
+ filter((viewportWidth) => viewportWidth >= 0)
45
+ )
46
+ .subscribe((viewportWidth) => {
47
+ layoutService.store.update((draft) => {
48
+ draft.viewportWidth = viewportWidth;
49
+ });
50
+ });
51
+ layoutService.adjustedViewportHeight$
52
+ .pipe(
53
+ takeUntil(destroy$),
54
+ map(
55
+ ([showHScrollbar, rawViewportHeight]) =>
56
+ rawViewportHeight - (showHScrollbar ? 16 : 0)
57
+ ),
58
+ distinctUntilChanged(),
59
+ filter((viewportHeight) => viewportHeight >= 0)
60
+ )
61
+ .subscribe((viewportHeight) => {
62
+ layoutService.store.update((draft) => {
63
+ draft.viewportHeight = viewportHeight;
64
+ });
65
+ });
66
+ }
@@ -0,0 +1,17 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import type { LayoutService } from "../layout";
4
+ import { updateColumnWidths } from "./update-column-widths";
5
+
6
+ export function applyColumnWidths(
7
+ layoutService: LayoutService,
8
+ destroy$: ObservableLike<void>
9
+ ) {
10
+ layoutService.resolvedColWidths$
11
+ .pipe(takeUntil(destroy$))
12
+ .subscribe((resolvedColWidths) => {
13
+ const gridDom = layoutService.gridDom;
14
+ const state = layoutService.store.getState();
15
+ updateColumnWidths(gridDom, state, resolvedColWidths);
16
+ }, "APPLY-COLUMN-WIDTHS");
17
+ }
@@ -0,0 +1,23 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import { resolveColumnWidths } from "../../column/methods";
4
+ import type { LayoutService } from "../layout";
5
+
6
+ export function computeColumnWidths(
7
+ layoutService: LayoutService,
8
+ destroy$: ObservableLike<void>
9
+ ) {
10
+ layoutService.viewportWidth$
11
+ .pipe(takeUntil(destroy$))
12
+ .subscribe((viewportWidth) => {
13
+ const columns = layoutService.store
14
+ .getState()
15
+ .columns.filter((col) => col.visible ?? true);
16
+ const resolvedColWidths = resolveColumnWidths(columns, viewportWidth);
17
+ const totalColumnWidth = resolvedColWidths.reduce((a, b) => a + b, 0);
18
+ layoutService.store.update((draft) => {
19
+ draft.resolvedColumnWidths = resolvedColWidths;
20
+ draft.totalColumnWidth = totalColumnWidth;
21
+ });
22
+ }, "RESOLVE-COLUMN-WIDTHS");
23
+ }
@@ -0,0 +1,16 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import type { LayoutService } from "../layout";
4
+
5
+ export function computeTotalRowHeight(
6
+ layoutService: LayoutService,
7
+ destroy$: ObservableLike<void>
8
+ ) {
9
+ layoutService.totalRowHeight$
10
+ .pipe(takeUntil(destroy$))
11
+ .subscribe((totalRowHeight) => {
12
+ layoutService.store.update((draft) => {
13
+ draft.totalRowHeight = totalRowHeight;
14
+ });
15
+ }, "SET-TOTALROWHEIGHT");
16
+ }
@@ -0,0 +1,12 @@
1
+ export * from "./compute-total-row-height";
2
+ export * from "./resize-v-scrollbar";
3
+ export * from "./resize-body";
4
+ export * from "./add-scroll-event-listeners";
5
+ export * from "./compute-column-widths";
6
+ export * from "./set-cell-width";
7
+ export * from "./apply-column-widths";
8
+ export * from "./adjust-viewport";
9
+ export * from "./initialize-layout-pipeline";
10
+ export * from "./set-up-resize-observer";
11
+ export * from "./set-grid-id";
12
+ export * from "./update-column-widths";
@@ -0,0 +1,39 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import type { LayoutService } from "../layout";
3
+
4
+ export function initializeLayoutPipeline(
5
+ layoutService: LayoutService,
6
+ destroy$: ObservableLike<void>
7
+ ) {
8
+ // --- PHASE 1: Fundamental metrics (row height, body height, scrollbar track) ---
9
+
10
+ // Compute total row height (rows × rowHeight)
11
+ layoutService.computeTotalRowHeight(layoutService, destroy$);
12
+
13
+ // Resize the vertical scrollbar track to match total row height
14
+ layoutService.resizeVScrollbar(layoutService, destroy$);
15
+
16
+ // Resize the body element to match total row height
17
+ layoutService.resizeBody(layoutService, destroy$);
18
+
19
+ // --- PHASE 2: Scrollbar visibility + viewport adjustment ---
20
+
21
+ // React to totalRowHeight + rawViewportHeight → showVScrollbar
22
+ // React to totalColumnWidth + rawViewportWidth → showHScrollbar
23
+ // Adjust viewportWidth/Height accordingly
24
+ layoutService.adjustViewport(layoutService, destroy$);
25
+
26
+ // --- PHASE 3: Column width resolution (depends on viewportWidth) ---
27
+
28
+ // Compute resolved column widths + totalColumnWidth
29
+ layoutService.computeColumnWidths(layoutService, destroy$);
30
+
31
+ // --- PHASE 4: Apply resolved column widths to DOM ---
32
+
33
+ // Apply column widths to header cells
34
+ layoutService.applyColumnWidths(layoutService, destroy$);
35
+
36
+ // --- PHASE 5: Scroll event syncing (body ↔ scrollbars) ---
37
+
38
+ layoutService.addScrollEventListeners(layoutService);
39
+ }
@@ -0,0 +1,15 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import type { LayoutService } from "../layout";
4
+
5
+ export function resizeBody(
6
+ layoutService: LayoutService,
7
+ destroy$: ObservableLike<void>
8
+ ) {
9
+ const gridDom = layoutService.gridDom;
10
+ layoutService.totalRowHeight$
11
+ .pipe(takeUntil(destroy$))
12
+ .subscribe((totalRowHeight) => {
13
+ gridDom.body.style.height = `${totalRowHeight}px`;
14
+ }, "RESIZE-BODY-HEIGHT");
15
+ }
@@ -0,0 +1,15 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import type { LayoutService } from "../layout";
4
+
5
+ export function resizeVScrollbar(
6
+ layoutService: LayoutService,
7
+ destroy$: ObservableLike<void>
8
+ ) {
9
+ const gridDom = layoutService.gridDom;
10
+ layoutService.totalRowHeight$
11
+ .pipe(takeUntil(destroy$))
12
+ .subscribe((totalRowHeight) => {
13
+ gridDom.vScrollTrack.style.height = `${totalRowHeight}px`;
14
+ }, "RESIZE-V-SCROLLBAR");
15
+ }
@@ -0,0 +1,21 @@
1
+ export function setCellWidth(
2
+ el: HTMLElement,
3
+ widths: number[],
4
+ vScrollbarVisible: boolean
5
+ ) {
6
+ const cells = el.children;
7
+
8
+ for (let i = 0; i < widths.length; i++) {
9
+ const cell = cells[i] as HTMLElement;
10
+ if (!cell) continue;
11
+
12
+ const w = widths[i] + "px";
13
+ cell.style.width = w;
14
+ cell.style.minWidth = w;
15
+ cell.style.maxWidth = w;
16
+
17
+ if (i === widths.length - 1) {
18
+ cell.classList.toggle("last-cell", !vScrollbarVisible);
19
+ }
20
+ }
21
+ }
@@ -0,0 +1,14 @@
1
+ import type { ObservableLike } from "../../../rx-lite/interfaces/observable-like";
2
+ import { takeUntil } from "../../../rx-lite/operators/takeuntil";
3
+ import type { LayoutService } from "../layout";
4
+
5
+ export function setGridId(
6
+ layoutService: LayoutService,
7
+ destroy$: ObservableLike<void>
8
+ ) {
9
+ const gridDom = layoutService.gridDom;
10
+ const grid = layoutService.grid;
11
+ layoutService.gridId$.pipe(takeUntil(destroy$)).subscribe((id) => {
12
+ gridDom.root.id = id;
13
+ }, "SET-GRID-ID");
14
+ }
@@ -0,0 +1,25 @@
1
+ import type { GridDOM } from "../../../core/grid-dom";
2
+ import type { PolyGridStore } from "../../../store/store";
3
+
4
+ export function setUpResizeObserver(
5
+ resizeObserver: ResizeObserver,
6
+ gridDom: GridDOM,
7
+ store: PolyGridStore
8
+ ) {
9
+ return (resizeObserver = new ResizeObserver((entries) => {
10
+ for (const entry of entries) {
11
+ const gridWidth = entry.contentRect.width;
12
+ const gridHeight = entry.contentRect.height;
13
+ const headerHeight =
14
+ gridDom.headerViewport.getBoundingClientRect().height;
15
+ const footerHeight =
16
+ gridDom.footerViewport.getBoundingClientRect().height;
17
+ store.update((draft) => {
18
+ draft.viewportWidth = gridWidth; // at this moment this is the full grid width without a v scroll bar
19
+ draft.viewportHeight = gridHeight - headerHeight - footerHeight; // at this moment this is the full grid height without a h scroll bar
20
+ draft.rawViewportWidth = gridWidth;
21
+ draft.rawViewportHeight = gridHeight - headerHeight - footerHeight;
22
+ });
23
+ }
24
+ }));
25
+ }
@@ -0,0 +1,28 @@
1
+ import type { GridDOM } from "../../../core/grid-dom";
2
+ import type { PolyGridState } from "../../../store/interfaces/grid-state";
3
+ import { setCellWidth } from "./set-cell-width";
4
+
5
+ export function updateColumnWidths(
6
+ gridDom: GridDOM,
7
+ state: PolyGridState,
8
+ resolvedColWidths: number[]
9
+ ) {
10
+ // set header, footer and body cell widths
11
+ setCellWidth(gridDom.header, resolvedColWidths, state.showVScrollbar);
12
+ setCellWidth(gridDom.footer, resolvedColWidths, state.showVScrollbar);
13
+ const bodyRows = gridDom.body.querySelectorAll(".pg-row");
14
+ bodyRows.forEach((row) => {
15
+ setCellWidth(row as HTMLElement, resolvedColWidths, state.showVScrollbar);
16
+ });
17
+ // set body width
18
+ const totalColWidth = resolvedColWidths.reduce((a, b) => a + b, 0);
19
+ gridDom.body.style.width = `${totalColWidth}px`;
20
+ // set header, footer width
21
+ gridDom.header.style.width = `${totalColWidth}px`;
22
+ gridDom.footer.style.width = `${totalColWidth}px`;
23
+ // set h-scrollbar width
24
+ gridDom.hScrollTrack.style.width = `${totalColWidth}px`;
25
+ // set viewport width
26
+ const viewportWidth = state.viewportWidth;
27
+ gridDom.viewport.style.width = `${viewportWidth}px`;
28
+ }
@@ -0,0 +1 @@
1
+ export * from "./renderer";
@@ -0,0 +1 @@
1
+ export * from "./re-render-cells";