@polygrid/core 1.0.2 → 1.0.3-b

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 (440) 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 +26 -0
  18. package/dist/engine/const/pg-css-class.d.ts.map +1 -0
  19. package/dist/engine/const/pg-css-class.js +26 -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 +34 -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/no-data/no-data.d.ts +2 -0
  262. package/dist/engine/services/renderer/parts/no-data/no-data.d.ts.map +1 -0
  263. package/dist/engine/services/renderer/parts/no-data/no-data.js +18 -0
  264. package/dist/engine/services/renderer/parts/no-data/no-data.js.map +1 -0
  265. package/dist/engine/services/renderer/parts/root/root.d.ts +4 -0
  266. package/dist/engine/services/renderer/parts/root/root.d.ts.map +1 -0
  267. package/dist/engine/services/renderer/parts/root/root.js +13 -0
  268. package/dist/engine/services/renderer/parts/root/root.js.map +1 -0
  269. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts +3 -0
  270. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.d.ts.map +1 -0
  271. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.js +15 -0
  272. package/dist/engine/services/renderer/parts/scrollbars/h-scrollbar.js.map +1 -0
  273. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts +2 -0
  274. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.d.ts.map +1 -0
  275. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.js +7 -0
  276. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.js.map +1 -0
  277. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts +2 -0
  278. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.d.ts.map +1 -0
  279. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.js +7 -0
  280. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.js.map +1 -0
  281. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts +2 -0
  282. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.d.ts.map +1 -0
  283. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.js +7 -0
  284. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.js.map +1 -0
  285. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts +3 -0
  286. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.d.ts.map +1 -0
  287. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.js +27 -0
  288. package/dist/engine/services/renderer/parts/scrollbars/v-scrollbar.js.map +1 -0
  289. package/dist/engine/services/renderer/parts/viewport/viewport.d.ts +4 -0
  290. package/dist/engine/services/renderer/parts/viewport/viewport.d.ts.map +1 -0
  291. package/dist/engine/services/renderer/parts/viewport/viewport.js +23 -0
  292. package/dist/engine/services/renderer/parts/viewport/viewport.js.map +1 -0
  293. package/dist/engine/services/renderer/renderer.d.ts +15 -0
  294. package/dist/engine/services/renderer/renderer.d.ts.map +1 -0
  295. package/dist/engine/services/renderer/renderer.js +12 -0
  296. package/dist/engine/services/renderer/renderer.js.map +1 -0
  297. package/dist/engine/services/row/index.d.ts +2 -0
  298. package/dist/engine/services/row/index.d.ts.map +1 -0
  299. package/dist/engine/services/row/index.js +2 -0
  300. package/dist/engine/services/row/index.js.map +1 -0
  301. package/dist/engine/services/row/interfaces/row.d.ts +5 -0
  302. package/dist/engine/services/row/interfaces/row.d.ts.map +1 -0
  303. package/dist/engine/services/row/interfaces/row.js +2 -0
  304. package/dist/engine/services/row/interfaces/row.js.map +1 -0
  305. package/dist/engine/services/row/methods/index.d.ts +1 -0
  306. package/dist/engine/services/row/methods/index.d.ts.map +1 -0
  307. package/dist/engine/services/row/methods/index.js +2 -0
  308. package/dist/engine/services/row/methods/index.js.map +1 -0
  309. package/dist/engine/services/row/row.d.ts +7 -0
  310. package/dist/engine/services/row/row.d.ts.map +1 -0
  311. package/dist/engine/services/row/row.js +6 -0
  312. package/dist/engine/services/row/row.js.map +1 -0
  313. package/dist/engine/services/services.d.ts +16 -0
  314. package/dist/engine/services/services.d.ts.map +1 -0
  315. package/dist/engine/services/services.js +16 -0
  316. package/dist/engine/services/services.js.map +1 -0
  317. package/dist/engine/store/interfaces/grid-state.d.ts +20 -0
  318. package/dist/engine/store/interfaces/grid-state.d.ts.map +1 -0
  319. package/dist/engine/store/interfaces/grid-state.js +2 -0
  320. package/dist/engine/store/interfaces/grid-state.js.map +1 -0
  321. package/dist/engine/store/methods/create-initial-state.d.ts +3 -0
  322. package/dist/engine/store/methods/create-initial-state.d.ts.map +1 -0
  323. package/dist/engine/store/methods/create-initial-state.js +19 -0
  324. package/dist/engine/store/methods/create-initial-state.js.map +1 -0
  325. package/dist/engine/store/methods/create-tracked-proxy.d.ts +3 -0
  326. package/dist/engine/store/methods/create-tracked-proxy.d.ts.map +1 -0
  327. package/dist/engine/store/methods/create-tracked-proxy.js +45 -0
  328. package/dist/engine/store/methods/create-tracked-proxy.js.map +1 -0
  329. package/dist/engine/store/methods/debug.d.ts +4 -0
  330. package/dist/engine/store/methods/debug.d.ts.map +1 -0
  331. package/dist/engine/store/methods/debug.js +17 -0
  332. package/dist/engine/store/methods/debug.js.map +1 -0
  333. package/dist/engine/store/store.d.ts +22 -0
  334. package/dist/engine/store/store.d.ts.map +1 -0
  335. package/dist/engine/store/store.js +55 -0
  336. package/dist/engine/store/store.js.map +1 -0
  337. package/{src/engine/store/types/state-key.ts → dist/engine/store/types/state-key.d.ts} +3 -3
  338. package/dist/engine/store/types/state-key.d.ts.map +1 -0
  339. package/dist/engine/store/types/state-key.js +2 -0
  340. package/dist/engine/store/types/state-key.js.map +1 -0
  341. package/dist/engine/store/types/store-mutation.d.ts +6 -0
  342. package/dist/engine/store/types/store-mutation.d.ts.map +1 -0
  343. package/dist/engine/store/types/store-mutation.js +2 -0
  344. package/dist/engine/store/types/store-mutation.js.map +1 -0
  345. package/{src/index.ts → dist/index.d.ts} +2 -1
  346. package/dist/index.d.ts.map +1 -0
  347. package/dist/index.js +2 -0
  348. package/dist/index.js.map +1 -0
  349. package/dist/polygrid.css +232 -0
  350. package/package.json +32 -39
  351. package/postcss.config.cjs +0 -3
  352. package/src/api/index.ts +0 -15
  353. package/src/api/set-columns.ts +0 -8
  354. package/src/api/set-data.ts +0 -8
  355. package/src/api/set-grid-id.ts +0 -7
  356. package/src/engine/const/pg-css-class.ts +0 -24
  357. package/src/engine/core/grid-dom.ts +0 -26
  358. package/src/engine/core/grid.ts +0 -77
  359. package/src/engine/core/interfaces/grid-options.ts +0 -8
  360. package/src/engine/core/methods/add-dom-listener.ts +0 -14
  361. package/src/engine/core/methods/consume-options.ts +0 -32
  362. package/src/engine/core/methods/normalize-rows.ts +0 -5
  363. package/src/engine/rx-lite/core/observable.ts +0 -29
  364. package/src/engine/rx-lite/core/subject.ts +0 -21
  365. package/src/engine/rx-lite/interfaces/observable-like.ts +0 -6
  366. package/src/engine/rx-lite/interfaces/pipe-fn.ts +0 -18
  367. package/src/engine/rx-lite/operators/combine-latest-any.ts +0 -51
  368. package/src/engine/rx-lite/operators/combine-latest.ts +0 -30
  369. package/src/engine/rx-lite/operators/distinct-until-array-changed.ts +0 -22
  370. package/src/engine/rx-lite/operators/distinct-until-changed.ts +0 -20
  371. package/src/engine/rx-lite/operators/filter.ts +0 -11
  372. package/src/engine/rx-lite/operators/map.ts +0 -9
  373. package/src/engine/rx-lite/operators/select-keyed.ts +0 -31
  374. package/src/engine/rx-lite/operators/select.ts +0 -26
  375. package/src/engine/rx-lite/operators/skip.ts +0 -18
  376. package/src/engine/rx-lite/operators/takeuntil.ts +0 -18
  377. package/src/engine/services/column/column.ts +0 -30
  378. package/src/engine/services/column/index.ts +0 -1
  379. package/src/engine/services/column/interfaces/column.ts +0 -6
  380. package/src/engine/services/column/methods/resolve-column-widths.ts +0 -46
  381. package/src/engine/services/column/methods/set-columns.ts +0 -28
  382. package/src/engine/services/data/data.ts +0 -27
  383. package/src/engine/services/data/index.ts +0 -1
  384. package/src/engine/services/data/methods/index.ts +0 -1
  385. package/src/engine/services/data/methods/set-rows.ts +0 -18
  386. package/src/engine/services/layout/index.ts +0 -1
  387. package/src/engine/services/layout/layout.ts +0 -100
  388. package/src/engine/services/layout/methods/add-scroll-event-listeners.ts +0 -38
  389. package/src/engine/services/layout/methods/adjust-viewport.ts +0 -66
  390. package/src/engine/services/layout/methods/apply-column-widths.ts +0 -17
  391. package/src/engine/services/layout/methods/compute-column-widths.ts +0 -23
  392. package/src/engine/services/layout/methods/compute-total-row-height.ts +0 -16
  393. package/src/engine/services/layout/methods/initialize-layout-pipeline.ts +0 -39
  394. package/src/engine/services/layout/methods/resize-body.ts +0 -15
  395. package/src/engine/services/layout/methods/resize-v-scrollbar.ts +0 -15
  396. package/src/engine/services/layout/methods/set-cell-width.ts +0 -21
  397. package/src/engine/services/layout/methods/set-grid-id.ts +0 -14
  398. package/src/engine/services/layout/methods/set-up-resize-observer.ts +0 -25
  399. package/src/engine/services/layout/methods/update-column-widths.ts +0 -28
  400. package/src/engine/services/renderer/index.ts +0 -1
  401. package/src/engine/services/renderer/methods/re-render-cells.ts +0 -31
  402. package/src/engine/services/renderer/parts/body/body.ts +0 -34
  403. package/src/engine/services/renderer/parts/body/cell.ts +0 -12
  404. package/src/engine/services/renderer/parts/body/row.ts +0 -26
  405. package/src/engine/services/renderer/parts/footer/footer-cells.ts +0 -15
  406. package/src/engine/services/renderer/parts/footer/footer.ts +0 -24
  407. package/src/engine/services/renderer/parts/grid/grid.ts +0 -21
  408. package/src/engine/services/renderer/parts/header/header-cells.ts +0 -15
  409. package/src/engine/services/renderer/parts/header/header.ts +0 -24
  410. package/src/engine/services/renderer/parts/root/root.ts +0 -22
  411. package/src/engine/services/renderer/parts/scrollbars/h-scrollbar.ts +0 -21
  412. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-bottom-corner.ts +0 -8
  413. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-bottom.ts +0 -8
  414. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar-spacer-top.ts +0 -8
  415. package/src/engine/services/renderer/parts/scrollbars/v-scrollbar.ts +0 -34
  416. package/src/engine/services/renderer/parts/viewport/viewport.ts +0 -32
  417. package/src/engine/services/renderer/renderer.ts +0 -23
  418. package/src/engine/services/row/index.ts +0 -1
  419. package/src/engine/services/row/interfaces/row.ts +0 -4
  420. package/src/engine/services/row/methods/index.ts +0 -0
  421. package/src/engine/services/row/row.ts +0 -10
  422. package/src/engine/services/services.ts +0 -26
  423. package/src/engine/store/interfaces/grid-state.ts +0 -20
  424. package/src/engine/store/methods/create-initial-state.ts +0 -20
  425. package/src/engine/store/methods/create-tracked-proxy.ts +0 -60
  426. package/src/engine/store/methods/debug.ts +0 -29
  427. package/src/engine/store/store.ts +0 -85
  428. package/src/engine/store/types/store-mutation.ts +0 -5
  429. package/src/styles/body.css +0 -13
  430. package/src/styles/cell.css +0 -15
  431. package/src/styles/footer.css +0 -30
  432. package/src/styles/grid.css +0 -5
  433. package/src/styles/header.css +0 -25
  434. package/src/styles/index.css +0 -9
  435. package/src/styles/root.css +0 -12
  436. package/src/styles/row.css +0 -12
  437. package/src/styles/scrollbar.css +0 -50
  438. package/src/styles/viewport.css +0 -6
  439. package/src/styles.d.ts +0 -1
  440. package/tsconfig.json +0 -23
@@ -1,30 +0,0 @@
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
- }
@@ -1,22 +0,0 @@
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
- }
@@ -1,20 +0,0 @@
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
- }
@@ -1,11 +0,0 @@
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
- }
@@ -1,9 +0,0 @@
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
- }
@@ -1,31 +0,0 @@
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
- }
@@ -1,26 +0,0 @@
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
- }
@@ -1,18 +0,0 @@
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
- }
@@ -1,18 +0,0 @@
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
- }
@@ -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
- }