@operato/data-grist 9.0.0-beta.61 → 9.0.0-beta.63

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 (418) 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-month.d.ts +4 -0
  174. package/dist/src/editors/ox-grist-editor-month.js +14 -0
  175. package/dist/src/editors/ox-grist-editor-month.js.map +1 -0
  176. package/dist/src/editors/ox-grist-editor-multiple-select.d.ts +8 -0
  177. package/dist/src/editors/ox-grist-editor-multiple-select.js +52 -0
  178. package/dist/src/editors/ox-grist-editor-multiple-select.js.map +1 -0
  179. package/dist/src/editors/ox-grist-editor-number.d.ts +6 -0
  180. package/dist/src/editors/ox-grist-editor-number.js +27 -0
  181. package/dist/src/editors/ox-grist-editor-number.js.map +1 -0
  182. package/dist/src/editors/ox-grist-editor-password.d.ts +4 -0
  183. package/dist/src/editors/ox-grist-editor-password.js +14 -0
  184. package/dist/src/editors/ox-grist-editor-password.js.map +1 -0
  185. package/dist/src/editors/ox-grist-editor-select.d.ts +4 -0
  186. package/dist/src/editors/ox-grist-editor-select.js +53 -0
  187. package/dist/src/editors/ox-grist-editor-select.js.map +1 -0
  188. package/dist/src/editors/ox-grist-editor-tel.d.ts +4 -0
  189. package/dist/src/editors/ox-grist-editor-tel.js +14 -0
  190. package/dist/src/editors/ox-grist-editor-tel.js.map +1 -0
  191. package/dist/src/editors/ox-grist-editor-text.d.ts +5 -0
  192. package/dist/src/editors/ox-grist-editor-text.js +17 -0
  193. package/dist/src/editors/ox-grist-editor-text.js.map +1 -0
  194. package/dist/src/editors/ox-grist-editor-textarea.d.ts +6 -0
  195. package/dist/src/editors/ox-grist-editor-textarea.js +18 -0
  196. package/dist/src/editors/ox-grist-editor-textarea.js.map +1 -0
  197. package/dist/src/editors/ox-grist-editor-time.d.ts +4 -0
  198. package/dist/src/editors/ox-grist-editor-time.js +14 -0
  199. package/dist/src/editors/ox-grist-editor-time.js.map +1 -0
  200. package/dist/src/editors/ox-grist-editor-tree.d.ts +6 -0
  201. package/dist/src/editors/ox-grist-editor-tree.js +27 -0
  202. package/dist/src/editors/ox-grist-editor-tree.js.map +1 -0
  203. package/dist/src/editors/ox-grist-editor-varname.d.ts +6 -0
  204. package/dist/src/editors/ox-grist-editor-varname.js +36 -0
  205. package/dist/src/editors/ox-grist-editor-varname.js.map +1 -0
  206. package/dist/src/editors/ox-grist-editor-week.d.ts +4 -0
  207. package/dist/src/editors/ox-grist-editor-week.js +14 -0
  208. package/dist/src/editors/ox-grist-editor-week.js.map +1 -0
  209. package/dist/src/editors/ox-grist-editor.d.ts +27 -0
  210. package/dist/src/editors/ox-grist-editor.js +197 -0
  211. package/dist/src/editors/ox-grist-editor.js.map +1 -0
  212. package/dist/src/editors/ox-input-tree.d.ts +20 -0
  213. package/dist/src/editors/ox-input-tree.js +221 -0
  214. package/dist/src/editors/ox-input-tree.js.map +1 -0
  215. package/dist/src/editors/registry.d.ts +12 -0
  216. package/dist/src/editors/registry.js +71 -0
  217. package/dist/src/editors/registry.js.map +1 -0
  218. package/dist/src/empty-note.d.ts +9 -0
  219. package/dist/src/empty-note.js +53 -0
  220. package/dist/src/empty-note.js.map +1 -0
  221. package/dist/src/filters/filter-checkbox.d.ts +3 -0
  222. package/dist/src/filters/filter-checkbox.js +41 -0
  223. package/dist/src/filters/filter-checkbox.js.map +1 -0
  224. package/dist/src/filters/filter-input-barcode.d.ts +3 -0
  225. package/dist/src/filters/filter-input-barcode.js +28 -0
  226. package/dist/src/filters/filter-input-barcode.js.map +1 -0
  227. package/dist/src/filters/filter-input.d.ts +2 -0
  228. package/dist/src/filters/filter-input.js +25 -0
  229. package/dist/src/filters/filter-input.js.map +1 -0
  230. package/dist/src/filters/filter-range-date.d.ts +2 -0
  231. package/dist/src/filters/filter-range-date.js +66 -0
  232. package/dist/src/filters/filter-range-date.js.map +1 -0
  233. package/dist/src/filters/filter-range-number.d.ts +2 -0
  234. package/dist/src/filters/filter-range-number.js +54 -0
  235. package/dist/src/filters/filter-range-number.js.map +1 -0
  236. package/dist/src/filters/filter-select-buttons.d.ts +3 -0
  237. package/dist/src/filters/filter-select-buttons.js +50 -0
  238. package/dist/src/filters/filter-select-buttons.js.map +1 -0
  239. package/dist/src/filters/filter-select.d.ts +3 -0
  240. package/dist/src/filters/filter-select.js +52 -0
  241. package/dist/src/filters/filter-select.js.map +1 -0
  242. package/dist/src/filters/filter-styles.d.ts +1 -0
  243. package/dist/src/filters/filter-styles.js +119 -0
  244. package/dist/src/filters/filter-styles.js.map +1 -0
  245. package/dist/src/filters/filters-form.d.ts +40 -0
  246. package/dist/src/filters/filters-form.js +430 -0
  247. package/dist/src/filters/filters-form.js.map +1 -0
  248. package/dist/src/filters/index.d.ts +8 -0
  249. package/dist/src/filters/index.js +9 -0
  250. package/dist/src/filters/index.js.map +1 -0
  251. package/dist/src/filters/registry.d.ts +7 -0
  252. package/dist/src/filters/registry.js +48 -0
  253. package/dist/src/filters/registry.js.map +1 -0
  254. package/dist/src/formatters/date-formatter.d.ts +1 -0
  255. package/dist/src/formatters/date-formatter.js +4 -0
  256. package/dist/src/formatters/date-formatter.js.map +1 -0
  257. package/dist/src/formatters/index.d.ts +1 -0
  258. package/dist/src/formatters/index.js +2 -0
  259. package/dist/src/formatters/index.js.map +1 -0
  260. package/dist/src/formatters/number-formatter.d.ts +1 -0
  261. package/dist/src/formatters/number-formatter.js +4 -0
  262. package/dist/src/formatters/number-formatter.js.map +1 -0
  263. package/dist/src/formatters/registry.d.ts +6 -0
  264. package/dist/src/formatters/registry.js +25 -0
  265. package/dist/src/formatters/registry.js.map +1 -0
  266. package/dist/src/formatters/text-formatter.d.ts +1 -0
  267. package/dist/src/formatters/text-formatter.js +4 -0
  268. package/dist/src/formatters/text-formatter.js.map +1 -0
  269. package/dist/src/gutters/gutter-button.d.ts +21 -0
  270. package/dist/src/gutters/gutter-button.js +40 -0
  271. package/dist/src/gutters/gutter-button.js.map +1 -0
  272. package/dist/src/gutters/gutter-dirty.d.ts +23 -0
  273. package/dist/src/gutters/gutter-dirty.js +87 -0
  274. package/dist/src/gutters/gutter-dirty.js.map +1 -0
  275. package/dist/src/gutters/gutter-row-selector.d.ts +21 -0
  276. package/dist/src/gutters/gutter-row-selector.js +70 -0
  277. package/dist/src/gutters/gutter-row-selector.js.map +1 -0
  278. package/dist/src/gutters/gutter-sequence.d.ts +35 -0
  279. package/dist/src/gutters/gutter-sequence.js +48 -0
  280. package/dist/src/gutters/gutter-sequence.js.map +1 -0
  281. package/dist/src/gutters/index.d.ts +1 -0
  282. package/dist/src/gutters/index.js +2 -0
  283. package/dist/src/gutters/index.js.map +1 -0
  284. package/dist/src/gutters/registry.d.ts +7 -0
  285. package/dist/src/gutters/registry.js +26 -0
  286. package/dist/src/gutters/registry.js.map +1 -0
  287. package/dist/src/handlers/contextmenu-tree-mutation.d.ts +3 -0
  288. package/dist/src/handlers/contextmenu-tree-mutation.js +64 -0
  289. package/dist/src/handlers/contextmenu-tree-mutation.js.map +1 -0
  290. package/dist/src/handlers/index.d.ts +1 -0
  291. package/dist/src/handlers/index.js +2 -0
  292. package/dist/src/handlers/index.js.map +1 -0
  293. package/dist/src/handlers/move-down.d.ts +3 -0
  294. package/dist/src/handlers/move-down.js +26 -0
  295. package/dist/src/handlers/move-down.js.map +1 -0
  296. package/dist/src/handlers/move-up.d.ts +3 -0
  297. package/dist/src/handlers/move-up.js +26 -0
  298. package/dist/src/handlers/move-up.js.map +1 -0
  299. package/dist/src/handlers/record-copy.d.ts +3 -0
  300. package/dist/src/handlers/record-copy.js +23 -0
  301. package/dist/src/handlers/record-copy.js.map +1 -0
  302. package/dist/src/handlers/record-delete.d.ts +3 -0
  303. package/dist/src/handlers/record-delete.js +16 -0
  304. package/dist/src/handlers/record-delete.js.map +1 -0
  305. package/dist/src/handlers/record-view-handler.d.ts +3 -0
  306. package/dist/src/handlers/record-view-handler.js +15 -0
  307. package/dist/src/handlers/record-view-handler.js.map +1 -0
  308. package/dist/src/handlers/registry.d.ts +7 -0
  309. package/dist/src/handlers/registry.js +34 -0
  310. package/dist/src/handlers/registry.js.map +1 -0
  311. package/dist/src/handlers/select-row-toggle.d.ts +3 -0
  312. package/dist/src/handlers/select-row-toggle.js +18 -0
  313. package/dist/src/handlers/select-row-toggle.js.map +1 -0
  314. package/dist/src/handlers/select-row.d.ts +3 -0
  315. package/dist/src/handlers/select-row.js +14 -0
  316. package/dist/src/handlers/select-row.js.map +1 -0
  317. package/dist/src/index.d.ts +14 -0
  318. package/dist/src/index.js +15 -0
  319. package/dist/src/index.js.map +1 -0
  320. package/dist/src/personalizer/index.d.ts +1 -0
  321. package/dist/src/personalizer/index.js +2 -0
  322. package/dist/src/personalizer/index.js.map +1 -0
  323. package/dist/src/personalizer/ox-grist-filter-personalizer.d.ts +8 -0
  324. package/dist/src/personalizer/ox-grist-filter-personalizer.js +178 -0
  325. package/dist/src/personalizer/ox-grist-filter-personalizer.js.map +1 -0
  326. package/dist/src/personalizer/ox-grist-personalizer.d.ts +8 -0
  327. package/dist/src/personalizer/ox-grist-personalizer.js +212 -0
  328. package/dist/src/personalizer/ox-grist-personalizer.js.map +1 -0
  329. package/dist/src/record-view/event-handlers/record-view-body-click-handler.d.ts +7 -0
  330. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js +27 -0
  331. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js.map +1 -0
  332. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.d.ts +7 -0
  333. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js +22 -0
  334. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js.map +1 -0
  335. package/dist/src/record-view/index.d.ts +2 -0
  336. package/dist/src/record-view/index.js +3 -0
  337. package/dist/src/record-view/index.js.map +1 -0
  338. package/dist/src/record-view/ox-record-creator.d.ts +26 -0
  339. package/dist/src/record-view/ox-record-creator.js +247 -0
  340. package/dist/src/record-view/ox-record-creator.js.map +1 -0
  341. package/dist/src/record-view/record-view-body.d.ts +21 -0
  342. package/dist/src/record-view/record-view-body.js +252 -0
  343. package/dist/src/record-view/record-view-body.js.map +1 -0
  344. package/dist/src/record-view/record-view-handler.d.ts +9 -0
  345. package/dist/src/record-view/record-view-handler.js +57 -0
  346. package/dist/src/record-view/record-view-handler.js.map +1 -0
  347. package/dist/src/record-view/record-view.d.ts +23 -0
  348. package/dist/src/record-view/record-view.js +117 -0
  349. package/dist/src/record-view/record-view.js.map +1 -0
  350. package/dist/src/renderers/index.d.ts +13 -0
  351. package/dist/src/renderers/index.js +14 -0
  352. package/dist/src/renderers/index.js.map +1 -0
  353. package/dist/src/renderers/ox-grist-renderer-boolean.d.ts +2 -0
  354. package/dist/src/renderers/ox-grist-renderer-boolean.js +39 -0
  355. package/dist/src/renderers/ox-grist-renderer-boolean.js.map +1 -0
  356. package/dist/src/renderers/ox-grist-renderer-color.d.ts +2 -0
  357. package/dist/src/renderers/ox-grist-renderer-color.js +12 -0
  358. package/dist/src/renderers/ox-grist-renderer-color.js.map +1 -0
  359. package/dist/src/renderers/ox-grist-renderer-date.d.ts +2 -0
  360. package/dist/src/renderers/ox-grist-renderer-date.js +53 -0
  361. package/dist/src/renderers/ox-grist-renderer-date.js.map +1 -0
  362. package/dist/src/renderers/ox-grist-renderer-file.d.ts +2 -0
  363. package/dist/src/renderers/ox-grist-renderer-file.js +27 -0
  364. package/dist/src/renderers/ox-grist-renderer-file.js.map +1 -0
  365. package/dist/src/renderers/ox-grist-renderer-image.d.ts +2 -0
  366. package/dist/src/renderers/ox-grist-renderer-image.js +24 -0
  367. package/dist/src/renderers/ox-grist-renderer-image.js.map +1 -0
  368. package/dist/src/renderers/ox-grist-renderer-json5.d.ts +2 -0
  369. package/dist/src/renderers/ox-grist-renderer-json5.js +30 -0
  370. package/dist/src/renderers/ox-grist-renderer-json5.js.map +1 -0
  371. package/dist/src/renderers/ox-grist-renderer-link.d.ts +2 -0
  372. package/dist/src/renderers/ox-grist-renderer-link.js +12 -0
  373. package/dist/src/renderers/ox-grist-renderer-link.js.map +1 -0
  374. package/dist/src/renderers/ox-grist-renderer-password.d.ts +2 -0
  375. package/dist/src/renderers/ox-grist-renderer-password.js +5 -0
  376. package/dist/src/renderers/ox-grist-renderer-password.js.map +1 -0
  377. package/dist/src/renderers/ox-grist-renderer-progress.d.ts +5 -0
  378. package/dist/src/renderers/ox-grist-renderer-progress.js +46 -0
  379. package/dist/src/renderers/ox-grist-renderer-progress.js.map +1 -0
  380. package/dist/src/renderers/ox-grist-renderer-select.d.ts +2 -0
  381. package/dist/src/renderers/ox-grist-renderer-select.js +50 -0
  382. package/dist/src/renderers/ox-grist-renderer-select.js.map +1 -0
  383. package/dist/src/renderers/ox-grist-renderer-text.d.ts +2 -0
  384. package/dist/src/renderers/ox-grist-renderer-text.js +11 -0
  385. package/dist/src/renderers/ox-grist-renderer-text.js.map +1 -0
  386. package/dist/src/renderers/ox-grist-renderer-textarea.d.ts +2 -0
  387. package/dist/src/renderers/ox-grist-renderer-textarea.js +5 -0
  388. package/dist/src/renderers/ox-grist-renderer-textarea.js.map +1 -0
  389. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +12 -0
  390. package/dist/src/renderers/ox-grist-renderer-tree.js +183 -0
  391. package/dist/src/renderers/ox-grist-renderer-tree.js.map +1 -0
  392. package/dist/src/renderers/ox-grist-renderer.d.ts +15 -0
  393. package/dist/src/renderers/ox-grist-renderer.js +48 -0
  394. package/dist/src/renderers/ox-grist-renderer.js.map +1 -0
  395. package/dist/src/renderers/registry.d.ts +12 -0
  396. package/dist/src/renderers/registry.js +70 -0
  397. package/dist/src/renderers/registry.js.map +1 -0
  398. package/dist/src/sorters/sorters-control.d.ts +12 -0
  399. package/dist/src/sorters/sorters-control.js +138 -0
  400. package/dist/src/sorters/sorters-control.js.map +1 -0
  401. package/dist/src/types.d.ts +696 -0
  402. package/dist/src/types.js +23 -0
  403. package/dist/src/types.js.map +1 -0
  404. package/dist/src/utils/index.d.ts +2 -0
  405. package/dist/src/utils/index.js +3 -0
  406. package/dist/src/utils/index.js.map +1 -0
  407. package/dist/src/utils/list-param.d.ts +16 -0
  408. package/dist/src/utils/list-param.js +40 -0
  409. package/dist/src/utils/list-param.js.map +1 -0
  410. package/dist/src/utils/supports-passive.d.ts +1 -0
  411. package/dist/src/utils/supports-passive.js +13 -0
  412. package/dist/src/utils/supports-passive.js.map +1 -0
  413. package/dist/tsconfig.tsbuildinfo +1 -1
  414. package/package.json +4 -4
  415. package/dist/index.d.ts +0 -1
  416. package/dist/index.js +0 -2
  417. package/dist/index.js.map +0 -1
  418. package/index.ts +0 -1
