@operato/data-grist 9.0.0-beta.62 → 9.0.0-beta.64

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 (424) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/src/accumulator/accumulator.d.ts +2 -0
  3. package/dist/src/accumulator/accumulator.js +42 -0
  4. package/dist/src/accumulator/accumulator.js.map +1 -0
  5. package/dist/src/configure/column-builder.d.ts +2 -0
  6. package/dist/src/configure/column-builder.js +99 -0
  7. package/dist/src/configure/column-builder.js.map +1 -0
  8. package/dist/src/configure/config-builder.d.ts +2 -0
  9. package/dist/src/configure/config-builder.js +36 -0
  10. package/dist/src/configure/config-builder.js.map +1 -0
  11. package/dist/src/configure/filters-option-builder.d.ts +2 -0
  12. package/dist/src/configure/filters-option-builder.js +7 -0
  13. package/dist/src/configure/filters-option-builder.js.map +1 -0
  14. package/dist/src/configure/imex-option-builder.d.ts +2 -0
  15. package/dist/src/configure/imex-option-builder.js +4 -0
  16. package/dist/src/configure/imex-option-builder.js.map +1 -0
  17. package/dist/src/configure/list-option-builder.d.ts +2 -0
  18. package/dist/src/configure/list-option-builder.js +8 -0
  19. package/dist/src/configure/list-option-builder.js.map +1 -0
  20. package/dist/src/configure/rows-option-builder.d.ts +2 -0
  21. package/dist/src/configure/rows-option-builder.js +26 -0
  22. package/dist/src/configure/rows-option-builder.js.map +1 -0
  23. package/dist/src/configure/tree-option-builder.d.ts +2 -0
  24. package/dist/src/configure/tree-option-builder.js +18 -0
  25. package/dist/src/configure/tree-option-builder.js.map +1 -0
  26. package/dist/src/configure/zero-config.d.ts +23 -0
  27. package/dist/src/configure/zero-config.js +59 -0
  28. package/dist/src/configure/zero-config.js.map +1 -0
  29. package/dist/src/const.d.ts +1 -0
  30. package/dist/src/const.js +2 -0
  31. package/dist/src/const.js.map +1 -0
  32. package/dist/src/data-card/data-card-field.d.ts +11 -0
  33. package/dist/src/data-card/data-card-field.js +106 -0
  34. package/dist/src/data-card/data-card-field.js.map +1 -0
  35. package/dist/src/data-card/data-card-gutter-menu.d.ts +2 -0
  36. package/dist/src/data-card/data-card-gutter-menu.js +96 -0
  37. package/dist/src/data-card/data-card-gutter-menu.js.map +1 -0
  38. package/dist/src/data-card/data-card-gutter.d.ts +12 -0
  39. package/dist/src/data-card/data-card-gutter.js +116 -0
  40. package/dist/src/data-card/data-card-gutter.js.map +1 -0
  41. package/dist/src/data-card/data-card.d.ts +19 -0
  42. package/dist/src/data-card/data-card.js +149 -0
  43. package/dist/src/data-card/data-card.js.map +1 -0
  44. package/dist/src/data-card/event-handlers/record-card-click-handler.d.ts +7 -0
  45. package/dist/src/data-card/event-handlers/record-card-click-handler.js +29 -0
  46. package/dist/src/data-card/event-handlers/record-card-click-handler.js.map +1 -0
  47. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.d.ts +7 -0
  48. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js +29 -0
  49. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js.map +1 -0
  50. package/dist/src/data-card/record-card.d.ts +23 -0
  51. package/dist/src/data-card/record-card.js +288 -0
  52. package/dist/src/data-card/record-card.js.map +1 -0
  53. package/dist/src/data-consumer.d.ts +10 -0
  54. package/dist/src/data-consumer.js +2 -0
  55. package/dist/src/data-consumer.js.map +1 -0
  56. package/dist/src/data-grid/data-grid-accum-field.d.ts +16 -0
  57. package/dist/src/data-grid/data-grid-accum-field.js +133 -0
  58. package/dist/src/data-grid/data-grid-accum-field.js.map +1 -0
  59. package/dist/src/data-grid/data-grid-body-style.d.ts +1 -0
  60. package/dist/src/data-grid/data-grid-body-style.js +99 -0
  61. package/dist/src/data-grid/data-grid-body-style.js.map +1 -0
  62. package/dist/src/data-grid/data-grid-body.d.ts +52 -0
  63. package/dist/src/data-grid/data-grid-body.js +660 -0
  64. package/dist/src/data-grid/data-grid-body.js.map +1 -0
  65. package/dist/src/data-grid/data-grid-field.d.ts +25 -0
  66. package/dist/src/data-grid/data-grid-field.js +263 -0
  67. package/dist/src/data-grid/data-grid-field.js.map +1 -0
  68. package/dist/src/data-grid/data-grid-footer.d.ts +11 -0
  69. package/dist/src/data-grid/data-grid-footer.js +120 -0
  70. package/dist/src/data-grid/data-grid-footer.js.map +1 -0
  71. package/dist/src/data-grid/data-grid-header.d.ts +29 -0
  72. package/dist/src/data-grid/data-grid-header.js +531 -0
  73. package/dist/src/data-grid/data-grid-header.js.map +1 -0
  74. package/dist/src/data-grid/data-grid.d.ts +36 -0
  75. package/dist/src/data-grid/data-grid.js +260 -0
  76. package/dist/src/data-grid/data-grid.js.map +1 -0
  77. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.d.ts +7 -0
  78. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js +57 -0
  79. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js.map +1 -0
  80. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.d.ts +7 -0
  81. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js +25 -0
  82. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js.map +1 -0
  83. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.d.ts +7 -0
  84. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js +34 -0
  85. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js.map +1 -0
  86. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.d.ts +7 -0
  87. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js +19 -0
  88. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js.map +1 -0
  89. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.d.ts +7 -0
  90. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js +226 -0
  91. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js.map +1 -0
  92. package/dist/src/data-grist.d.ts +367 -0
  93. package/dist/src/data-grist.js +1064 -0
  94. package/dist/src/data-grist.js.map +1 -0
  95. package/dist/src/data-list/data-list-field.d.ts +11 -0
  96. package/dist/src/data-list/data-list-field.js +95 -0
  97. package/dist/src/data-list/data-list-field.js.map +1 -0
  98. package/dist/src/data-list/data-list-gutter.d.ts +12 -0
  99. package/dist/src/data-list/data-list-gutter.js +121 -0
  100. package/dist/src/data-list/data-list-gutter.js.map +1 -0
  101. package/dist/src/data-list/data-list.d.ts +18 -0
  102. package/dist/src/data-list/data-list.js +139 -0
  103. package/dist/src/data-list/data-list.js.map +1 -0
  104. package/dist/src/data-list/event-handlers/record-partial-click-handler.d.ts +7 -0
  105. package/dist/src/data-list/event-handlers/record-partial-click-handler.js +29 -0
  106. package/dist/src/data-list/event-handlers/record-partial-click-handler.js.map +1 -0
  107. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.d.ts +7 -0
  108. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js +29 -0
  109. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js.map +1 -0
  110. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.d.ts +7 -0
  111. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js +29 -0
  112. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js.map +1 -0
  113. package/dist/src/data-list/record-partial.d.ts +21 -0
  114. package/dist/src/data-list/record-partial.js +252 -0
  115. package/dist/src/data-list/record-partial.js.map +1 -0
  116. package/dist/src/data-manipulator.d.ts +38 -0
  117. package/dist/src/data-manipulator.js +324 -0
  118. package/dist/src/data-manipulator.js.map +1 -0
  119. package/dist/src/data-provider.d.ts +50 -0
  120. package/dist/src/data-provider.js +200 -0
  121. package/dist/src/data-provider.js.map +1 -0
  122. package/dist/src/data-report/data-report-body-style.d.ts +1 -0
  123. package/dist/src/data-report/data-report-body-style.js +58 -0
  124. package/dist/src/data-report/data-report-body-style.js.map +1 -0
  125. package/dist/src/data-report/data-report-body.d.ts +18 -0
  126. package/dist/src/data-report/data-report-body.js +181 -0
  127. package/dist/src/data-report/data-report-body.js.map +1 -0
  128. package/dist/src/data-report/data-report-component.d.ts +21 -0
  129. package/dist/src/data-report/data-report-component.js +138 -0
  130. package/dist/src/data-report/data-report-component.js.map +1 -0
  131. package/dist/src/data-report/data-report-field.d.ts +13 -0
  132. package/dist/src/data-report/data-report-field.js +99 -0
  133. package/dist/src/data-report/data-report-field.js.map +1 -0
  134. package/dist/src/data-report/data-report-header.d.ts +1 -0
  135. package/dist/src/data-report/data-report-header.js +221 -0
  136. package/dist/src/data-report/data-report-header.js.map +1 -0
  137. package/dist/src/data-report/event-handlers/data-report-body-click-handler.d.ts +5 -0
  138. package/dist/src/data-report/event-handlers/data-report-body-click-handler.js +33 -0
  139. package/dist/src/data-report/event-handlers/data-report-body-click-handler.js.map +1 -0
  140. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.d.ts +5 -0
  141. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js +19 -0
  142. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js.map +1 -0
  143. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.d.ts +5 -0
  144. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js +58 -0
  145. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js.map +1 -0
  146. package/dist/src/data-report.d.ts +44 -0
  147. package/dist/src/data-report.js +386 -0
  148. package/dist/src/data-report.js.map +1 -0
  149. package/dist/src/editors/index.d.ts +3 -0
  150. package/dist/src/editors/index.js +4 -0
  151. package/dist/src/editors/index.js.map +1 -0
  152. package/dist/src/editors/ox-grist-editor-checkbox.d.ts +7 -0
  153. package/dist/src/editors/ox-grist-editor-checkbox.js +27 -0
  154. package/dist/src/editors/ox-grist-editor-checkbox.js.map +1 -0
  155. package/dist/src/editors/ox-grist-editor-color.d.ts +4 -0
  156. package/dist/src/editors/ox-grist-editor-color.js +14 -0
  157. package/dist/src/editors/ox-grist-editor-color.js.map +1 -0
  158. package/dist/src/editors/ox-grist-editor-date.d.ts +4 -0
  159. package/dist/src/editors/ox-grist-editor-date.js +14 -0
  160. package/dist/src/editors/ox-grist-editor-date.js.map +1 -0
  161. package/dist/src/editors/ox-grist-editor-datetime.d.ts +6 -0
  162. package/dist/src/editors/ox-grist-editor-datetime.js +26 -0
  163. package/dist/src/editors/ox-grist-editor-datetime.js.map +1 -0
  164. package/dist/src/editors/ox-grist-editor-email.d.ts +4 -0
  165. package/dist/src/editors/ox-grist-editor-email.js +14 -0
  166. package/dist/src/editors/ox-grist-editor-email.js.map +1 -0
  167. package/dist/src/editors/ox-grist-editor-file.d.ts +6 -0
  168. package/dist/src/editors/ox-grist-editor-file.js +25 -0
  169. package/dist/src/editors/ox-grist-editor-file.js.map +1 -0
  170. package/dist/src/editors/ox-grist-editor-image.d.ts +7 -0
  171. package/dist/src/editors/ox-grist-editor-image.js +31 -0
  172. package/dist/src/editors/ox-grist-editor-image.js.map +1 -0
  173. package/dist/src/editors/ox-grist-editor-json5.d.ts +8 -0
  174. package/dist/src/editors/ox-grist-editor-json5.js +66 -0
  175. package/dist/src/editors/ox-grist-editor-json5.js.map +1 -0
  176. package/dist/src/editors/ox-grist-editor-month.d.ts +4 -0
  177. package/dist/src/editors/ox-grist-editor-month.js +14 -0
  178. package/dist/src/editors/ox-grist-editor-month.js.map +1 -0
  179. package/dist/src/editors/ox-grist-editor-multiple-select.d.ts +8 -0
  180. package/dist/src/editors/ox-grist-editor-multiple-select.js +52 -0
  181. package/dist/src/editors/ox-grist-editor-multiple-select.js.map +1 -0
  182. package/dist/src/editors/ox-grist-editor-number.d.ts +6 -0
  183. package/dist/src/editors/ox-grist-editor-number.js +27 -0
  184. package/dist/src/editors/ox-grist-editor-number.js.map +1 -0
  185. package/dist/src/editors/ox-grist-editor-password.d.ts +4 -0
  186. package/dist/src/editors/ox-grist-editor-password.js +14 -0
  187. package/dist/src/editors/ox-grist-editor-password.js.map +1 -0
  188. package/dist/src/editors/ox-grist-editor-select.d.ts +4 -0
  189. package/dist/src/editors/ox-grist-editor-select.js +53 -0
  190. package/dist/src/editors/ox-grist-editor-select.js.map +1 -0
  191. package/dist/src/editors/ox-grist-editor-tel.d.ts +4 -0
  192. package/dist/src/editors/ox-grist-editor-tel.js +14 -0
  193. package/dist/src/editors/ox-grist-editor-tel.js.map +1 -0
  194. package/dist/src/editors/ox-grist-editor-text.d.ts +5 -0
  195. package/dist/src/editors/ox-grist-editor-text.js +17 -0
  196. package/dist/src/editors/ox-grist-editor-text.js.map +1 -0
  197. package/dist/src/editors/ox-grist-editor-textarea.d.ts +6 -0
  198. package/dist/src/editors/ox-grist-editor-textarea.js +18 -0
  199. package/dist/src/editors/ox-grist-editor-textarea.js.map +1 -0
  200. package/dist/src/editors/ox-grist-editor-time.d.ts +4 -0
  201. package/dist/src/editors/ox-grist-editor-time.js +14 -0
  202. package/dist/src/editors/ox-grist-editor-time.js.map +1 -0
  203. package/dist/src/editors/ox-grist-editor-tree.d.ts +6 -0
  204. package/dist/src/editors/ox-grist-editor-tree.js +27 -0
  205. package/dist/src/editors/ox-grist-editor-tree.js.map +1 -0
  206. package/dist/src/editors/ox-grist-editor-varname.d.ts +6 -0
  207. package/dist/src/editors/ox-grist-editor-varname.js +36 -0
  208. package/dist/src/editors/ox-grist-editor-varname.js.map +1 -0
  209. package/dist/src/editors/ox-grist-editor-week.d.ts +4 -0
  210. package/dist/src/editors/ox-grist-editor-week.js +14 -0
  211. package/dist/src/editors/ox-grist-editor-week.js.map +1 -0
  212. package/dist/src/editors/ox-grist-editor.d.ts +27 -0
  213. package/dist/src/editors/ox-grist-editor.js +197 -0
  214. package/dist/src/editors/ox-grist-editor.js.map +1 -0
  215. package/dist/src/editors/ox-input-tree.d.ts +20 -0
  216. package/dist/src/editors/ox-input-tree.js +221 -0
  217. package/dist/src/editors/ox-input-tree.js.map +1 -0
  218. package/dist/src/editors/ox-popup-code-input.d.ts +14 -0
  219. package/dist/src/editors/ox-popup-code-input.js +78 -0
  220. package/dist/src/editors/ox-popup-code-input.js.map +1 -0
  221. package/dist/src/editors/registry.d.ts +12 -0
  222. package/dist/src/editors/registry.js +73 -0
  223. package/dist/src/editors/registry.js.map +1 -0
  224. package/dist/src/empty-note.d.ts +9 -0
  225. package/dist/src/empty-note.js +53 -0
  226. package/dist/src/empty-note.js.map +1 -0
  227. package/dist/src/filters/filter-checkbox.d.ts +3 -0
  228. package/dist/src/filters/filter-checkbox.js +41 -0
  229. package/dist/src/filters/filter-checkbox.js.map +1 -0
  230. package/dist/src/filters/filter-input-barcode.d.ts +3 -0
  231. package/dist/src/filters/filter-input-barcode.js +28 -0
  232. package/dist/src/filters/filter-input-barcode.js.map +1 -0
  233. package/dist/src/filters/filter-input.d.ts +2 -0
  234. package/dist/src/filters/filter-input.js +25 -0
  235. package/dist/src/filters/filter-input.js.map +1 -0
  236. package/dist/src/filters/filter-range-date.d.ts +2 -0
  237. package/dist/src/filters/filter-range-date.js +66 -0
  238. package/dist/src/filters/filter-range-date.js.map +1 -0
  239. package/dist/src/filters/filter-range-number.d.ts +2 -0
  240. package/dist/src/filters/filter-range-number.js +54 -0
  241. package/dist/src/filters/filter-range-number.js.map +1 -0
  242. package/dist/src/filters/filter-select-buttons.d.ts +3 -0
  243. package/dist/src/filters/filter-select-buttons.js +50 -0
  244. package/dist/src/filters/filter-select-buttons.js.map +1 -0
  245. package/dist/src/filters/filter-select.d.ts +3 -0
  246. package/dist/src/filters/filter-select.js +52 -0
  247. package/dist/src/filters/filter-select.js.map +1 -0
  248. package/dist/src/filters/filter-styles.d.ts +1 -0
  249. package/dist/src/filters/filter-styles.js +119 -0
  250. package/dist/src/filters/filter-styles.js.map +1 -0
  251. package/dist/src/filters/filters-form.d.ts +40 -0
  252. package/dist/src/filters/filters-form.js +430 -0
  253. package/dist/src/filters/filters-form.js.map +1 -0
  254. package/dist/src/filters/index.d.ts +8 -0
  255. package/dist/src/filters/index.js +9 -0
  256. package/dist/src/filters/index.js.map +1 -0
  257. package/dist/src/filters/registry.d.ts +7 -0
  258. package/dist/src/filters/registry.js +48 -0
  259. package/dist/src/filters/registry.js.map +1 -0
  260. package/dist/src/formatters/date-formatter.d.ts +1 -0
  261. package/dist/src/formatters/date-formatter.js +4 -0
  262. package/dist/src/formatters/date-formatter.js.map +1 -0
  263. package/dist/src/formatters/index.d.ts +1 -0
  264. package/dist/src/formatters/index.js +2 -0
  265. package/dist/src/formatters/index.js.map +1 -0
  266. package/dist/src/formatters/number-formatter.d.ts +1 -0
  267. package/dist/src/formatters/number-formatter.js +4 -0
  268. package/dist/src/formatters/number-formatter.js.map +1 -0
  269. package/dist/src/formatters/registry.d.ts +6 -0
  270. package/dist/src/formatters/registry.js +25 -0
  271. package/dist/src/formatters/registry.js.map +1 -0
  272. package/dist/src/formatters/text-formatter.d.ts +1 -0
  273. package/dist/src/formatters/text-formatter.js +4 -0
  274. package/dist/src/formatters/text-formatter.js.map +1 -0
  275. package/dist/src/gutters/gutter-button.d.ts +21 -0
  276. package/dist/src/gutters/gutter-button.js +40 -0
  277. package/dist/src/gutters/gutter-button.js.map +1 -0
  278. package/dist/src/gutters/gutter-dirty.d.ts +23 -0
  279. package/dist/src/gutters/gutter-dirty.js +87 -0
  280. package/dist/src/gutters/gutter-dirty.js.map +1 -0
  281. package/dist/src/gutters/gutter-row-selector.d.ts +21 -0
  282. package/dist/src/gutters/gutter-row-selector.js +70 -0
  283. package/dist/src/gutters/gutter-row-selector.js.map +1 -0
  284. package/dist/src/gutters/gutter-sequence.d.ts +35 -0
  285. package/dist/src/gutters/gutter-sequence.js +48 -0
  286. package/dist/src/gutters/gutter-sequence.js.map +1 -0
  287. package/dist/src/gutters/index.d.ts +1 -0
  288. package/dist/src/gutters/index.js +2 -0
  289. package/dist/src/gutters/index.js.map +1 -0
  290. package/dist/src/gutters/registry.d.ts +7 -0
  291. package/dist/src/gutters/registry.js +26 -0
  292. package/dist/src/gutters/registry.js.map +1 -0
  293. package/dist/src/handlers/contextmenu-tree-mutation.d.ts +3 -0
  294. package/dist/src/handlers/contextmenu-tree-mutation.js +64 -0
  295. package/dist/src/handlers/contextmenu-tree-mutation.js.map +1 -0
  296. package/dist/src/handlers/index.d.ts +1 -0
  297. package/dist/src/handlers/index.js +2 -0
  298. package/dist/src/handlers/index.js.map +1 -0
  299. package/dist/src/handlers/move-down.d.ts +3 -0
  300. package/dist/src/handlers/move-down.js +26 -0
  301. package/dist/src/handlers/move-down.js.map +1 -0
  302. package/dist/src/handlers/move-up.d.ts +3 -0
  303. package/dist/src/handlers/move-up.js +26 -0
  304. package/dist/src/handlers/move-up.js.map +1 -0
  305. package/dist/src/handlers/record-copy.d.ts +3 -0
  306. package/dist/src/handlers/record-copy.js +23 -0
  307. package/dist/src/handlers/record-copy.js.map +1 -0
  308. package/dist/src/handlers/record-delete.d.ts +3 -0
  309. package/dist/src/handlers/record-delete.js +16 -0
  310. package/dist/src/handlers/record-delete.js.map +1 -0
  311. package/dist/src/handlers/record-view-handler.d.ts +3 -0
  312. package/dist/src/handlers/record-view-handler.js +15 -0
  313. package/dist/src/handlers/record-view-handler.js.map +1 -0
  314. package/dist/src/handlers/registry.d.ts +7 -0
  315. package/dist/src/handlers/registry.js +34 -0
  316. package/dist/src/handlers/registry.js.map +1 -0
  317. package/dist/src/handlers/select-row-toggle.d.ts +3 -0
  318. package/dist/src/handlers/select-row-toggle.js +18 -0
  319. package/dist/src/handlers/select-row-toggle.js.map +1 -0
  320. package/dist/src/handlers/select-row.d.ts +3 -0
  321. package/dist/src/handlers/select-row.js +14 -0
  322. package/dist/src/handlers/select-row.js.map +1 -0
  323. package/dist/src/index.d.ts +14 -0
  324. package/dist/src/index.js +15 -0
  325. package/dist/src/index.js.map +1 -0
  326. package/dist/src/personalizer/index.d.ts +1 -0
  327. package/dist/src/personalizer/index.js +2 -0
  328. package/dist/src/personalizer/index.js.map +1 -0
  329. package/dist/src/personalizer/ox-grist-filter-personalizer.d.ts +8 -0
  330. package/dist/src/personalizer/ox-grist-filter-personalizer.js +178 -0
  331. package/dist/src/personalizer/ox-grist-filter-personalizer.js.map +1 -0
  332. package/dist/src/personalizer/ox-grist-personalizer.d.ts +8 -0
  333. package/dist/src/personalizer/ox-grist-personalizer.js +212 -0
  334. package/dist/src/personalizer/ox-grist-personalizer.js.map +1 -0
  335. package/dist/src/record-view/event-handlers/record-view-body-click-handler.d.ts +7 -0
  336. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js +27 -0
  337. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js.map +1 -0
  338. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.d.ts +7 -0
  339. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js +22 -0
  340. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js.map +1 -0
  341. package/dist/src/record-view/index.d.ts +2 -0
  342. package/dist/src/record-view/index.js +3 -0
  343. package/dist/src/record-view/index.js.map +1 -0
  344. package/dist/src/record-view/ox-record-creator.d.ts +26 -0
  345. package/dist/src/record-view/ox-record-creator.js +247 -0
  346. package/dist/src/record-view/ox-record-creator.js.map +1 -0
  347. package/dist/src/record-view/record-view-body.d.ts +21 -0
  348. package/dist/src/record-view/record-view-body.js +252 -0
  349. package/dist/src/record-view/record-view-body.js.map +1 -0
  350. package/dist/src/record-view/record-view-handler.d.ts +9 -0
  351. package/dist/src/record-view/record-view-handler.js +57 -0
  352. package/dist/src/record-view/record-view-handler.js.map +1 -0
  353. package/dist/src/record-view/record-view.d.ts +23 -0
  354. package/dist/src/record-view/record-view.js +117 -0
  355. package/dist/src/record-view/record-view.js.map +1 -0
  356. package/dist/src/renderers/index.d.ts +13 -0
  357. package/dist/src/renderers/index.js +14 -0
  358. package/dist/src/renderers/index.js.map +1 -0
  359. package/dist/src/renderers/ox-grist-renderer-boolean.d.ts +2 -0
  360. package/dist/src/renderers/ox-grist-renderer-boolean.js +39 -0
  361. package/dist/src/renderers/ox-grist-renderer-boolean.js.map +1 -0
  362. package/dist/src/renderers/ox-grist-renderer-color.d.ts +2 -0
  363. package/dist/src/renderers/ox-grist-renderer-color.js +12 -0
  364. package/dist/src/renderers/ox-grist-renderer-color.js.map +1 -0
  365. package/dist/src/renderers/ox-grist-renderer-date.d.ts +2 -0
  366. package/dist/src/renderers/ox-grist-renderer-date.js +53 -0
  367. package/dist/src/renderers/ox-grist-renderer-date.js.map +1 -0
  368. package/dist/src/renderers/ox-grist-renderer-file.d.ts +2 -0
  369. package/dist/src/renderers/ox-grist-renderer-file.js +27 -0
  370. package/dist/src/renderers/ox-grist-renderer-file.js.map +1 -0
  371. package/dist/src/renderers/ox-grist-renderer-image.d.ts +2 -0
  372. package/dist/src/renderers/ox-grist-renderer-image.js +24 -0
  373. package/dist/src/renderers/ox-grist-renderer-image.js.map +1 -0
  374. package/dist/src/renderers/ox-grist-renderer-json5.d.ts +2 -0
  375. package/dist/src/renderers/ox-grist-renderer-json5.js +30 -0
  376. package/dist/src/renderers/ox-grist-renderer-json5.js.map +1 -0
  377. package/dist/src/renderers/ox-grist-renderer-link.d.ts +2 -0
  378. package/dist/src/renderers/ox-grist-renderer-link.js +12 -0
  379. package/dist/src/renderers/ox-grist-renderer-link.js.map +1 -0
  380. package/dist/src/renderers/ox-grist-renderer-password.d.ts +2 -0
  381. package/dist/src/renderers/ox-grist-renderer-password.js +5 -0
  382. package/dist/src/renderers/ox-grist-renderer-password.js.map +1 -0
  383. package/dist/src/renderers/ox-grist-renderer-progress.d.ts +5 -0
  384. package/dist/src/renderers/ox-grist-renderer-progress.js +46 -0
  385. package/dist/src/renderers/ox-grist-renderer-progress.js.map +1 -0
  386. package/dist/src/renderers/ox-grist-renderer-select.d.ts +2 -0
  387. package/dist/src/renderers/ox-grist-renderer-select.js +50 -0
  388. package/dist/src/renderers/ox-grist-renderer-select.js.map +1 -0
  389. package/dist/src/renderers/ox-grist-renderer-text.d.ts +2 -0
  390. package/dist/src/renderers/ox-grist-renderer-text.js +11 -0
  391. package/dist/src/renderers/ox-grist-renderer-text.js.map +1 -0
  392. package/dist/src/renderers/ox-grist-renderer-textarea.d.ts +2 -0
  393. package/dist/src/renderers/ox-grist-renderer-textarea.js +5 -0
  394. package/dist/src/renderers/ox-grist-renderer-textarea.js.map +1 -0
  395. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +12 -0
  396. package/dist/src/renderers/ox-grist-renderer-tree.js +183 -0
  397. package/dist/src/renderers/ox-grist-renderer-tree.js.map +1 -0
  398. package/dist/src/renderers/ox-grist-renderer.d.ts +15 -0
  399. package/dist/src/renderers/ox-grist-renderer.js +48 -0
  400. package/dist/src/renderers/ox-grist-renderer.js.map +1 -0
  401. package/dist/src/renderers/registry.d.ts +12 -0
  402. package/dist/src/renderers/registry.js +70 -0
  403. package/dist/src/renderers/registry.js.map +1 -0
  404. package/dist/src/sorters/sorters-control.d.ts +12 -0
  405. package/dist/src/sorters/sorters-control.js +138 -0
  406. package/dist/src/sorters/sorters-control.js.map +1 -0
  407. package/dist/src/types.d.ts +696 -0
  408. package/dist/src/types.js +23 -0
  409. package/dist/src/types.js.map +1 -0
  410. package/dist/src/utils/index.d.ts +2 -0
  411. package/dist/src/utils/index.js +3 -0
  412. package/dist/src/utils/index.js.map +1 -0
  413. package/dist/src/utils/list-param.d.ts +16 -0
  414. package/dist/src/utils/list-param.js +40 -0
  415. package/dist/src/utils/list-param.js.map +1 -0
  416. package/dist/src/utils/supports-passive.d.ts +1 -0
  417. package/dist/src/utils/supports-passive.js +13 -0
  418. package/dist/src/utils/supports-passive.js.map +1 -0
  419. package/dist/tsconfig.tsbuildinfo +1 -1
  420. package/package.json +9 -5
  421. package/dist/index.d.ts +0 -1
  422. package/dist/index.js +0 -2
  423. package/dist/index.js.map +0 -1
  424. package/index.ts +0 -1
