@polygrid/core 1.0.2 → 1.0.3-a

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 (436) hide show
  1. package/dist/api/index.d.ts +9 -0
  2. package/dist/api/index.d.ts.map +1 -0
  3. package/dist/api/index.js +11 -0
  4. package/dist/api/index.js.map +1 -0
  5. package/dist/api/set-columns.d.ts +4 -0
  6. package/dist/api/set-columns.d.ts.map +1 -0
  7. package/dist/api/set-columns.js +6 -0
  8. package/dist/api/set-columns.js.map +1 -0
  9. package/dist/api/set-data.d.ts +3 -0
  10. package/dist/api/set-data.d.ts.map +1 -0
  11. package/dist/api/set-data.js +7 -0
  12. package/dist/api/set-data.js.map +1 -0
  13. package/dist/api/set-grid-id.d.ts +3 -0
  14. package/dist/api/set-grid-id.d.ts.map +1 -0
  15. package/dist/api/set-grid-id.js +6 -0
  16. package/dist/api/set-grid-id.js.map +1 -0
  17. package/dist/engine/const/pg-css-class.d.ts +25 -0
  18. package/dist/engine/const/pg-css-class.d.ts.map +1 -0
  19. package/dist/engine/const/pg-css-class.js +25 -0
  20. package/dist/engine/const/pg-css-class.js.map +1 -0
  21. package/dist/engine/core/grid-dom.d.ts +23 -0
  22. package/dist/engine/core/grid-dom.d.ts.map +1 -0
  23. package/dist/engine/core/grid-dom.js +8 -0
  24. package/dist/engine/core/grid-dom.js.map +1 -0
  25. package/dist/engine/core/grid.d.ts +19 -0
  26. package/dist/engine/core/grid.d.ts.map +1 -0
  27. package/dist/engine/core/grid.js +50 -0
  28. package/dist/engine/core/grid.js.map +1 -0
  29. package/dist/engine/core/interfaces/grid-options.d.ts +8 -0
  30. package/dist/engine/core/interfaces/grid-options.d.ts.map +1 -0
  31. package/dist/engine/core/interfaces/grid-options.js +2 -0
  32. package/dist/engine/core/interfaces/grid-options.js.map +1 -0
  33. package/dist/engine/core/methods/add-dom-listener.d.ts +3 -0
  34. package/dist/engine/core/methods/add-dom-listener.d.ts.map +1 -0
  35. package/dist/engine/core/methods/add-dom-listener.js +7 -0
  36. package/dist/engine/core/methods/add-dom-listener.js.map +1 -0
  37. package/dist/engine/core/methods/consume-options.d.ts +4 -0
  38. package/dist/engine/core/methods/consume-options.d.ts.map +1 -0
  39. package/dist/engine/core/methods/consume-options.js +27 -0
  40. package/dist/engine/core/methods/consume-options.js.map +1 -0
  41. package/dist/engine/core/methods/index.d.ts +3 -0
  42. package/dist/engine/core/methods/index.d.ts.map +1 -0
  43. package/{src/engine/core/methods/index.ts → dist/engine/core/methods/index.js} +3 -2
  44. package/dist/engine/core/methods/index.js.map +1 -0
  45. package/dist/engine/core/methods/normalize-rows.d.ts +3 -0
  46. package/dist/engine/core/methods/normalize-rows.d.ts.map +1 -0
  47. package/dist/engine/core/methods/normalize-rows.js +4 -0
  48. package/dist/engine/core/methods/normalize-rows.js.map +1 -0
  49. package/dist/engine/debug.config.d.ts +4 -0
  50. package/dist/engine/debug.config.d.ts.map +1 -0
  51. package/{src/engine/debug.config.ts → dist/engine/debug.config.js} +4 -3
  52. package/dist/engine/debug.config.js.map +1 -0
  53. package/dist/engine/rx-lite/core/observable.d.ts +9 -0
  54. package/dist/engine/rx-lite/core/observable.d.ts.map +1 -0
  55. package/dist/engine/rx-lite/core/observable.js +22 -0
  56. package/dist/engine/rx-lite/core/observable.js.map +1 -0
  57. package/dist/engine/rx-lite/core/subject.d.ts +9 -0
  58. package/dist/engine/rx-lite/core/subject.d.ts.map +1 -0
  59. package/dist/engine/rx-lite/core/subject.js +18 -0
  60. package/dist/engine/rx-lite/core/subject.js.map +1 -0
  61. package/dist/engine/rx-lite/interfaces/observable-like.d.ts +6 -0
  62. package/dist/engine/rx-lite/interfaces/observable-like.d.ts.map +1 -0
  63. package/dist/engine/rx-lite/interfaces/observable-like.js +2 -0
  64. package/dist/engine/rx-lite/interfaces/observable-like.js.map +1 -0
  65. package/dist/engine/rx-lite/interfaces/pipe-fn.d.ts +9 -0
  66. package/dist/engine/rx-lite/interfaces/pipe-fn.d.ts.map +1 -0
  67. package/dist/engine/rx-lite/interfaces/pipe-fn.js +2 -0
  68. package/dist/engine/rx-lite/interfaces/pipe-fn.js.map +1 -0
  69. package/dist/engine/rx-lite/operators/combine-latest-any.d.ts +7 -0
  70. package/dist/engine/rx-lite/operators/combine-latest-any.d.ts.map +1 -0
  71. package/dist/engine/rx-lite/operators/combine-latest-any.js +37 -0
  72. package/dist/engine/rx-lite/operators/combine-latest-any.js.map +1 -0
  73. package/dist/engine/rx-lite/operators/combine-latest.d.ts +7 -0
  74. package/dist/engine/rx-lite/operators/combine-latest.d.ts.map +1 -0
  75. package/dist/engine/rx-lite/operators/combine-latest.js +20 -0
  76. package/dist/engine/rx-lite/operators/combine-latest.js.map +1 -0
  77. package/dist/engine/rx-lite/operators/distinct-until-array-changed.d.ts +4 -0
  78. package/dist/engine/rx-lite/operators/distinct-until-array-changed.d.ts.map +1 -0
  79. package/dist/engine/rx-lite/operators/distinct-until-array-changed.js +16 -0
  80. package/dist/engine/rx-lite/operators/distinct-until-array-changed.js.map +1 -0
  81. package/dist/engine/rx-lite/operators/distinct-until-changed.d.ts +3 -0
  82. package/dist/engine/rx-lite/operators/distinct-until-changed.d.ts.map +1 -0
  83. package/dist/engine/rx-lite/operators/distinct-until-changed.js +15 -0
  84. package/dist/engine/rx-lite/operators/distinct-until-changed.js.map +1 -0
  85. package/dist/engine/rx-lite/operators/filter.d.ts +3 -0
  86. package/dist/engine/rx-lite/operators/filter.d.ts.map +1 -0
  87. package/dist/engine/rx-lite/operators/filter.js +8 -0
  88. package/dist/engine/rx-lite/operators/filter.js.map +1 -0
  89. package/dist/engine/rx-lite/operators/map.d.ts +3 -0
  90. package/dist/engine/rx-lite/operators/map.d.ts.map +1 -0
  91. package/dist/engine/rx-lite/operators/map.js +5 -0
  92. package/dist/engine/rx-lite/operators/map.js.map +1 -0
  93. package/dist/engine/rx-lite/operators/select-keyed.d.ts +5 -0
  94. package/dist/engine/rx-lite/operators/select-keyed.d.ts.map +1 -0
  95. package/dist/engine/rx-lite/operators/select-keyed.js +19 -0
  96. package/dist/engine/rx-lite/operators/select-keyed.js.map +1 -0
  97. package/dist/engine/rx-lite/operators/select.d.ts +5 -0
  98. package/dist/engine/rx-lite/operators/select.d.ts.map +1 -0
  99. package/dist/engine/rx-lite/operators/select.js +17 -0
  100. package/dist/engine/rx-lite/operators/select.js.map +1 -0
  101. package/dist/engine/rx-lite/operators/skip.d.ts +3 -0
  102. package/dist/engine/rx-lite/operators/skip.d.ts.map +1 -0
  103. package/dist/engine/rx-lite/operators/skip.js +14 -0
  104. package/dist/engine/rx-lite/operators/skip.js.map +1 -0
  105. package/dist/engine/rx-lite/operators/takeuntil.d.ts +4 -0
  106. package/dist/engine/rx-lite/operators/takeuntil.d.ts.map +1 -0
  107. package/dist/engine/rx-lite/operators/takeuntil.js +15 -0
  108. package/dist/engine/rx-lite/operators/takeuntil.js.map +1 -0
  109. package/{src/engine/rx-lite/types/operator.ts → dist/engine/rx-lite/types/operator.d.ts} +3 -3
  110. package/dist/engine/rx-lite/types/operator.d.ts.map +1 -0
  111. package/dist/engine/rx-lite/types/operator.js +2 -0
  112. package/dist/engine/rx-lite/types/operator.js.map +1 -0
  113. package/dist/engine/services/column/column.d.ts +18 -0
  114. package/dist/engine/services/column/column.d.ts.map +1 -0
  115. package/dist/engine/services/column/column.js +16 -0
  116. package/dist/engine/services/column/column.js.map +1 -0
  117. package/dist/engine/services/column/index.d.ts +2 -0
  118. package/dist/engine/services/column/index.d.ts.map +1 -0
  119. package/dist/engine/services/column/index.js +2 -0
  120. package/dist/engine/services/column/index.js.map +1 -0
  121. package/dist/engine/services/column/interfaces/column.d.ts +7 -0
  122. package/dist/engine/services/column/interfaces/column.d.ts.map +1 -0
  123. package/dist/engine/services/column/interfaces/column.js +2 -0
  124. package/dist/engine/services/column/interfaces/column.js.map +1 -0
  125. package/dist/engine/services/column/methods/index.d.ts +3 -0
  126. package/dist/engine/services/column/methods/index.d.ts.map +1 -0
  127. package/{src/engine/services/column/methods/index.ts → dist/engine/services/column/methods/index.js} +3 -2
  128. package/dist/engine/services/column/methods/index.js.map +1 -0
  129. package/dist/engine/services/column/methods/resolve-column-widths.d.ts +3 -0
  130. package/dist/engine/services/column/methods/resolve-column-widths.d.ts.map +1 -0
  131. package/dist/engine/services/column/methods/resolve-column-widths.js +34 -0
  132. package/dist/engine/services/column/methods/resolve-column-widths.js.map +1 -0
  133. package/dist/engine/services/column/methods/set-columns.d.ts +4 -0
  134. package/dist/engine/services/column/methods/set-columns.d.ts.map +1 -0
  135. package/dist/engine/services/column/methods/set-columns.js +23 -0
  136. package/dist/engine/services/column/methods/set-columns.js.map +1 -0
  137. package/{src/engine/services/column/types/column-width-state.ts → dist/engine/services/column/types/column-width-state.d.ts} +2 -1
  138. package/dist/engine/services/column/types/column-width-state.d.ts.map +1 -0
  139. package/dist/engine/services/column/types/column-width-state.js +2 -0
  140. package/dist/engine/services/column/types/column-width-state.js.map +1 -0
  141. package/dist/engine/services/data/data.d.ts +15 -0
  142. package/dist/engine/services/data/data.d.ts.map +1 -0
  143. package/dist/engine/services/data/data.js +14 -0
  144. package/dist/engine/services/data/data.js.map +1 -0
  145. package/dist/engine/services/data/index.d.ts +2 -0
  146. package/dist/engine/services/data/index.d.ts.map +1 -0
  147. package/dist/engine/services/data/index.js +2 -0
  148. package/dist/engine/services/data/index.js.map +1 -0
  149. package/dist/engine/services/data/methods/index.d.ts +2 -0
  150. package/dist/engine/services/data/methods/index.d.ts.map +1 -0
  151. package/dist/engine/services/data/methods/index.js +2 -0
  152. package/dist/engine/services/data/methods/index.js.map +1 -0
  153. package/dist/engine/services/data/methods/set-rows.d.ts +4 -0
  154. package/dist/engine/services/data/methods/set-rows.d.ts.map +1 -0
  155. package/dist/engine/services/data/methods/set-rows.js +13 -0
  156. package/dist/engine/services/data/methods/set-rows.js.map +1 -0
  157. package/dist/engine/services/layout/index.d.ts +2 -0
  158. package/dist/engine/services/layout/index.d.ts.map +1 -0
  159. package/dist/engine/services/layout/index.js +2 -0
  160. package/dist/engine/services/layout/index.js.map +1 -0
  161. package/dist/engine/services/layout/layout.d.ts +34 -0
  162. package/dist/engine/services/layout/layout.d.ts.map +1 -0
  163. package/dist/engine/services/layout/layout.js +57 -0
  164. package/dist/engine/services/layout/layout.js.map +1 -0
  165. package/dist/engine/services/layout/methods/add-scroll-event-listeners.d.ts +3 -0
  166. package/dist/engine/services/layout/methods/add-scroll-event-listeners.d.ts.map +1 -0
  167. package/dist/engine/services/layout/methods/add-scroll-event-listeners.js +35 -0
  168. package/dist/engine/services/layout/methods/add-scroll-event-listeners.js.map +1 -0
  169. package/dist/engine/services/layout/methods/adjust-viewport.d.ts +4 -0
  170. package/dist/engine/services/layout/methods/adjust-viewport.d.ts.map +1 -0
  171. package/dist/engine/services/layout/methods/adjust-viewport.js +45 -0
  172. package/dist/engine/services/layout/methods/adjust-viewport.js.map +1 -0
  173. package/dist/engine/services/layout/methods/apply-column-widths.d.ts +4 -0
  174. package/dist/engine/services/layout/methods/apply-column-widths.d.ts.map +1 -0
  175. package/dist/engine/services/layout/methods/apply-column-widths.js +12 -0
  176. package/dist/engine/services/layout/methods/apply-column-widths.js.map +1 -0
  177. package/dist/engine/services/layout/methods/compute-column-widths.d.ts +4 -0
  178. package/dist/engine/services/layout/methods/compute-column-widths.d.ts.map +1 -0
  179. package/dist/engine/services/layout/methods/compute-column-widths.js +18 -0
  180. package/dist/engine/services/layout/methods/compute-column-widths.js.map +1 -0
  181. package/dist/engine/services/layout/methods/compute-total-row-height.d.ts +4 -0
  182. package/dist/engine/services/layout/methods/compute-total-row-height.d.ts.map +1 -0
  183. package/dist/engine/services/layout/methods/compute-total-row-height.js +11 -0
  184. package/dist/engine/services/layout/methods/compute-total-row-height.js.map +1 -0
  185. package/dist/engine/services/layout/methods/index.d.ts +13 -0
  186. package/dist/engine/services/layout/methods/index.d.ts.map +1 -0
  187. package/{src/engine/services/layout/methods/index.ts → dist/engine/services/layout/methods/index.js} +13 -12
  188. package/dist/engine/services/layout/methods/index.js.map +1 -0
  189. package/dist/engine/services/layout/methods/initialize-layout-pipeline.d.ts +4 -0
  190. package/dist/engine/services/layout/methods/initialize-layout-pipeline.d.ts.map +1 -0
  191. package/dist/engine/services/layout/methods/initialize-layout-pipeline.js +23 -0
  192. package/dist/engine/services/layout/methods/initialize-layout-pipeline.js.map +1 -0
  193. package/dist/engine/services/layout/methods/resize-body.d.ts +4 -0
  194. package/dist/engine/services/layout/methods/resize-body.d.ts.map +1 -0
  195. package/dist/engine/services/layout/methods/resize-body.js +10 -0
  196. package/dist/engine/services/layout/methods/resize-body.js.map +1 -0
  197. package/dist/engine/services/layout/methods/resize-v-scrollbar.d.ts +4 -0
  198. package/dist/engine/services/layout/methods/resize-v-scrollbar.d.ts.map +1 -0
  199. package/dist/engine/services/layout/methods/resize-v-scrollbar.js +10 -0
  200. package/dist/engine/services/layout/methods/resize-v-scrollbar.js.map +1 -0
  201. package/dist/engine/services/layout/methods/set-cell-width.d.ts +2 -0
  202. package/dist/engine/services/layout/methods/set-cell-width.d.ts.map +1 -0
  203. package/dist/engine/services/layout/methods/set-cell-width.js +16 -0
  204. package/dist/engine/services/layout/methods/set-cell-width.js.map +1 -0
  205. package/dist/engine/services/layout/methods/set-grid-id.d.ts +4 -0
  206. package/dist/engine/services/layout/methods/set-grid-id.d.ts.map +1 -0
  207. package/dist/engine/services/layout/methods/set-grid-id.js +9 -0
  208. package/dist/engine/services/layout/methods/set-grid-id.js.map +1 -0
  209. package/dist/engine/services/layout/methods/set-up-resize-observer.d.ts +4 -0
  210. package/dist/engine/services/layout/methods/set-up-resize-observer.d.ts.map +1 -0
  211. package/dist/engine/services/layout/methods/set-up-resize-observer.js +15 -0
  212. package/dist/engine/services/layout/methods/set-up-resize-observer.js.map +1 -0
  213. package/dist/engine/services/layout/methods/update-column-widths.d.ts +4 -0
  214. package/dist/engine/services/layout/methods/update-column-widths.d.ts.map +1 -0
  215. package/dist/engine/services/layout/methods/update-column-widths.js +22 -0
  216. package/dist/engine/services/layout/methods/update-column-widths.js.map +1 -0
  217. package/dist/engine/services/renderer/index.d.ts +2 -0
  218. package/dist/engine/services/renderer/index.d.ts.map +1 -0
  219. package/dist/engine/services/renderer/index.js +2 -0
  220. package/dist/engine/services/renderer/index.js.map +1 -0
  221. package/dist/engine/services/renderer/methods/index.d.ts +2 -0
  222. package/dist/engine/services/renderer/methods/index.d.ts.map +1 -0
  223. package/{src/engine/services/renderer/methods/index.ts → dist/engine/services/renderer/methods/index.js} +2 -1
  224. package/dist/engine/services/renderer/methods/index.js.map +1 -0
  225. package/dist/engine/services/renderer/methods/re-render-cells.d.ts +4 -0
  226. package/dist/engine/services/renderer/methods/re-render-cells.d.ts.map +1 -0
  227. package/dist/engine/services/renderer/methods/re-render-cells.js +29 -0
  228. package/dist/engine/services/renderer/methods/re-render-cells.js.map +1 -0
  229. package/dist/engine/services/renderer/parts/body/body.d.ts +4 -0
  230. package/dist/engine/services/renderer/parts/body/body.d.ts.map +1 -0
  231. package/dist/engine/services/renderer/parts/body/body.js +26 -0
  232. package/dist/engine/services/renderer/parts/body/body.js.map +1 -0
  233. package/dist/engine/services/renderer/parts/body/cell.d.ts +3 -0
  234. package/dist/engine/services/renderer/parts/body/cell.d.ts.map +1 -0
  235. package/dist/engine/services/renderer/parts/body/cell.js +9 -0
  236. package/dist/engine/services/renderer/parts/body/cell.js.map +1 -0
  237. package/dist/engine/services/renderer/parts/body/row.d.ts +4 -0
  238. package/dist/engine/services/renderer/parts/body/row.d.ts.map +1 -0
  239. package/dist/engine/services/renderer/parts/body/row.js +18 -0
  240. package/dist/engine/services/renderer/parts/body/row.js.map +1 -0
  241. package/dist/engine/services/renderer/parts/footer/footer-cells.d.ts +3 -0
  242. package/dist/engine/services/renderer/parts/footer/footer-cells.d.ts.map +1 -0
  243. package/dist/engine/services/renderer/parts/footer/footer-cells.js +12 -0
  244. package/dist/engine/services/renderer/parts/footer/footer-cells.js.map +1 -0
  245. package/dist/engine/services/renderer/parts/footer/footer.d.ts +4 -0
  246. package/dist/engine/services/renderer/parts/footer/footer.d.ts.map +1 -0
  247. package/dist/engine/services/renderer/parts/footer/footer.js +16 -0
  248. package/dist/engine/services/renderer/parts/footer/footer.js.map +1 -0
  249. package/dist/engine/services/renderer/parts/grid/grid.d.ts +4 -0
  250. package/dist/engine/services/renderer/parts/grid/grid.d.ts.map +1 -0
  251. package/dist/engine/services/renderer/parts/grid/grid.js +15 -0
  252. package/dist/engine/services/renderer/parts/grid/grid.js.map +1 -0
  253. package/dist/engine/services/renderer/parts/header/header-cells.d.ts +3 -0
  254. package/dist/engine/services/renderer/parts/header/header-cells.d.ts.map +1 -0
  255. package/dist/engine/services/renderer/parts/header/header-cells.js +12 -0
  256. package/dist/engine/services/renderer/parts/header/header-cells.js.map +1 -0
  257. package/dist/engine/services/renderer/parts/header/header.d.ts +4 -0
  258. package/dist/engine/services/renderer/parts/header/header.d.ts.map +1 -0
  259. package/dist/engine/services/renderer/parts/header/header.js +16 -0
  260. package/dist/engine/services/renderer/parts/header/header.js.map +1 -0
  261. package/dist/engine/services/renderer/parts/root/root.d.ts +4 -0
  262. package/dist/engine/services/renderer/parts/root/root.d.ts.map +1 -0
  263. package/dist/engine/services/renderer/parts/root/root.js +13 -0
  264. package/dist/engine/services/renderer/parts/root/root.js.map +1 -0
  265. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts +3 -0
  266. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts.map +1 -0
  267. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.js +15 -0
  268. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.js.map +1 -0
  269. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts +2 -0
  270. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts.map +1 -0
  271. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.js +7 -0
  272. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.js.map +1 -0
  273. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts +2 -0
  274. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts.map +1 -0
  275. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.js +7 -0
  276. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.js.map +1 -0
  277. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts +2 -0
  278. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts.map +1 -0
  279. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.js +7 -0
  280. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.js.map +1 -0
  281. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts +3 -0
  282. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts.map +1 -0
  283. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.js +27 -0
  284. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.js.map +1 -0
  285. package/dist/engine/services/renderer/parts/viewport/viewport.d.ts +4 -0
  286. package/dist/engine/services/renderer/parts/viewport/viewport.d.ts.map +1 -0
  287. package/dist/engine/services/renderer/parts/viewport/viewport.js +23 -0
  288. package/dist/engine/services/renderer/parts/viewport/viewport.js.map +1 -0
  289. package/dist/engine/services/renderer/renderer.d.ts +15 -0
  290. package/dist/engine/services/renderer/renderer.d.ts.map +1 -0
  291. package/dist/engine/services/renderer/renderer.js +12 -0
  292. package/dist/engine/services/renderer/renderer.js.map +1 -0
  293. package/dist/engine/services/row/index.d.ts +2 -0
  294. package/dist/engine/services/row/index.d.ts.map +1 -0
  295. package/dist/engine/services/row/index.js +2 -0
  296. package/dist/engine/services/row/index.js.map +1 -0
  297. package/dist/engine/services/row/interfaces/row.d.ts +5 -0
  298. package/dist/engine/services/row/interfaces/row.d.ts.map +1 -0
  299. package/dist/engine/services/row/interfaces/row.js +2 -0
  300. package/dist/engine/services/row/interfaces/row.js.map +1 -0
  301. package/dist/engine/services/row/methods/index.d.ts +1 -0
  302. package/dist/engine/services/row/methods/index.d.ts.map +1 -0
  303. package/dist/engine/services/row/methods/index.js +2 -0
  304. package/dist/engine/services/row/methods/index.js.map +1 -0
  305. package/dist/engine/services/row/row.d.ts +7 -0
  306. package/dist/engine/services/row/row.d.ts.map +1 -0
  307. package/dist/engine/services/row/row.js +6 -0
  308. package/dist/engine/services/row/row.js.map +1 -0
  309. package/dist/engine/services/services.d.ts +16 -0
  310. package/dist/engine/services/services.d.ts.map +1 -0
  311. package/dist/engine/services/services.js +16 -0
  312. package/dist/engine/services/services.js.map +1 -0
  313. package/dist/engine/store/interfaces/grid-state.d.ts +20 -0
  314. package/dist/engine/store/interfaces/grid-state.d.ts.map +1 -0
  315. package/dist/engine/store/interfaces/grid-state.js +2 -0
  316. package/dist/engine/store/interfaces/grid-state.js.map +1 -0
  317. package/dist/engine/store/methods/create-initial-state.d.ts +3 -0
  318. package/dist/engine/store/methods/create-initial-state.d.ts.map +1 -0
  319. package/dist/engine/store/methods/create-initial-state.js +19 -0
  320. package/dist/engine/store/methods/create-initial-state.js.map +1 -0
  321. package/dist/engine/store/methods/create-tracked-proxy.d.ts +3 -0
  322. package/dist/engine/store/methods/create-tracked-proxy.d.ts.map +1 -0
  323. package/dist/engine/store/methods/create-tracked-proxy.js +45 -0
  324. package/dist/engine/store/methods/create-tracked-proxy.js.map +1 -0
  325. package/dist/engine/store/methods/debug.d.ts +4 -0
  326. package/dist/engine/store/methods/debug.d.ts.map +1 -0
  327. package/dist/engine/store/methods/debug.js +17 -0
  328. package/dist/engine/store/methods/debug.js.map +1 -0
  329. package/dist/engine/store/store.d.ts +22 -0
  330. package/dist/engine/store/store.d.ts.map +1 -0
  331. package/dist/engine/store/store.js +55 -0
  332. package/dist/engine/store/store.js.map +1 -0
  333. package/{src/engine/store/types/state-key.ts → dist/engine/store/types/state-key.d.ts} +3 -3
  334. package/dist/engine/store/types/state-key.d.ts.map +1 -0
  335. package/dist/engine/store/types/state-key.js +2 -0
  336. package/dist/engine/store/types/state-key.js.map +1 -0
  337. package/dist/engine/store/types/store-mutation.d.ts +6 -0
  338. package/dist/engine/store/types/store-mutation.d.ts.map +1 -0
  339. package/dist/engine/store/types/store-mutation.js +2 -0
  340. package/dist/engine/store/types/store-mutation.js.map +1 -0
  341. package/{src/index.ts → dist/index.d.ts} +2 -1
  342. package/dist/index.d.ts.map +1 -0
  343. package/dist/index.js +2 -0
  344. package/dist/index.js.map +1 -0
  345. package/dist/polygrid.css +176 -0
  346. package/package.json +32 -39
  347. package/postcss.config.cjs +0 -3
  348. package/src/api/index.ts +0 -15
  349. package/src/api/set-columns.ts +0 -8
  350. package/src/api/set-data.ts +0 -8
  351. package/src/api/set-grid-id.ts +0 -7
  352. package/src/engine/const/pg-css-class.ts +0 -24
  353. package/src/engine/core/grid-dom.ts +0 -26
  354. package/src/engine/core/grid.ts +0 -77
  355. package/src/engine/core/interfaces/grid-options.ts +0 -8
  356. package/src/engine/core/methods/add-dom-listener.ts +0 -14
  357. package/src/engine/core/methods/consume-options.ts +0 -32
  358. package/src/engine/core/methods/normalize-rows.ts +0 -5
  359. package/src/engine/rx-lite/core/observable.ts +0 -29
  360. package/src/engine/rx-lite/core/subject.ts +0 -21
  361. package/src/engine/rx-lite/interfaces/observable-like.ts +0 -6
  362. package/src/engine/rx-lite/interfaces/pipe-fn.ts +0 -18
  363. package/src/engine/rx-lite/operators/combine-latest-any.ts +0 -51
  364. package/src/engine/rx-lite/operators/combine-latest.ts +0 -30
  365. package/src/engine/rx-lite/operators/distinct-until-array-changed.ts +0 -22
  366. package/src/engine/rx-lite/operators/distinct-until-changed.ts +0 -20
  367. package/src/engine/rx-lite/operators/filter.ts +0 -11
  368. package/src/engine/rx-lite/operators/map.ts +0 -9
  369. package/src/engine/rx-lite/operators/select-keyed.ts +0 -31
  370. package/src/engine/rx-lite/operators/select.ts +0 -26
  371. package/src/engine/rx-lite/operators/skip.ts +0 -18
  372. package/src/engine/rx-lite/operators/takeuntil.ts +0 -18
  373. package/src/engine/services/column/column.ts +0 -30
  374. package/src/engine/services/column/index.ts +0 -1
  375. package/src/engine/services/column/interfaces/column.ts +0 -6
  376. package/src/engine/services/column/methods/resolve-column-widths.ts +0 -46
  377. package/src/engine/services/column/methods/set-columns.ts +0 -28
  378. package/src/engine/services/data/data.ts +0 -27
  379. package/src/engine/services/data/index.ts +0 -1
  380. package/src/engine/services/data/methods/index.ts +0 -1
  381. package/src/engine/services/data/methods/set-rows.ts +0 -18
  382. package/src/engine/services/layout/index.ts +0 -1
  383. package/src/engine/services/layout/layout.ts +0 -100
  384. package/src/engine/services/layout/methods/add-scroll-event-listeners.ts +0 -38
  385. package/src/engine/services/layout/methods/adjust-viewport.ts +0 -66
  386. package/src/engine/services/layout/methods/apply-column-widths.ts +0 -17
  387. package/src/engine/services/layout/methods/compute-column-widths.ts +0 -23
  388. package/src/engine/services/layout/methods/compute-total-row-height.ts +0 -16
  389. package/src/engine/services/layout/methods/initialize-layout-pipeline.ts +0 -39
  390. package/src/engine/services/layout/methods/resize-body.ts +0 -15
  391. package/src/engine/services/layout/methods/resize-v-scrollbar.ts +0 -15
  392. package/src/engine/services/layout/methods/set-cell-width.ts +0 -21
  393. package/src/engine/services/layout/methods/set-grid-id.ts +0 -14
  394. package/src/engine/services/layout/methods/set-up-resize-observer.ts +0 -25
  395. package/src/engine/services/layout/methods/update-column-widths.ts +0 -28
  396. package/src/engine/services/renderer/index.ts +0 -1
  397. package/src/engine/services/renderer/methods/re-render-cells.ts +0 -31
  398. package/src/engine/services/renderer/parts/body/body.ts +0 -34
  399. package/src/engine/services/renderer/parts/body/cell.ts +0 -12
  400. package/src/engine/services/renderer/parts/body/row.ts +0 -26
  401. package/src/engine/services/renderer/parts/footer/footer-cells.ts +0 -15
  402. package/src/engine/services/renderer/parts/footer/footer.ts +0 -24
  403. package/src/engine/services/renderer/parts/grid/grid.ts +0 -21
  404. package/src/engine/services/renderer/parts/header/header-cells.ts +0 -15
  405. package/src/engine/services/renderer/parts/header/header.ts +0 -24
  406. package/src/engine/services/renderer/parts/root/root.ts +0 -22
  407. package/src/engine/services/renderer/parts/scrollbars/h-scrollbar.ts +0 -21
  408. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.ts +0 -8
  409. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.ts +0 -8
  410. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.ts +0 -8
  411. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar.ts +0 -34
  412. package/src/engine/services/renderer/parts/viewport/viewport.ts +0 -32
  413. package/src/engine/services/renderer/renderer.ts +0 -23
  414. package/src/engine/services/row/index.ts +0 -1
  415. package/src/engine/services/row/interfaces/row.ts +0 -4
  416. package/src/engine/services/row/methods/index.ts +0 -0
  417. package/src/engine/services/row/row.ts +0 -10
  418. package/src/engine/services/services.ts +0 -26
  419. package/src/engine/store/interfaces/grid-state.ts +0 -20
  420. package/src/engine/store/methods/create-initial-state.ts +0 -20
  421. package/src/engine/store/methods/create-tracked-proxy.ts +0 -60
  422. package/src/engine/store/methods/debug.ts +0 -29
  423. package/src/engine/store/store.ts +0 -85
  424. package/src/engine/store/types/store-mutation.ts +0 -5
  425. package/src/styles/body.css +0 -13
  426. package/src/styles/cell.css +0 -15
  427. package/src/styles/footer.css +0 -30
  428. package/src/styles/grid.css +0 -5
  429. package/src/styles/header.css +0 -25
  430. package/src/styles/index.css +0 -9
  431. package/src/styles/root.css +0 -12
  432. package/src/styles/row.css +0 -12
  433. package/src/styles/scrollbar.css +0 -50
  434. package/src/styles/viewport.css +0 -6
  435. package/src/styles.d.ts +0 -1
  436. package/tsconfig.json +0 -23
