@operato/data-grist 2.0.0-alpha.7 → 2.0.0-alpha.80

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 (267) hide show
  1. package/CHANGELOG.md +297 -0
  2. package/demo/data-grist-test.html +25 -14
  3. package/demo/index.html +25 -14
  4. package/demo/report-test.html +13 -2
  5. package/dist/src/accumulator/accumulator.js +4 -4
  6. package/dist/src/accumulator/accumulator.js.map +1 -1
  7. package/dist/src/configure/rows-option-builder.js +2 -1
  8. package/dist/src/configure/rows-option-builder.js.map +1 -1
  9. package/dist/src/configure/zero-config.js +1 -0
  10. package/dist/src/configure/zero-config.js.map +1 -1
  11. package/dist/src/data-card/data-card-gutter-menu.d.ts +1 -1
  12. package/dist/src/data-card/data-card-gutter-menu.js +5 -5
  13. package/dist/src/data-card/data-card-gutter-menu.js.map +1 -1
  14. package/dist/src/data-card/data-card.d.ts +2 -2
  15. package/dist/src/data-card/data-card.js +3 -3
  16. package/dist/src/data-card/data-card.js.map +1 -1
  17. package/dist/src/data-card/event-handlers/record-card-click-handler.js +1 -1
  18. package/dist/src/data-card/event-handlers/record-card-click-handler.js.map +1 -1
  19. package/dist/src/data-card/record-card.d.ts +2 -2
  20. package/dist/src/data-card/record-card.js +26 -26
  21. package/dist/src/data-card/record-card.js.map +1 -1
  22. package/dist/src/data-grid/data-grid-accum-field.js +8 -3
  23. package/dist/src/data-grid/data-grid-accum-field.js.map +1 -1
  24. package/dist/src/data-grid/data-grid-body.d.ts +3 -3
  25. package/dist/src/data-grid/data-grid-body.js +9 -4
  26. package/dist/src/data-grid/data-grid-body.js.map +1 -1
  27. package/dist/src/data-grid/data-grid-field.d.ts +1 -1
  28. package/dist/src/data-grid/data-grid-field.js +2 -2
  29. package/dist/src/data-grid/data-grid-field.js.map +1 -1
  30. package/dist/src/data-grid/data-grid-footer.d.ts +2 -2
  31. package/dist/src/data-grid/data-grid-footer.js +17 -9
  32. package/dist/src/data-grid/data-grid-footer.js.map +1 -1
  33. package/dist/src/data-grid/data-grid-header.d.ts +1 -1
  34. package/dist/src/data-grid/data-grid-header.js +37 -37
  35. package/dist/src/data-grid/data-grid-header.js.map +1 -1
  36. package/dist/src/data-grid/data-grid.d.ts +1 -1
  37. package/dist/src/data-grid/data-grid.js +1 -1
  38. package/dist/src/data-grid/data-grid.js.map +1 -1
  39. package/dist/src/data-grist.d.ts +226 -4
  40. package/dist/src/data-grist.js +217 -25
  41. package/dist/src/data-grist.js.map +1 -1
  42. package/dist/src/data-list/data-list-gutter.js +12 -0
  43. package/dist/src/data-list/data-list-gutter.js.map +1 -1
  44. package/dist/src/data-list/data-list.d.ts +2 -2
  45. package/dist/src/data-list/data-list.js +3 -3
  46. package/dist/src/data-list/data-list.js.map +1 -1
  47. package/dist/src/data-list/event-handlers/record-partial-click-handler.js +1 -1
  48. package/dist/src/data-list/event-handlers/record-partial-click-handler.js.map +1 -1
  49. package/dist/src/data-list/record-partial.d.ts +2 -2
  50. package/dist/src/data-list/record-partial.js +20 -18
  51. package/dist/src/data-list/record-partial.js.map +1 -1
  52. package/dist/src/data-manipulator.d.ts +6 -6
  53. package/dist/src/data-manipulator.js +44 -29
  54. package/dist/src/data-manipulator.js.map +1 -1
  55. package/dist/src/data-report/data-report-body.d.ts +1 -1
  56. package/dist/src/data-report/data-report-component.d.ts +1 -1
  57. package/dist/src/data-report.d.ts +1 -1
  58. package/dist/src/editors/ox-grist-editor-checkbox.d.ts +3 -2
  59. package/dist/src/editors/ox-grist-editor-checkbox.js +9 -2
  60. package/dist/src/editors/ox-grist-editor-checkbox.js.map +1 -1
  61. package/dist/src/editors/ox-grist-editor-color.d.ts +1 -1
  62. package/dist/src/editors/ox-grist-editor-date.d.ts +1 -1
  63. package/dist/src/editors/ox-grist-editor-datetime.d.ts +2 -2
  64. package/dist/src/editors/ox-grist-editor-datetime.js +1 -2
  65. package/dist/src/editors/ox-grist-editor-datetime.js.map +1 -1
  66. package/dist/src/editors/ox-grist-editor-email.d.ts +1 -1
  67. package/dist/src/editors/ox-grist-editor-file.d.ts +3 -2
  68. package/dist/src/editors/ox-grist-editor-file.js +8 -2
  69. package/dist/src/editors/ox-grist-editor-file.js.map +1 -1
  70. package/dist/src/editors/ox-grist-editor-image.d.ts +2 -2
  71. package/dist/src/editors/ox-grist-editor-image.js +8 -8
  72. package/dist/src/editors/ox-grist-editor-image.js.map +1 -1
  73. package/dist/src/editors/ox-grist-editor-month.d.ts +1 -1
  74. package/dist/src/editors/ox-grist-editor-multiple-select.d.ts +1 -1
  75. package/dist/src/editors/ox-grist-editor-number.d.ts +3 -2
  76. package/dist/src/editors/ox-grist-editor-number.js +10 -9
  77. package/dist/src/editors/ox-grist-editor-number.js.map +1 -1
  78. package/dist/src/editors/ox-grist-editor-password.d.ts +1 -1
  79. package/dist/src/editors/ox-grist-editor-select.d.ts +1 -1
  80. package/dist/src/editors/ox-grist-editor-tel.d.ts +1 -1
  81. package/dist/src/editors/ox-grist-editor-text.d.ts +2 -1
  82. package/dist/src/editors/ox-grist-editor-text.js +3 -0
  83. package/dist/src/editors/ox-grist-editor-text.js.map +1 -1
  84. package/dist/src/editors/ox-grist-editor-textarea.d.ts +2 -1
  85. package/dist/src/editors/ox-grist-editor-textarea.js +3 -0
  86. package/dist/src/editors/ox-grist-editor-textarea.js.map +1 -1
  87. package/dist/src/editors/ox-grist-editor-time.d.ts +1 -1
  88. package/dist/src/editors/ox-grist-editor-tree.d.ts +1 -1
  89. package/dist/src/editors/ox-grist-editor-week.d.ts +1 -1
  90. package/dist/src/editors/ox-grist-editor.d.ts +4 -4
  91. package/dist/src/editors/ox-grist-editor.js +14 -12
  92. package/dist/src/editors/ox-grist-editor.js.map +1 -1
  93. package/dist/src/editors/ox-input-tree.d.ts +1 -1
  94. package/dist/src/empty-note.d.ts +2 -2
  95. package/dist/src/empty-note.js +3 -3
  96. package/dist/src/empty-note.js.map +1 -1
  97. package/dist/src/filters/filter-range-date.js +12 -1
  98. package/dist/src/filters/filter-range-date.js.map +1 -1
  99. package/dist/src/filters/filters-form.d.ts +1 -0
  100. package/dist/src/filters/filters-form.js +41 -23
  101. package/dist/src/filters/filters-form.js.map +1 -1
  102. package/dist/src/gutters/gutter-button.d.ts +1 -1
  103. package/dist/src/gutters/gutter-button.js +3 -3
  104. package/dist/src/gutters/gutter-button.js.map +1 -1
  105. package/dist/src/gutters/gutter-dirty.d.ts +1 -1
  106. package/dist/src/gutters/gutter-dirty.js +5 -5
  107. package/dist/src/gutters/gutter-dirty.js.map +1 -1
  108. package/dist/src/handlers/contextmenu-tree-mutation.js +5 -23
  109. package/dist/src/handlers/contextmenu-tree-mutation.js.map +1 -1
  110. package/dist/src/index.d.ts +0 -1
  111. package/dist/src/index.js +0 -1
  112. package/dist/src/index.js.map +1 -1
  113. package/dist/src/record-view/record-creator.d.ts +2 -2
  114. package/dist/src/record-view/record-creator.js +1 -1
  115. package/dist/src/record-view/record-creator.js.map +1 -1
  116. package/dist/src/record-view/record-view-body.d.ts +3 -3
  117. package/dist/src/record-view/record-view-body.js +4 -4
  118. package/dist/src/record-view/record-view-body.js.map +1 -1
  119. package/dist/src/record-view/record-view.d.ts +2 -2
  120. package/dist/src/record-view/record-view.js +5 -5
  121. package/dist/src/record-view/record-view.js.map +1 -1
  122. package/dist/src/renderers/ox-grist-renderer-progress.d.ts +1 -1
  123. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +1 -1
  124. package/dist/src/renderers/ox-grist-renderer.d.ts +2 -2
  125. package/dist/src/sorters/sorters-control.js +3 -3
  126. package/dist/src/sorters/sorters-control.js.map +1 -1
  127. package/dist/src/types.d.ts +1 -8
  128. package/dist/src/types.js.map +1 -1
  129. package/dist/stories/accumulator.stories.d.ts +1 -1
  130. package/dist/stories/accumulator.stories.js +126 -112
  131. package/dist/stories/accumulator.stories.js.map +1 -1
  132. package/dist/stories/barcode-input-filter.stories.d.ts +1 -1
  133. package/dist/stories/barcode-input-filter.stories.js +80 -72
  134. package/dist/stories/barcode-input-filter.stories.js.map +1 -1
  135. package/dist/stories/default-filters.stories.d.ts +1 -1
  136. package/dist/stories/default-filters.stories.js +80 -72
  137. package/dist/stories/default-filters.stories.js.map +1 -1
  138. package/dist/stories/dynamic-editable.stories.d.ts +1 -1
  139. package/dist/stories/dynamic-editable.stories.js +100 -79
  140. package/dist/stories/dynamic-editable.stories.js.map +1 -1
  141. package/dist/stories/empty-sorters.stories.d.ts +1 -1
  142. package/dist/stories/empty-sorters.stories.js +80 -71
  143. package/dist/stories/empty-sorters.stories.js.map +1 -1
  144. package/dist/stories/explicit-fetch.stories.d.ts +1 -1
  145. package/dist/stories/explicit-fetch.stories.js +81 -72
  146. package/dist/stories/explicit-fetch.stories.js.map +1 -1
  147. package/dist/stories/fixed-column.stories.d.ts +1 -1
  148. package/dist/stories/fixed-column.stories.js +122 -113
  149. package/dist/stories/fixed-column.stories.js.map +1 -1
  150. package/dist/stories/grist-modes.stories.d.ts +1 -1
  151. package/dist/stories/grist-modes.stories.js +155 -125
  152. package/dist/stories/grist-modes.stories.js.map +1 -1
  153. package/dist/stories/group-header.stories.d.ts +1 -1
  154. package/dist/stories/group-header.stories.js +122 -113
  155. package/dist/stories/group-header.stories.js.map +1 -1
  156. package/dist/stories/textarea.stories.d.ts +1 -1
  157. package/dist/stories/textarea.stories.js +113 -104
  158. package/dist/stories/textarea.stories.js.map +1 -1
  159. package/dist/stories/tree-column-with-checkbox.stories.d.ts +1 -1
  160. package/dist/stories/tree-column-with-checkbox.stories.js +126 -117
  161. package/dist/stories/tree-column-with-checkbox.stories.js.map +1 -1
  162. package/dist/stories/tree-column.stories.d.ts +1 -1
  163. package/dist/stories/tree-column.stories.js +126 -117
  164. package/dist/stories/tree-column.stories.js.map +1 -1
  165. package/dist/tsconfig.tsbuildinfo +1 -1
  166. package/docs/default-value/default-value.md +1 -1
  167. package/docs/default-value/value-generator/date-generator.md +2 -2
  168. package/docs/default-value/value-generator/month-date-generator.md +2 -2
  169. package/docs/default-value/value-generator/week-date-generator.md +2 -2
  170. package/docs/default-value/value-generator/year-date-generator.md +2 -2
  171. package/package.json +21 -20
  172. package/src/accumulator/accumulator.ts +4 -4
  173. package/src/configure/rows-option-builder.ts +11 -1
  174. package/src/configure/zero-config.ts +1 -0
  175. package/src/data-card/data-card-gutter-menu.ts +5 -5
  176. package/src/data-card/data-card.ts +3 -3
  177. package/src/data-card/event-handlers/record-card-click-handler.ts +1 -1
  178. package/src/data-card/record-card.ts +30 -32
  179. package/src/data-grid/data-grid-accum-field.ts +8 -3
  180. package/src/data-grid/data-grid-body.ts +10 -5
  181. package/src/data-grid/data-grid-field.ts +1 -1
  182. package/src/data-grid/data-grid-footer.ts +18 -11
  183. package/src/data-grid/data-grid-header.ts +67 -68
  184. package/src/data-grid/data-grid.ts +3 -3
  185. package/src/data-grist.ts +274 -27
  186. package/src/data-list/data-list-gutter.ts +12 -0
  187. package/src/data-list/data-list.ts +3 -3
  188. package/src/data-list/event-handlers/record-partial-click-handler.ts +1 -1
  189. package/src/data-list/record-partial.ts +22 -22
  190. package/src/data-manipulator.ts +52 -31
  191. package/src/editors/ox-grist-editor-checkbox.ts +12 -2
  192. package/src/editors/ox-grist-editor-datetime.ts +1 -2
  193. package/src/editors/ox-grist-editor-file.ts +12 -2
  194. package/src/editors/ox-grist-editor-image.ts +10 -7
  195. package/src/editors/ox-grist-editor-number.ts +11 -9
  196. package/src/editors/ox-grist-editor-text.ts +4 -0
  197. package/src/editors/ox-grist-editor-textarea.ts +4 -0
  198. package/src/editors/ox-grist-editor.ts +14 -10
  199. package/src/empty-note.ts +3 -3
  200. package/src/filters/filter-range-date.ts +16 -1
  201. package/src/filters/filters-form.ts +69 -46
  202. package/src/gutters/gutter-button.ts +3 -3
  203. package/src/gutters/gutter-dirty.ts +5 -5
  204. package/src/handlers/contextmenu-tree-mutation.ts +5 -23
  205. package/src/index.ts +0 -1
  206. package/src/record-view/record-creator.ts +1 -1
  207. package/src/record-view/record-view-body.ts +4 -4
  208. package/src/record-view/record-view.ts +5 -5
  209. package/src/sorters/sorters-control.ts +3 -3
  210. package/src/types.ts +1 -9
  211. package/stories/accumulator.stories.ts +128 -118
  212. package/stories/barcode-input-filter.stories.ts +91 -82
  213. package/stories/default-filters.stories.ts +91 -82
  214. package/stories/dynamic-editable.stories.ts +108 -86
  215. package/stories/empty-sorters.stories.ts +92 -82
  216. package/stories/explicit-fetch.stories.ts +93 -83
  217. package/stories/fixed-column.stories.ts +134 -124
  218. package/stories/grist-modes.stories.ts +167 -141
  219. package/stories/group-header.stories.ts +134 -124
  220. package/stories/textarea.stories.ts +115 -110
  221. package/stories/tree-column-with-checkbox.stories.ts +134 -124
  222. package/stories/tree-column.stories.ts +134 -124
  223. package/themes/grist-theme.css +1 -1
  224. package/dist/src/value-generator/date-generator.d.ts +0 -6
  225. package/dist/src/value-generator/date-generator.js +0 -30
  226. package/dist/src/value-generator/date-generator.js.map +0 -1
  227. package/dist/src/value-generator/hour-time-generator.d.ts +0 -7
  228. package/dist/src/value-generator/hour-time-generator.js +0 -29
  229. package/dist/src/value-generator/hour-time-generator.js.map +0 -1
  230. package/dist/src/value-generator/index.d.ts +0 -1
  231. package/dist/src/value-generator/index.js +0 -2
  232. package/dist/src/value-generator/index.js.map +0 -1
  233. package/dist/src/value-generator/minute-time-generator.d.ts +0 -7
  234. package/dist/src/value-generator/minute-time-generator.js +0 -29
  235. package/dist/src/value-generator/minute-time-generator.js.map +0 -1
  236. package/dist/src/value-generator/month-date-generator.d.ts +0 -7
  237. package/dist/src/value-generator/month-date-generator.js +0 -31
  238. package/dist/src/value-generator/month-date-generator.js.map +0 -1
  239. package/dist/src/value-generator/now-generator.d.ts +0 -4
  240. package/dist/src/value-generator/now-generator.js +0 -8
  241. package/dist/src/value-generator/now-generator.js.map +0 -1
  242. package/dist/src/value-generator/registry.d.ts +0 -11
  243. package/dist/src/value-generator/registry.js +0 -50
  244. package/dist/src/value-generator/registry.js.map +0 -1
  245. package/dist/src/value-generator/time-generator.d.ts +0 -6
  246. package/dist/src/value-generator/time-generator.js +0 -28
  247. package/dist/src/value-generator/time-generator.js.map +0 -1
  248. package/dist/src/value-generator/today-generator.d.ts +0 -4
  249. package/dist/src/value-generator/today-generator.js +0 -8
  250. package/dist/src/value-generator/today-generator.js.map +0 -1
  251. package/dist/src/value-generator/week-date-generator.d.ts +0 -7
  252. package/dist/src/value-generator/week-date-generator.js +0 -29
  253. package/dist/src/value-generator/week-date-generator.js.map +0 -1
  254. package/dist/src/value-generator/year-date-generator.d.ts +0 -7
  255. package/dist/src/value-generator/year-date-generator.js +0 -29
  256. package/dist/src/value-generator/year-date-generator.js.map +0 -1
  257. package/src/value-generator/date-generator.ts +0 -35
  258. package/src/value-generator/hour-time-generator.ts +0 -43
  259. package/src/value-generator/index.ts +0 -1
  260. package/src/value-generator/minute-time-generator.ts +0 -43
  261. package/src/value-generator/month-date-generator.ts +0 -38
  262. package/src/value-generator/now-generator.ts +0 -10
  263. package/src/value-generator/registry.ts +0 -58
  264. package/src/value-generator/time-generator.ts +0 -33
  265. package/src/value-generator/today-generator.ts +0 -10
  266. package/src/value-generator/week-date-generator.ts +0 -40
  267. package/src/value-generator/year-date-generator.ts +0 -36
