@polygrid/core 1.0.0 → 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
package/package.json CHANGED
@@ -1,12 +1,39 @@
1
- {
2
- "name": "@polygrid/core",
3
- "version": "1.0.0",
4
- "description": "PolyGrid core library",
5
- "main": "polygrid.umd.js",
6
- "module": "polygrid.es.js",
7
- "types": "types/index.d.ts",
8
- "sideEffects": false,
9
- "license": "MIT",
10
- "author": "",
11
- "keywords": []
12
- }
1
+ {
2
+ "name": "@polygrid/core",
3
+ "version": "1.0.2",
4
+ "description": "",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.js",
11
+ "types": "./dist/index.d.ts"
12
+ },
13
+ "./*": {
14
+ "import": "./dist/*.js",
15
+ "types": "./dist/*.d.ts"
16
+ }
17
+ },
18
+ "scripts": {
19
+ "dev": "vite",
20
+ "clean": "rimraf dist angular/dist",
21
+ "build": "npm run clean && tsc --outDir dist && npm run build:css",
22
+ "build:angular": "npm run build --workspace=@polygrid/angular",
23
+ "build:all": "npm run clean && npm run build && npm run build:angular",
24
+ "build:css": "postcss src/styles/index.css -o dist/polygrid.css",
25
+ "preview": "vite preview"
26
+ },
27
+ "keywords": [],
28
+ "author": "",
29
+ "license": "ISC",
30
+ "devDependencies": {
31
+ "@types/node": "^25.0.3",
32
+ "postcss": "^8.5.6",
33
+ "postcss-cli": "^11.0.1",
34
+ "postcss-import": "^16.1.1",
35
+ "rimraf": "^6.1.2",
36
+ "typescript": "^5.9.3",
37
+ "vite": "^7.3.0"
38
+ }
39
+ }
@@ -0,0 +1,3 @@
1
+ module.exports = {
2
+ plugins: [require("postcss-import")],
3
+ };
@@ -0,0 +1,15 @@
1
+ import type { PolyGrid } from "../engine/core/grid";
2
+ import type { PolyGridColumn } from "../engine/services/column/interfaces/column";
3
+ import { setColumns } from "./set-columns";
4
+ import { setData } from "./set-data";
5
+ import { setGridId } from "./set-grid-id";
6
+
7
+ export type PolyGridApi = ReturnType<typeof createApi>;
8
+
9
+ export function createApi(grid: PolyGrid) {
10
+ return {
11
+ setGridId: (id: string) => setGridId(grid, id),
12
+ setData: (data: any[]) => setData(grid, data),
13
+ setColumns: (columns: PolyGridColumn[]) => setColumns(grid, columns),
14
+ };
15
+ }
@@ -0,0 +1,8 @@
1
+ import type { PolyGrid } from "../engine/core/grid";
2
+ import type { PolyGridColumn } from "../engine/services/column/interfaces/column";
3
+
4
+ export function setColumns(grid: PolyGrid, columns: PolyGridColumn[]) {
5
+ grid._store.update((draft) => {
6
+ draft.columns = columns;
7
+ });
8
+ }
@@ -0,0 +1,8 @@
1
+ import type { PolyGrid } from "../engine/core/grid";
2
+ import { normalizeRows } from "../engine/core/methods/normalize-rows";
3
+
4
+ export function setData(grid: PolyGrid, data: any[]) {
5
+ grid._store.update((draft) => {
6
+ draft.rows = normalizeRows(data);
7
+ });
8
+ }
@@ -0,0 +1,7 @@
1
+ import type { PolyGrid } from "../engine/core/grid";
2
+
3
+ export function setGridId(grid: PolyGrid, id: string) {
4
+ grid._store.update((draft) => {
5
+ draft.id = id;
6
+ });
7
+ }
@@ -0,0 +1,24 @@
1
+ export const PG_CSS_CLASS = {
2
+ root: "pg-root",
3
+ grid: "pg-grid",
4
+ viewport: "pg-viewport",
5
+ vScroll: "pg-v-scroll",
6
+ vScrollSpacerTop: "pg-v-scroll-spacer-top",
7
+ vScrollInner: "pg-v-scroll-inner",
8
+ vScrollTrack: "pg-v-scroll-track",
9
+ vScrollSpacerBottom: "pg-v-scroll-spacer-bottom",
10
+ vScrollBottomCorner: "pg-v-scroll-bottom-corner",
11
+ hScroll: "pg-h-scroll",
12
+ hScrollInner: "pg-h-scroll-inner",
13
+ hScrollTrack: "pg-h-scroll-track",
14
+ headerViewport: "pg-header-viewport",
15
+ header: "pg-header",
16
+ headerCell: "pg-header-cell",
17
+ bodyViewport: "pg-body-viewport",
18
+ body: "pg-body",
19
+ row: "pg-row",
20
+ cell: "pg-cell",
21
+ footerViewport: "pg-footer-viewport",
22
+ footer: "pg-footer",
23
+ footerCell: "pg-footer-cell",
24
+ } as const;
@@ -0,0 +1,26 @@
1
+ export class GridDOM {
2
+ root!: HTMLElement;
3
+ grid!: HTMLElement;
4
+ viewport!: HTMLElement;
5
+ headerViewport!: HTMLElement;
6
+ header!: HTMLElement;
7
+ bodyViewport!: HTMLElement;
8
+ body!: HTMLElement;
9
+ footerViewport!: HTMLElement;
10
+ footer!: HTMLElement;
11
+ hScrollbar!: HTMLElement;
12
+ hScrollInner!: HTMLElement;
13
+ hScrollTrack!: HTMLElement;
14
+ vScrollbar!: HTMLElement;
15
+ vScrollSpacerTop!: HTMLElement;
16
+ vScrollInner!: HTMLElement;
17
+ vScrollTrack!: HTMLElement;
18
+ vScrollSpacerBottom!: HTMLElement;
19
+ vScrollBottomCorner!: HTMLElement;
20
+
21
+ // A list of cleanup functions for DOM event listeners or other teardown logic.
22
+ // The main grid destroy() method will call each of these.
23
+ cleanups: Array<() => void> = [];
24
+
25
+ constructor() {}
26
+ }
@@ -0,0 +1,77 @@
1
+ import type { PolyGridOptions } from "./interfaces/grid-options";
2
+ import { renderRoot } from "../services/renderer/parts/root/root";
3
+ import { PolyGridStore } from "../store/store";
4
+ import { Subject } from "../rx-lite/core/subject";
5
+ import { PolyGridServices } from "../services/services";
6
+ import * as methods from "./methods/index";
7
+ import { GridDOM } from "./grid-dom";
8
+ import { createApi, type PolyGridApi } from "../../api";
9
+
10
+ export class PolyGrid {
11
+ private store: PolyGridStore;
12
+ private services: PolyGridServices;
13
+ private destroy$: Subject<void>;
14
+ private gridDom: GridDOM;
15
+ private resizeObserver!: ResizeObserver;
16
+
17
+ api: PolyGridApi;
18
+
19
+ constructor(hostElement: HTMLElement, options: PolyGridOptions) {
20
+ this.store = new PolyGridStore();
21
+ this.gridDom = new GridDOM();
22
+ this.destroy$ = new Subject<void>();
23
+ this.services = new PolyGridServices(this);
24
+
25
+ // process the options
26
+ methods.consumeOptions(this.store, options);
27
+
28
+ // render the root element
29
+ renderRoot(this.store, hostElement, this.gridDom);
30
+
31
+ // setting up a resize observer for the grid
32
+ this.resizeObserver = this.services.layout.setUpResizeObserver(
33
+ this.resizeObserver,
34
+ this.gridDom,
35
+ this.store
36
+ );
37
+ this.resizeObserver.observe(this.gridDom.grid);
38
+
39
+ // init layout pipeline
40
+ this.services.layout.initializeLayoutPipeline(
41
+ this.services.layout,
42
+ this.destroy$
43
+ );
44
+
45
+ // set up public api
46
+ this.api = createApi(this);
47
+
48
+ // init api subscriptions
49
+ this.services.layout.initApiSubscriptions();
50
+ this.services.data.initApiSubscriptions();
51
+ this.services.column.initApiSubscriptions();
52
+ this.services.renderer.initApiSubscriptions();
53
+
54
+ console.log("PolyGrid initialized");
55
+ }
56
+
57
+ destroy() {
58
+ this.destroy$.next();
59
+ this.destroy$.complete();
60
+ // cleanup event listeners
61
+ for (const fn of this.gridDom.cleanups) {
62
+ fn();
63
+ }
64
+ }
65
+
66
+ get _store() {
67
+ return this.store;
68
+ }
69
+
70
+ get _destroy$() {
71
+ return this.destroy$;
72
+ }
73
+
74
+ get _gridDom() {
75
+ return this.gridDom;
76
+ }
77
+ }
@@ -0,0 +1,8 @@
1
+ import type { PolyGridColumn } from "../../services/column/interfaces/column";
2
+
3
+ export interface PolyGridOptions {
4
+ id: string;
5
+ columns?: PolyGridColumn[];
6
+ data?: any[];
7
+ rowHeight?: number;
8
+ }
@@ -0,0 +1,14 @@
1
+ import type { GridDOM } from "../grid-dom";
2
+
3
+ export function addDomListener<K extends keyof HTMLElementEventMap>(
4
+ dom: GridDOM,
5
+ target: HTMLElement,
6
+ event: K,
7
+ handler: (ev: HTMLElementEventMap[K]) => void
8
+ ) {
9
+ target.addEventListener(event, handler);
10
+
11
+ dom.cleanups.push(() => {
12
+ target.removeEventListener(event, handler);
13
+ });
14
+ }
@@ -0,0 +1,32 @@
1
+ import { normalizeRows } from "./normalize-rows";
2
+ import type { PolyGridOptions } from "../interfaces/grid-options";
3
+ import type { PolyGridStore } from "../../store/store";
4
+
5
+ export function consumeOptions(store: PolyGridStore, options: PolyGridOptions) {
6
+ // assign id
7
+ store.update((draft) => (draft.id = options.id));
8
+
9
+ // assign columns
10
+ const cols = options.columns;
11
+ if (cols) {
12
+ store.update((state) => {
13
+ state.columns = cols;
14
+ });
15
+ }
16
+
17
+ // assign data
18
+ const data = options.data;
19
+ if (data) {
20
+ store.update((state) => {
21
+ state.rows = normalizeRows(data);
22
+ });
23
+ }
24
+
25
+ // assign row height
26
+ const rowHeight = options.rowHeight;
27
+ if (rowHeight) {
28
+ store.update((state) => {
29
+ state.rowHeight = rowHeight;
30
+ });
31
+ }
32
+ }
@@ -0,0 +1,2 @@
1
+ export * from "./consume-options";
2
+ export * from "./add-dom-listener";
@@ -0,0 +1,5 @@
1
+ import type { PolyGridRow } from "../../services/row/interfaces/row";
2
+
3
+ export function normalizeRows(data: any[]): PolyGridRow[] {
4
+ return data.map((item, index) => ({ index, data: item }));
5
+ }
@@ -0,0 +1,3 @@
1
+ export const DEBUG = true;
2
+ export const DEBUG_SHOW_FULL_STATE_DIFF = false;
3
+ export const DEBUG_SHOW_SUBSCR_LABEL = true;
@@ -0,0 +1,29 @@
1
+ import { DEBUG_SHOW_SUBSCR_LABEL } from "../../debug.config";
2
+ import type { ObservableLike } from "../interfaces/observable-like";
3
+ import type { Operator } from "../types/operator";
4
+
5
+ export class Observable<T> implements ObservableLike<T> {
6
+ constructor(
7
+ private _subscribe: (subscriber: (value: T) => void) => () => void
8
+ ) {}
9
+
10
+ subscribe(subscriber: (value: T) => void, label?: string) {
11
+ const wrapped = (value: T) => {
12
+ if (DEBUG_SHOW_SUBSCR_LABEL && label)
13
+ console.log(
14
+ `%cSubscription ${label ? `(${label})` : ""} reacted`,
15
+ "color:#9C27B0;font-weight:bold;"
16
+ );
17
+ subscriber(value);
18
+ };
19
+ return this._subscribe(wrapped);
20
+ }
21
+
22
+ pipe<R>(...operators: Operator<any, any>[]): ObservableLike<R> {
23
+ let result: ObservableLike<any> = this;
24
+ for (const op of operators) {
25
+ result = op(result);
26
+ }
27
+ return result as ObservableLike<R>;
28
+ }
29
+ }
@@ -0,0 +1,21 @@
1
+ import type { ObservableLike } from "../interfaces/observable-like";
2
+ import { Observable } from "./observable";
3
+
4
+ export class Subject<T> implements ObservableLike<T> {
5
+ private subscribers = new Set<(value: T) => void>();
6
+
7
+ subscribe(subscriber: (value: T) => void) {
8
+ this.subscribers.add(subscriber);
9
+ return () => this.subscribers.delete(subscriber);
10
+ }
11
+
12
+ next(value: T) {
13
+ this.subscribers.forEach((s) => s(value));
14
+ }
15
+
16
+ complete() {
17
+ this.subscribers.clear();
18
+ }
19
+
20
+ pipe = Observable.prototype.pipe;
21
+ }
@@ -0,0 +1,6 @@
1
+ import type { PipeFn } from "./pipe-fn";
2
+
3
+ export interface ObservableLike<T> {
4
+ subscribe(subscriber: (value: T) => void, label?: string): () => void;
5
+ pipe: PipeFn<T>;
6
+ }
@@ -0,0 +1,18 @@
1
+ import type { Operator } from "../types/operator";
2
+ import type { ObservableLike } from "./observable-like";
3
+
4
+ export interface PipeFn<T> {
5
+ <A>(op1: Operator<T, A>): ObservableLike<A>;
6
+ <A, B>(op1: Operator<T, A>, op2: Operator<A, B>): ObservableLike<B>;
7
+ <A, B, C>(
8
+ op1: Operator<T, A>,
9
+ op2: Operator<A, B>,
10
+ op3: Operator<B, C>
11
+ ): ObservableLike<C>;
12
+ <A, B, C, D>(
13
+ op1: Operator<T, A>,
14
+ op2: Operator<A, B>,
15
+ op3: Operator<B, C>,
16
+ op4: Operator<C, D>
17
+ ): ObservableLike<D>;
18
+ }
@@ -0,0 +1,51 @@
1
+ import type { PolyGridState } from "../../store/interfaces/grid-state";
2
+ import type { PolyGridStore } from "../../store/store";
3
+ import { Observable } from "../core/observable";
4
+ import type { ObservableLike } from "../interfaces/observable-like";
5
+
6
+ export function createCombineLatestAny<T extends any[]>(
7
+ store: PolyGridStore,
8
+ sources: {
9
+ [K in keyof T]: ((state: PolyGridState) => T[K]) | ObservableLike<T[K]>;
10
+ }
11
+ ): ObservableLike<T> {
12
+ return new Observable<T>((subscriber) => {
13
+ const values = new Array(sources.length) as T;
14
+ const ready = new Array(sources.length).fill(false);
15
+
16
+ const unsubscribers = sources.map((src, index) => {
17
+ // --- CASE 1: Selector ---
18
+ if (typeof src === "function") {
19
+ const selector = src as (state: PolyGridState) => T[typeof index];
20
+ // Initial value
21
+ values[index] = selector(store.getState());
22
+ ready[index] = true;
23
+
24
+ // Subscribe to selector
25
+ return store.select(selector).subscribe((newValue) => {
26
+ values[index] = newValue;
27
+ subscriber([...values] as T);
28
+ });
29
+ }
30
+
31
+ // --- CASE 2: Observable ---
32
+ const obs = src as ObservableLike<T[typeof index]>;
33
+ return obs.subscribe((newValue) => {
34
+ values[index] = newValue;
35
+ ready[index] = true;
36
+
37
+ // Emit only when all sources have emitted at least once
38
+ if (ready.every(Boolean)) {
39
+ subscriber([...values] as T);
40
+ }
41
+ });
42
+ });
43
+
44
+ // Emit initial values if all selectors were ready
45
+ if (ready.every(Boolean)) {
46
+ subscriber([...values] as T);
47
+ }
48
+
49
+ return () => unsubscribers.forEach((u) => u());
50
+ });
51
+ }
@@ -0,0 +1,30 @@
1
+ import type { PolyGridState } from "../../store/interfaces/grid-state";
2
+ import type { ObservableLike } from "../interfaces/observable-like";
3
+ import type { PolyGridStore } from "../../store/store";
4
+ import { Observable } from "../core/observable";
5
+
6
+ export function createCombineLatest<T extends any[]>(
7
+ store: PolyGridStore,
8
+ selectors: { [K in keyof T]: (state: PolyGridState) => T[K] }
9
+ ): ObservableLike<T> {
10
+ return new Observable<T>((subscriber) => {
11
+ // Initial values
12
+ let values = selectors.map((sel) => sel(store.getState())) as T;
13
+ subscriber(values);
14
+
15
+ // Subscribe to each selector
16
+ const unsubscribers = selectors.map((sel, index) =>
17
+ store.select(sel).subscribe((newValue) => {
18
+ if (!Object.is(values[index], newValue)) {
19
+ const next = [...values] as T;
20
+ next[index] = newValue;
21
+ values = next;
22
+ subscriber(values);
23
+ }
24
+ })
25
+ );
26
+
27
+ // Cleanup
28
+ return () => unsubscribers.forEach((u) => u());
29
+ });
30
+ }
@@ -0,0 +1,22 @@
1
+ import { Observable } from "../core/observable";
2
+ import type { ObservableLike } from "../interfaces/observable-like";
3
+
4
+ export function distinctUntilArrayChanged<T>() {
5
+ return (source: ObservableLike<T[]>) =>
6
+ new Observable<T[]>((subscriber) => {
7
+ let last: T[] | undefined;
8
+
9
+ return source.subscribe((next) => {
10
+ if (
11
+ last &&
12
+ last.length === next.length &&
13
+ last.every((v, i) => Object.is(v, next[i]))
14
+ ) {
15
+ return; // no change → do not emit
16
+ }
17
+
18
+ last = next;
19
+ subscriber(next);
20
+ });
21
+ });
22
+ }
@@ -0,0 +1,20 @@
1
+ import type { Operator } from "../types/operator";
2
+ import { Observable } from "../core/observable";
3
+
4
+ export function distinctUntilChanged<T>(
5
+ compare: (prev: T, next: T) => boolean = (a, b) => a === b
6
+ ): Operator<T, T> {
7
+ return (source) =>
8
+ new Observable<T>((subscriber) => {
9
+ let hasPrev = false;
10
+ let prevValue: T;
11
+
12
+ return source.subscribe((value) => {
13
+ if (!hasPrev || !compare(prevValue, value)) {
14
+ hasPrev = true;
15
+ prevValue = value;
16
+ subscriber(value);
17
+ }
18
+ });
19
+ });
20
+ }
@@ -0,0 +1,11 @@
1
+ import type { Operator } from "../types/operator";
2
+ import { Observable } from "../core/observable";
3
+
4
+ export function filter<T>(predicate: (value: T) => boolean): Operator<T, T> {
5
+ return (source) =>
6
+ new Observable<T>((subscriber) =>
7
+ source.subscribe((value) => {
8
+ if (predicate(value)) subscriber(value);
9
+ })
10
+ );
11
+ }
@@ -0,0 +1,9 @@
1
+ import type { Operator } from "../types/operator";
2
+ import { Observable } from "../core/observable";
3
+
4
+ export function map<I, O>(project: (value: I) => O): Operator<I, O> {
5
+ return (source) =>
6
+ new Observable<O>((subscriber) =>
7
+ source.subscribe((value) => subscriber(project(value)))
8
+ );
9
+ }
@@ -0,0 +1,31 @@
1
+ import type { PolyGridState } from "../../store/interfaces/grid-state";
2
+ import type { PolyGridStore } from "../../store/store";
3
+ import { Observable } from "../core/observable";
4
+ import type { ObservableLike } from "../interfaces/observable-like";
5
+
6
+ export function createSelectKeyed<T>(
7
+ store: PolyGridStore,
8
+ key: keyof PolyGridState,
9
+ selector: (state: PolyGridState) => T
10
+ ): ObservableLike<T> {
11
+ let last = selector(store.getState());
12
+
13
+ return new Observable<T>((subscriber) => {
14
+ const wrapped = (
15
+ state: PolyGridState,
16
+ changedKeys: (keyof PolyGridState)[]
17
+ ) => {
18
+ // Only react when THIS key changed
19
+ if (!changedKeys.includes(key)) return;
20
+
21
+ const next = selector(state);
22
+ if (!Object.is(last, next)) {
23
+ last = next;
24
+ subscriber(next);
25
+ }
26
+ };
27
+
28
+ store.getSubscribers().add(wrapped);
29
+ return () => store.getSubscribers().delete(wrapped);
30
+ });
31
+ }
@@ -0,0 +1,26 @@
1
+ import type { PolyGridState } from "../../store/interfaces/grid-state";
2
+ import type { ObservableLike } from "../interfaces/observable-like";
3
+ import type { PolyGridStore } from "../../store/store";
4
+ import { Observable } from "../core/observable";
5
+
6
+ export function createSelect<T>(
7
+ store: PolyGridStore,
8
+ selector: (state: PolyGridState) => T
9
+ ): ObservableLike<T> {
10
+ let last = selector(store.getState());
11
+
12
+ return new Observable<T>((subscriber) => {
13
+ subscriber(last);
14
+
15
+ const wrapped = (state: PolyGridState) => {
16
+ const next = selector(state);
17
+ if (!Object.is(last, next)) {
18
+ last = next;
19
+ subscriber(next);
20
+ }
21
+ };
22
+
23
+ store.getSubscribers().add(wrapped);
24
+ return () => store.getSubscribers().delete(wrapped);
25
+ });
26
+ }
@@ -0,0 +1,18 @@
1
+ import { Observable } from "../core/observable";
2
+ import type { ObservableLike } from "../interfaces/observable-like";
3
+ import type { Operator } from "../types/operator";
4
+
5
+ export function skip<T>(count: number): Operator<T, T> {
6
+ return (source: ObservableLike<T>) =>
7
+ new Observable<T>((subscriber) => {
8
+ let remaining = count;
9
+
10
+ return source.subscribe((value) => {
11
+ if (remaining > 0) {
12
+ remaining--;
13
+ return;
14
+ }
15
+ subscriber(value);
16
+ });
17
+ });
18
+ }
@@ -0,0 +1,18 @@
1
+ import type { ObservableLike } from "../interfaces/observable-like";
2
+ import type { Operator } from "../types/operator";
3
+ import { Observable } from "../core/observable";
4
+
5
+ export function takeUntil<T>(notifier: ObservableLike<any>): Operator<T, T> {
6
+ return (source) =>
7
+ new Observable<T>((subscriber) => {
8
+ const unsubSource = source.subscribe(subscriber);
9
+ const unsubNotifier = notifier.subscribe(() => {
10
+ unsubSource();
11
+ unsubNotifier();
12
+ });
13
+ return () => {
14
+ unsubSource();
15
+ unsubNotifier();
16
+ };
17
+ });
18
+ }
@@ -0,0 +1,3 @@
1
+ import type { ObservableLike } from "../interfaces/observable-like";
2
+
3
+ export type Operator<I, O> = (source: ObservableLike<I>) => ObservableLike<O>;