@@ -0,0 +1,197 @@
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js';
5
+ import { getDefaultValue } from '@operato/time-calculator';
6
+ const STYLE = css `
7
+ :host {
8
+ display: flex;
9
+
10
+ align-items: center;
11
+
12
+ width: 100%;
13
+ height: 100%;
14
+
15
+ border: 0;
16
+ background-color: transparent;
17
+
18
+ overflow: hidden;
19
+ justify-content: var(--data-grid-field-justify-content, flex-start);
20
+ }
21
+
22
+ :host > * {
23
+ display: flex;
24
+
25
+ width: 100%;
26
+ height: 100%;
27
+
28
+ border: 0;
29
+ background-color: transparent;
30
+
31
+ box-sizing: border-box;
32
+
33
+ align-items: center;
34
+ }
35
+
36
+ :host > style {
37
+ display: none;
38
+ }
39
+
40
+ :host > input {
41
+ color: var(--md-sys-color-on-background);
42
+ }
43
+
44
+ :host > input[type='checkbox'] {
45
+ width: initial;
46
+ margin: 0;
47
+ }
48
+ *:focus {
49
+ outline: none;
50
+ }
51
+
52
+ input[type='file'] {
53
+ opacity: 0%;
54
+ }
55
+
56
+ @media screen and (max-width: 460px) {
57
+ :host > * {
58
+ border: initial;
59
+ background-color: initial;
60
+ }
61
+
62
+ *:focus {
63
+ outline: none;
64
+ }
65
+
66
+ input,
67
+ select,
68
+ textarea {
69
+ font-size: 16px;
70
+ }
71
+ }
72
+ `;
73
+ let OxGristEditor = class OxGristEditor extends LitElement {
74
+ constructor() {
75
+ super(...arguments);
76
+ this.column = ZERO_COLUMN;
77
+ this.record = ZERO_RECORD;
78
+ }
79
+ render() {
80
+ return this.editorTemplate;
81
+ }
82
+ get editor() {
83
+ return this.renderRoot.firstElementChild;
84
+ }
85
+ get inlineEditable() {
86
+ return false;
87
+ }
88
+ async firstUpdated() {
89
+ var _a;
90
+ this.renderRoot.addEventListener('change', this._onchange.bind(this));
91
+ this.renderRoot.addEventListener('focusout', this._onfocusout.bind(this));
92
+ this.addEventListener('click', this._onclick.bind(this));
93
+ this.addEventListener('dblclick', this._ondblclick.bind(this));
94
+ this.addEventListener('keydown', this._onkeydown.bind(this));
95
+ /* editor mode 인 경우의 마우스 움직임이, grist-body의 이벤트 처리에 의해서 에디터를 리셋시킬 수 있으므로, 이벤트 전파를 막는다. */
96
+ this.addEventListener('pointerdown', (e) => e.stopPropagation());
97
+ this.addEventListener('pointermove', (e) => e.stopPropagation());
98
+ this.addEventListener('pointerup', (e) => e.stopPropagation());
99
+ const { name = '' } = this.column;
100
+ const { align, defaultValue } = this.column.record;
101
+ if (align) {
102
+ this.style.textAlign = align;
103
+ this.style.textAlignLast = align; /* for select */
104
+ }
105
+ var currentValue = this.record[name];
106
+ if (typeof currentValue == 'undefined' && defaultValue) {
107
+ currentValue = getDefaultValue(defaultValue, this.record);
108
+ }
109
+ this.value = this._dirtyValue = this.formatForEditor(currentValue);
110
+ // 입력을 위한 키를 누르면서 편집모드가 될때는 누른 키가 처음에 입력되도록, enter 같은 것을 눌러서 편집모드가 되면 현재 값으로 편집모드 전환
111
+ const valueWith = this.inlineEditable && ((_a = this.field) === null || _a === void 0 ? void 0 : _a.valueWith);
112
+ this.value = this._dirtyValue = valueWith ? this.formatFromEditor(valueWith) : this.formatForEditor(currentValue);
113
+ requestAnimationFrame(() => {
114
+ this.focus();
115
+ !valueWith && this.select();
116
+ });
117
+ }
118
+ select() {
119
+ const editor = this.editor;
120
+ if (editor === null || editor === void 0 ? void 0 : editor.select) {
121
+ return editor.select();
122
+ }
123
+ }
124
+ focus() {
125
+ const editor = this.editor;
126
+ if (editor) {
127
+ editor.focus();
128
+ }
129
+ }
130
+ formatForEditor(value) {
131
+ return value == null ? '' : value;
132
+ }
133
+ formatFromEditor(value) {
134
+ return value;
135
+ }
136
+ _onfocusout() {
137
+ var _a;
138
+ // paste시 field-change는 Body에서 하므로 X
139
+ if (((_a = this.field) === null || _a === void 0 ? void 0 : _a.isWorking) === true)
140
+ return;
141
+ const { name = '' } = this.column;
142
+ var currentValue = this.record[name] || '';
143
+ if (this._dirtyValue !== currentValue) {
144
+ this.dispatchEvent(new CustomEvent('field-change', {
145
+ bubbles: true,
146
+ composed: true,
147
+ detail: {
148
+ before: currentValue,
149
+ after: this._dirtyValue,
150
+ column: this.column,
151
+ record: this.record,
152
+ row: this.row
153
+ }
154
+ }));
155
+ }
156
+ }
157
+ _onchange(e) {
158
+ var _a;
159
+ e.stopPropagation();
160
+ const value = (_a = e.target) === null || _a === void 0 ? void 0 : _a.value;
161
+ this._dirtyValue = this.formatFromEditor(value);
162
+ }
163
+ _onkeydown(e) { }
164
+ _onclick(e) {
165
+ e.stopPropagation();
166
+ }
167
+ _ondblclick(e) {
168
+ e.stopPropagation();
169
+ }
170
+ get editorTemplate() {
171
+ return html ``;
172
+ }
173
+ };
174
+ OxGristEditor.styles = [STYLE];
175
+ __decorate([
176
+ property({ type: Object })
177
+ ], OxGristEditor.prototype, "value", void 0);
178
+ __decorate([
179
+ property({ type: Object })
180
+ ], OxGristEditor.prototype, "column", void 0);
181
+ __decorate([
182
+ property({ type: Object })
183
+ ], OxGristEditor.prototype, "record", void 0);
184
+ __decorate([
185
+ property({ type: Number })
186
+ ], OxGristEditor.prototype, "rowIndex", void 0);
187
+ __decorate([
188
+ property({ type: Object })
189
+ ], OxGristEditor.prototype, "field", void 0);
190
+ __decorate([
191
+ property({ type: Number })
192
+ ], OxGristEditor.prototype, "row", void 0);
193
+ OxGristEditor = __decorate([
194
+ customElement('ox-grist-editor')
195
+ ], OxGristEditor);
196
+ export { OxGristEditor };
197
+ //# sourceMappingURL=ox-grist-editor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-grist-editor.js","sourceRoot":"","sources":["../../../src/editors/ox-grist-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement, PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js'\nimport { DataGridField } from '../data-grid/data-grid-field.js'\nimport { ColumnConfig, GristRecord } from '../types.js'\nimport { getDefaultValue } from '@operato/time-calculator'\n\nconst STYLE = css`\n :host {\n display: flex;\n\n align-items: center;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n overflow: hidden;\n justify-content: var(--data-grid-field-justify-content, flex-start);\n }\n\n :host > * {\n display: flex;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n box-sizing: border-box;\n\n align-items: center;\n }\n\n :host > style {\n display: none;\n }\n\n :host > input {\n color: var(--md-sys-color-on-background);\n }\n\n :host > input[type='checkbox'] {\n width: initial;\n margin: 0;\n }\n *:focus {\n outline: none;\n }\n\n input[type='file'] {\n opacity: 0%;\n }\n\n @media screen and (max-width: 460px) {\n :host > * {\n border: initial;\n background-color: initial;\n }\n\n *:focus {\n outline: none;\n }\n\n input,\n select,\n textarea {\n font-size: 16px;\n }\n }\n`\n\n@customElement('ox-grist-editor')\nexport class OxGristEditor extends LitElement {\n static styles = [STYLE]\n\n @property({ type: Object }) value?: any\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Number }) rowIndex?: number\n @property({ type: Object }) field?: DataGridField\n @property({ type: Number }) row?: number\n\n protected _dirtyValue?: any\n\n render() {\n return this.editorTemplate\n }\n\n get editor(): HTMLElement | null {\n return this.renderRoot.firstElementChild as HTMLElement\n }\n\n get inlineEditable() {\n return false\n }\n\n async firstUpdated() {\n this.renderRoot.addEventListener('change', this._onchange.bind(this))\n this.renderRoot.addEventListener('focusout', this._onfocusout.bind(this))\n this.addEventListener('click', this._onclick.bind(this))\n this.addEventListener('dblclick', this._ondblclick.bind(this))\n this.addEventListener('keydown', this._onkeydown.bind(this))\n\n /* editor mode 인 경우의 마우스 움직임이, grist-body의 이벤트 처리에 의해서 에디터를 리셋시킬 수 있으므로, 이벤트 전파를 막는다. */\n this.addEventListener('pointerdown', (e: Event) => e.stopPropagation())\n this.addEventListener('pointermove', (e: Event) => e.stopPropagation())\n this.addEventListener('pointerup', (e: Event) => e.stopPropagation())\n\n const { name = '' } = this.column\n const { align, defaultValue } = this.column.record\n\n if (align) {\n this.style.textAlign = align\n this.style.textAlignLast = align /* for select */\n }\n\n var currentValue = this.record[name]\n\n if (typeof currentValue == 'undefined' && defaultValue) {\n currentValue = getDefaultValue(defaultValue, this.record)\n }\n\n this.value = this._dirtyValue = this.formatForEditor(currentValue)\n\n // 입력을 위한 키를 누르면서 편집모드가 될때는 누른 키가 처음에 입력되도록, enter 같은 것을 눌러서 편집모드가 되면 현재 값으로 편집모드 전환\n const valueWith = this.inlineEditable && this.field?.valueWith\n this.value = this._dirtyValue = valueWith ? this.formatFromEditor(valueWith) : this.formatForEditor(currentValue)\n\n requestAnimationFrame(() => {\n this.focus()\n !valueWith && this.select()\n })\n }\n\n select() {\n const editor = this.editor\n if ((editor as HTMLInputElement)?.select) {\n return (editor as HTMLInputElement).select()\n }\n }\n\n focus() {\n const editor = this.editor\n if (editor) {\n editor.focus()\n }\n }\n\n formatForEditor(value: any): any {\n return value == null ? '' : value\n }\n\n formatFromEditor(value: any): any {\n return value\n }\n\n _onfocusout() {\n // paste시 field-change는 Body에서 하므로 X\n if (this.field?.isWorking === true) return\n\n const { name = '' } = this.column\n var currentValue = this.record[name] || ''\n\n if (this._dirtyValue !== currentValue) {\n this.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: currentValue,\n after: this._dirtyValue,\n column: this.column,\n record: this.record,\n row: this.row\n }\n })\n )\n }\n }\n\n _onchange(e: Event): void {\n e.stopPropagation()\n\n const value = (e.target as any)?.value\n\n this._dirtyValue = this.formatFromEditor(value)\n }\n\n _onkeydown(e: Event): void {}\n\n _onclick(e: Event): void {\n e.stopPropagation()\n }\n\n _ondblclick(e: Event): void {\n e.stopPropagation()\n }\n\n get editorTemplate() {\n return html``\n }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { PropertyValues } from 'lit';
5
+ import { OxFormField } from '@operato/input';
6
+ import { GristRecord } from '../types.js';
7
+ export declare class OxInputTree extends OxFormField {
8
+ static styles: import("lit").CSSResult;
9
+ record: GristRecord;
10
+ selectable?: boolean;
11
+ private checked?;
12
+ private expanded?;
13
+ input: HTMLInputElement;
14
+ render(): import("lit-html").TemplateResult<1>;
15
+ updated(changes: PropertyValues<this>): void;
16
+ focus(): void;
17
+ select(): void;
18
+ onClickCheckbox(e: MouseEvent): void;
19
+ onClickExpander(e: MouseEvent): void;
20
+ }
@@ -0,0 +1,221 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { __decorate } from "tslib";
5
+ import { css, html, nothing } from 'lit';
6
+ import { customElement, property, query, state } from 'lit/decorators.js';
7
+ import { ifDefined } from 'lit/directives/if-defined.js';
8
+ import { OxFormField } from '@operato/input';
9
+ let OxInputTree = class OxInputTree extends OxFormField {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.expanded = false;
13
+ }
14
+ render() {
15
+ var { __children__ } = this.record;
16
+ const expandable = __children__ && __children__.length > 0;
17
+ return html `
18
+ <div wrap>
19
+ ${expandable
20
+ ? html `
21
+ <span
22
+ expander
23
+ @click=${this.onClickExpander.bind(this)}
24
+ ?expanded=${this.expanded}
25
+ ?collapsed=${!this.expanded}
26
+ ></span>
27
+ `
28
+ : html `<span expander></span>`}
29
+ ${this.selectable
30
+ ? html ` <span checkbox @click=${this.onClickCheckbox.bind(this)} checked=${ifDefined(this.checked)}></span>`
31
+ : nothing}
32
+
33
+ <span label
34
+ ><input
35
+ value=${ifDefined(this.value)}
36
+ @change=${(e) => {
37
+ e.stopPropagation();
38
+ this.value = e.target.value;
39
+ this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true }));
40
+ }}
41
+ focus
42
+ /></span>
43
+
44
+ <!-- <span label>${this.value}</span> -->
45
+ </div>
46
+ `;
47
+ }
48
+ updated(changes) {
49
+ var { __depth__, __check_in_tree__, __expanded__ } = this.record;
50
+ this.checked = __check_in_tree__;
51
+ this.expanded = __expanded__;
52
+ this.style.setProperty('--tree-depth', String(__depth__));
53
+ }
54
+ focus() {
55
+ this.input.focus();
56
+ }
57
+ select() {
58
+ this.input.select();
59
+ }
60
+ onClickCheckbox(e) {
61
+ e.stopPropagation();
62
+ this.dispatchEvent(new CustomEvent('check-in-tree', {
63
+ bubbles: true,
64
+ composed: true,
65
+ detail: this.record
66
+ }));
67
+ this.requestUpdate();
68
+ }
69
+ onClickExpander(e) {
70
+ e.stopPropagation();
71
+ this.dispatchEvent(new CustomEvent(this.record.__expanded__ ? 'collapse-node' : 'expand-node', {
72
+ bubbles: true,
73
+ composed: true,
74
+ detail: this.record
75
+ }));
76
+ this.requestUpdate();
77
+ }
78
+ };
79
+ OxInputTree.styles = css `
80
+ :host {
81
+ overflow: hidden;
82
+ }
83
+
84
+ div[wrap] {
85
+ flex: 1;
86
+
87
+ position: relative;
88
+
89
+ display: flex;
90
+ align-items: center;
91
+ gap: 6px;
92
+
93
+ padding-left: calc(var(--tree-depth, 0) * 18px);
94
+ }
95
+
96
+ span[expander] {
97
+ display: inline-block;
98
+ vertical-align: middle;
99
+ width: 12px;
100
+ height: 20px;
101
+ cursor: pointer;
102
+ position: relative;
103
+ }
104
+
105
+ span[expander][collapsed]::before {
106
+ position: absolute;
107
+ top: 50%;
108
+ left: 50%;
109
+ transform: translate(-25%, -50%) rotate(-90deg);
110
+ content: ' ';
111
+ border: 5px solid transparent;
112
+ border-top: 5px solid var(--md-sys-color-on-primary-container, #1890ff);
113
+ }
114
+
115
+ span[expander][expanded]::before {
116
+ position: absolute;
117
+ top: 50%;
118
+ left: 50%;
119
+ transform: translate(-50%, -25%);
120
+ content: ' ';
121
+ border: 5px solid transparent;
122
+ border-top: 5px solid var(--md-sys-color-on-primary-container, #1890ff);
123
+ }
124
+
125
+ span[checkbox] {
126
+ display: inline-block;
127
+ vertical-align: middle;
128
+ width: 12px;
129
+ height: 20px;
130
+ cursor: pointer;
131
+ position: relative;
132
+ }
133
+
134
+ span[checkbox]::before {
135
+ cursor: pointer;
136
+ position: absolute;
137
+ top: 50%;
138
+ left: 50%;
139
+ transform: translate(-50%, -50%);
140
+ content: ' ';
141
+ display: block;
142
+ width: 10px;
143
+ height: 10px;
144
+ border: 1px solid var(--md-sys-color-on-primary-container, #1890ff);
145
+ border-radius: 2px;
146
+ }
147
+
148
+ span[checkbox][checked='checked']::before {
149
+ background-color: var(--md-sys-color-on-primary-container, #1890ff);
150
+ border-color: var(--md-sys-color-on-primary-container, #1890ff);
151
+ }
152
+
153
+ span[checkbox][checked='checked']::after {
154
+ position: absolute;
155
+ content: ' ';
156
+ display: block;
157
+ top: 50%;
158
+ left: 50%;
159
+ width: 3px;
160
+ height: 7px;
161
+ border: 2px solid #fff;
162
+ border-top: none;
163
+ border-left: none;
164
+ -webkit-transform: translate(-50%, -50%) rotate(45deg);
165
+ -ms-transform: translate(-50%, -50%) rotate(45deg);
166
+ transform: translate(-50%, -50%) rotate(45deg);
167
+ }
168
+
169
+ span[checkbox][checked='half-checked']::before {
170
+ background-color: var(--md-sys-color-on-primary-container, #1890ff);
171
+ border-color: var(--md-sys-color-on-primary-container, #1890ff);
172
+ }
173
+
174
+ span[checkbox][checked='half-checked']::after {
175
+ position: absolute;
176
+ content: ' ';
177
+ display: block;
178
+ top: 50%;
179
+ left: 50%;
180
+ transform: translate(-50%, -50%);
181
+ width: 10px;
182
+ height: 2px;
183
+ background-color: var(--md-sys-color-surface);
184
+ }
185
+
186
+ span[label] {
187
+ flex: 1;
188
+ }
189
+
190
+ input {
191
+ width: 100%;
192
+ height: 100%;
193
+ border: 0;
194
+ background-color: transparent;
195
+ box-sizing: border-box;
196
+ }
197
+
198
+ input:focus {
199
+ outline: none;
200
+ }
201
+ `;
202
+ __decorate([
203
+ property({ type: Object })
204
+ ], OxInputTree.prototype, "record", void 0);
205
+ __decorate([
206
+ property({ type: Boolean })
207
+ ], OxInputTree.prototype, "selectable", void 0);
208
+ __decorate([
209
+ state()
210
+ ], OxInputTree.prototype, "checked", void 0);
211
+ __decorate([
212
+ state()
213
+ ], OxInputTree.prototype, "expanded", void 0);
214
+ __decorate([
215
+ query('input')
216
+ ], OxInputTree.prototype, "input", void 0);
217
+ OxInputTree = __decorate([
218
+ customElement('ox-input-tree')
219
+ ], OxInputTree);
220
+ export { OxInputTree };
221
+ //# sourceMappingURL=ox-input-tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-input-tree.js","sourceRoot":"","sources":["../../../src/editors/ox-input-tree.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport { PropertyValues, css, html, nothing } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\n\nimport { OxFormField } from '@operato/input'\nimport { GristRecord } from '../types.js'\n\n@customElement('ox-input-tree')\nexport class OxInputTree extends OxFormField {\n static styles = css`\n :host {\n overflow: hidden;\n }\n\n div[wrap] {\n flex: 1;\n\n position: relative;\n\n display: flex;\n align-items: center;\n gap: 6px;\n\n padding-left: calc(var(--tree-depth, 0) * 18px);\n }\n\n span[expander] {\n display: inline-block;\n vertical-align: middle;\n width: 12px;\n height: 20px;\n cursor: pointer;\n position: relative;\n }\n\n span[expander][collapsed]::before {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-25%, -50%) rotate(-90deg);\n content: ' ';\n border: 5px solid transparent;\n border-top: 5px solid var(--md-sys-color-on-primary-container, #1890ff);\n }\n\n span[expander][expanded]::before {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -25%);\n content: ' ';\n border: 5px solid transparent;\n border-top: 5px solid var(--md-sys-color-on-primary-container, #1890ff);\n }\n\n span[checkbox] {\n display: inline-block;\n vertical-align: middle;\n width: 12px;\n height: 20px;\n cursor: pointer;\n position: relative;\n }\n\n span[checkbox]::before {\n cursor: pointer;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n content: ' ';\n display: block;\n width: 10px;\n height: 10px;\n border: 1px solid var(--md-sys-color-on-primary-container, #1890ff);\n border-radius: 2px;\n }\n\n span[checkbox][checked='checked']::before {\n background-color: var(--md-sys-color-on-primary-container, #1890ff);\n border-color: var(--md-sys-color-on-primary-container, #1890ff);\n }\n\n span[checkbox][checked='checked']::after {\n position: absolute;\n content: ' ';\n display: block;\n top: 50%;\n left: 50%;\n width: 3px;\n height: 7px;\n border: 2px solid #fff;\n border-top: none;\n border-left: none;\n -webkit-transform: translate(-50%, -50%) rotate(45deg);\n -ms-transform: translate(-50%, -50%) rotate(45deg);\n transform: translate(-50%, -50%) rotate(45deg);\n }\n\n span[checkbox][checked='half-checked']::before {\n background-color: var(--md-sys-color-on-primary-container, #1890ff);\n border-color: var(--md-sys-color-on-primary-container, #1890ff);\n }\n\n span[checkbox][checked='half-checked']::after {\n position: absolute;\n content: ' ';\n display: block;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 10px;\n height: 2px;\n background-color: var(--md-sys-color-surface);\n }\n\n span[label] {\n flex: 1;\n }\n\n input {\n width: 100%;\n height: 100%;\n border: 0;\n background-color: transparent;\n box-sizing: border-box;\n }\n\n input:focus {\n outline: none;\n }\n `\n\n @property({ type: Object }) record!: GristRecord\n @property({ type: Boolean }) selectable?: boolean\n\n @state() private checked?: 'checked' | 'half-checked' | 'unchecked'\n @state() private expanded?: boolean = false\n\n @query('input') input!: HTMLInputElement\n\n render() {\n var { __children__ } = this.record\n\n const expandable = __children__ && __children__.length > 0\n\n return html`\n <div wrap>\n ${expandable\n ? html`\n <span\n expander\n @click=${this.onClickExpander.bind(this)}\n ?expanded=${this.expanded}\n ?collapsed=${!this.expanded}\n ></span>\n `\n : html`<span expander></span>`}\n ${this.selectable\n ? html` <span checkbox @click=${this.onClickCheckbox.bind(this)} checked=${ifDefined(this.checked)}></span>`\n : nothing}\n\n <span label\n ><input\n value=${ifDefined(this.value)}\n @change=${(e: Event) => {\n e.stopPropagation()\n this.value = (e.target as HTMLInputElement).value\n this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true }))\n }}\n focus\n /></span>\n\n <!-- <span label>${this.value}</span> -->\n </div>\n `\n }\n\n updated(changes: PropertyValues<this>) {\n var { __depth__, __check_in_tree__, __expanded__ } = this.record\n this.checked = __check_in_tree__\n this.expanded = __expanded__\n\n this.style.setProperty('--tree-depth', String(__depth__))\n }\n\n focus() {\n this.input.focus()\n }\n\n select() {\n this.input.select()\n }\n\n onClickCheckbox(e: MouseEvent) {\n e.stopPropagation()\n\n this.dispatchEvent(\n new CustomEvent('check-in-tree', {\n bubbles: true,\n composed: true,\n detail: this.record\n })\n )\n\n this.requestUpdate()\n }\n\n onClickExpander(e: MouseEvent) {\n e.stopPropagation()\n\n this.dispatchEvent(\n new CustomEvent(this.record.__expanded__ ? 'collapse-node' : 'expand-node', {\n bubbles: true,\n composed: true,\n detail: this.record\n })\n )\n\n this.requestUpdate()\n }\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import { FieldEditor } from '../types.js';
2
+ import { OxGristEditor } from './ox-grist-editor.js';
3
+ export declare function registerEditor(type: string, editor: {
4
+ new (): OxGristEditor;
5
+ }): void;
6
+ export declare function unregisterEditor(type: string): void;
7
+ export declare function getEditors(): {
8
+ [name: string]: {
9
+ new (): OxGristEditor;
10
+ };
11
+ };
12
+ export declare function getEditor(type: string): FieldEditor;
@@ -0,0 +1,71 @@
1
+ import { OxGristEditorCheckbox } from './ox-grist-editor-checkbox.js';
2
+ import { OxGristEditorColor } from './ox-grist-editor-color.js';
3
+ import { OxGristEditorDate } from './ox-grist-editor-date.js';
4
+ import { OxGristEditorDateTime } from './ox-grist-editor-datetime.js';
5
+ import { OxGristEditorEmail } from './ox-grist-editor-email.js';
6
+ import { OxGristEditorFile } from './ox-grist-editor-file.js';
7
+ import { OxGristEditorImage } from './ox-grist-editor-image.js';
8
+ import { OxGristEditorMonth } from './ox-grist-editor-month.js';
9
+ import { OxGristEditorMultipleSelect } from './ox-grist-editor-multiple-select.js';
10
+ import { OxGristEditorNumber } from './ox-grist-editor-number.js';
11
+ import { OxGristEditorPassword } from './ox-grist-editor-password.js';
12
+ import { OxGristEditorSelect } from './ox-grist-editor-select.js';
13
+ import { OxGristEditorTel } from './ox-grist-editor-tel.js';
14
+ import { OxGristEditorText } from './ox-grist-editor-text.js';
15
+ import { OxGristEditorTextarea } from './ox-grist-editor-textarea.js';
16
+ import { OxGristEditorTime } from './ox-grist-editor-time.js';
17
+ import { OxGristEditorTree } from './ox-grist-editor-tree.js';
18
+ import { OxGristEditorWeek } from './ox-grist-editor-week.js';
19
+ import { OxGristEditorVarname } from './ox-grist-editor-varname.js';
20
+ var EDITORS = {
21
+ string: OxGristEditorText,
22
+ text: OxGristEditorText,
23
+ textarea: OxGristEditorTextarea,
24
+ email: OxGristEditorEmail,
25
+ tel: OxGristEditorTel,
26
+ password: OxGristEditorPassword,
27
+ integer: OxGristEditorNumber,
28
+ float: OxGristEditorNumber,
29
+ number: OxGristEditorNumber,
30
+ select: OxGristEditorSelect,
31
+ boolean: OxGristEditorCheckbox,
32
+ checkbox: OxGristEditorCheckbox,
33
+ month: OxGristEditorMonth,
34
+ week: OxGristEditorWeek,
35
+ date: OxGristEditorDate,
36
+ time: OxGristEditorTime,
37
+ datetime: OxGristEditorDateTime,
38
+ color: OxGristEditorColor,
39
+ progress: OxGristEditorNumber,
40
+ link: OxGristEditorText,
41
+ image: OxGristEditorImage,
42
+ file: OxGristEditorFile,
43
+ 'string[]': OxGristEditorMultipleSelect,
44
+ tree: OxGristEditorTree,
45
+ varname: OxGristEditorVarname
46
+ };
47
+ export function registerEditor(type, editor) {
48
+ EDITORS[type] = editor;
49
+ }
50
+ export function unregisterEditor(type) {
51
+ delete EDITORS[type];
52
+ }
53
+ export function getEditors() {
54
+ return { ...EDITORS };
55
+ }
56
+ export function getEditor(type) {
57
+ if (typeof type == 'function') {
58
+ return type;
59
+ }
60
+ return function (value, column, record, rowIndex, field) {
61
+ var clazz = EDITORS[type || 'text'] || OxGristEditorText;
62
+ var element = new clazz();
63
+ element.value = value;
64
+ element.record = record;
65
+ element.column = column;
66
+ element.row = rowIndex;
67
+ element.field = field;
68
+ return element;
69
+ };
70
+ }
71
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/editors/registry.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataGridField } from '../data-grid/data-grid-field.js'\nimport { ColumnConfig, FieldEditor, GristRecord } from '../types.js'\nimport { OxGristEditor } from './ox-grist-editor.js'\nimport { OxGristEditorCheckbox } from './ox-grist-editor-checkbox.js'\nimport { OxGristEditorColor } from './ox-grist-editor-color.js'\nimport { OxGristEditorDate } from './ox-grist-editor-date.js'\nimport { OxGristEditorDateTime } from './ox-grist-editor-datetime.js'\nimport { OxGristEditorEmail } from './ox-grist-editor-email.js'\nimport { OxGristEditorFile } from './ox-grist-editor-file.js'\nimport { OxGristEditorImage } from './ox-grist-editor-image.js'\nimport { OxGristEditorMonth } from './ox-grist-editor-month.js'\nimport { OxGristEditorMultipleSelect } from './ox-grist-editor-multiple-select.js'\nimport { OxGristEditorNumber } from './ox-grist-editor-number.js'\nimport { OxGristEditorPassword } from './ox-grist-editor-password.js'\nimport { OxGristEditorSelect } from './ox-grist-editor-select.js'\nimport { OxGristEditorTel } from './ox-grist-editor-tel.js'\nimport { OxGristEditorText } from './ox-grist-editor-text.js'\nimport { OxGristEditorTextarea } from './ox-grist-editor-textarea.js'\nimport { OxGristEditorTime } from './ox-grist-editor-time.js'\nimport { OxGristEditorTree } from './ox-grist-editor-tree.js'\nimport { OxGristEditorWeek } from './ox-grist-editor-week.js'\nimport { OxGristEditorVarname } from './ox-grist-editor-varname.js'\n\nvar EDITORS: { [name: string]: { new (): OxGristEditor } } = {\n string: OxGristEditorText,\n text: OxGristEditorText,\n textarea: OxGristEditorTextarea,\n email: OxGristEditorEmail,\n tel: OxGristEditorTel,\n password: OxGristEditorPassword,\n integer: OxGristEditorNumber,\n float: OxGristEditorNumber,\n number: OxGristEditorNumber,\n select: OxGristEditorSelect,\n boolean: OxGristEditorCheckbox,\n checkbox: OxGristEditorCheckbox,\n month: OxGristEditorMonth,\n week: OxGristEditorWeek,\n date: OxGristEditorDate,\n time: OxGristEditorTime,\n datetime: OxGristEditorDateTime,\n color: OxGristEditorColor,\n progress: OxGristEditorNumber,\n link: OxGristEditorText,\n image: OxGristEditorImage,\n file: OxGristEditorFile,\n 'string[]': OxGristEditorMultipleSelect,\n tree: OxGristEditorTree,\n varname: OxGristEditorVarname\n}\n\nexport function registerEditor(type: string, editor: { new (): OxGristEditor }) {\n EDITORS[type] = editor\n}\n\nexport function unregisterEditor(type: string) {\n delete EDITORS[type]\n}\n\nexport function getEditors(): { [name: string]: { new (): OxGristEditor } } {\n return { ...EDITORS }\n}\n\nexport function getEditor(type: string): FieldEditor {\n if (typeof type == 'function') {\n return type\n }\n\n return function (value: any, column: ColumnConfig, record: GristRecord, rowIndex: number, field: DataGridField) {\n var clazz = EDITORS[type || 'text'] || OxGristEditorText\n\n var element = new clazz()\n\n element.value = value\n element.record = record\n element.column = column\n element.row = rowIndex\n element.field = field\n\n return element\n }\n}\n"]}
@@ -0,0 +1,9 @@
1
+ import '@material/web/icon/icon.js';
2
+ import { LitElement } from 'lit';
3
+ export declare class EmptyNote extends LitElement {
4
+ static styles: import("lit").CSSResult;
5
+ icon?: string;
6
+ title: string;
7
+ description?: string;
8
+ render(): import("lit-html").TemplateResult<1>;
9
+ }
@@ -0,0 +1,53 @@
1
+ import { __decorate } from "tslib";
2
+ import '@material/web/icon/icon.js';
3
+ import { LitElement, css, html } from 'lit';
4
+ import { customElement, property } from 'lit/decorators.js';
5
+ let EmptyNote = class EmptyNote extends LitElement {
6
+ render() {
7
+ return html `
8
+ ${this.icon ? html `<md-icon>${this.icon}</md-icon>` : html ``}
9
+ <div titler>${this.title}</div>
10
+ ${this.description ? html `<div description>${this.description}</div>` : html ``}
11
+ `;
12
+ }
13
+ };
14
+ EmptyNote.styles = css `
15
+ :host {
16
+ display: block;
17
+ text-align: center;
18
+ }
19
+
20
+ md-icon {
21
+ font: var(--oops-note-icon-font);
22
+ color: var(--oops-note-icon-color);
23
+ border: var(--oops-note-icon-border);
24
+ border-radius: var(--oops-note-icon-border-radius);
25
+ padding: var(--oops-note-icon-padding);
26
+ }
27
+
28
+ [titler] {
29
+ margin: var(--oops-note-title-margin);
30
+ font: var(--oops-note-title-font);
31
+ color: var(--oops-note-title-color);
32
+ text-transform: capitalize;
33
+ }
34
+
35
+ [description] {
36
+ font: var(--oops-note-description-font);
37
+ color: var(--oops-note-description-color);
38
+ }
39
+ `;
40
+ __decorate([
41
+ property()
42
+ ], EmptyNote.prototype, "icon", void 0);
43
+ __decorate([
44
+ property()
45
+ ], EmptyNote.prototype, "title", void 0);
46
+ __decorate([
47
+ property()
48
+ ], EmptyNote.prototype, "description", void 0);
49
+ EmptyNote = __decorate([
50
+ customElement('ox-empty-note')
51
+ ], EmptyNote);
52
+ export { EmptyNote };
53
+ //# sourceMappingURL=empty-note.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"empty-note.js","sourceRoot":"","sources":["../../src/empty-note.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AAEnC,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAGpD,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,UAAU;IAgCvC,MAAM;QACJ,OAAO,IAAI,CAAA;QACP,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA,YAAY,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAA,EAAE;oBAC9C,IAAI,CAAC,KAAK;QACtB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAA,oBAAoB,IAAI,CAAC,WAAW,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAA,EAAE;KAC/E,CAAA;IACH,CAAC;;AArCM,gBAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBlB,AAzBY,CAyBZ;AAEW;IAAX,QAAQ,EAAE;uCAAc;AACb;IAAX,QAAQ,EAAE;wCAAe;AACd;IAAX,QAAQ,EAAE;8CAAqB;AA9BrB,SAAS;IADrB,aAAa,CAAC,eAAe,CAAC;GAClB,SAAS,CAuCrB","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { LitElement, css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('ox-empty-note')\nexport class EmptyNote extends LitElement {\n static styles = css`\n :host {\n display: block;\n text-align: center;\n }\n\n md-icon {\n font: var(--oops-note-icon-font);\n color: var(--oops-note-icon-color);\n border: var(--oops-note-icon-border);\n border-radius: var(--oops-note-icon-border-radius);\n padding: var(--oops-note-icon-padding);\n }\n\n [titler] {\n margin: var(--oops-note-title-margin);\n font: var(--oops-note-title-font);\n color: var(--oops-note-title-color);\n text-transform: capitalize;\n }\n\n [description] {\n font: var(--oops-note-description-font);\n color: var(--oops-note-description-color);\n }\n `\n\n @property() icon?: string\n @property() title!: string\n @property() description?: string\n\n render() {\n return html`\n ${this.icon ? html`<md-icon>${this.icon}</md-icon>` : html``}\n <div titler>${this.title}</div>\n ${this.description ? html`<div description>${this.description}</div>` : html``}\n `\n }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import '@operato/input/ox-checkbox.js';
2
+ import { FilterSelectRenderer } from '../types.js';
3
+ export declare const FilterCheckbox: FilterSelectRenderer;