@@ -64,14 +64,16 @@ export class DataManipulator extends LitElement {
64
64
  })
65
65
 
66
66
  /* tree processing */
67
- this.addEventListener('collapse-all', (e: Event) => this.onCollapseAll(e as CustomEvent))
68
- this.addEventListener('expand-all', (e: Event) => this.onExpandAll(e as CustomEvent))
69
- this.addEventListener('collapse-node', (e: Event) => this.onCollapse(e as CustomEvent))
70
- this.addEventListener('expand-node', (e: Event) => this.onExpand(e as CustomEvent))
67
+ this.addEventListener('collapse-all', (e: Event) => this.collapseAll())
68
+ this.addEventListener('expand-all', (e: Event) => this.expandAll())
69
+ this.addEventListener('collapse-node', (e: Event) => this.collapseNode((e as CustomEvent).detail as GristRecord))
70
+ this.addEventListener('expand-node', (e: Event) => this.expandNode((e as CustomEvent).detail as GristRecord))
71
71
  this.addEventListener('check-in-tree', (e: Event) => this.onCheckInTree(e as CustomEvent))
72
72
 
73
- this.addEventListener('add-sibling-node', (e: Event) => this.onAddSiblingNode(e as CustomEvent))
74
- this.addEventListener('add-child-node', (e: Event) => this.onAddChildNode(e as CustomEvent))
73
+ this.addEventListener('add-sibling-node', (e: Event) =>
74
+ this.addSiblingNode((e as CustomEvent).detail as GristRecord)
75
+ )
76
+ this.addEventListener('add-child-node', (e: Event) => this.addChildNode((e as CustomEvent).detail as GristRecord))
75
77
  }