@@ -1,30 +0,0 @@
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
- }
@@ -1 +0,0 @@
1
- export * from "./column";
@@ -1,6 +0,0 @@
1
- export interface PolyGridColumn {
2
- header: string;
3
- field: string;
4
- width?: number;
5
- visible?: boolean;
6
- }
@@ -1,46 +0,0 @@
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
- }
@@ -1,28 +0,0 @@
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,27 +0,0 @@
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
- }
@@ -1 +0,0 @@
1
- export * from "./data";
@@ -1 +0,0 @@
1
- export * from "./set-rows";
@@ -1,18 +0,0 @@
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
- }
@@ -1 +0,0 @@
1
- export * from "./layout";
@@ -1,100 +0,0 @@
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
- }
@@ -1,38 +0,0 @@
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
- }
@@ -1,66 +0,0 @@
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
- }
@@ -1,17 +0,0 @@
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
- }
@@ -1,23 +0,0 @@
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
- }
@@ -1,16 +0,0 @@
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
- }
@@ -1,39 +0,0 @@
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
- }
@@ -1,15 +0,0 @@
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
- }
@@ -1,15 +0,0 @@
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
- }
@@ -1,21 +0,0 @@
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
- }
@@ -1,14 +0,0 @@
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
- }
@@ -1,25 +0,0 @@
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
- }
@@ -1,28 +0,0 @@
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
- }
@@ -1 +0,0 @@
1
- export * from "./renderer";
@@ -1,31 +0,0 @@
1
- import type { GridDOM } from "../../../core/grid-dom";
2
- import { renderRows } from "../parts/body/row";
3
- import { renderFooterCells } from "../parts/footer/footer-cells";
4
- import { renderHeaderCells } from "../parts/header/header-cells";
5
- import type { PolyGridStore } from "../../../store/store";
6
-
7
- export function reRenderCells(gridDom: GridDOM, store: PolyGridStore) {
8
- // rerender header, body, footer cells
9
- // header
10
- const header = gridDom.header;
11
- header.replaceChildren();
12
- renderHeaderCells(header, store);
13
- // body
14
- const body = gridDom.body;
15
- body.replaceChildren();
16
- const rows = store.getState().rows;
17
- const columns = store.getState().columns;
18
- const rowHeight = store.getState().rowHeight;
19
- const bodyRows = renderRows(rows, columns, rowHeight);
20
- const fragment = document.createDocumentFragment();
21
- for (const row of bodyRows) {
22
- fragment.appendChild(row);
23
- }
24
- body.appendChild(fragment);
25
- const lastRow = gridDom.body.querySelector(".pg-row:last-child");
26
- lastRow?.classList.toggle("last-row", !store.getState().showVScrollbar);
27
- // footer
28
- const footer = gridDom.footer;
29
- footer.replaceChildren();
30
- renderFooterCells(footer, store);
31
- }