@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,8 @@
1
+ import '@material/web/button/outlined-button.js';
2
+ import { LitElement } from 'lit';
3
+ export declare class OxGristPersonalizer extends LitElement {
4
+ static styles: import("lit").CSSResult[];
5
+ debug: boolean;
6
+ private preference?;
7
+ render(): import("lit-html").TemplateResult<1>;
8
+ }
@@ -0,0 +1,212 @@
1
+ import { __decorate } from "tslib";
2
+ import '@material/web/button/outlined-button.js';
3
+ import { css, html, LitElement } from 'lit';
4
+ import { customElement, property, state } from 'lit/decorators.js';
5
+ import { i18next } from '@operato/i18n';
6
+ import { OxPopupList } from '@operato/popup';
7
+ let OxGristPersonalizer = class OxGristPersonalizer extends LitElement {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.debug = false;
11
+ }
12
+ render() {
13
+ return html `
14
+ <md-icon
15
+ @click=${(e) => {
16
+ const grist = this.closest('ox-grist');
17
+ const { config, compiledConfig, sorters, pagination, mode } = grist;
18
+ const { columns: compiledColumns } = compiledConfig;
19
+ const columns = compiledColumns
20
+ .filter(ccolumn => {
21
+ const column = config.columns.find((column) => column.name == ccolumn.name);
22
+ return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable;
23
+ })
24
+ .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name));
25
+ this.preference = {
26
+ columns: columns.map(column => {
27
+ return {
28
+ name: column.name,
29
+ hidden: column.hidden,
30
+ width: column.width
31
+ };
32
+ }),
33
+ sorters,
34
+ pagination: {
35
+ ...pagination,
36
+ limit: grist.getCurrentLimit()
37
+ },
38
+ mode
39
+ };
40
+ const template = html `
41
+ <div class="personalizer-header" slot="header">
42
+ <div
43
+ style=${`
44
+ display: flex;
45
+ align-items: center;
46
+ margin: 0 0 0 auto;
47
+ min-height: 1.4em;
48
+ color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
49
+ background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
50
+ border-radius: var(--md-sys-shape-corner-small);
51
+ padding: 0 var(--spacing-small);
52
+ cursor: pointer;
53
+ `}
54
+ @click=${async (e) => {
55
+ if (grist.personalConfigProvider) {
56
+ const { mode, columns, sorters, pagination } = this.preference || {};
57
+ grist.personalConfig = this.preference = await grist.personalConfigProvider.save({
58
+ mode,
59
+ columns,
60
+ sorters,
61
+ pagination
62
+ });
63
+ }
64
+ popup.close();
65
+ }}
66
+ >
67
+ ${String(i18next.t('button.save'))}
68
+ </div>
69
+ <div
70
+ style=${`
71
+ display: flex;
72
+ align-items: center;
73
+ margin: 0 0 0 var(--spacing-small, 4px);
74
+ min-height: 1.4em;
75
+ color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
76
+ background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
77
+ border-radius: var(--md-sys-shape-corner-small);
78
+ padding: 0 var(--spacing-small);
79
+ cursor: pointer;
80
+ `}
81
+ @click=${async (e) => {
82
+ if (grist.personalConfigProvider) {
83
+ grist.personalConfig = this.preference = {};
84
+ await grist.personalConfigProvider.reset();
85
+ }
86
+ popup.close();
87
+ }}
88
+ >
89
+ ${String(i18next.t('button.delete'))}
90
+ </div>
91
+ <md-icon
92
+ style=${`
93
+ --md-icon-size: 1.2em;
94
+ margin-left: var(--spacing-tiny, 2px);
95
+ cursor: pointer;
96
+ `}
97
+ @click=${async (e) => popup.close()}
98
+ title=${String(i18next.t('button.close'))}
99
+ >close</md-icon
100
+ >
101
+ </div>
102
+
103
+ ${columns.map(column => html `
104
+ <ox-checkbox label="checkbox" ?checked=${!column.hidden} value=${column.name} option
105
+ >${column.header.renderer(column)}<span
106
+ style="position: absolute; right: 10px; cursor: row-resize;opacity:.5"
107
+ handle
108
+ >☰</span
109
+ ></ox-checkbox
110
+ >
111
+ `)}
112
+ `;
113
+ const popup = OxPopupList.open({
114
+ template,
115
+ multiple: true,
116
+ sortable: true,
117
+ debug: this.debug,
118
+ attrSelected: 'checked',
119
+ top: e.pageY,
120
+ left: e.pageX,
121
+ styles: css `
122
+ :host {
123
+ width: 240px;
124
+ min-height: 300px;
125
+ max-height: 80%;
126
+ overflow: auto;
127
+ }
128
+
129
+ ::slotted(.personalizer-header) {
130
+ --md-icon-size: 1.4em;
131
+
132
+ display: flex;
133
+ flex-direction: row;
134
+ align-items: center;
135
+ text-transform: capitalize;
136
+ box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
137
+ }
138
+
139
+ ::slotted([option]) {
140
+ position: relative;
141
+ user-select: none;
142
+ }
143
+ `
144
+ });
145
+ popup.onselect = (e) => {
146
+ var _a;
147
+ const selected = e.detail;
148
+ const pconfig = grist.personalConfig || {};
149
+ const pcolumns = ((_a = this.preference) === null || _a === void 0 ? void 0 : _a.columns) || columns;
150
+ pconfig.columns = pcolumns.map(column => {
151
+ return {
152
+ name: column.name,
153
+ hidden: selected.indexOf(column.name) == -1,
154
+ width: column.width
155
+ };
156
+ });
157
+ this.preference = pconfig;
158
+ grist.personalConfig = this.preference;
159
+ grist.applyUpdatedConfiguration();
160
+ };
161
+ popup.addEventListener('sorted', (e) => {
162
+ const sorted = e.detail;
163
+ const pconfig = grist.personalConfig || {};
164
+ pconfig.columns = sorted.map(element => {
165
+ var _a;
166
+ const name = element.value;
167
+ return {
168
+ name,
169
+ hidden: !element.hasAttribute('checked'),
170
+ width: (_a = columns.find(column => column.name == name)) === null || _a === void 0 ? void 0 : _a.width
171
+ };
172
+ });
173
+ this.preference = pconfig;
174
+ grist.personalConfig = this.preference;
175
+ grist.applyUpdatedConfiguration();
176
+ });
177
+ }}
178
+ >settings</md-icon
179
+ >
180
+ `;
181
+ }
182
+ };
183
+ OxGristPersonalizer.styles = [
184
+ css `
185
+ md-icon {
186
+ --md-icon-size: 14px;
187
+ width: 16px;
188
+ height: 16px;
189
+ color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));
190
+ background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));
191
+ border-radius: 0px 0px 7px 7px;
192
+ cursor: pointer;
193
+ padding-top: var(--spacing-small);
194
+
195
+ &:hover {
196
+ color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));
197
+ background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));
198
+ }
199
+ }
200
+ `
201
+ ];
202
+ __decorate([
203
+ property({ type: Boolean, attribute: true })
204
+ ], OxGristPersonalizer.prototype, "debug", void 0);
205
+ __decorate([
206
+ state()
207
+ ], OxGristPersonalizer.prototype, "preference", void 0);
208
+ OxGristPersonalizer = __decorate([
209
+ customElement('ox-grist-personalizer')
210
+ ], OxGristPersonalizer);
211
+ export { OxGristPersonalizer };
212
+ //# sourceMappingURL=ox-grist-personalizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-grist-personalizer.js","sourceRoot":"","sources":["../../../src/personalizer/ox-grist-personalizer.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/button/outlined-button.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { i18next } from '@operato/i18n'\nimport { OxPopupList } from '@operato/popup'\nimport { OxCheckbox } from '@operato/input'\n\nimport { ColumnConfig, PersonalGristPreference } from '../types.js'\nimport { DataGrist } from '../data-grist.js'\n\n@customElement('ox-grist-personalizer')\nexport class OxGristPersonalizer extends LitElement {\n static styles = [\n css`\n md-icon {\n --md-icon-size: 14px;\n width: 16px;\n height: 16px;\n color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));\n border-radius: 0px 0px 7px 7px;\n cursor: pointer;\n padding-top: var(--spacing-small);\n\n &:hover {\n color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));\n }\n }\n `\n ]\n\n @property({ type: Boolean, attribute: true }) debug: boolean = false\n\n @state() private preference?: PersonalGristPreference\n\n render() {\n return html`\n <md-icon\n @click=${(e: MouseEvent) => {\n const grist = this.closest('ox-grist') as DataGrist\n\n const { config, compiledConfig, sorters, pagination, mode } = grist\n const { columns: compiledColumns } = compiledConfig\n\n const columns = compiledColumns\n .filter(ccolumn => {\n const column = config.columns.find((column: Partial<ColumnConfig>) => column.name == ccolumn.name)\n return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable\n })\n .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name)!)\n\n this.preference = {\n columns: columns.map(column => {\n return {\n name: column.name,\n hidden: column.hidden,\n width: column.width\n }\n }),\n sorters,\n pagination: {\n ...pagination,\n limit: grist.getCurrentLimit()\n },\n mode\n }\n\n const template = html`\n <div class=\"personalizer-header\" slot=\"header\">\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 auto;\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n const { mode, columns, sorters, pagination } = this.preference || {}\n grist.personalConfig = this.preference = await grist.personalConfigProvider.save({\n mode,\n columns,\n sorters,\n pagination\n })\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.save'))}\n </div>\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 var(--spacing-small, 4px);\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n grist.personalConfig = this.preference = {}\n await grist.personalConfigProvider.reset()\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.delete'))}\n </div>\n <md-icon\n style=${`\n --md-icon-size: 1.2em;\n margin-left: var(--spacing-tiny, 2px);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => popup.close()}\n title=${String(i18next.t('button.close'))}\n >close</md-icon\n >\n </div>\n\n ${columns.map(\n column => html`\n <ox-checkbox label=\"checkbox\" ?checked=${!column.hidden} value=${column.name} option\n >${column.header.renderer(column)}<span\n style=\"position: absolute; right: 10px; cursor: row-resize;opacity:.5\"\n handle\n >☰</span\n ></ox-checkbox\n >\n `\n )}\n `\n\n const popup = OxPopupList.open({\n template,\n multiple: true,\n sortable: true,\n debug: this.debug,\n attrSelected: 'checked',\n top: e.pageY,\n left: e.pageX,\n styles: css`\n :host {\n width: 240px;\n min-height: 300px;\n max-height: 80%;\n overflow: auto;\n }\n\n ::slotted(.personalizer-header) {\n --md-icon-size: 1.4em;\n\n display: flex;\n flex-direction: row;\n align-items: center;\n text-transform: capitalize;\n box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);\n }\n\n ::slotted([option]) {\n position: relative;\n user-select: none;\n }\n `\n })\n\n popup.onselect = (e: Event) => {\n const selected = (e as CustomEvent).detail\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n const pcolumns = this.preference?.columns || columns\n\n pconfig.columns = pcolumns.map(column => {\n return {\n name: column.name,\n hidden: selected.indexOf(column.name) == -1,\n width: column.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n }\n\n popup.addEventListener('sorted', (e: Event) => {\n const sorted = (e as CustomEvent).detail as HTMLElement[]\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n\n pconfig.columns = sorted.map(element => {\n const name = (element as OxCheckbox).value\n return {\n name,\n hidden: !element.hasAttribute('checked'),\n width: columns.find(column => column.name == name)?.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n })\n }}\n >settings</md-icon\n >\n `\n }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { RecordViewBody } from '../record-view-body.js';
2
+ /**
3
+ * ox-record-view-body 의 click handler
4
+ *
5
+ * - handler의 this 는 ox-record-view-body임.
6
+ */
7
+ export declare function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void;
@@ -0,0 +1,27 @@
1
+ /**
2
+ * ox-record-view-body 의 click handler
3
+ *
4
+ * - handler의 this 는 ox-record-view-body임.
5
+ */
6
+ export function recordViewBodyClickHandler(e) {
7
+ var _a;
8
+ e.stopPropagation();
9
+ /* target should be 'ox-grid-field' */
10
+ var target = e.target;
11
+ if (this.currentTarget) {
12
+ this.focus();
13
+ this.currentTarget.removeAttribute('editing');
14
+ }
15
+ let editable = (_a = target === null || target === void 0 ? void 0 : target.column) === null || _a === void 0 ? void 0 : _a.record.editable;
16
+ if (typeof editable === 'function') {
17
+ editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this);
18
+ }
19
+ if (target.tagName !== 'OX-GRID-FIELD' || !editable) {
20
+ this.focus();
21
+ this.currentTarget = null;
22
+ return;
23
+ }
24
+ this.currentTarget = target;
25
+ target.setAttribute('editing', 'true');
26
+ }
27
+ //# sourceMappingURL=record-view-body-click-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record-view-body-click-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-click-handler.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,0BAA0B,CAAuB,CAAQ;;IACvE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,sCAAsC;IACtC,IAAI,MAAM,GAAG,CAAC,CAAC,MAAuB,CAAA;IAEtC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;IAC/C,CAAC;IAED,IAAI,QAAQ,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,0CAAE,MAAM,CAAC,QAAQ,CAAA;IAC9C,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;QACnC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAA;IACnG,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,KAAK,eAAe,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;QACzB,OAAM;IACR,CAAC;IAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAA;IAC3B,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAA;AACxC,CAAC","sourcesContent":["import { DataGridField } from '../../data-grid/data-grid-field.js'\nimport { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 click handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void {\n e.stopPropagation()\n\n /* target should be 'ox-grid-field' */\n var target = e.target as DataGridField\n\n if (this.currentTarget) {\n this.focus()\n this.currentTarget.removeAttribute('editing')\n }\n\n let editable = target?.column?.record.editable\n if (typeof editable === 'function') {\n editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this)\n }\n\n if (target.tagName !== 'OX-GRID-FIELD' || !editable) {\n this.focus()\n this.currentTarget = null\n return\n }\n\n this.currentTarget = target\n target.setAttribute('editing', 'true')\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { RecordViewBody } from '../record-view-body.js';
2
+ /**
3
+ * ox-record-view-body 의 keydown handler
4
+ *
5
+ * - handler의 this 는 ox-record-view-body임.
6
+ */
7
+ export declare function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void>;
@@ -0,0 +1,22 @@
1
+ /**
2
+ * ox-record-view-body 의 keydown handler
3
+ *
4
+ * - handler의 this 는 ox-record-view-body임.
5
+ */
6
+ export async function recordViewBodyKeydownHandler(e) {
7
+ switch (e.key) {
8
+ case 'Esc':
9
+ case 'Escape':
10
+ /* TODO 편집이 취소되어야 한다. */
11
+ case 'Enter':
12
+ /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */
13
+ this.focus();
14
+ if (this.currentTarget) {
15
+ this.currentTarget.removeAttribute('editing');
16
+ }
17
+ this.currentTarget = null;
18
+ break;
19
+ default:
20
+ }
21
+ }
22
+ //# sourceMappingURL=record-view-body-keydown-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record-view-body-keydown-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-keydown-handler.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAuB,CAAQ;IAC/E,QAAS,CAAmB,CAAC,GAAG,EAAE,CAAC;QACjC,KAAK,KAAK,CAAC;QACX,KAAK,QAAQ,CAAC;QACd,wBAAwB;QACxB,KAAK,OAAO;YACV,+DAA+D;YAC/D,IAAI,CAAC,KAAK,EAAE,CAAA;YAEZ,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;YAC/C,CAAC;YAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;YAEzB,MAAK;QACP,QAAQ;IACV,CAAC;AACH,CAAC","sourcesContent":["import { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 keydown handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport async function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void> {\n switch ((e as KeyboardEvent).key) {\n case 'Esc':\n case 'Escape':\n /* TODO 편집이 취소되어야 한다. */\n case 'Enter':\n /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */\n this.focus()\n\n if (this.currentTarget) {\n this.currentTarget.removeAttribute('editing')\n }\n\n this.currentTarget = null\n\n break\n default:\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './record-view.js';
2
+ export * from './ox-record-creator.js';
@@ -0,0 +1,3 @@
1
+ export * from './record-view.js';
2
+ export * from './ox-record-creator.js';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/record-view/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA","sourcesContent":["export * from './record-view.js'\nexport * from './ox-record-creator.js'\n"]}
@@ -0,0 +1,26 @@
1
+ import '@material/web/icon/icon.js';
2
+ import './record-view.js';
3
+ import { LitElement } from 'lit';
4
+ import { DataGrist } from '../data-grist.js';
5
+ import { GristRecord, ValidationReason } from '../types.js';
6
+ export declare class OxRecordCreator extends LitElement {
7
+ static styles: import("lit").CSSResult[];
8
+ grist?: DataGrist;
9
+ callback?: (record: GristRecord) => boolean;
10
+ customPopupCallback?: (popup: any) => boolean;
11
+ lightPopup: boolean;
12
+ preventCloseOnBlur: boolean;
13
+ constructor();
14
+ connectedCallback(): void;
15
+ render(): import("lit-html").TemplateResult<1>;
16
+ validateRecord(record: GristRecord): {
17
+ field: string;
18
+ reason: ValidationReason;
19
+ }[];
20
+ openLightPopup(): void;
21
+ openPopup(): void;
22
+ lightPopupRecordView(): void;
23
+ popupRecordView(): void;
24
+ lightPopupCustomCreator(originalContent: HTMLElement): void;
25
+ popupCustomCreator(originalContent: HTMLElement): void;
26
+ }
@@ -0,0 +1,247 @@
1
+ import { __decorate } from "tslib";
2
+ import '@material/web/icon/icon.js';
3
+ import './record-view.js';
4
+ import { css, html, LitElement } from 'lit';
5
+ import { customElement, property, state } from 'lit/decorators.js';
6
+ import { OxPopup } from '@operato/popup';
7
+ import { ValidationReason } from '../types.js';
8
+ let OxRecordCreator = class OxRecordCreator extends LitElement {
9
+ constructor() {
10
+ super();
11
+ this.lightPopup = false;
12
+ this.preventCloseOnBlur = false;
13
+ this.addEventListener('click', (e) => {
14
+ e.preventDefault();
15
+ e.stopPropagation();
16
+ if (this.lightPopup) {
17
+ this.openLightPopup();
18
+ }
19
+ else {
20
+ this.openPopup();
21
+ }
22
+ });
23
+ }
24
+ connectedCallback() {
25
+ super.connectedCallback();
26
+ this.grist = this.closest('ox-grist');
27
+ }
28
+ render() {
29
+ return html `
30
+ <slot></slot>
31
+ <slot name="popup"></slot>
32
+ `;
33
+ }
34
+ validateRecord(record) {
35
+ const columns = this.grist.compiledConfig.columns;
36
+ const invalidFields = [];
37
+ columns
38
+ .filter(column => !column.hidden)
39
+ .forEach(column => {
40
+ var _a;
41
+ if (((_a = column.record) === null || _a === void 0 ? void 0 : _a.mandatory) &&
42
+ (record[column.name] === undefined || record[column.name] === null || record[column.name] === '')) {
43
+ invalidFields.push({
44
+ field: column.name,
45
+ reason: ValidationReason.MANDATORY
46
+ });
47
+ }
48
+ });
49
+ return invalidFields;
50
+ }
51
+ openLightPopup() {
52
+ var _a;
53
+ const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
54
+ const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
55
+ const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
56
+ if (originalContent) {
57
+ this.lightPopupCustomCreator(originalContent);
58
+ }
59
+ else {
60
+ this.lightPopupRecordView();
61
+ }
62
+ }
63
+ openPopup() {
64
+ var _a;
65
+ const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
66
+ const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
67
+ const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
68
+ if (originalContent) {
69
+ this.popupCustomCreator(originalContent);
70
+ }
71
+ else {
72
+ this.popupRecordView();
73
+ }
74
+ }
75
+ lightPopupRecordView() {
76
+ const config = this.grist.compiledConfig;
77
+ var title = 'create';
78
+ const rowIndex = -1;
79
+ var record = {};
80
+ const columns = config.columns;
81
+ var popup = OxPopup.open({
82
+ template: html `
83
+ <div title>${title}</div>
84
+ <ox-record-view
85
+ @field-change=${(e) => {
86
+ const view = e.currentTarget;
87
+ var { after, before, column, record, row } = e.detail;
88
+ var validation = column.validation;
89
+ if (validation && typeof validation == 'function') {
90
+ if (!validation.call(this, after, before, record, column)) {
91
+ return;
92
+ }
93
+ }
94
+ view.record = {
95
+ ...record,
96
+ [column.name]: after
97
+ };
98
+ }}
99
+ .columns=${columns}
100
+ .record=${record}
101
+ .rowIndex=${rowIndex}
102
+ @reset=${(e) => {
103
+ const view = e.currentTarget;
104
+ view.record = {};
105
+ }}
106
+ @cancel=${(e) => {
107
+ popup.close();
108
+ }}
109
+ @ok=${async (e) => {
110
+ const view = e.currentTarget;
111
+ const invalidFields = await this.validateRecord(view.record);
112
+ if (invalidFields.length > 0) {
113
+ view.setFocusOnInvalid(invalidFields);
114
+ return false;
115
+ }
116
+ popup.close();
117
+ this.dispatchEvent(new CustomEvent('ok', {
118
+ bubbles: true,
119
+ composed: true,
120
+ detail: view.record
121
+ }));
122
+ }}
123
+ ></ox-record-view>
124
+ `,
125
+ parent: document.body,
126
+ preventCloseOnBlur: this.preventCloseOnBlur
127
+ });
128
+ }
129
+ popupRecordView() {
130
+ const config = this.grist.compiledConfig;
131
+ const rowIndex = -1;
132
+ var record = {};
133
+ const columns = config.columns;
134
+ var title = 'create';
135
+ var recordView = document.createElement('ox-record-view');
136
+ recordView.columns = columns;
137
+ recordView.record = record;
138
+ recordView.rowIndex = rowIndex;
139
+ document.dispatchEvent(new CustomEvent('open-popup', {
140
+ detail: {
141
+ template: recordView,
142
+ options: {
143
+ backdrop: true,
144
+ size: 'large',
145
+ title
146
+ },
147
+ callback: (popup) => {
148
+ recordView.addEventListener('reset', (e) => {
149
+ const view = e.currentTarget;
150
+ view.record = {};
151
+ });
152
+ recordView.addEventListener('cancel', (e) => {
153
+ popup.close();
154
+ });
155
+ recordView.addEventListener('ok', async (e) => {
156
+ var _a;
157
+ const view = e.currentTarget;
158
+ const invalidFields = await this.validateRecord(view.record);
159
+ if (invalidFields.length > 0) {
160
+ view.setFocusOnInvalid(invalidFields);
161
+ return false;
162
+ }
163
+ if (await ((_a = this.callback) === null || _a === void 0 ? void 0 : _a.call(this, view.record))) {
164
+ popup.close();
165
+ }
166
+ else {
167
+ console.error('validation failed');
168
+ }
169
+ });
170
+ recordView.addEventListener('field-change', async (e) => {
171
+ const view = e.currentTarget;
172
+ var { after, before, column, record, row } = e.detail;
173
+ var validation = column.validation;
174
+ if (validation && typeof validation == 'function') {
175
+ if (!(await validation.call(this, after, before, record, column))) {
176
+ return;
177
+ }
178
+ }
179
+ view.record = {
180
+ ...record,
181
+ [column.name]: after
182
+ };
183
+ });
184
+ popup.onclosed = () => { };
185
+ }
186
+ }
187
+ }));
188
+ }
189
+ lightPopupCustomCreator(originalContent) {
190
+ var _a;
191
+ const title = 'create';
192
+ const popupContent = originalContent.cloneNode(true);
193
+ popupContent.removeAttribute('slot');
194
+ OxPopup.open({
195
+ template: html `
196
+ <div title>${title}</div>
197
+ ${popupContent}
198
+ `,
199
+ parent: document.body,
200
+ preventCloseOnBlur: this.preventCloseOnBlur
201
+ });
202
+ (_a = this.customPopupCallback) === null || _a === void 0 ? void 0 : _a.call(this, popupContent); // 사용자 정의 팝업용 콜백 실행
203
+ }
204
+ popupCustomCreator(originalContent) {
205
+ const title = 'create';
206
+ const popupContent = originalContent.cloneNode(true);
207
+ popupContent.removeAttribute('slot');
208
+ document.dispatchEvent(new CustomEvent('open-popup', {
209
+ detail: {
210
+ template: popupContent,
211
+ options: {
212
+ backdrop: true,
213
+ size: 'large',
214
+ title
215
+ },
216
+ callback: this.customPopupCallback
217
+ }
218
+ }));
219
+ }
220
+ };
221
+ OxRecordCreator.styles = [
222
+ css `
223
+ ::slotted([slot='popup']) {
224
+ display: none;
225
+ }
226
+ `
227
+ ];
228
+ __decorate([
229
+ state()
230
+ ], OxRecordCreator.prototype, "grist", void 0);
231
+ __decorate([
232
+ property({ type: Object })
233
+ ], OxRecordCreator.prototype, "callback", void 0);
234
+ __decorate([
235
+ property({ type: Object })
236
+ ], OxRecordCreator.prototype, "customPopupCallback", void 0);
237
+ __decorate([
238
+ property({ type: Boolean, attribute: 'light-popup' })
239
+ ], OxRecordCreator.prototype, "lightPopup", void 0);
240
+ __decorate([
241
+ property({ type: Boolean, attribute: 'prevent-close-on-blur' })
242
+ ], OxRecordCreator.prototype, "preventCloseOnBlur", void 0);
243
+ OxRecordCreator = __decorate([
244
+ customElement('ox-record-creator')
245
+ ], OxRecordCreator);
246
+ export { OxRecordCreator };
247
+ //# sourceMappingURL=ox-record-creator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-record-creator.js","sourceRoot":"","sources":["../../../src/record-view/ox-record-creator.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport './record-view.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxPopup } from '@operato/popup'\n\nimport { DataGrist } from '../data-grist.js'\nimport { ColumnConfig, GristRecord, ValidationReason } from '../types.js'\nimport { RecordView } from './record-view.js'\n\n@customElement('ox-record-creator')\nexport class OxRecordCreator extends LitElement {\n static styles = [\n css`\n ::slotted([slot='popup']) {\n display: none;\n }\n `\n ]\n\n @state() grist?: DataGrist\n\n @property({ type: Object }) callback?: (record: GristRecord) => boolean\n @property({ type: Object }) customPopupCallback?: (popup: any) => boolean\n @property({ type: Boolean, attribute: 'light-popup' }) lightPopup: boolean = false\n @property({ type: Boolean, attribute: 'prevent-close-on-blur' }) preventCloseOnBlur = false\n\n constructor() {\n super()\n\n this.addEventListener('click', (e: Event) => {\n e.preventDefault()\n e.stopPropagation()\n\n if (this.lightPopup) {\n this.openLightPopup()\n } else {\n this.openPopup()\n }\n })\n }\n\n connectedCallback(): void {\n super.connectedCallback()\n\n this.grist = this.closest('ox-grist') as DataGrist\n }\n\n render() {\n return html`\n <slot></slot>\n <slot name=\"popup\"></slot>\n `\n }\n\n validateRecord(record: GristRecord): { field: string; reason: ValidationReason }[] {\n const columns = this.grist!.compiledConfig.columns\n const invalidFields: { field: string; reason: ValidationReason }[] = []\n\n columns\n .filter(column => !column.hidden)\n .forEach(column => {\n if (\n column.record?.mandatory &&\n (record[column.name] === undefined || record[column.name] === null || record[column.name] === '')\n ) {\n invalidFields.push({\n field: column.name,\n reason: ValidationReason.MANDATORY\n })\n }\n })\n\n return invalidFields\n }\n\n openLightPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.lightPopupCustomCreator(originalContent)\n } else {\n this.lightPopupRecordView()\n }\n }\n\n openPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.popupCustomCreator(originalContent)\n } else {\n this.popupRecordView()\n }\n }\n\n lightPopupRecordView() {\n const config = this.grist!.compiledConfig\n var title = 'create'\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var popup = OxPopup.open({\n template: html`\n <div title>${title}</div>\n <ox-record-view\n @field-change=${(e: CustomEvent) => {\n const view = e.currentTarget as RecordView\n\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n view.record = {\n ...record,\n [column.name]: after\n }\n }}\n .columns=${columns}\n .record=${record}\n .rowIndex=${rowIndex}\n @reset=${(e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n }}\n @cancel=${(e: Event) => {\n popup.close()\n }}\n @ok=${async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n popup.close()\n\n this.dispatchEvent(\n new CustomEvent('ok', {\n bubbles: true,\n composed: true,\n detail: view.record\n })\n )\n }}\n ></ox-record-view>\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n }\n\n popupRecordView() {\n const config = this.grist!.compiledConfig\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var title = 'create'\n\n var recordView = document.createElement('ox-record-view') as RecordView\n\n recordView.columns = columns\n recordView.record = record\n recordView.rowIndex = rowIndex\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: recordView,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: (popup: any) => {\n recordView.addEventListener('reset', (e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n })\n\n recordView.addEventListener('cancel', (e: Event) => {\n popup.close()\n })\n\n recordView.addEventListener('ok', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n if (await this.callback?.(view.record)) {\n popup.close()\n } else {\n console.error('validation failed')\n }\n })\n\n recordView.addEventListener('field-change', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!(await validation.call(this, after, before, record, column))) {\n return\n }\n }\n\n view.record = {\n ...record,\n [column.name]: after\n }\n })\n\n popup.onclosed = () => {}\n }\n }\n })\n )\n }\n\n lightPopupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n OxPopup.open({\n template: html`\n <div title>${title}</div>\n ${popupContent}\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n\n this.customPopupCallback?.(popupContent) // 사용자 정의 팝업용 콜백 실행\n }\n\n popupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: popupContent,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: this.customPopupCallback\n }\n })\n )\n }\n}\n"]}