@@ -0,0 +1,58 @@
1
+ import { css } from 'lit';
2
+ export const dataReportBodyStyle = css `
3
+ :host {
4
+ display: grid;
5
+ grid-template-columns: var(--report-template-columns);
6
+ grid-auto-rows: var(--report-record-height, min-content);
7
+
8
+ overflow: auto;
9
+ outline: none;
10
+ }
11
+
12
+ :host > [focused] {
13
+ border: var(--report-record-focused-border);
14
+ }
15
+
16
+ :host > [focused-row] {
17
+ background-color: var(--report-record-focused-background-color);
18
+ }
19
+
20
+ :host > [totalized] {
21
+ background-color: var(--report-totalized-background-color);
22
+ border-top: var(--report-totalized-border);
23
+ border-bottom: var(--report-totalized-border);
24
+ color: var(--report-totalized-color);
25
+
26
+ font-weight: 700;
27
+ }
28
+
29
+ :host > [grouped] {
30
+ background-color: var(--report-grouped-background-color);
31
+ border-right: var(--report-grouped-border);
32
+ border-bottom: var(--report-grouped-border);
33
+ color: var(--report-grouped-color);
34
+
35
+ font-weight: 600;
36
+ }
37
+
38
+ @media print {
39
+ :host {
40
+ -webkit-print-color-adjust: exact;
41
+ grid-template-columns: var(--report-template-print-columns);
42
+ }
43
+ :host > [focused] {
44
+ border-width: 0 1px 1px 0;
45
+ border-right: var(--report-grouped-border);
46
+ border-bottom: var(--report-grouped-border);
47
+ }
48
+
49
+ :host > [focused-row] {
50
+ background-color: initial;
51
+ color: #000;
52
+ }
53
+ :host > [grouped] {
54
+ background-color: var(--report-grouped-background-color);
55
+ }
56
+ }
57
+ `;
58
+ //# sourceMappingURL=data-report-body-style.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-report-body-style.js","sourceRoot":"","sources":["../../../src/data-report/data-report-body-style.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAEzB,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuDrC,CAAA","sourcesContent":["import { css } from 'lit'\n\nexport const dataReportBodyStyle = css`\n :host {\n display: grid;\n grid-template-columns: var(--report-template-columns);\n grid-auto-rows: var(--report-record-height, min-content);\n\n overflow: auto;\n outline: none;\n }\n\n :host > [focused] {\n border: var(--report-record-focused-border);\n }\n\n :host > [focused-row] {\n background-color: var(--report-record-focused-background-color);\n }\n\n :host > [totalized] {\n background-color: var(--report-totalized-background-color);\n border-top: var(--report-totalized-border);\n border-bottom: var(--report-totalized-border);\n color: var(--report-totalized-color);\n\n font-weight: 700;\n }\n\n :host > [grouped] {\n background-color: var(--report-grouped-background-color);\n border-right: var(--report-grouped-border);\n border-bottom: var(--report-grouped-border);\n color: var(--report-grouped-color);\n\n font-weight: 600;\n }\n\n @media print {\n :host {\n -webkit-print-color-adjust: exact;\n grid-template-columns: var(--report-template-print-columns);\n }\n :host > [focused] {\n border-width: 0 1px 1px 0;\n border-right: var(--report-grouped-border);\n border-bottom: var(--report-grouped-border);\n }\n\n :host > [focused-row] {\n background-color: initial;\n color: #000;\n }\n :host > [grouped] {\n background-color: var(--report-grouped-background-color);\n }\n }\n`\n"]}
@@ -0,0 +1,18 @@
1
+ import './data-report-field.js';
2
+ import { LitElement, PropertyValues } from 'lit';
3
+ import { ColumnConfig, GristConfig, GristData } from '../types.js';
4
+ export declare class DataReportBody extends LitElement {
5
+ static styles: import("lit").CSSResult[];
6
+ config: GristConfig;
7
+ columns: ColumnConfig[];
8
+ data: GristData;
9
+ focused?: {
10
+ row: number;
11
+ column: number;
12
+ };
13
+ private _focusedListener?;
14
+ render(): import("lit-html").TemplateResult<1>;
15
+ firstUpdated(): void;
16
+ updated(changes: PropertyValues<this>): void;
17
+ focus(): void;
18
+ }
@@ -0,0 +1,181 @@
1
+ import { __decorate } from "tslib";
2
+ import './data-report-field.js';
3
+ import { html, LitElement } from 'lit';
4
+ import { customElement, property } from 'lit/decorators.js';
5
+ import { ZERO_CONFIG, ZERO_DATA } from '../configure/zero-config.js';
6
+ import { dataReportBodyStyle } from './data-report-body-style.js';
7
+ import { dataReportBodyClickHandler } from './event-handlers/data-report-body-click-handler.js';
8
+ import { dataReportBodyDblclickHandler } from './event-handlers/data-report-body-dblclick-handler.js';
9
+ import { dataReportBodyKeydownHandler } from './event-handlers/data-report-body-keydown-handler.js';
10
+ function calcScrollPos(parent, child) {
11
+ /* getBoundingClientRect는 safari에서 스크롤 상태에서 다른 브라우저와는 다른 값을 리턴함 - 사파리는 약간 이상 작동함. */
12
+ var { top: ct, left: cl, right: cr, bottom: cb } = child.getBoundingClientRect();
13
+ var { top: pt, left: pl, right: pr, bottom: pb } = parent.getBoundingClientRect();
14
+ var { scrollLeft, scrollTop } = parent;
15
+ var scrollbarWidth = parent.clientWidth - parent.offsetWidth;
16
+ var scrollbarHeight = parent.clientHeight - parent.offsetHeight;
17
+ return {
18
+ left: cl < pl ? scrollLeft - (pl - cl) : cr > pr ? scrollLeft - (pr - cr) - scrollbarWidth : undefined,
19
+ top: ct < pt ? scrollTop - (pt - ct) : cb > pb ? scrollTop - (pb - cb) - scrollbarHeight : undefined
20
+ };
21
+ }
22
+ let DataReportBody = class DataReportBody extends LitElement {
23
+ constructor() {
24
+ super(...arguments);
25
+ this.config = ZERO_CONFIG;
26
+ this.columns = [];
27
+ this.data = ZERO_DATA;
28
+ }
29
+ render() {
30
+ var { rows } = this.config;
31
+ var { groups } = rows || {};
32
+ var getColumnIndex = (name) => this.columns.filter(column => !column.hidden).findIndex(column => column.name == name);
33
+ var getColumn = (name) => this.columns.find(column => column.name == name);
34
+ var { row: focusedRow = 0, column: focusedColumn = 0 } = this.focused || {};
35
+ var columns = (this.columns || []).filter(column => !column.hidden && groups.map(group => group.column).indexOf(column.name) == -1);
36
+ var data = this.data;
37
+ var { records = [] } = data;
38
+ return html `
39
+ ${records.map((record, idxRow) => {
40
+ var attrFocusedRow = idxRow === focusedRow;
41
+ var totalic = record['*'];
42
+ var totalicColumn = totalic && (totalic.groupName == '*' ? getColumn(groups[0].column) : getColumn(totalic.groupName));
43
+ return html `
44
+ ${!totalic || (totalic && totalic.value)
45
+ ? html `
46
+ ${columns.map(column => {
47
+ let columnIndex = getColumnIndex(column.name);
48
+ return html `
49
+ <ox-report-field
50
+ .data=${data}
51
+ .rowIndex=${idxRow}
52
+ .columnIndex=${columnIndex}
53
+ .column=${column}
54
+ .record=${record}
55
+ ?gutter=${column.type == 'gutter'}
56
+ ?focused-row=${attrFocusedRow}
57
+ ?focused=${attrFocusedRow && columnIndex === focusedColumn}
58
+ ?totalized=${totalic}
59
+ .value=${record[column.name]}
60
+ ></ox-report-field>
61
+ `;
62
+ })}
63
+ <ox-report-field
64
+ .data=${data}
65
+ .rowIndex=${idxRow}
66
+ .record=${record}
67
+ ?focused-row=${attrFocusedRow}
68
+ ?totalized=${totalic}
69
+ ></ox-report-field>
70
+ `
71
+ : html ``}
72
+ ${!totalic
73
+ ? html ``
74
+ : html `
75
+ ${totalic.groupName == '*'
76
+ ? html ``
77
+ : html `
78
+ <ox-report-field
79
+ .data=${data}
80
+ .rowIndex=${totalic.row - 1}
81
+ .columnIndex=${totalic.column - 1}
82
+ .column=${totalicColumn}
83
+ .record=${record}
84
+ ?focused-row=${totalic.row - 1 <= focusedRow && totalic.row - 1 + totalic.rowspan > focusedRow}
85
+ ?focused=${totalic.row - 1 === focusedRow && totalic.column - 1 === focusedColumn}
86
+ ?grouped=${true}
87
+ .value=${record[totalic.groupName]}
88
+ .style="grid-area: ${totalic.row} / ${totalic.column} / span ${totalic.rowspan} / span 1;"
89
+ ></ox-report-field>
90
+ `}
91
+ ${!totalic.value
92
+ ? html ``
93
+ : html `
94
+ <ox-report-field
95
+ .data=${data}
96
+ .rowIndex=${idxRow}
97
+ .columnIndex=${totalic.column - 1}
98
+ .column=${totalic.titleColumn}
99
+ .record=${record}
100
+ ?focused-row=${attrFocusedRow}
101
+ ?focused=${idxRow === focusedRow && totalic.column - 1 === focusedColumn}
102
+ ?grouped=${true}
103
+ .value=${totalic.value}
104
+ .style="grid-area: ${totalic.row +
105
+ totalic.rowspan} / ${totalic.column} / span 1 / span ${totalic.colspan};"
106
+ ></ox-report-field>
107
+ `}
108
+ `}
109
+ `;
110
+ })}
111
+ `;
112
+ }
113
+ firstUpdated() {
114
+ /* focus() 를 받을 수 있도록 함. */
115
+ this.setAttribute('tabindex', '-1');
116
+ /*
117
+ * focusout 으로 property를 변경시키는 경우, focusout에 의해 update가 발생하는 경우에는,
118
+ * 그리드 내부의 컴포넌트가 갱신되는 현상을 초래하게 된다.
119
+ * 따라서, focusout 핸들러에서 update를 유발하는 코드는 강력하게 금지시킨다.
120
+ */
121
+ this.addEventListener('focusout', e => {
122
+ if (this._focusedListener) {
123
+ window.removeEventListener('keydown', this._focusedListener);
124
+ delete this._focusedListener;
125
+ }
126
+ });
127
+ this.addEventListener('focusin', e => {
128
+ if (!this._focusedListener) {
129
+ this._focusedListener = dataReportBodyKeydownHandler.bind(this);
130
+ window.addEventListener('keydown', this._focusedListener);
131
+ }
132
+ });
133
+ this.renderRoot.addEventListener('click', dataReportBodyClickHandler.bind(this));
134
+ this.renderRoot.addEventListener('dblclick', dataReportBodyDblclickHandler.bind(this));
135
+ }
136
+ updated(changes) {
137
+ if (changes.has('focused')) {
138
+ let element = this.renderRoot.querySelector('[focused]');
139
+ if (!element) {
140
+ return;
141
+ }
142
+ let { top, left } = calcScrollPos(this, element);
143
+ // TODO this.scroll()을 사용하면, 효과가 좋으나 left 계산에 문제가 있는 것 같음.
144
+ // this.scroll({
145
+ // top,
146
+ // left,
147
+ // behavior: 'smooth'
148
+ // })
149
+ if (top !== undefined) {
150
+ this.scrollTop = top;
151
+ }
152
+ if (left !== undefined) {
153
+ this.scrollLeft = left;
154
+ }
155
+ }
156
+ }
157
+ focus() {
158
+ super.focus();
159
+ if (!this.focused || this.focused.row == null) {
160
+ this.focused = { row: 0, column: 0 };
161
+ }
162
+ }
163
+ };
164
+ DataReportBody.styles = [dataReportBodyStyle];
165
+ __decorate([
166
+ property({ type: Object })
167
+ ], DataReportBody.prototype, "config", void 0);
168
+ __decorate([
169
+ property({ type: Array })
170
+ ], DataReportBody.prototype, "columns", void 0);
171
+ __decorate([
172
+ property({ type: Object })
173
+ ], DataReportBody.prototype, "data", void 0);
174
+ __decorate([
175
+ property({ type: Object })
176
+ ], DataReportBody.prototype, "focused", void 0);
177
+ DataReportBody = __decorate([
178
+ customElement('ox-report-body')
179
+ ], DataReportBody);
180
+ export { DataReportBody };
181
+ //# sourceMappingURL=data-report-body.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-report-body.js","sourceRoot":"","sources":["../../../src/data-report/data-report-body.ts"],"names":[],"mappings":"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","sourcesContent":["import './data-report-field.js'\n\nimport { html, LitElement, PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_CONFIG, ZERO_DATA } from '../configure/zero-config.js'\nimport { ColumnConfig, GristConfig, GristData } from '../types.js'\nimport { dataReportBodyStyle } from './data-report-body-style.js'\nimport { dataReportBodyClickHandler } from './event-handlers/data-report-body-click-handler.js'\nimport { dataReportBodyDblclickHandler } from './event-handlers/data-report-body-dblclick-handler.js'\nimport { dataReportBodyKeydownHandler } from './event-handlers/data-report-body-keydown-handler.js'\n\nfunction calcScrollPos(parent: DataReportBody, child: Element) {\n /* getBoundingClientRect는 safari에서 스크롤 상태에서 다른 브라우저와는 다른 값을 리턴함 - 사파리는 약간 이상 작동함. */\n var { top: ct, left: cl, right: cr, bottom: cb } = child.getBoundingClientRect()\n var { top: pt, left: pl, right: pr, bottom: pb } = parent.getBoundingClientRect()\n var { scrollLeft, scrollTop } = parent\n var scrollbarWidth = parent.clientWidth - parent.offsetWidth\n var scrollbarHeight = parent.clientHeight - parent.offsetHeight\n\n return {\n left: cl < pl ? scrollLeft - (pl - cl) : cr > pr ? scrollLeft - (pr - cr) - scrollbarWidth : undefined,\n top: ct < pt ? scrollTop - (pt - ct) : cb > pb ? scrollTop - (pb - cb) - scrollbarHeight : undefined\n }\n}\n\n@customElement('ox-report-body')\nexport class DataReportBody extends LitElement {\n static styles = [dataReportBodyStyle]\n\n @property({ type: Object }) config: GristConfig = ZERO_CONFIG\n @property({ type: Array }) columns: ColumnConfig[] = []\n @property({ type: Object }) data: GristData = ZERO_DATA\n @property({ type: Object }) focused?: { row: number; column: number }\n\n private _focusedListener?: EventListener\n\n render() {\n var { rows } = this.config\n var { groups } = rows || {}\n\n var getColumnIndex = (name: string) =>\n this.columns.filter(column => !column.hidden).findIndex(column => column.name == name)\n var getColumn = (name: string | number) => this.columns.find(column => column.name == name)\n\n var { row: focusedRow = 0, column: focusedColumn = 0 } = this.focused || {}\n\n var columns = (this.columns || []).filter(\n column => !column.hidden && groups.map(group => group.column).indexOf(column.name) == -1\n )\n var data = this.data\n var { records = [] } = data\n\n return html`\n ${records.map((record, idxRow) => {\n var attrFocusedRow = idxRow === focusedRow\n var totalic = record['*']\n var totalicColumn =\n totalic && (totalic.groupName == '*' ? getColumn(groups[0].column) : getColumn(totalic.groupName))\n\n return html`\n ${!totalic || (totalic && totalic.value)\n ? html`\n ${columns.map(column => {\n let columnIndex = getColumnIndex(column.name)\n return html`\n <ox-report-field\n .data=${data}\n .rowIndex=${idxRow}\n .columnIndex=${columnIndex}\n .column=${column}\n .record=${record}\n ?gutter=${column.type == 'gutter'}\n ?focused-row=${attrFocusedRow}\n ?focused=${attrFocusedRow && columnIndex === focusedColumn}\n ?totalized=${totalic}\n .value=${record[column.name]}\n ></ox-report-field>\n `\n })}\n <ox-report-field\n .data=${data}\n .rowIndex=${idxRow}\n .record=${record}\n ?focused-row=${attrFocusedRow}\n ?totalized=${totalic}\n ></ox-report-field>\n `\n : html``}\n ${!totalic\n ? html``\n : html`\n ${totalic.groupName == '*'\n ? html``\n : html`\n <ox-report-field\n .data=${data}\n .rowIndex=${totalic.row - 1}\n .columnIndex=${totalic.column - 1}\n .column=${totalicColumn}\n .record=${record}\n ?focused-row=${totalic.row - 1 <= focusedRow && totalic.row - 1 + totalic.rowspan > focusedRow}\n ?focused=${totalic.row - 1 === focusedRow && totalic.column - 1 === focusedColumn}\n ?grouped=${true}\n .value=${record[totalic.groupName]}\n .style=\"grid-area: ${totalic.row} / ${totalic.column} / span ${totalic.rowspan} / span 1;\"\n ></ox-report-field>\n `}\n ${!totalic.value\n ? html``\n : html`\n <ox-report-field\n .data=${data}\n .rowIndex=${idxRow}\n .columnIndex=${totalic.column - 1}\n .column=${totalic.titleColumn}\n .record=${record}\n ?focused-row=${attrFocusedRow}\n ?focused=${idxRow === focusedRow && totalic.column - 1 === focusedColumn}\n ?grouped=${true}\n .value=${totalic.value}\n .style=\"grid-area: ${totalic.row +\n totalic.rowspan} / ${totalic.column} / span 1 / span ${totalic.colspan};\"\n ></ox-report-field>\n `}\n `}\n `\n })}\n `\n }\n\n firstUpdated() {\n /* focus() 를 받을 수 있도록 함. */\n this.setAttribute('tabindex', '-1')\n\n /*\n * focusout 으로 property를 변경시키는 경우, focusout에 의해 update가 발생하는 경우에는,\n * 그리드 내부의 컴포넌트가 갱신되는 현상을 초래하게 된다.\n * 따라서, focusout 핸들러에서 update를 유발하는 코드는 강력하게 금지시킨다.\n */\n this.addEventListener('focusout', e => {\n if (this._focusedListener) {\n window.removeEventListener('keydown', this._focusedListener)\n delete this._focusedListener\n }\n })\n\n this.addEventListener('focusin', e => {\n if (!this._focusedListener) {\n this._focusedListener = dataReportBodyKeydownHandler.bind(this) as EventListener\n window.addEventListener('keydown', this._focusedListener)\n }\n })\n\n this.renderRoot.addEventListener('click', dataReportBodyClickHandler.bind(this))\n this.renderRoot.addEventListener('dblclick', dataReportBodyDblclickHandler.bind(this))\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('focused')) {\n let element = this.renderRoot.querySelector('[focused]')\n if (!element) {\n return\n }\n\n let { top, left } = calcScrollPos(this, element)\n // TODO this.scroll()을 사용하면, 효과가 좋으나 left 계산에 문제가 있는 것 같음.\n // this.scroll({\n // top,\n // left,\n // behavior: 'smooth'\n // })\n if (top !== undefined) {\n this.scrollTop = top\n }\n if (left !== undefined) {\n this.scrollLeft = left\n }\n }\n }\n\n focus() {\n super.focus()\n\n if (!this.focused || this.focused.row == null) {\n this.focused = { row: 0, column: 0 }\n }\n }\n}\n"]}
@@ -0,0 +1,21 @@
1
+ import './data-report-header.js';
2
+ import './data-report-body.js';
3
+ import { LitElement, PropertyValues } from 'lit';
4
+ import { ColumnConfig, GristConfig, GristData } from '../types.js';
5
+ /**
6
+ * DataReportComponent
7
+ */
8
+ export declare class DataReportComponent extends LitElement {
9
+ static styles: import("lit").CSSResult[];
10
+ config: GristConfig;
11
+ data: GristData;
12
+ private _widths;
13
+ body: HTMLElement;
14
+ header: HTMLElement;
15
+ firstUpdated(): void;
16
+ updated(changes: PropertyValues<this>): void;
17
+ calculateWidths(columns: ColumnConfig[]): void;
18
+ render(): import("lit-html").TemplateResult<1>;
19
+ focus(): void;
20
+ get pullToRefreshTarget(): HTMLElement;
21
+ }
@@ -0,0 +1,138 @@
1
+ import { __decorate } from "tslib";
2
+ import './data-report-header.js';
3
+ import './data-report-body.js';
4
+ import { LitElement, css, html } from 'lit';
5
+ import { customElement, property, query } from 'lit/decorators.js';
6
+ import { ZERO_CONFIG, ZERO_DATA } from '../configure/zero-config.js';
7
+ import { ScrollbarStyles } from '@operato/styles';
8
+ /**
9
+ * DataReportComponent
10
+ */
11
+ let DataReportComponent = class DataReportComponent extends LitElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.config = ZERO_CONFIG;
15
+ this.data = ZERO_DATA;
16
+ this._widths = '';
17
+ }
18
+ firstUpdated() {
19
+ var _a, _b;
20
+ /* header and body scroll synchronization */
21
+ (_a = this.header) === null || _a === void 0 ? void 0 : _a.addEventListener('scroll', (e) => {
22
+ const body = this.body;
23
+ const header = this.header;
24
+ if (body && header) {
25
+ if (body.scrollLeft !== header.scrollLeft) {
26
+ body.scrollLeft = header.scrollLeft;
27
+ }
28
+ }
29
+ });
30
+ (_b = this.body) === null || _b === void 0 ? void 0 : _b.addEventListener('scroll', e => {
31
+ const body = this.body;
32
+ const header = this.header;
33
+ if (body && header) {
34
+ if (body.scrollLeft !== header.scrollLeft) {
35
+ header.scrollLeft = body.scrollLeft;
36
+ }
37
+ }
38
+ });
39
+ }
40
+ updated(changes) {
41
+ if (changes.has('config') || changes.has('data')) {
42
+ /*
43
+ * 데이타 내용에 따라 동적으로 컬럼의 폭이 달라지는 경우(예를 들면, sequence field)가 있으므로,
44
+ * data의 변동에 대해서도 다시 계산되어야 한다.
45
+ */
46
+ this.calculateWidths(this.config && this.config.columns);
47
+ }
48
+ }
49
+ calculateWidths(columns) {
50
+ /*
51
+ * 컬럼 모델 마지막에 'auto' cell을 추가하여, 자투리 영역을 꽉 채워서 표시한다.
52
+ */
53
+ this._widths = columns
54
+ .filter(column => !column.hidden)
55
+ .map(column => {
56
+ switch (typeof column.width) {
57
+ case 'number':
58
+ return column.width + 'px';
59
+ case 'string':
60
+ return column.width;
61
+ case 'function':
62
+ return column.width.call(this, column);
63
+ default:
64
+ return 'auto';
65
+ }
66
+ })
67
+ .concat(['auto'])
68
+ .join(' ');
69
+ this.style.setProperty('--report-template-columns', this._widths);
70
+ this.style.setProperty('--report-template-print-columns', this._widths.replace(/px/gi, 'fr'));
71
+ }
72
+ render() {
73
+ var { columns } = this.config;
74
+ var data = this.data;
75
+ return html `
76
+ <ox-report-header
77
+ .config=${this.config}
78
+ .columns=${columns}
79
+ .data=${data}
80
+ @column-width-change=${(e) => {
81
+ let { idx, width } = e.detail;
82
+ columns[idx].width = width;
83
+ this.calculateWidths(columns);
84
+ }}
85
+ ></ox-report-header>
86
+
87
+ <ox-report-body .config=${this.config} .columns=${columns} .data=${data}></ox-report-body>
88
+ `;
89
+ }
90
+ focus() {
91
+ super.focus();
92
+ this.body.focus();
93
+ }
94
+ get pullToRefreshTarget() {
95
+ return this.body;
96
+ }
97
+ };
98
+ DataReportComponent.styles = [
99
+ ScrollbarStyles,
100
+ css `
101
+ :host {
102
+ display: flex;
103
+ flex-direction: column;
104
+
105
+ overflow: hidden;
106
+
107
+ border: 1px solid var(--report-header-border-color);
108
+ border-radius: var(--report-component-border-radius);
109
+ }
110
+
111
+ ox-report-body {
112
+ flex: 1;
113
+ }
114
+
115
+ @media print {
116
+ :host {
117
+ zoom: 80%;
118
+ }
119
+ }
120
+ `
121
+ ];
122
+ __decorate([
123
+ property({ type: Object })
124
+ ], DataReportComponent.prototype, "config", void 0);
125
+ __decorate([
126
+ property({ type: Object })
127
+ ], DataReportComponent.prototype, "data", void 0);
128
+ __decorate([
129
+ query('ox-report-body', true)
130
+ ], DataReportComponent.prototype, "body", void 0);
131
+ __decorate([
132
+ query('ox-report-header', true)
133
+ ], DataReportComponent.prototype, "header", void 0);
134
+ DataReportComponent = __decorate([
135
+ customElement('ox-report-component')
136
+ ], DataReportComponent);
137
+ export { DataReportComponent };
138
+ //# sourceMappingURL=data-report-component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-report-component.js","sourceRoot":"","sources":["../../../src/data-report/data-report-component.ts"],"names":[],"mappings":"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","sourcesContent":["import './data-report-header.js'\nimport './data-report-body.js'\n\nimport { LitElement, PropertyValues, css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { ColumnConfig, GristConfig, GristData } from '../types.js'\nimport { ZERO_CONFIG, ZERO_DATA } from '../configure/zero-config.js'\n\nimport { ScrollbarStyles } from '@operato/styles'\n\n/**\n * DataReportComponent\n */\n\n@customElement('ox-report-component')\nexport class DataReportComponent extends LitElement {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n\n overflow: hidden;\n\n border: 1px solid var(--report-header-border-color);\n border-radius: var(--report-component-border-radius);\n }\n\n ox-report-body {\n flex: 1;\n }\n\n @media print {\n :host {\n zoom: 80%;\n }\n }\n `\n ]\n\n @property({ type: Object }) config: GristConfig = ZERO_CONFIG\n @property({ type: Object }) data: GristData = ZERO_DATA\n\n private _widths: string = ''\n\n @query('ox-report-body', true) body!: HTMLElement\n @query('ox-report-header', true) header!: HTMLElement\n\n firstUpdated() {\n /* header and body scroll synchronization */\n this.header?.addEventListener('scroll', (e: Event) => {\n const body = this.body\n const header = this.header\n if (body && header) {\n if (body.scrollLeft !== header.scrollLeft) {\n body.scrollLeft = header.scrollLeft\n }\n }\n })\n\n this.body?.addEventListener('scroll', e => {\n const body = this.body\n const header = this.header\n if (body && header) {\n if (body.scrollLeft !== header.scrollLeft) {\n header.scrollLeft = body.scrollLeft\n }\n }\n })\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('config') || changes.has('data')) {\n /*\n * 데이타 내용에 따라 동적으로 컬럼의 폭이 달라지는 경우(예를 들면, sequence field)가 있으므로,\n * data의 변동에 대해서도 다시 계산되어야 한다.\n */\n this.calculateWidths(this.config && this.config.columns)\n }\n }\n\n calculateWidths(columns: ColumnConfig[]) {\n /*\n * 컬럼 모델 마지막에 'auto' cell을 추가하여, 자투리 영역을 꽉 채워서 표시한다.\n */\n this._widths = columns\n .filter(column => !column.hidden)\n .map(column => {\n switch (typeof column.width) {\n case 'number':\n return column.width + 'px'\n case 'string':\n return column.width\n case 'function':\n return column.width.call(this, column)\n default:\n return 'auto'\n }\n })\n .concat(['auto'])\n .join(' ')\n\n this.style.setProperty('--report-template-columns', this._widths)\n this.style.setProperty('--report-template-print-columns', this._widths.replace(/px/gi, 'fr'))\n }\n\n render() {\n var { columns } = this.config\n\n var data = this.data\n\n return html`\n <ox-report-header\n .config=${this.config}\n .columns=${columns}\n .data=${data}\n @column-width-change=${(e: CustomEvent) => {\n let { idx, width } = e.detail\n columns[idx].width = width\n this.calculateWidths(columns)\n }}\n ></ox-report-header>\n\n <ox-report-body .config=${this.config} .columns=${columns} .data=${data}></ox-report-body>\n `\n }\n\n focus() {\n super.focus()\n\n this.body.focus()\n }\n\n get pullToRefreshTarget() {\n return this.body\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import { ColumnConfig, GristRecord } from '../types.js';
3
+ export declare class DataReportField extends LitElement {
4
+ static styles: import("lit").CSSResult[];
5
+ align?: string;
6
+ record: GristRecord;
7
+ column: ColumnConfig;
8
+ rowIndex: number;
9
+ columnIndex: number;
10
+ value: any;
11
+ render(): TemplateResult;
12
+ updated(changes: PropertyValues<this>): void;
13
+ }
@@ -0,0 +1,99 @@
1
+ import { __decorate } from "tslib";
2
+ import { LitElement, css, html } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js';
5
+ const DEFAULT_TEXT_ALIGN = 'left';
6
+ let DataReportField = class DataReportField extends LitElement {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.record = ZERO_RECORD;
10
+ this.column = ZERO_COLUMN;
11
+ this.rowIndex = -1;
12
+ this.columnIndex = -1;
13
+ }
14
+ render() {
15
+ if (!this.column) {
16
+ return html ``;
17
+ }
18
+ var { value, column, record, rowIndex } = this;
19
+ var { renderer } = column.record;
20
+ return html ` ${renderer(value, column, record, rowIndex, this)} `;
21
+ }
22
+ updated(changes) {
23
+ if (changes.has('column')) {
24
+ var align = (this.column.record && this.column.record.align) || DEFAULT_TEXT_ALIGN;
25
+ if (align != DEFAULT_TEXT_ALIGN) {
26
+ let justify = 'center';
27
+ switch (align) {
28
+ case 'right':
29
+ justify = 'flex-end';
30
+ break;
31
+ }
32
+ this.style.setProperty('--data-report-field-justify-content', justify);
33
+ this.style.setProperty('--data-report-field-text-align', align);
34
+ }
35
+ }
36
+ }
37
+ };
38
+ DataReportField.styles = [
39
+ css `
40
+ :host {
41
+ display: flex;
42
+ align-items: center;
43
+ justify-content: var(--data-report-field-justify-content, flex-start);
44
+ position: relative;
45
+
46
+ white-space: nowrap;
47
+ overflow: hidden;
48
+ background-color: var(--report-record-background-color);
49
+ padding: var(--report-record-field-padding);
50
+ border: 1px solid transparent;
51
+ border-bottom: var(--report-record-field-border-bottom);
52
+
53
+ font-size: var(--report-record-wide-fontsize);
54
+ text-overflow: ellipsis;
55
+
56
+ min-height: 30px;
57
+ box-sizing: border-box;
58
+ }
59
+
60
+ :host([gutter]) * {
61
+ cursor: default;
62
+ font-size: 1.2em;
63
+ }
64
+
65
+ * {
66
+ flex: 1;
67
+ margin: 0;
68
+ text-align: var(--data-report-field-text-align);
69
+ }
70
+
71
+ *[center] {
72
+ flex: none;
73
+ margin: 0 auto;
74
+ }
75
+ `
76
+ ];
77
+ __decorate([
78
+ property({ attribute: true })
79
+ ], DataReportField.prototype, "align", void 0);
80
+ __decorate([
81
+ property({ type: Object })
82
+ ], DataReportField.prototype, "record", void 0);
83
+ __decorate([
84
+ property({ type: Object })
85
+ ], DataReportField.prototype, "column", void 0);
86
+ __decorate([
87
+ property({ type: Number })
88
+ ], DataReportField.prototype, "rowIndex", void 0);
89
+ __decorate([
90
+ property({ type: Number })
91
+ ], DataReportField.prototype, "columnIndex", void 0);
92
+ __decorate([
93
+ property({ type: Object })
94
+ ], DataReportField.prototype, "value", void 0);
95
+ DataReportField = __decorate([
96
+ customElement('ox-report-field')
97
+ ], DataReportField);
98
+ export { DataReportField };
99
+ //# sourceMappingURL=data-report-field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-report-field.js","sourceRoot":"","sources":["../../../src/data-report/data-report-field.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAkC,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC3E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AAEtE,MAAM,kBAAkB,GAAG,MAAM,CAAA;AAG1B,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,UAAU;IAAxC;;QA0CuB,WAAM,GAAgB,WAAW,CAAA;QACjC,WAAM,GAAiB,WAAW,CAAA;QAClC,aAAQ,GAAW,CAAC,CAAC,CAAA;QACrB,gBAAW,GAAW,CAAC,CAAC,CAAA;IA6BtD,CAAC;IA1BC,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,OAAO,IAAI,CAAA,EAAE,CAAA;QACf,CAAC;QAED,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAC9C,IAAI,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC,MAAM,CAAA;QAEhC,OAAO,IAAI,CAAA,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAA;IACnE,CAAC;IAED,OAAO,CAAC,OAA6B;QACnC,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAA;YAClF,IAAI,KAAK,IAAI,kBAAkB,EAAE,CAAC;gBAChC,IAAI,OAAO,GAAG,QAAQ,CAAA;gBACtB,QAAQ,KAAK,EAAE,CAAC;oBACd,KAAK,OAAO;wBACV,OAAO,GAAG,UAAU,CAAA;wBACpB,MAAK;gBACT,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,qCAAqC,EAAE,OAAO,CAAC,CAAA;gBACtE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAA;YACjE,CAAC;QACH,CAAC;IACH,CAAC;;AAxEM,sBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoCF;CACF,AAtCY,CAsCZ;AAE8B;IAA9B,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;8CAAe;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAkC;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAmC;AAClC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;iDAAsB;AACrB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;oDAAyB;AACxB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAAW;AA9C3B,eAAe;IAD3B,aAAa,CAAC,iBAAiB,CAAC;GACpB,eAAe,CA0E3B","sourcesContent":["import { LitElement, PropertyValues, TemplateResult, css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { ColumnConfig, GristRecord } from '../types.js'\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js'\n\nconst DEFAULT_TEXT_ALIGN = 'left'\n\n@customElement('ox-report-field')\nexport class DataReportField extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n align-items: center;\n justify-content: var(--data-report-field-justify-content, flex-start);\n position: relative;\n\n white-space: nowrap;\n overflow: hidden;\n background-color: var(--report-record-background-color);\n padding: var(--report-record-field-padding);\n border: 1px solid transparent;\n border-bottom: var(--report-record-field-border-bottom);\n\n font-size: var(--report-record-wide-fontsize);\n text-overflow: ellipsis;\n\n min-height: 30px;\n box-sizing: border-box;\n }\n\n :host([gutter]) * {\n cursor: default;\n font-size: 1.2em;\n }\n\n * {\n flex: 1;\n margin: 0;\n text-align: var(--data-report-field-text-align);\n }\n\n *[center] {\n flex: none;\n margin: 0 auto;\n }\n `\n ]\n\n @property({ attribute: true }) align?: string\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Number }) rowIndex: number = -1\n @property({ type: Number }) columnIndex: number = -1\n @property({ type: Object }) value: any\n\n render(): TemplateResult {\n if (!this.column) {\n return html``\n }\n\n var { value, column, record, rowIndex } = this\n var { renderer } = column.record\n\n return html` ${renderer(value, column, record, rowIndex, this)} `\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('column')) {\n var align = (this.column.record && this.column.record.align) || DEFAULT_TEXT_ALIGN\n if (align != DEFAULT_TEXT_ALIGN) {\n let justify = 'center'\n switch (align) {\n case 'right':\n justify = 'flex-end'\n break\n }\n this.style.setProperty('--data-report-field-justify-content', justify)\n this.style.setProperty('--data-report-field-text-align', align)\n }\n }\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export {};