76
78
 
77
79
  onFieldChange({
@@ -212,36 +214,46 @@ export class DataManipulator extends LitElement {
212
214
  this.requestUpdate()
213
215
  }
214
216
 
215
- onCollapseAll(e: CustomEvent) {
217
+ collapseAll() {
216
218
  this.refresh(false)
217
219
  }
218
220
 
219
- onExpandAll(e: CustomEvent) {
221
+ expandAll() {
220
222
  this.refresh(true)
221
223
  }
222
224
 
223
- onCollapse(e: CustomEvent) {
224
- const record = e.detail as GristRecord
225
+ collapseNode(record: GristRecord) {
225
226
  record.__expanded__ = false
226
227
 
227
228
  this.refresh()
228
229
  }
229
230
 
230
- onExpand(e: CustomEvent) {
231
- const record = e.detail as GristRecord
231
+ expandNode(record: GristRecord) {
232
232
  record.__expanded__ = true
233
233
 
234
234
  this.refresh()
235
235
  }
236
236
 
237
- onAddSiblingNode(e: CustomEvent) {
237
+ // onCollapse(e: CustomEvent) {
238
+ // const record = e.detail as GristRecord
239
+ // record.__expanded__ = false
240
+
241
+ // this.refresh()
242
+ // }
243
+
244
+ // onExpand(e: CustomEvent) {
245
+ // const record = e.detail as GristRecord
246
+ // record.__expanded__ = true
247
+
248
+ // this.refresh()
249
+ // }
250
+
251
+ addSiblingNode(record: GristRecord) {
238
252
  const { records } = this.data
239
253
  const toplevelRecords = records.filter(
240
254
  record => !record.__depth__
241
255
  ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */
242
256
 
243
- const field = e.detail
244
- const { record } = field
245
257
  const { __depth__ } = record as GristRecord
246
258
 
247
259
  function findParent(record: GristRecord, parent?: GristRecord): GristRecord | undefined {
@@ -264,15 +276,27 @@ export class DataManipulator extends LitElement {
264
276
  const sibling = {
265
277
  __depth__,
266
278
  __dirty__: '+'
267
- }
279
+ } as GristRecord
268
280
 
269
281
  if (parent) {
270
- const { __children__ } = parent as GristRecord
282
+ const { id } = parent as GristRecord
271
283
 
272
- if (!__children__) {
284
+ sibling.parent = { id }
285
+
286
+ if (!parent.__children__) {
273
287
  parent.__children__ = [sibling]
274
288
  } else {
275
- parent.__children__ = [...__children__, sibling]
289
+ let index = parent.__children__.indexOf(record)
290
+
291
+ if (index !== -1) {
292
+ parent.__children__ = [
293
+ ...parent.__children__.slice(0, index + 1),
294
+ sibling,
295
+ ...parent.__children__.slice(index + 1)
296
+ ]
297
+ } else {
298
+ parent.__children__ = [...parent.__children__, sibling]
299
+ }
276
300
  }
277
301
 
278
302
  parent.__expanded__ = true
@@ -283,25 +307,25 @@ export class DataManipulator extends LitElement {
283
307
  this.refresh()
284
308
  }
285
309
 
286
- onAddChildNode(e: CustomEvent) {
287
- const field = e.detail
288
- const { record } = field
289
-
290
- const { __children__, __depth__, __seq__ } = record as GristRecord
310
+ addChildNode(record: GristRecord) {
311
+ const { id: parentId, __children__, __depth__ } = record as GristRecord
291
312
  const child = {
313
+ parent: {
314
+ id: parentId
315
+ },
292
316
  __depth__: (__depth__ || 0) + 1,
293
317
  __dirty__: '+'
294
318
  }
295
319
 
296
- if (!__children__) {
320
+ if (!record.__children__) {
297
321
  record.__children__ = [child]
298
322
  } else {
299
- record.__children__.push(child)
323
+ record.__children__.unshift(child)
300
324
  }
301
325
 
302
326
  record.__expanded__ = true
303
327
 
304
- field.requestUpdate()
328
+ // this.requestUpdate()
305
329
 
306
330
  this.refresh()
307
331
  }
@@ -388,10 +412,7 @@ export class DataManipulator extends LitElement {
388
412
 
389
413
  private traverseRefresh(record: GristRecord, forceExpandOrCollapse?: boolean): GristRecord[] {
390
414
  if (forceExpandOrCollapse !== undefined) {
391
- record = {
392
- ...record,
393
- __expanded__: forceExpandOrCollapse
394
- }
415
+ record.__expanded__ = forceExpandOrCollapse
395
416
  }
396
417
 
397
418
  const { __expanded__, __children__ = [] } = record
@@ -4,8 +4,18 @@ import { html } from 'lit'
4
4
 
5
5
  @customElement('ox-grist-editor-checkbox')
6
6
  export class OxGristEditorCheckbox extends OxGristEditor {
7
- formatFromEditor(e: Event) {
8
- return (e.target as HTMLInputElement).checked
7
+ _onchange(e: Event) {
8
+ e.stopPropagation()
9
+
10
+ const input = e.target as HTMLInputElement
11
+
12
+ this._dirtyValue = this.formatFromEditor(input.checked)
13
+ }
14
+
15
+ formatFromEditor(value: any) {
16
+ if (typeof value == 'boolean') {
17
+ return value
18
+ }
9
19
  }
10
20
 
11
21
  formatForEditor(value: any): any {
@@ -15,8 +15,7 @@ export class OxGristEditorDateTime extends OxGristEditor {
15
15
  return new Date(timestamp - tzoffset).toISOString().slice(0, -1)
16
16
  }
17
17
 
18
- formatFromEditor(e: Event) {
19
- var value = (e.target as HTMLInputElement).value
18
+ formatFromEditor(value: any) {
20
19
  var datetime = new Date(value)
21
20
 
22
21
  return datetime.getTime()
@@ -5,8 +5,18 @@ import { OxGristEditor } from './ox-grist-editor.js'
5
5
 
6
6
  @customElement('ox-grist-editor-file')
7
7
  export class OxGristEditorFile extends OxGristEditor {
8
- formatFromEditor(e: Event): any {
9
- return (e.target as HTMLInputElement).files
8
+ _onchange(e: Event) {
9
+ e.stopPropagation()
10
+
11
+ const input = e.target as HTMLInputElement
12
+
13
+ this._dirtyValue = this.formatFromEditor(input.files)
14
+
15
+ this._onfocusout()
16
+ }
17
+
18
+ formatFromEditor(value: any): any {
19
+ return value
10
20
  }
11
21
 
12
22
  get editorTemplate() {
@@ -12,17 +12,20 @@ export class OxGristEditorImage extends OxGristEditor {
12
12
 
13
13
  _onchange(e: Event) {
14
14
  e.stopPropagation()
15
- this._dirtyValue = this.formatFromEditor(e)
16
- this._onfocusout()
17
- }
18
15
 
19
- formatFromEditor(e: Event) {
20
- // value가 image file object인지, image url인지 확인
21
16
  const input = e.target as HTMLInputElement
17
+
18
+ // value가 image file object인지, image url인지 확인
22
19
  if (input.files?.[0]) {
23
- return input.files[0]
20
+ this._dirtyValue = this.formatFromEditor(input.files[0])
24
21
  } else {
25
- return input.value
22
+ this._dirtyValue = this.formatFromEditor(input.value)
26
23
  }
24
+
25
+ this._onfocusout()
26
+ }
27
+
28
+ formatFromEditor(value: any) {
29
+ return value
27
30
  }
28
31
  }
@@ -1,20 +1,22 @@
1
1
  import { OxGristEditor } from './ox-grist-editor.js'
2
2
  import { customElement } from 'lit/decorators.js'
3
3
  import { html } from 'lit'
4
+ import { parseToNumberOrNull } from '@operato/utils'
4
5
 
5
6
  @customElement('ox-grist-editor-number')
6
7
  export class OxGristEditorNumber extends OxGristEditor {
7
- formatFromEditor(e: Event) {
8
- let value = (e.target as HTMLInputElement).value
8
+ get inlineEditable() {
9
+ return true
10
+ }
11
+
12
+ formatFromEditor(value: any) {
13
+ const parsed = parseToNumberOrNull(value) ?? null
9
14
 
10
- switch (this.column.type) {
11
- case 'float':
12
- return Number.parseFloat(value)
13
- case 'integer':
14
- return Number.parseInt(value)
15
- default:
16
- return Number(value)
15
+ if (parsed !== null && this.column.type == 'integer') {
16
+ return Math.floor(parsed)
17
17
  }
18
+
19
+ return parsed
18
20
  }
19
21
 
20
22
  get editorTemplate() {
@@ -4,6 +4,10 @@ import { html } from 'lit'
4
4
 
5
5
  @customElement('ox-grist-editor-text')
6
6
  export class OxGristEditorText extends OxGristEditor {
7
+ get inlineEditable() {
8
+ return true
9
+ }
10
+
7
11
  get editorTemplate() {
8
12
  return html` <input type="text" .value=${this.value} /> `
9
13
  }
@@ -6,6 +6,10 @@ import { html } from 'lit'
6
6
 
7
7
  @customElement('ox-grist-editor-textarea')
8
8
  export class OxGristEditorTextarea extends OxGristEditor {
9
+ get inlineEditable() {
10
+ return true
11
+ }
12
+
9
13
  get editorTemplate() {
10
14
  return html` <ox-input-textarea .value=${this.value}></ox-input-textarea> `
11
15
  }
@@ -4,7 +4,7 @@ import { customElement, property } from 'lit/decorators.js'
4
4
  import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config'
5
5
  import { DataGridField } from '../data-grid/data-grid-field'
6
6
  import { ColumnConfig, GristRecord } from '../types'
7
- import { getDefaultValue } from '../value-generator'
7
+ import { getDefaultValue } from '@operato/time-calculator'
8
8
 
9
9
  const STYLE = css`
10
10
  :host {
@@ -91,8 +91,8 @@ export class OxGristEditor extends LitElement {
91
91
  return this.renderRoot.firstElementChild as HTMLElement
92
92
  }
93
93
 
94
- get directEditable() {
95
- return true
94
+ get inlineEditable() {
95
+ return false
96
96
  }
97
97
 
98
98
  async firstUpdated() {
@@ -121,19 +121,21 @@ export class OxGristEditor extends LitElement {
121
121
  currentValue = getDefaultValue(defaultValue, this.record)
122
122
  }
123
123
 
124
+ this.value = this._dirtyValue = this.formatForEditor(currentValue)
125
+
124
126
  // 입력을 위한 키를 누르면서 편집모드가 될때는 누른 키가 처음에 입력되도록, enter 같은 것을 눌러서 편집모드가 되면 현재 값으로 편집모드 전환
125
- const editorValue = this.field?.valueWithEdit ? this.field.valueWithEdit : this.formatForEditor(currentValue)
126
- this.value = this._dirtyValue = this.field?.type === 'number' ? Number(editorValue) : editorValue
127
+ const valueWith = this.inlineEditable && this.field?.valueWith
128
+ this.value = this._dirtyValue = valueWith ? this.formatFromEditor(valueWith) : this.formatForEditor(currentValue)
127
129
 
128
130
  requestAnimationFrame(() => {
129
131
  this.focus()
130
- this.select()
132
+ !valueWith && this.select()
131
133
  })
132
134
  }
133
135
 
134
136
  select() {
135
137
  const editor = this.editor
136
- if ((editor as HTMLInputElement)?.select && !this.field?.valueWithEdit) {
138
+ if ((editor as HTMLInputElement)?.select) {
137
139
  return (editor as HTMLInputElement).select()
138
140
  }
139
141
  }
@@ -149,8 +151,8 @@ export class OxGristEditor extends LitElement {
149
151
  return value == null ? '' : value
150
152
  }
151
153
 
152
- formatFromEditor(e: Event): any {
153
- return (e.target as HTMLInputElement).value
154
+ formatFromEditor(value: any): any {
155
+ return value
154
156
  }
155
157
 
156
158
  _onfocusout() {
@@ -180,7 +182,9 @@ export class OxGristEditor extends LitElement {
180
182
  _onchange(e: Event): void {
181
183
  e.stopPropagation()
182
184
 
183
- this._dirtyValue = this.formatFromEditor(e)
185
+ const value = (e.target as any)?.value
186
+
187
+ this._dirtyValue = this.formatFromEditor(value)
184
188
  }
185
189
 
186
190
  _onkeydown(e: Event): void {}
package/src/empty-note.ts CHANGED
@@ -1,4 +1,4 @@
1
- import '@material/mwc-icon'
1
+ import '@material/web/icon/icon.js'
2
2
 
3
3
  import { LitElement, css, html } from 'lit'
4
4
  import { customElement, property } from 'lit/decorators.js'
@@ -11,7 +11,7 @@ export class EmptyNote extends LitElement {
11
11
  text-align: center;
12
12
  }
13
13
 
14
- mwc-icon {
14
+ md-icon {
15
15
  font: var(--oops-note-icon-font);
16
16
  color: var(--oops-note-icon-color);
17
17
  border: var(--oops-note-icon-border);
@@ -38,7 +38,7 @@ export class EmptyNote extends LitElement {
38
38
 
39
39
  render() {
40
40
  return html`
41
- ${this.icon ? html`<mwc-icon>${this.icon}</mwc-icon>` : html``}
41
+ ${this.icon ? html`<md-icon>${this.icon}</md-icon>` : html``}
42
42
  <div titler>${this.title}</div>
43
43
  ${this.description ? html`<div description>${this.description}</div>` : html``}
44
44
  `
@@ -2,16 +2,31 @@ import { FilterConfigObject, FilterSelectRenderer } from '../types'
2
2
 
3
3
  import { html } from 'lit-html'
4
4
 
5
+ function formatDate(type: string, date: Date) {
6
+ var year = date.getFullYear()
7
+ var month = ('0' + (date.getMonth() + 1)).slice(-2)
8
+ var day = ('0' + date.getDate()).slice(-2)
9
+ var hours = ('0' + date.getHours()).slice(-2)
10
+ var minutes = ('0' + date.getMinutes()).slice(-2)
11
+
12
+ var formatDate = year + '-' + month + '-' + day
13
+
14
+ return type == 'date' ? formatDate : formatDate + 'T' + hours + ':' + minutes
15
+ }
16
+
5
17
  export const FilterRangeDate: FilterSelectRenderer = (column, value, owner) => {
6
18
  const filter = column.filter as FilterConfigObject
7
19
 
8
- const [from, to] = value instanceof Array ? value : []
20
+ var [from, to] = value instanceof Array ? value : []
9
21
 
10
22
  var type: any = filter?.type || column.type
11
23
  if (type === 'datetime') {
12
24
  type = 'datetime-local'
13
25
  }
14
26
 
27
+ from = formatDate(type, new Date(from))
28
+ to = formatDate(type, new Date(to))
29
+
15
30
  return html`
16
31
  <input
17
32
  name=${column.name}
@@ -6,6 +6,8 @@ import '@operato/input/ox-input-search.js'
6
6
  import { css, html, LitElement, PropertyValues, TemplateResult, nothing } from 'lit'
7
7
  import { customElement, property, queryAsync, state } from 'lit/decorators.js'
8
8
 
9
+ import { getDefaultValue } from '@operato/time-calculator'
10
+
9
11
  import { FilterConfigObject } from '..'
10
12
  import { DataGrist } from '../data-grist'
11
13
  import { ColumnConfig, FilterOperator, FilterValue, GristConfig } from '../types'
@@ -72,7 +74,6 @@ export class FiltersForm extends LitElement {
72
74
 
73
75
  if (grist) {
74
76
  this.config = grist.compiledConfig
75
- this.value = grist.filters || []
76
77
 
77
78
  grist.addEventListener('config-change', (e: Event) => {
78
79
  this.config = (e as CustomEvent).detail
@@ -102,6 +103,17 @@ export class FiltersForm extends LitElement {
102
103
  }
103
104
  }
104
105
 
106
+ buildDefaultValue(operator: string, defaultValue: any) {
107
+ if (defaultValue === undefined) {
108
+ return
109
+ }
110
+ if (operator == 'between') {
111
+ return (defaultValue as Array<any>).map(v => getDefaultValue(v, this))
112
+ } else {
113
+ return getDefaultValue(defaultValue, this)
114
+ }
115
+ }
116
+
105
117
  updated(changes: PropertyValues<this>) {
106
118
  if (changes.has('config')) {
107
119
  const filters = this.config.columns.filter(columnConfig => !!columnConfig.filter)
@@ -114,6 +126,15 @@ export class FiltersForm extends LitElement {
114
126
  return filter!.operator === 'search'
115
127
  })
116
128
 
129
+ const grist = this.closest('ox-grist') as DataGrist
130
+
131
+ this.value = (grist?.filters || []).map(filter => {
132
+ return {
133
+ ...filter,
134
+ value: this.buildDefaultValue(filter!.operator, filter!.value)
135
+ }
136
+ })
137
+
117
138
  this.empty = (this.searchColumns.length === 0 || this.withoutSearch) && this.filterColumns.length === 0
118
139
  }
119
140
  }
@@ -151,8 +172,8 @@ export class FiltersForm extends LitElement {
151
172
  filterLabel !== undefined
152
173
  ? filterLabel
153
174
  : typeof label === 'object' && label.renderer
154
- ? label.renderer(column)
155
- : header.renderer(column) || name
175
+ ? label.renderer(column)
176
+ : header.renderer(column) || name
156
177
 
157
178
  const idx = operator === 'between' ? 1 : 0
158
179
  const renderer = getFilterRenderer(
@@ -160,7 +181,9 @@ export class FiltersForm extends LitElement {
160
181
  ? 'text'
161
182
  : type
162
183
  )[idx]
163
- const value = this.value?.find(filter => filter.name == name)?.value
184
+ const value =
185
+ this.value?.find(filter => filter.name == name)?.value ??
186
+ this.buildDefaultValue(operator!, (filter as FilterConfigObject)?.value)
164
187
 
165
188
  if (!renderer) {
166
189
  return html``
@@ -171,48 +194,48 @@ export class FiltersForm extends LitElement {
171
194
  ><span>${labelText}</span> ${renderer(column, value, this)}
172
195
  </label> `
173
196
  : type !== 'select' && !labelText
174
- ? renderer(column, value, this)
175
- : operator === 'in'
176
- ? html`
177
- <ox-select
178
- name=${name}
179
- placeholder=${labelText}
180
- .value=${value}
181
- @change=${(e: CustomEvent) =>
182
- e.target?.dispatchEvent(
183
- new CustomEvent('filter-change', {
184
- detail: {
185
- name,
186
- operator,
187
- value: e.detail
188
- }
189
- })
190
- )}
191
- >
192
- <ox-popup-list multiple attr-selected="checked" with-search>
193
- ${renderer(column, value, this)}
194
- </ox-popup-list>
195
- </ox-select>
196
- `
197
- : html`
198
- <ox-select
199
- name=${name}
200
- placeholder=${labelText}
201
- .value=${value}
202
- @change=${(e: CustomEvent) =>
203
- e.target?.dispatchEvent(
204
- new CustomEvent('filter-change', {
205
- detail: {
206
- name,
207
- operator,
208
- value: e.detail
209
- }
210
- })
211
- )}
212
- >
213
- <ox-popup-list with-search> ${renderer(column, value, this)} </ox-popup-list>
214
- </ox-select>
215
- `
197
+ ? renderer(column, value, this)
198
+ : operator === 'in'
199
+ ? html`
200
+ <ox-select
201
+ name=${name}
202
+ placeholder=${labelText}
203
+ .value=${value}
204
+ @change=${(e: CustomEvent) =>
205
+ e.target?.dispatchEvent(
206
+ new CustomEvent('filter-change', {
207
+ detail: {
208
+ name,
209
+ operator,
210
+ value: e.detail
211
+ }
212
+ })
213
+ )}
214
+ >
215
+ <ox-popup-list multiple attr-selected="checked" with-search>
216
+ ${renderer(column, value, this)}
217
+ </ox-popup-list>
218
+ </ox-select>
219
+ `
220
+ : html`
221
+ <ox-select
222
+ name=${name}
223
+ placeholder=${labelText}
224
+ .value=${value}
225
+ @change=${(e: CustomEvent) =>
226
+ e.target?.dispatchEvent(
227
+ new CustomEvent('filter-change', {
228
+ detail: {
229
+ name,
230
+ operator,
231
+ value: e.detail
232
+ }
233
+ })
234
+ )}
235
+ >
236
+ <ox-popup-list with-search> ${renderer(column, value, this)} </ox-popup-list>
237
+ </ox-select>
238
+ `
216
239
  })}
217
240
  </form>
218
241
  `
@@ -1,4 +1,4 @@
1
- import '@material/mwc-icon'
1
+ import '@material/web/icon/icon.js'
2
2
 
3
3
  import { html } from 'lit'
4
4
 
@@ -23,13 +23,13 @@ export class GutterButton {
23
23
  sortable: false,
24
24
  header: {
25
25
  renderer: function (column) {
26
- return html` <mwc-icon style=${inlineHeaderStyle} title=${title}>${iconFn()}</mwc-icon> `
26
+ return html` <md-icon style=${inlineHeaderStyle} title=${title}>${iconFn()}</md-icon> `
27
27
  } as HeaderRenderer
28
28
  },
29
29
  record: {
30
30
  align: 'center',
31
31
  renderer: function (value, column, record, rowIndex, field) {
32
- return html` <mwc-icon style=${inlineRecordStyle} title=${title}>${iconFn(record)}</mwc-icon> `
32
+ return html` <md-icon style=${inlineRecordStyle} title=${title}>${iconFn(record)}</md-icon> `
33
33
  } as FieldRenderer
34
34
  },
35
35
  forGrid: true,
@@ -1,4 +1,4 @@
1
- import '@material/mwc-icon'
1
+ import '@material/web/icon/icon.js'
2
2
 
3
3
  import { css, html, LitElement } from 'lit'
4
4
  import { customElement, property } from 'lit/decorators.js'
@@ -13,7 +13,7 @@ class GutterDirtyElement extends LitElement {
13
13
  margin: auto;
14
14
  }
15
15
 
16
- mwc-icon {
16
+ md-icon {
17
17
  width: var(--grid-record-dirty-icon-size);
18
18
  height: var(--grid-record-dirty-icon-size);
19
19
  border-radius: 50%;
@@ -38,11 +38,11 @@ class GutterDirtyElement extends LitElement {
38
38
  render() {
39
39
  switch (this.value) {
40
40
  case '+':
41
- return html` <mwc-icon style=${INLINESTYLE} center add>add</mwc-icon> `
41
+ return html` <md-icon style=${INLINESTYLE} center add>add</md-icon> `
42
42
  case '-':
43
- return html` <mwc-icon style=${INLINESTYLE} center remove>remove</mwc-icon> `
43
+ return html` <md-icon style=${INLINESTYLE} center remove>remove</md-icon> `
44
44
  case 'M':
45
- return html` <mwc-icon style=${INLINESTYLE} center done>done</mwc-icon> `
45
+ return html` <md-icon style=${INLINESTYLE} center done>done</md-icon> `
46
46
  default:
47
47
  return ''
48
48
  }