@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,119 @@
1
+ import { css } from 'lit';
2
+ export const FilterStyles = css `
3
+ :host {
4
+ --ox-filters-input-placeholder-color: var(--input-placeholder-color, var(--md-sys-color-on-surface));
5
+
6
+ --ox-filters-input-border: var(--input-border, 1px solid rgba(0, 0, 0, 0.2));
7
+ --ox-filters-input-focus-border: var(--input-focus-border, 1px solid var(--md-sys-color-outline-variant));
8
+ --ox-filters-input-font: var(--input-font, normal 14px var(--theme-font));
9
+ --ox-filters-input-color: var(--input-color, var(--md-sys-color-on-surface));
10
+ --ox-filters-input-focus-color: var(--input-focus-color, var(--md-sys-color-on-surface-variant));
11
+ --ox-filters-label-font: var(--label-font, normal 14px var(--theme-font));
12
+ --ox-filters-label-color: var(--label-color, var(--md-sys-color-on-surface));
13
+ --ox-filters-input-background-color: transparent;
14
+
15
+ --ox-filters-form-gap: var(--input-gap-vertical, 8px) var(--input-gap-horizontal, 16px);
16
+ --ox-filters-input-padding: var(--spacing-small, 4px);
17
+
18
+ --ox-select-padding: var(--ox-filters-input-padding);
19
+ --ox-checkbox-background-color: var(--ox-filters-input-background-color, transparent);
20
+ }
21
+
22
+ label {
23
+ color: var(--ox-filters-label-color, var(--md-sys-color-on-primary-container));
24
+ }
25
+
26
+ span {
27
+ font-weight: var(--md-sys-typescale-label-medium-weight);
28
+ text-transform: capitalize;
29
+ }
30
+
31
+ input::placeholder {
32
+ color: var(--ox-filters-input-placeholder-color, var(--md-sys-color-surface-dim));
33
+ opacity: 0.6;
34
+ }
35
+
36
+ input,
37
+ ox-input-search,
38
+ [filter-input] {
39
+ padding: var(--ox-filters-input-padding);
40
+ }
41
+
42
+ ox-select,
43
+ ox-input-search,
44
+ input,
45
+ [filter-input] {
46
+ border: none;
47
+ border-bottom: var(--ox-filters-input-border, var(--md-sys-color-outline));
48
+ font: var(--ox-filters-input-font);
49
+ color: var(--ox-filters-input-color, var(--md-sys-color-on-surface));
50
+ background-color: var(--ox-filters-input-background-color, transparent);
51
+ vertical-align: middle;
52
+ }
53
+
54
+ ox-select:focus,
55
+ input:focus,
56
+ [filter-input]:focus {
57
+ outline: none;
58
+ border-bottom: var(--ox-filters-input-focus-border, var(--md-sys-color-outline-variant));
59
+ color: var(--ox-filters-input-focus-color, var(--md-sys-color-on-surface-variant));
60
+ }
61
+
62
+ ox-select {
63
+ min-width: 90px;
64
+ max-width: 170px;
65
+ }
66
+
67
+ ox-input-search {
68
+ max-width: 150px;
69
+ }
70
+
71
+ input[type='number'] {
72
+ max-width: 90px;
73
+ }
74
+
75
+ input[type*='date'],
76
+ input[type*='time'],
77
+ input[type='week'],
78
+ input[type='month'] {
79
+ max-width: 170px;
80
+ }
81
+
82
+ [filter-input] {
83
+ min-width: 140px;
84
+ max-width: 170px;
85
+ }
86
+
87
+ @media only screen and (max-width: 460px) {
88
+ :host {
89
+ --ox-filters-form-label-font: bold 13px var(--theme-font);
90
+ --ox-filters-input-font: normal 16px var(--theme-font);
91
+ }
92
+
93
+ ox-input-barcode {
94
+ max-width: unset;
95
+ flex: 1;
96
+ }
97
+
98
+ ox-input-search {
99
+ max-width: unset;
100
+ }
101
+
102
+ ox-select {
103
+ max-width: unset;
104
+ }
105
+
106
+ ox-checkbox {
107
+ max-width: unset;
108
+ }
109
+
110
+ input[type='number'] {
111
+ max-width: unset;
112
+ }
113
+
114
+ input {
115
+ flex: 1;
116
+ }
117
+ }
118
+ `;
119
+ //# sourceMappingURL=filter-styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-styles.js","sourceRoot":"","sources":["../../../src/filters/filter-styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAEzB,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAoH9B,CAAA","sourcesContent":["import { css } from 'lit'\n\nexport const FilterStyles = css`\n :host {\n --ox-filters-input-placeholder-color: var(--input-placeholder-color, var(--md-sys-color-on-surface));\n\n --ox-filters-input-border: var(--input-border, 1px solid rgba(0, 0, 0, 0.2));\n --ox-filters-input-focus-border: var(--input-focus-border, 1px solid var(--md-sys-color-outline-variant));\n --ox-filters-input-font: var(--input-font, normal 14px var(--theme-font));\n --ox-filters-input-color: var(--input-color, var(--md-sys-color-on-surface));\n --ox-filters-input-focus-color: var(--input-focus-color, var(--md-sys-color-on-surface-variant));\n --ox-filters-label-font: var(--label-font, normal 14px var(--theme-font));\n --ox-filters-label-color: var(--label-color, var(--md-sys-color-on-surface));\n --ox-filters-input-background-color: transparent;\n\n --ox-filters-form-gap: var(--input-gap-vertical, 8px) var(--input-gap-horizontal, 16px);\n --ox-filters-input-padding: var(--spacing-small, 4px);\n\n --ox-select-padding: var(--ox-filters-input-padding);\n --ox-checkbox-background-color: var(--ox-filters-input-background-color, transparent);\n }\n\n label {\n color: var(--ox-filters-label-color, var(--md-sys-color-on-primary-container));\n }\n\n span {\n font-weight: var(--md-sys-typescale-label-medium-weight);\n text-transform: capitalize;\n }\n\n input::placeholder {\n color: var(--ox-filters-input-placeholder-color, var(--md-sys-color-surface-dim));\n opacity: 0.6;\n }\n\n input,\n ox-input-search,\n [filter-input] {\n padding: var(--ox-filters-input-padding);\n }\n\n ox-select,\n ox-input-search,\n input,\n [filter-input] {\n border: none;\n border-bottom: var(--ox-filters-input-border, var(--md-sys-color-outline));\n font: var(--ox-filters-input-font);\n color: var(--ox-filters-input-color, var(--md-sys-color-on-surface));\n background-color: var(--ox-filters-input-background-color, transparent);\n vertical-align: middle;\n }\n\n ox-select:focus,\n input:focus,\n [filter-input]:focus {\n outline: none;\n border-bottom: var(--ox-filters-input-focus-border, var(--md-sys-color-outline-variant));\n color: var(--ox-filters-input-focus-color, var(--md-sys-color-on-surface-variant));\n }\n\n ox-select {\n min-width: 90px;\n max-width: 170px;\n }\n\n ox-input-search {\n max-width: 150px;\n }\n\n input[type='number'] {\n max-width: 90px;\n }\n\n input[type*='date'],\n input[type*='time'],\n input[type='week'],\n input[type='month'] {\n max-width: 170px;\n }\n\n [filter-input] {\n min-width: 140px;\n max-width: 170px;\n }\n\n @media only screen and (max-width: 460px) {\n :host {\n --ox-filters-form-label-font: bold 13px var(--theme-font);\n --ox-filters-input-font: normal 16px var(--theme-font);\n }\n\n ox-input-barcode {\n max-width: unset;\n flex: 1;\n }\n\n ox-input-search {\n max-width: unset;\n }\n\n ox-select {\n max-width: unset;\n }\n\n ox-checkbox {\n max-width: unset;\n }\n\n input[type='number'] {\n max-width: unset;\n }\n\n input {\n flex: 1;\n }\n }\n`\n"]}
@@ -0,0 +1,40 @@
1
+ import '@operato/input/ox-checkbox.js';
2
+ import '@operato/input/ox-select.js';
3
+ import '@operato/popup/ox-popup-list.js';
4
+ import '@operato/input/ox-input-search.js';
5
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
6
+ import { PagePreferenceProvider } from '@operato/p13n';
7
+ import { ColumnConfig, FilterPreference, FilterOperator, FilterValue, GristConfig, PersonalGristPreference } from '../types.js';
8
+ export type QueryFilterRangeValue = [from: number, to: number];
9
+ export type QueryFilter = {
10
+ name: string;
11
+ operator: FilterOperator;
12
+ value: any;
13
+ };
14
+ export declare class OxFiltersForm extends LitElement {
15
+ static styles: import("lit").CSSResult[];
16
+ value: FilterValue[];
17
+ withoutSearch: boolean;
18
+ autofocus: boolean;
19
+ empty: boolean;
20
+ personalConfigProvider?: PagePreferenceProvider;
21
+ personalConfig?: PersonalGristPreference;
22
+ personalFilters?: FilterPreference[];
23
+ config: GristConfig;
24
+ filterColumns: ColumnConfig[];
25
+ searchColumns: ColumnConfig[];
26
+ form: HTMLFormElement;
27
+ private autoUpdateTargetsOnChange;
28
+ private objectValue?;
29
+ connectedCallback(): void;
30
+ buildDefaultValue(operator: FilterOperator, defaultValue: any): any;
31
+ updated(changes: PropertyValues<this>): Promise<void>;
32
+ render(): TemplateResult;
33
+ applyUpdatedConfiguration(): void;
34
+ getQueryFilters(): Promise<QueryFilter[]>;
35
+ setInputValue(name: string, value: any): void;
36
+ getInputValue(name: string): any;
37
+ private updateObjectValues;
38
+ getFormObjectValue(): object | undefined;
39
+ reset(): void;
40
+ }
@@ -0,0 +1,430 @@
1
+ import { __decorate } from "tslib";
2
+ import '@operato/input/ox-checkbox.js';
3
+ import '@operato/input/ox-select.js';
4
+ import '@operato/popup/ox-popup-list.js';
5
+ import '@operato/input/ox-input-search.js';
6
+ import { css, html, LitElement } from 'lit';
7
+ import { customElement, property, queryAsync, state } from 'lit/decorators.js';
8
+ import { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js';
9
+ import { getDefaultValue } from '@operato/time-calculator';
10
+ import { FilterStyles } from './filter-styles.js';
11
+ import { getFilterRenderer } from './registry.js';
12
+ let OxFiltersForm = class OxFiltersForm extends LitElement {
13
+ constructor() {
14
+ super(...arguments);
15
+ this.value = [];
16
+ this.withoutSearch = false;
17
+ this.autofocus = true;
18
+ this.empty = true;
19
+ this.filterColumns = [];
20
+ this.searchColumns = [];
21
+ this.autoUpdateTargetsOnChange = {};
22
+ }
23
+ connectedCallback() {
24
+ super.connectedCallback();
25
+ const grist = this.closest('ox-grist');
26
+ if (grist) {
27
+ this.config = grist.compiledConfig;
28
+ this.personalConfigProvider = grist.personalConfigProvider;
29
+ grist.addEventListener('config-change', (e) => {
30
+ this.config = e.detail;
31
+ });
32
+ grist.addEventListener('fetch-params-change', (e) => {
33
+ const { filters, from } = e.detail || {};
34
+ if (from === 'filters-form') {
35
+ return;
36
+ }
37
+ this.value = filters;
38
+ });
39
+ this.renderRoot.addEventListener('change', async (e) => {
40
+ const { target, detail: value } = e;
41
+ const name = target.name;
42
+ const { filter } = this.filterColumns.find(filter => filter.name == name) || {};
43
+ if (this.autoUpdateTargetsOnChange[name]) {
44
+ /* 일단은 심플하게, boundTo로 연결된 필터값이 바뀌면, 폼 전체를 update하도록 함. */
45
+ ;
46
+ (this.autoUpdateTargetsOnChange[name] || []).forEach(name => {
47
+ const target = this.renderRoot.querySelector(`[name='${name}']`);
48
+ if (target) {
49
+ ;
50
+ target.value = '';
51
+ }
52
+ });
53
+ await this.updateObjectValues();
54
+ this.requestUpdate();
55
+ }
56
+ const onchange = typeof filter == 'object' ? filter.onchange : null;
57
+ const keepGoing = onchange ? await onchange.call(null, value !== null && value !== void 0 ? value : target.value, this) : true;
58
+ keepGoing &&
59
+ this.dispatchEvent(new CustomEvent('fetch-params-change', {
60
+ bubbles: true,
61
+ composed: true,
62
+ detail: {
63
+ filters: await this.getQueryFilters(),
64
+ from: 'filters-form'
65
+ }
66
+ }));
67
+ });
68
+ }
69
+ }
70
+ buildDefaultValue(operator, defaultValue) {
71
+ if (defaultValue === undefined) {
72
+ return;
73
+ }
74
+ if (operator == 'between') {
75
+ return defaultValue.map(v => getDefaultValue(v, this));
76
+ }
77
+ else {
78
+ return getDefaultValue(defaultValue, this);
79
+ }
80
+ }
81
+ async updated(changes) {
82
+ if (changes.has('personalConfigProvider') && this.personalConfigProvider) {
83
+ this.personalConfig = await this.personalConfigProvider.load();
84
+ }
85
+ else if (changes.has('config') || changes.has('personalConfig')) {
86
+ this.applyUpdatedConfiguration();
87
+ }
88
+ }
89
+ render() {
90
+ var _a, _b, _c, _d;
91
+ const searchValue = ((_d = (_c = (_b = (_a = this.value) === null || _a === void 0 ? void 0 : _a.find(filter => filter.operator === 'search')) === null || _b === void 0 ? void 0 : _b.value) === null || _c === void 0 ? void 0 : _c.match(/^\%(.*)\%$/)) === null || _d === void 0 ? void 0 : _d[1]) || '';
92
+ return this.empty
93
+ ? html ``
94
+ : html `
95
+ <form
96
+ class="md-typescale-body-medium-prominent"
97
+ @submit=${(e) => {
98
+ e.stopPropagation();
99
+ e.preventDefault();
100
+ const grist = this.closest('ox-grist');
101
+ grist && grist.fetch();
102
+ }}
103
+ >
104
+ ${this.filterColumns
105
+ .filter(column => !column.filter.hidden)
106
+ .map((column) => {
107
+ var _a, _b, _c;
108
+ const { name, header, label, filter } = column;
109
+ const type = filter.type;
110
+ if (type == 'search') {
111
+ return html `
112
+ <ox-input-search name="search" .value=${searchValue} ?autofocus=${this.autofocus}></ox-input-search>
113
+ `;
114
+ }
115
+ const operator = filter.operator;
116
+ const filterLabel = filter.label;
117
+ const labelText = filterLabel !== undefined
118
+ ? filterLabel
119
+ : typeof label === 'object' && label.renderer
120
+ ? label.renderer(column)
121
+ : header.renderer(column) || name;
122
+ const idx = operator === 'between' ? 1 : 0;
123
+ const renderer = getFilterRenderer(operator === 'like' || operator === 'i_like' || operator === 'i_nlike' || operator === 'nlike'
124
+ ? 'text'
125
+ : type)[idx];
126
+ const value = (_c = (_b = (_a = this.value) === null || _a === void 0 ? void 0 : _a.find(filter => filter.name == name)) === null || _b === void 0 ? void 0 : _b.value) !== null && _c !== void 0 ? _c : this.buildDefaultValue(operator, filter === null || filter === void 0 ? void 0 : filter.value);
127
+ if (!renderer) {
128
+ return html ``;
129
+ }
130
+ return type === 'boolean' || type === 'checkbox'
131
+ ? renderer(column, value, this)
132
+ : type !== 'select' && labelText
133
+ ? html `<label filter-title ?between=${operator === 'between'}
134
+ ><span>${labelText}</span> ${renderer(column, value, this)}
135
+ </label> `
136
+ : type !== 'select' && !labelText
137
+ ? renderer(column, value, this)
138
+ : operator === 'in'
139
+ ? html `
140
+ <ox-select
141
+ name=${name}
142
+ placeholder=${labelText}
143
+ .value=${value}
144
+ @change=${(e) => {
145
+ var _a;
146
+ return (_a = e.target) === null || _a === void 0 ? void 0 : _a.dispatchEvent(new CustomEvent('filter-change', {
147
+ detail: {
148
+ name,
149
+ operator,
150
+ value: e.detail
151
+ }
152
+ }));
153
+ }}
154
+ >
155
+ <ox-popup-list multiple attr-selected="checked" with-search>
156
+ ${renderer(column, value, this)}
157
+ </ox-popup-list>
158
+ </ox-select>
159
+ `
160
+ : html `
161
+ <ox-select
162
+ name=${name}
163
+ placeholder=${labelText}
164
+ .value=${value}
165
+ @change=${(e) => {
166
+ var _a;
167
+ return (_a = e.target) === null || _a === void 0 ? void 0 : _a.dispatchEvent(new CustomEvent('filter-change', {
168
+ detail: {
169
+ name,
170
+ operator,
171
+ value: e.detail
172
+ }
173
+ }));
174
+ }}
175
+ >
176
+ <ox-popup-list with-search> ${renderer(column, value, this)} </ox-popup-list>
177
+ </ox-select>
178
+ `;
179
+ })}
180
+ </form>
181
+ <slot name="setting"></slot>
182
+ `;
183
+ }
184
+ applyUpdatedConfiguration() {
185
+ var _a;
186
+ if (!this.config) {
187
+ return;
188
+ }
189
+ const filters = this.config.columns.filter(columnConfig => !!columnConfig.filter);
190
+ this.filterColumns = filters.filter((columnConfig) => {
191
+ const filter = columnConfig.filter;
192
+ return filter.operator !== 'search';
193
+ });
194
+ this.searchColumns = filters.filter(columnConfig => {
195
+ const filter = columnConfig.filter;
196
+ return filter.operator === 'search';
197
+ });
198
+ if (this.searchColumns.length > 0 && !this.withoutSearch) {
199
+ this.filterColumns.unshift({ name: 'search', filter: { type: 'search' } });
200
+ }
201
+ if (!this.personalConfig) {
202
+ this.personalFilters = this.filterColumns.map(column => {
203
+ return { name: column.name };
204
+ });
205
+ }
206
+ else {
207
+ const { filters: personalFilters = [] } = this.personalConfig;
208
+ if (personalFilters) {
209
+ const xfilters = this.filterColumns.map(column => {
210
+ return personalFilters.find(pFilter => pFilter.name == column.name) || { name: column.name };
211
+ });
212
+ function reorderList(a, b) {
213
+ // 결과 배열 초기화, a 배열 길이만큼 undefined로 채움
214
+ const result = new Array(a.length);
215
+ // b 배열에 없는 아이템은 원래 위치로 채움
216
+ a.forEach((item, index) => {
217
+ if (!item.name || !b.find(bi => bi.name == item.name)) {
218
+ result[index] = item;
219
+ }
220
+ });
221
+ b.forEach(item => {
222
+ const ai = a.find(ai => ai.name == item.name);
223
+ if (ai) {
224
+ result[result.findIndex(slot => slot === undefined)] = ai;
225
+ }
226
+ });
227
+ return result;
228
+ }
229
+ // 배열 재정렬 실행
230
+ this.personalFilters = reorderList(xfilters, personalFilters);
231
+ this.filterColumns = this.personalFilters
232
+ .map(filter => {
233
+ const column = this.filterColumns.find(column => column.name == filter.name);
234
+ if (column === null || column === void 0 ? void 0 : column.filter) {
235
+ ;
236
+ column.filter.hidden = filter.hidden;
237
+ }
238
+ return column;
239
+ })
240
+ .filter(Boolean);
241
+ }
242
+ }
243
+ const grist = this.closest('ox-grist');
244
+ this.value = ((grist === null || grist === void 0 ? void 0 : grist.filters) || []).map(filter => {
245
+ return {
246
+ ...filter,
247
+ value: this.buildDefaultValue(filter.operator, filter.value)
248
+ };
249
+ });
250
+ this.empty = (this.searchColumns.length === 0 || this.withoutSearch) && this.filterColumns.length === 0;
251
+ this.autoUpdateTargetsOnChange = {};
252
+ (_a = this.filterColumns) === null || _a === void 0 ? void 0 : _a.filter(({ filter }) => {
253
+ return typeof filter == 'object' && filter.boundTo && filter.boundTo.length > 0;
254
+ }).map(({ name, filter }) => {
255
+ const boundTo = filter.boundTo;
256
+ boundTo.forEach(to => {
257
+ const origin = this.autoUpdateTargetsOnChange[to] || [];
258
+ if (name && !origin.includes(name)) {
259
+ this.autoUpdateTargetsOnChange[to] = [...origin, name];
260
+ }
261
+ });
262
+ });
263
+ }
264
+ async getQueryFilters() {
265
+ var _a;
266
+ const form = await this.form;
267
+ if (!form)
268
+ return [];
269
+ const formData = new FormData(form);
270
+ const search = (_a = formData.get('search')) === null || _a === void 0 ? void 0 : _a.toString();
271
+ var filters = this.filterColumns
272
+ .filter(column => column.name !== 'search' && !column.filter.hidden)
273
+ .map((column) => {
274
+ const { name, type, filter } = column;
275
+ const operator = filter.operator;
276
+ var value = formData.getAll(name);
277
+ if (value.length == 0) {
278
+ return;
279
+ }
280
+ if (-1 === value.findIndex(v => v !== '')) {
281
+ return;
282
+ }
283
+ const filterValue = value.map(v => {
284
+ const value = v.toString();
285
+ /* TODO registry에서 타입별로 parsing 방법을 지정할 수 있도록 해야한다. */
286
+ switch (type) {
287
+ case 'integer':
288
+ case 'float':
289
+ case 'number':
290
+ case 'progress':
291
+ case 'checkbox':
292
+ case 'boolean':
293
+ return !value ? undefined : JSON.parse(value);
294
+ default:
295
+ return value;
296
+ }
297
+ });
298
+ return {
299
+ name,
300
+ operator,
301
+ value: filterValue.length === 1 ? filterValue[0] : filterValue
302
+ };
303
+ })
304
+ .filter(result => result !== undefined);
305
+ if (search) {
306
+ filters = filters.concat(this.searchColumns.map((column) => {
307
+ const { name } = column;
308
+ return {
309
+ name,
310
+ operator: 'search',
311
+ value: `%${search}%`
312
+ };
313
+ }));
314
+ }
315
+ return filters;
316
+ }
317
+ setInputValue(name, value) {
318
+ const input = this.renderRoot.querySelector(`form [name="${name}"]`);
319
+ if (input) {
320
+ input.value = value;
321
+ input.dispatchEvent(new Event('change', { bubbles: true }));
322
+ }
323
+ }
324
+ getInputValue(name) {
325
+ const input = this.renderRoot.querySelector(`form [name="${name}"]`);
326
+ return input === null || input === void 0 ? void 0 : input.value;
327
+ }
328
+ async updateObjectValues() {
329
+ const form = await this.form;
330
+ if (!form)
331
+ return [];
332
+ const formData = new FormData(form);
333
+ const object = {};
334
+ formData.forEach((value, key) => {
335
+ const prev = object[key];
336
+ if (key in object) {
337
+ object[key] = prev instanceof Array ? [...prev, value] : [prev, value];
338
+ }
339
+ else {
340
+ object[key] = value;
341
+ }
342
+ });
343
+ this.objectValue = object;
344
+ }
345
+ getFormObjectValue() {
346
+ return this.objectValue;
347
+ }
348
+ reset() {
349
+ this.form
350
+ .then((form) => {
351
+ form.reset();
352
+ })
353
+ .catch((error) => {
354
+ console.error('Error resetting the form:', error);
355
+ });
356
+ }
357
+ };
358
+ OxFiltersForm.styles = [
359
+ MDTypeScaleStyles,
360
+ FilterStyles,
361
+ css `
362
+ :host {
363
+ display: flex;
364
+ padding: var(--spacing-small);
365
+ }
366
+
367
+ form {
368
+ flex: 1;
369
+
370
+ display: flex;
371
+ flex-flow: row wrap;
372
+ gap: var(--ox-filters-form-gap);
373
+ }
374
+
375
+ form > * {
376
+ display: flex;
377
+ align-items: center;
378
+ gap: var(--input-intra-gap, 7px);
379
+ }
380
+
381
+ label span {
382
+ display: block;
383
+ }
384
+
385
+ @media only screen and (max-width: 460px) {
386
+ form {
387
+ flex-direction: column;
388
+ flex-flow: column;
389
+ }
390
+ }
391
+ `
392
+ ];
393
+ __decorate([
394
+ property({ type: Array })
395
+ ], OxFiltersForm.prototype, "value", void 0);
396
+ __decorate([
397
+ property({ type: Boolean, attribute: 'without-search' })
398
+ ], OxFiltersForm.prototype, "withoutSearch", void 0);
399
+ __decorate([
400
+ property({ type: Boolean, attribute: 'autofocus' })
401
+ ], OxFiltersForm.prototype, "autofocus", void 0);
402
+ __decorate([
403
+ property({ type: Boolean, attribute: 'empty', reflect: true })
404
+ ], OxFiltersForm.prototype, "empty", void 0);
405
+ __decorate([
406
+ state()
407
+ ], OxFiltersForm.prototype, "personalConfigProvider", void 0);
408
+ __decorate([
409
+ state()
410
+ ], OxFiltersForm.prototype, "personalConfig", void 0);
411
+ __decorate([
412
+ state()
413
+ ], OxFiltersForm.prototype, "personalFilters", void 0);
414
+ __decorate([
415
+ state()
416
+ ], OxFiltersForm.prototype, "config", void 0);
417
+ __decorate([
418
+ state()
419
+ ], OxFiltersForm.prototype, "filterColumns", void 0);
420
+ __decorate([
421
+ state()
422
+ ], OxFiltersForm.prototype, "searchColumns", void 0);
423
+ __decorate([
424
+ queryAsync('form')
425
+ ], OxFiltersForm.prototype, "form", void 0);
426
+ OxFiltersForm = __decorate([
427
+ customElement('ox-filters-form')
428
+ ], OxFiltersForm);
429
+ export { OxFiltersForm };
430
+ //# sourceMappingURL=filters-form.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters-form.js","sourceRoot":"","sources":["../../../src/filters/filters-form.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/input/ox-checkbox.js'\nimport '@operato/input/ox-select.js'\nimport '@operato/popup/ox-popup-list.js'\nimport '@operato/input/ox-input-search.js'\n\nimport { css, html, LitElement, PropertyValues, TemplateResult, nothing } from 'lit'\nimport { customElement, property, queryAsync, state } from 'lit/decorators.js'\nimport { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js'\n\nimport { PagePreferenceProvider } from '@operato/p13n'\nimport { getDefaultValue } from '@operato/time-calculator'\n\nimport {\n ColumnConfig,\n FilterConfigObject,\n FilterPreference,\n FilterOperator,\n FilterValue,\n GristConfig,\n PersonalGristPreference\n} from '../types.js'\nimport { DataGrist } from '../data-grist.js'\nimport { FilterStyles } from './filter-styles.js'\nimport { getFilterRenderer } from './registry.js'\n\nexport type QueryFilterRangeValue = [from: number, to: number]\n\nexport type QueryFilter = {\n name: string\n operator: FilterOperator\n value: any\n}\n\n@customElement('ox-filters-form')\nexport class OxFiltersForm extends LitElement {\n static styles = [\n MDTypeScaleStyles,\n FilterStyles,\n css`\n :host {\n display: flex;\n padding: var(--spacing-small);\n }\n\n form {\n flex: 1;\n\n display: flex;\n flex-flow: row wrap;\n gap: var(--ox-filters-form-gap);\n }\n\n form > * {\n display: flex;\n align-items: center;\n gap: var(--input-intra-gap, 7px);\n }\n\n label span {\n display: block;\n }\n\n @media only screen and (max-width: 460px) {\n form {\n flex-direction: column;\n flex-flow: column;\n }\n }\n `\n ]\n\n @property({ type: Array }) value: FilterValue[] = []\n @property({ type: Boolean, attribute: 'without-search' }) withoutSearch: boolean = false\n @property({ type: Boolean, attribute: 'autofocus' }) autofocus: boolean = true\n @property({ type: Boolean, attribute: 'empty', reflect: true }) empty: boolean = true\n\n @state() personalConfigProvider?: PagePreferenceProvider\n @state() personalConfig?: PersonalGristPreference\n @state() personalFilters?: FilterPreference[]\n\n @state() config!: GristConfig\n @state() filterColumns: ColumnConfig[] = []\n @state() searchColumns: ColumnConfig[] = []\n\n @queryAsync('form') form!: HTMLFormElement\n\n private autoUpdateTargetsOnChange: { [name: string]: string[] } = {}\n private objectValue?: object\n\n connectedCallback(): void {\n super.connectedCallback()\n\n const grist = this.closest('ox-grist') as DataGrist\n\n if (grist) {\n this.config = grist.compiledConfig\n this.personalConfigProvider = grist.personalConfigProvider\n\n grist.addEventListener('config-change', (e: Event) => {\n this.config = (e as CustomEvent).detail\n })\n\n grist.addEventListener('fetch-params-change', (e: Event) => {\n const { filters, from } = (e as CustomEvent).detail || {}\n if (from === 'filters-form') {\n return\n }\n\n this.value = filters\n })\n\n this.renderRoot.addEventListener('change', async (e: Event) => {\n const { target, detail: value } = e as CustomEvent\n const name = (target as HTMLInputElement).name\n const { filter } = this.filterColumns.find(filter => filter.name == name) || {}\n\n if (this.autoUpdateTargetsOnChange[name]) {\n /* 일단은 심플하게, boundTo로 연결된 필터값이 바뀌면, 폼 전체를 update하도록 함. */\n ;(this.autoUpdateTargetsOnChange[name] || []).forEach(name => {\n const target = this.renderRoot.querySelector(`[name='${name}']`)\n if (target) {\n ;(target as HTMLInputElement).value = ''\n }\n })\n\n await this.updateObjectValues()\n this.requestUpdate()\n }\n\n const onchange = typeof filter == 'object' ? filter.onchange : null\n const keepGoing = onchange ? await onchange.call(null, value ?? (target as HTMLInputElement).value, this) : true\n\n keepGoing &&\n this.dispatchEvent(\n new CustomEvent('fetch-params-change', {\n bubbles: true,\n composed: true,\n detail: {\n filters: await this.getQueryFilters(),\n from: 'filters-form'\n }\n })\n )\n })\n }\n }\n\n buildDefaultValue(operator: FilterOperator, defaultValue: any) {\n if (defaultValue === undefined) {\n return\n }\n if (operator == 'between') {\n return (defaultValue as Array<any>).map(v => getDefaultValue(v, this))\n } else {\n return getDefaultValue(defaultValue, this)\n }\n }\n\n async updated(changes: PropertyValues<this>) {\n if (changes.has('personalConfigProvider') && this.personalConfigProvider) {\n this.personalConfig = await this.personalConfigProvider.load()\n } else if (changes.has('config') || changes.has('personalConfig')) {\n this.applyUpdatedConfiguration()\n }\n }\n\n render(): TemplateResult {\n const searchValue =\n (this.value?.find(filter => filter.operator === 'search')?.value as string)?.match(/^\\%(.*)\\%$/)?.[1] || ''\n\n return this.empty\n ? html``\n : html`\n <form\n class=\"md-typescale-body-medium-prominent\"\n @submit=${(e: Event) => {\n e.stopPropagation()\n e.preventDefault()\n\n const grist = this.closest('ox-grist') as DataGrist\n\n grist && grist.fetch()\n }}\n >\n ${this.filterColumns\n .filter(column => !(column.filter as FilterConfigObject).hidden)\n .map((column: ColumnConfig) => {\n const { name, header, label, filter } = column\n\n const type = (filter as FilterConfigObject).type\n\n if (type == 'search') {\n return html`\n <ox-input-search name=\"search\" .value=${searchValue} ?autofocus=${this.autofocus}></ox-input-search>\n `\n }\n\n const operator = (filter as FilterConfigObject).operator\n const filterLabel = (filter as FilterConfigObject).label\n\n const labelText =\n filterLabel !== undefined\n ? filterLabel\n : typeof label === 'object' && label.renderer\n ? label.renderer(column)\n : header.renderer(column) || name\n\n const idx = operator === 'between' ? 1 : 0\n const renderer = getFilterRenderer(\n operator === 'like' || operator === 'i_like' || operator === 'i_nlike' || operator === 'nlike'\n ? 'text'\n : type\n )[idx]\n const value =\n this.value?.find(filter => filter.name == name)?.value ??\n this.buildDefaultValue(operator!, (filter as FilterConfigObject)?.value)\n\n if (!renderer) {\n return html``\n }\n\n return type === 'boolean' || type === 'checkbox'\n ? renderer(column, value, this)\n : type !== 'select' && labelText\n ? html`<label filter-title ?between=${operator === 'between'}\n ><span>${labelText}</span> ${renderer(column, value, this)}\n </label> `\n : type !== 'select' && !labelText\n ? renderer(column, value, this)\n : operator === 'in'\n ? html`\n <ox-select\n name=${name}\n placeholder=${labelText}\n .value=${value}\n @change=${(e: CustomEvent) =>\n e.target?.dispatchEvent(\n new CustomEvent('filter-change', {\n detail: {\n name,\n operator,\n value: e.detail\n }\n })\n )}\n >\n <ox-popup-list multiple attr-selected=\"checked\" with-search>\n ${renderer(column, value, this)}\n </ox-popup-list>\n </ox-select>\n `\n : html`\n <ox-select\n name=${name}\n placeholder=${labelText}\n .value=${value}\n @change=${(e: CustomEvent) =>\n e.target?.dispatchEvent(\n new CustomEvent('filter-change', {\n detail: {\n name,\n operator,\n value: e.detail\n }\n })\n )}\n >\n <ox-popup-list with-search> ${renderer(column, value, this)} </ox-popup-list>\n </ox-select>\n `\n })}\n </form>\n <slot name=\"setting\"></slot>\n `\n }\n\n applyUpdatedConfiguration() {\n if (!this.config) {\n return\n }\n\n const filters = this.config.columns.filter(columnConfig => !!columnConfig.filter)\n\n this.filterColumns = filters.filter((columnConfig: ColumnConfig) => {\n const filter = columnConfig.filter as FilterConfigObject\n return filter!.operator !== 'search'\n })\n this.searchColumns = filters.filter(columnConfig => {\n const filter = columnConfig.filter as FilterConfigObject\n return filter!.operator === 'search'\n })\n\n if (this.searchColumns.length > 0 && !this.withoutSearch) {\n this.filterColumns.unshift({ name: 'search', filter: { type: 'search' } } as any)\n }\n\n if (!this.personalConfig) {\n this.personalFilters = this.filterColumns.map(column => {\n return { name: column.name }\n })\n } else {\n const { filters: personalFilters = [] } = this.personalConfig\n\n if (personalFilters) {\n const xfilters = this.filterColumns.map(column => {\n return personalFilters.find(pFilter => pFilter.name == column.name) || { name: column.name }\n })\n\n function reorderList(a: FilterPreference[], b: FilterPreference[]): FilterPreference[] {\n // 결과 배열 초기화, a 배열 길이만큼 undefined로 채움\n const result = new Array(a.length)\n\n // b 배열에 없는 아이템은 원래 위치로 채움\n a.forEach((item, index) => {\n if (!item.name || !b.find(bi => bi.name == item.name)) {\n result[index] = item\n }\n })\n\n b.forEach(item => {\n const ai = a.find(ai => ai.name == item.name)\n if (ai) {\n result[result.findIndex(slot => slot === undefined)] = ai\n }\n })\n\n return result\n }\n\n // 배열 재정렬 실행\n this.personalFilters = reorderList(xfilters as any, personalFilters as any) as FilterPreference[]\n\n this.filterColumns = this.personalFilters\n .map(filter => {\n const column = this.filterColumns.find(column => column.name == filter.name)\n if (column?.filter) {\n ;(column.filter as FilterConfigObject)!.hidden = filter.hidden\n }\n return column\n })\n .filter(Boolean) as ColumnConfig[]\n }\n }\n\n const grist = this.closest('ox-grist') as DataGrist\n\n this.value = (grist?.filters || []).map(filter => {\n return {\n ...filter,\n value: this.buildDefaultValue(filter!.operator, filter!.value)\n }\n })\n\n this.empty = (this.searchColumns.length === 0 || this.withoutSearch) && this.filterColumns.length === 0\n\n this.autoUpdateTargetsOnChange = {}\n this.filterColumns\n ?.filter(({ filter }) => {\n return typeof filter == 'object' && filter.boundTo && filter.boundTo.length > 0\n })\n .map(({ name, filter }) => {\n const boundTo = (filter as FilterConfigObject).boundTo\n\n boundTo!.forEach(to => {\n const origin = this.autoUpdateTargetsOnChange[to] || []\n if (name && !origin.includes(name)) {\n this.autoUpdateTargetsOnChange[to] = [...origin, name]\n }\n })\n })\n }\n\n async getQueryFilters(): Promise<QueryFilter[]> {\n const form = await this.form\n if (!form) return []\n\n const formData = new FormData(form)\n const search: string | undefined = formData.get('search')?.toString()\n\n var filters = this.filterColumns\n .filter(column => column.name !== 'search' && !(column.filter as FilterConfigObject)!.hidden)\n .map((column: ColumnConfig) => {\n const { name, type, filter } = column\n const operator = (filter as FilterConfigObject).operator\n\n var value = formData.getAll(name)\n if (value.length == 0) {\n return\n }\n\n if (-1 === value.findIndex(v => v !== '')) {\n return\n }\n\n const filterValue = value.map(v => {\n const value = v.toString()\n\n /* TODO registry에서 타입별로 parsing 방법을 지정할 수 있도록 해야한다. */\n switch (type) {\n case 'integer':\n case 'float':\n case 'number':\n case 'progress':\n case 'checkbox':\n case 'boolean':\n return !value ? undefined : JSON.parse(value)\n default:\n return value\n }\n })\n\n return {\n name,\n operator,\n value: filterValue.length === 1 ? filterValue[0] : filterValue\n }\n })\n .filter(result => result !== undefined) as QueryFilter[]\n\n if (search) {\n filters = filters.concat(\n this.searchColumns.map((column: ColumnConfig) => {\n const { name } = column\n\n return {\n name,\n operator: 'search',\n value: `%${search}%`\n }\n })\n )\n }\n\n return filters\n }\n\n public setInputValue(name: string, value: any) {\n const input = this.renderRoot.querySelector(`form [name=\"${name}\"]`) as HTMLInputElement\n if (input) {\n input.value = value\n input.dispatchEvent(new Event('change', { bubbles: true }))\n }\n }\n\n public getInputValue(name: string): any {\n const input = this.renderRoot.querySelector(`form [name=\"${name}\"]`) as HTMLInputElement\n return input?.value\n }\n\n private async updateObjectValues() {\n const form = await this.form\n if (!form) return []\n\n const formData = new FormData(form)\n\n const object = {} as any\n formData.forEach((value, key) => {\n const prev = object[key]\n\n if (key in object) {\n object[key] = prev instanceof Array ? [...prev, value] : [prev, value]\n } else {\n object[key] = value\n }\n })\n\n this.objectValue = object\n }\n\n public getFormObjectValue() {\n return this.objectValue\n }\n\n reset() {\n this.form\n .then((form: HTMLFormElement) => {\n form.reset()\n })\n .catch((error: any) => {\n console.error('Error resetting the form:', error)\n })\n }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ export * from './registry.js';
2
+ export * from './filter-select.js';
3
+ export * from './filter-input.js';
4
+ export * from './filter-checkbox.js';
5
+ export * from './filter-range-date.js';
6
+ export * from './filter-range-number.js';
7
+ export * from './filter-select-buttons.js';
8
+ export * from './filters-form.js';