@operato/data-grist 8.0.0 → 9.0.0-beta.10

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 (309) hide show
  1. package/CHANGELOG.md +223 -30
  2. package/dist/index.d.ts +1 -1
  3. package/dist/index.js +1 -1
  4. package/dist/index.js.map +1 -1
  5. package/dist/src/accumulator/accumulator.d.ts +1 -1
  6. package/dist/src/accumulator/accumulator.js.map +1 -1
  7. package/dist/src/configure/column-builder.d.ts +1 -1
  8. package/dist/src/configure/column-builder.js +5 -5
  9. package/dist/src/configure/column-builder.js.map +1 -1
  10. package/dist/src/configure/config-builder.d.ts +1 -1
  11. package/dist/src/configure/config-builder.js +6 -6
  12. package/dist/src/configure/config-builder.js.map +1 -1
  13. package/dist/src/configure/filters-option-builder.d.ts +1 -1
  14. package/dist/src/configure/filters-option-builder.js.map +1 -1
  15. package/dist/src/configure/imex-option-builder.d.ts +1 -1
  16. package/dist/src/configure/imex-option-builder.js.map +1 -1
  17. package/dist/src/configure/list-option-builder.d.ts +1 -1
  18. package/dist/src/configure/list-option-builder.js.map +1 -1
  19. package/dist/src/configure/rows-option-builder.d.ts +1 -1
  20. package/dist/src/configure/rows-option-builder.js +2 -2
  21. package/dist/src/configure/rows-option-builder.js.map +1 -1
  22. package/dist/src/configure/tree-option-builder.d.ts +1 -1
  23. package/dist/src/configure/tree-option-builder.js.map +1 -1
  24. package/dist/src/configure/zero-config.d.ts +1 -1
  25. package/dist/src/configure/zero-config.js.map +1 -1
  26. package/dist/src/data-card/data-card-field.d.ts +1 -1
  27. package/dist/src/data-card/data-card-field.js +39 -7
  28. package/dist/src/data-card/data-card-field.js.map +1 -1
  29. package/dist/src/data-card/data-card-gutter-menu.js +46 -2
  30. package/dist/src/data-card/data-card-gutter-menu.js.map +1 -1
  31. package/dist/src/data-card/data-card-gutter.d.ts +1 -1
  32. package/dist/src/data-card/data-card-gutter.js +39 -7
  33. package/dist/src/data-card/data-card-gutter.js.map +1 -1
  34. package/dist/src/data-card/data-card.d.ts +3 -3
  35. package/dist/src/data-card/data-card.js +47 -11
  36. package/dist/src/data-card/data-card.js.map +1 -1
  37. package/dist/src/data-card/event-handlers/record-card-click-handler.d.ts +1 -1
  38. package/dist/src/data-card/event-handlers/record-card-click-handler.js.map +1 -1
  39. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.d.ts +1 -1
  40. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js.map +1 -1
  41. package/dist/src/data-card/record-card.d.ts +5 -5
  42. package/dist/src/data-card/record-card.js +80 -20
  43. package/dist/src/data-card/record-card.js.map +1 -1
  44. package/dist/src/data-consumer.d.ts +1 -1
  45. package/dist/src/data-consumer.js.map +1 -1
  46. package/dist/src/data-grid/data-grid-accum-field.d.ts +1 -1
  47. package/dist/src/data-grid/data-grid-accum-field.js +63 -12
  48. package/dist/src/data-grid/data-grid-accum-field.js.map +1 -1
  49. package/dist/src/data-grid/data-grid-body.d.ts +4 -4
  50. package/dist/src/data-grid/data-grid-body.js +140 -38
  51. package/dist/src/data-grid/data-grid-body.js.map +1 -1
  52. package/dist/src/data-grid/data-grid-field.d.ts +1 -1
  53. package/dist/src/data-grid/data-grid-field.js +112 -17
  54. package/dist/src/data-grid/data-grid-field.js.map +1 -1
  55. package/dist/src/data-grid/data-grid-footer.d.ts +1 -1
  56. package/dist/src/data-grid/data-grid-footer.js +23 -6
  57. package/dist/src/data-grid/data-grid-footer.js.map +1 -1
  58. package/dist/src/data-grid/data-grid-header.d.ts +2 -2
  59. package/dist/src/data-grid/data-grid-header.js +86 -25
  60. package/dist/src/data-grid/data-grid-header.js.map +1 -1
  61. package/dist/src/data-grid/data-grid.d.ts +7 -7
  62. package/dist/src/data-grid/data-grid.js +52 -12
  63. package/dist/src/data-grid/data-grid.js.map +1 -1
  64. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.d.ts +1 -1
  65. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js.map +1 -1
  66. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.d.ts +1 -1
  67. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js.map +1 -1
  68. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.d.ts +1 -1
  69. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js.map +1 -1
  70. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.d.ts +1 -1
  71. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js.map +1 -1
  72. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.d.ts +1 -1
  73. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js.map +1 -1
  74. package/dist/src/data-grist.d.ts +8 -8
  75. package/dist/src/data-grist.js +308 -91
  76. package/dist/src/data-grist.js.map +1 -1
  77. package/dist/src/data-list/data-list-field.d.ts +1 -1
  78. package/dist/src/data-list/data-list-field.js +39 -7
  79. package/dist/src/data-list/data-list-field.js.map +1 -1
  80. package/dist/src/data-list/data-list-gutter.d.ts +1 -1
  81. package/dist/src/data-list/data-list-gutter.js +39 -7
  82. package/dist/src/data-list/data-list-gutter.js.map +1 -1
  83. package/dist/src/data-list/data-list.d.ts +2 -2
  84. package/dist/src/data-list/data-list.js +46 -10
  85. package/dist/src/data-list/data-list.js.map +1 -1
  86. package/dist/src/data-list/event-handlers/record-partial-click-handler.d.ts +1 -1
  87. package/dist/src/data-list/event-handlers/record-partial-click-handler.js.map +1 -1
  88. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.d.ts +1 -1
  89. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js.map +1 -1
  90. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.d.ts +1 -1
  91. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js.map +1 -1
  92. package/dist/src/data-list/record-partial.d.ts +4 -4
  93. package/dist/src/data-list/record-partial.js +68 -18
  94. package/dist/src/data-list/record-partial.js.map +1 -1
  95. package/dist/src/data-manipulator.d.ts +1 -1
  96. package/dist/src/data-manipulator.js +31 -6
  97. package/dist/src/data-manipulator.js.map +1 -1
  98. package/dist/src/data-provider.js +90 -9
  99. package/dist/src/data-provider.js.map +1 -1
  100. package/dist/src/data-report/data-report-body.d.ts +2 -2
  101. package/dist/src/data-report/data-report-body.js +42 -10
  102. package/dist/src/data-report/data-report-body.js.map +1 -1
  103. package/dist/src/data-report/data-report-component.d.ts +3 -3
  104. package/dist/src/data-report/data-report-component.js +42 -10
  105. package/dist/src/data-report/data-report-component.js.map +1 -1
  106. package/dist/src/data-report/data-report-field.d.ts +1 -1
  107. package/dist/src/data-report/data-report-field.js +46 -9
  108. package/dist/src/data-report/data-report-field.js.map +1 -1
  109. package/dist/src/data-report/data-report-header.js +41 -8
  110. package/dist/src/data-report/data-report-header.js.map +1 -1
  111. package/dist/src/data-report/event-handlers/data-report-body-click-handler.d.ts +1 -1
  112. package/dist/src/data-report/event-handlers/data-report-body-click-handler.js.map +1 -1
  113. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.d.ts +1 -1
  114. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js.map +1 -1
  115. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.d.ts +1 -1
  116. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js.map +1 -1
  117. package/dist/src/data-report.d.ts +4 -4
  118. package/dist/src/data-report.js +88 -16
  119. package/dist/src/data-report.js.map +1 -1
  120. package/dist/src/editors/index.d.ts +1 -1
  121. package/dist/src/editors/index.js +1 -1
  122. package/dist/src/editors/index.js.map +1 -1
  123. package/dist/src/editors/ox-grist-editor-multiple-select.js +9 -4
  124. package/dist/src/editors/ox-grist-editor-multiple-select.js.map +1 -1
  125. package/dist/src/editors/ox-grist-editor-tree.d.ts +1 -1
  126. package/dist/src/editors/ox-grist-editor-tree.js +9 -4
  127. package/dist/src/editors/ox-grist-editor-tree.js.map +1 -1
  128. package/dist/src/editors/ox-grist-editor.d.ts +2 -2
  129. package/dist/src/editors/ox-grist-editor.js +52 -7
  130. package/dist/src/editors/ox-grist-editor.js.map +1 -1
  131. package/dist/src/editors/ox-input-tree.d.ts +1 -1
  132. package/dist/src/editors/ox-input-tree.js +37 -3
  133. package/dist/src/editors/ox-input-tree.js.map +1 -1
  134. package/dist/src/editors/registry.d.ts +2 -2
  135. package/dist/src/editors/registry.js +19 -19
  136. package/dist/src/editors/registry.js.map +1 -1
  137. package/dist/src/empty-note.js +28 -2
  138. package/dist/src/empty-note.js.map +1 -1
  139. package/dist/src/filters/filter-input.d.ts +1 -1
  140. package/dist/src/filters/filter-input.js.map +1 -1
  141. package/dist/src/filters/filter-range-date.d.ts +1 -1
  142. package/dist/src/filters/filter-range-date.js.map +1 -1
  143. package/dist/src/filters/filter-range-number.d.ts +1 -1
  144. package/dist/src/filters/filter-range-number.js.map +1 -1
  145. package/dist/src/filters/filter-select-buttons.d.ts +1 -1
  146. package/dist/src/filters/filter-select-buttons.js.map +1 -1
  147. package/dist/src/filters/filter-select.d.ts +1 -1
  148. package/dist/src/filters/filter-select.js +1 -1
  149. package/dist/src/filters/filter-select.js.map +1 -1
  150. package/dist/src/filters/filters-form.d.ts +1 -2
  151. package/dist/src/filters/filters-form.js +91 -15
  152. package/dist/src/filters/filters-form.js.map +1 -1
  153. package/dist/src/filters/index.d.ts +8 -8
  154. package/dist/src/filters/index.js +8 -8
  155. package/dist/src/filters/index.js.map +1 -1
  156. package/dist/src/formatters/index.d.ts +1 -1
  157. package/dist/src/formatters/index.js +1 -1
  158. package/dist/src/formatters/index.js.map +1 -1
  159. package/dist/src/formatters/registry.js +4 -4
  160. package/dist/src/formatters/registry.js.map +1 -1
  161. package/dist/src/gutters/gutter-button.d.ts +1 -1
  162. package/dist/src/gutters/gutter-button.js.map +1 -1
  163. package/dist/src/gutters/gutter-dirty.d.ts +1 -1
  164. package/dist/src/gutters/gutter-dirty.js +16 -2
  165. package/dist/src/gutters/gutter-dirty.js.map +1 -1
  166. package/dist/src/gutters/gutter-row-selector.d.ts +1 -1
  167. package/dist/src/gutters/gutter-row-selector.js.map +1 -1
  168. package/dist/src/gutters/gutter-sequence.d.ts +9 -9
  169. package/dist/src/gutters/gutter-sequence.js.map +1 -1
  170. package/dist/src/gutters/index.d.ts +1 -1
  171. package/dist/src/gutters/index.js +1 -1
  172. package/dist/src/gutters/index.js.map +1 -1
  173. package/dist/src/gutters/registry.d.ts +1 -1
  174. package/dist/src/gutters/registry.js +4 -4
  175. package/dist/src/gutters/registry.js.map +1 -1
  176. package/dist/src/handlers/contextmenu-tree-mutation.d.ts +2 -2
  177. package/dist/src/handlers/contextmenu-tree-mutation.js.map +1 -1
  178. package/dist/src/handlers/index.d.ts +1 -1
  179. package/dist/src/handlers/index.js +1 -1
  180. package/dist/src/handlers/index.js.map +1 -1
  181. package/dist/src/handlers/move-down.d.ts +2 -2
  182. package/dist/src/handlers/move-down.js.map +1 -1
  183. package/dist/src/handlers/move-up.d.ts +2 -2
  184. package/dist/src/handlers/move-up.js.map +1 -1
  185. package/dist/src/handlers/record-copy.d.ts +2 -2
  186. package/dist/src/handlers/record-copy.js.map +1 -1
  187. package/dist/src/handlers/record-delete.d.ts +2 -2
  188. package/dist/src/handlers/record-delete.js.map +1 -1
  189. package/dist/src/handlers/record-view-handler.d.ts +2 -2
  190. package/dist/src/handlers/record-view-handler.js.map +1 -1
  191. package/dist/src/handlers/registry.d.ts +1 -1
  192. package/dist/src/handlers/registry.js +8 -8
  193. package/dist/src/handlers/registry.js.map +1 -1
  194. package/dist/src/handlers/select-row-toggle.d.ts +2 -2
  195. package/dist/src/handlers/select-row-toggle.js.map +1 -1
  196. package/dist/src/handlers/select-row.d.ts +2 -2
  197. package/dist/src/handlers/select-row.js.map +1 -1
  198. package/dist/src/index.d.ts +14 -14
  199. package/dist/src/index.js +14 -14
  200. package/dist/src/index.js.map +1 -1
  201. package/dist/src/personalizer/index.d.ts +1 -1
  202. package/dist/src/personalizer/index.js +1 -1
  203. package/dist/src/personalizer/index.js.map +1 -1
  204. package/dist/src/personalizer/ox-grist-filter-personalizer.js +20 -4
  205. package/dist/src/personalizer/ox-grist-filter-personalizer.js.map +1 -1
  206. package/dist/src/personalizer/ox-grist-personalizer.js +20 -4
  207. package/dist/src/personalizer/ox-grist-personalizer.js.map +1 -1
  208. package/dist/src/record-view/event-handlers/record-view-body-click-handler.d.ts +1 -1
  209. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js.map +1 -1
  210. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.d.ts +1 -1
  211. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js.map +1 -1
  212. package/dist/src/record-view/index.d.ts +2 -2
  213. package/dist/src/record-view/index.js +2 -2
  214. package/dist/src/record-view/index.js.map +1 -1
  215. package/dist/src/record-view/ox-record-creator.d.ts +3 -3
  216. package/dist/src/record-view/ox-record-creator.js +40 -7
  217. package/dist/src/record-view/ox-record-creator.js.map +1 -1
  218. package/dist/src/record-view/record-view-body.d.ts +2 -2
  219. package/dist/src/record-view/record-view-body.js +44 -10
  220. package/dist/src/record-view/record-view-body.js.map +1 -1
  221. package/dist/src/record-view/record-view-handler.d.ts +6 -6
  222. package/dist/src/record-view/record-view-handler.js.map +1 -1
  223. package/dist/src/record-view/record-view.d.ts +4 -4
  224. package/dist/src/record-view/record-view.js +36 -10
  225. package/dist/src/record-view/record-view.js.map +1 -1
  226. package/dist/src/renderers/ox-grist-renderer-boolean.d.ts +1 -1
  227. package/dist/src/renderers/ox-grist-renderer-boolean.js +1 -1
  228. package/dist/src/renderers/ox-grist-renderer-boolean.js.map +1 -1
  229. package/dist/src/renderers/ox-grist-renderer-color.d.ts +1 -1
  230. package/dist/src/renderers/ox-grist-renderer-color.js.map +1 -1
  231. package/dist/src/renderers/ox-grist-renderer-date.d.ts +1 -1
  232. package/dist/src/renderers/ox-grist-renderer-date.js.map +1 -1
  233. package/dist/src/renderers/ox-grist-renderer-file.d.ts +1 -1
  234. package/dist/src/renderers/ox-grist-renderer-file.js.map +1 -1
  235. package/dist/src/renderers/ox-grist-renderer-image.d.ts +1 -1
  236. package/dist/src/renderers/ox-grist-renderer-image.js.map +1 -1
  237. package/dist/src/renderers/ox-grist-renderer-json5.d.ts +1 -1
  238. package/dist/src/renderers/ox-grist-renderer-json5.js.map +1 -1
  239. package/dist/src/renderers/ox-grist-renderer-link.d.ts +1 -1
  240. package/dist/src/renderers/ox-grist-renderer-link.js.map +1 -1
  241. package/dist/src/renderers/ox-grist-renderer-password.d.ts +1 -1
  242. package/dist/src/renderers/ox-grist-renderer-password.js.map +1 -1
  243. package/dist/src/renderers/ox-grist-renderer-progress.d.ts +1 -1
  244. package/dist/src/renderers/ox-grist-renderer-progress.js +8 -3
  245. package/dist/src/renderers/ox-grist-renderer-progress.js.map +1 -1
  246. package/dist/src/renderers/ox-grist-renderer-select.d.ts +1 -1
  247. package/dist/src/renderers/ox-grist-renderer-select.js.map +1 -1
  248. package/dist/src/renderers/ox-grist-renderer-text.d.ts +1 -1
  249. package/dist/src/renderers/ox-grist-renderer-text.js.map +1 -1
  250. package/dist/src/renderers/ox-grist-renderer-textarea.d.ts +1 -1
  251. package/dist/src/renderers/ox-grist-renderer-textarea.js.map +1 -1
  252. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +1 -1
  253. package/dist/src/renderers/ox-grist-renderer-tree.js +20 -4
  254. package/dist/src/renderers/ox-grist-renderer-tree.js.map +1 -1
  255. package/dist/src/renderers/ox-grist-renderer.d.ts +2 -2
  256. package/dist/src/renderers/ox-grist-renderer.js +43 -4
  257. package/dist/src/renderers/ox-grist-renderer.js.map +1 -1
  258. package/dist/src/sorters/sorters-control.d.ts +1 -1
  259. package/dist/src/sorters/sorters-control.js +26 -5
  260. package/dist/src/sorters/sorters-control.js.map +1 -1
  261. package/dist/src/types.d.ts +11 -11
  262. package/dist/src/types.js.map +1 -1
  263. package/dist/src/utils/index.d.ts +2 -2
  264. package/dist/src/utils/index.js +2 -2
  265. package/dist/src/utils/index.js.map +1 -1
  266. package/dist/src/utils/list-param.d.ts +1 -1
  267. package/dist/src/utils/list-param.js +1 -1
  268. package/dist/src/utils/list-param.js.map +1 -1
  269. package/dist/stories/accumulator-format.stories.js +1 -1
  270. package/dist/stories/accumulator-format.stories.js.map +1 -1
  271. package/dist/stories/barcode-input-filter.stories.js +1 -1
  272. package/dist/stories/barcode-input-filter.stories.js.map +1 -1
  273. package/dist/stories/bounded-select-filters.stories.js +1 -1
  274. package/dist/stories/bounded-select-filters.stories.js.map +1 -1
  275. package/dist/stories/bounded-select-record.stories.js +1 -1
  276. package/dist/stories/bounded-select-record.stories.js.map +1 -1
  277. package/dist/stories/click-event-custom.stories.js +1 -1
  278. package/dist/stories/click-event-custom.stories.js.map +1 -1
  279. package/dist/stories/click-event.stories.js +1 -1
  280. package/dist/stories/click-event.stories.js.map +1 -1
  281. package/dist/stories/creatable-only-column.stories.js +1 -1
  282. package/dist/stories/creatable-only-column.stories.js.map +1 -1
  283. package/dist/stories/default-filters.stories.js +1 -1
  284. package/dist/stories/default-filters.stories.js.map +1 -1
  285. package/dist/stories/dynamic-editable.stories.js +1 -1
  286. package/dist/stories/dynamic-editable.stories.js.map +1 -1
  287. package/dist/stories/empty-sorters.stories.js +1 -1
  288. package/dist/stories/empty-sorters.stories.js.map +1 -1
  289. package/dist/stories/explicit-fetch.stories.js +1 -1
  290. package/dist/stories/explicit-fetch.stories.js.map +1 -1
  291. package/dist/stories/fixed-column.stories.js +1 -1
  292. package/dist/stories/fixed-column.stories.js.map +1 -1
  293. package/dist/stories/grid-setting.stories.js +1 -1
  294. package/dist/stories/grid-setting.stories.js.map +1 -1
  295. package/dist/stories/grist-modes.stories.js +1 -1
  296. package/dist/stories/grist-modes.stories.js.map +1 -1
  297. package/dist/stories/group-header.stories.js +1 -1
  298. package/dist/stories/group-header.stories.js.map +1 -1
  299. package/dist/stories/record-view.stories.js +1 -1
  300. package/dist/stories/record-view.stories.js.map +1 -1
  301. package/dist/stories/textarea.stories.js +1 -1
  302. package/dist/stories/textarea.stories.js.map +1 -1
  303. package/dist/stories/tree-column-with-checkbox.stories.js +1 -1
  304. package/dist/stories/tree-column-with-checkbox.stories.js.map +1 -1
  305. package/dist/stories/tree-column.stories.js +1 -1
  306. package/dist/stories/tree-column.stories.js.map +1 -1
  307. package/dist/tsconfig.tsbuildinfo +1 -1
  308. package/index.ts +1 -1
  309. package/package.json +20 -19
@@ -1,13 +1,40 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { css, html, LitElement } from 'lit';
3
3
  import { customElement, property } from 'lit/decorators.js';
4
- import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config';
4
+ import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js';
5
5
  let DataCardField = class DataCardField extends LitElement {
6
6
  constructor() {
7
7
  super(...arguments);
8
- this.record = ZERO_RECORD;
9
- this.column = ZERO_COLUMN;
10
- this.rowIndex = -1;
8
+ Object.defineProperty(this, "align", {
9
+ enumerable: true,
10
+ configurable: true,
11
+ writable: true,
12
+ value: void 0
13
+ });
14
+ Object.defineProperty(this, "record", {
15
+ enumerable: true,
16
+ configurable: true,
17
+ writable: true,
18
+ value: ZERO_RECORD
19
+ });
20
+ Object.defineProperty(this, "column", {
21
+ enumerable: true,
22
+ configurable: true,
23
+ writable: true,
24
+ value: ZERO_COLUMN
25
+ });
26
+ Object.defineProperty(this, "rowIndex", {
27
+ enumerable: true,
28
+ configurable: true,
29
+ writable: true,
30
+ value: -1
31
+ });
32
+ Object.defineProperty(this, "value", {
33
+ enumerable: true,
34
+ configurable: true,
35
+ writable: true,
36
+ value: void 0
37
+ });
11
38
  }
12
39
  render() {
13
40
  var { value, column, record, rowIndex } = this;
@@ -21,8 +48,12 @@ let DataCardField = class DataCardField extends LitElement {
21
48
  }
22
49
  }
23
50
  };
24
- DataCardField.styles = [
25
- css `
51
+ Object.defineProperty(DataCardField, "styles", {
52
+ enumerable: true,
53
+ configurable: true,
54
+ writable: true,
55
+ value: [
56
+ css `
26
57
  :host {
27
58
  display: flex;
28
59
  align-items: center;
@@ -83,7 +114,8 @@ DataCardField.styles = [
83
114
  }
84
115
  }
85
116
  `
86
- ];
117
+ ]
118
+ });
87
119
  __decorate([
88
120
  property({ attribute: true })
89
121
  ], DataCardField.prototype, "align", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"data-card-field.js","sourceRoot":"","sources":["../../../src/data-card/data-card-field.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AAI5D,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,UAAU;IAAtC;;QAkEuB,WAAM,GAAgB,WAAW,CAAA;QACjC,WAAM,GAAiB,WAAW,CAAA;QAClC,aAAQ,GAAW,CAAC,CAAC,CAAA;IAkBnD,CAAC;IAfC,MAAM;QACJ,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAE9C,IAAI,EACF,KAAK,EACL,MAAM,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAE,EACrC,GAAG,MAAM,CAAA;QAEV,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;YACvC,OAAO,IAAI,CAAA,UAAU,aAAa,CAAC,MAAM,CAAC,WAAW,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAA;QAC9G,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAA,GAAG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAA;QACvE,CAAC;IACH,CAAC;;AApFM,oBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4DF;CACF,AA9DY,CA8DZ;AAE8B;IAA9B,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;4CAAe;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAkC;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAmC;AAClC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAsB;AACrB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;4CAAe;AArE/B,aAAa;IADzB,aAAa,CAAC,eAAe,CAAC;GAClB,aAAa,CAsFzB","sourcesContent":["import { css, html, LitElement, TemplateResult } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config'\nimport { ColumnConfig, GristRecord } from '../types'\n\n@customElement('ox-card-field')\nexport class DataCardField extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n position: relative;\n\n white-space: nowrap;\n\n font: inherit;\n }\n\n :host([thumbnail]) {\n flex-direction: column;\n justify-content: center;\n }\n\n :host([thumbnail]) > * {\n object-fit: contain;\n max-width: 100%;\n max-height: 100%;\n }\n\n :host > * {\n margin: var(--spacing-none);\n\n overflow: hidden;\n\n text-overflow: ellipsis;\n text-align: left;\n }\n\n :host > *[center] {\n flex: none;\n margin: var(--spacing-none) auto;\n }\n\n :host([name]) label {\n display: none;\n }\n\n label {\n flex: none;\n width: 33%;\n padding-bottom: 2px;\n font: var(--data-card-item-etc-label-font);\n text-transform: capitalize;\n }\n\n :host([name]) > span,\n label + a {\n display: block;\n min-width: 100%;\n }\n\n @media only screen and (max-width: 460px) {\n *[center] {\n margin: initial;\n }\n }\n `\n ]\n\n @property({ attribute: true }) align?: string\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Number }) rowIndex: number = -1\n @property({ type: Object }) value?: object\n\n render(): TemplateResult {\n var { value, column, record, rowIndex } = this\n\n var {\n label,\n record: { renderer: recordRenderer }\n } = column\n\n if (typeof label == 'object') {\n let { renderer: labelRenderer } = label\n return html`<label>${labelRenderer(column)}</label>${recordRenderer(value, column, record, rowIndex, this)}`\n } else {\n return html`${recordRenderer(value, column, record, rowIndex, this)}`\n }\n }\n}\n"]}
1
+ {"version":3,"file":"data-card-field.js","sourceRoot":"","sources":["../../../src/data-card/data-card-field.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AAI/D,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,UAAU;IAAtC;;QAiE0B;;;;;WAAc;QACjB;;;;mBAAsB,WAAW;WAAA;QACjC;;;;mBAAuB,WAAW;WAAA;QAClC;;;;mBAAmB,CAAC,CAAC;WAAA;QACrB;;;;;WAAc;IAiB5C,CAAC;IAfC,MAAM;QACJ,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAE9C,IAAI,EACF,KAAK,EACL,MAAM,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAE,EACrC,GAAG,MAAM,CAAA;QAEV,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;YACvC,OAAO,IAAI,CAAA,UAAU,aAAa,CAAC,MAAM,CAAC,WAAW,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAA;QAC9G,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAA,GAAG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAA;QACvE,CAAC;IACH,CAAC;;AApFM;;;;WAAS;QACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4DF;KACF;EA9DY,CA8DZ;AAE8B;IAA9B,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;4CAAe;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAkC;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAmC;AAClC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAsB;AACrB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;4CAAe;AArE/B,aAAa;IADzB,aAAa,CAAC,eAAe,CAAC;GAClB,aAAa,CAsFzB","sourcesContent":["import { css, html, LitElement, TemplateResult } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js'\nimport { ColumnConfig, GristRecord } from '../types.js'\n\n@customElement('ox-card-field')\nexport class DataCardField extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n position: relative;\n\n white-space: nowrap;\n\n font: inherit;\n }\n\n :host([thumbnail]) {\n flex-direction: column;\n justify-content: center;\n }\n\n :host([thumbnail]) > * {\n object-fit: contain;\n max-width: 100%;\n max-height: 100%;\n }\n\n :host > * {\n margin: var(--spacing-none);\n\n overflow: hidden;\n\n text-overflow: ellipsis;\n text-align: left;\n }\n\n :host > *[center] {\n flex: none;\n margin: var(--spacing-none) auto;\n }\n\n :host([name]) label {\n display: none;\n }\n\n label {\n flex: none;\n width: 33%;\n padding-bottom: 2px;\n font: var(--data-card-item-etc-label-font);\n text-transform: capitalize;\n }\n\n :host([name]) > span,\n label + a {\n display: block;\n min-width: 100%;\n }\n\n @media only screen and (max-width: 460px) {\n *[center] {\n margin: initial;\n }\n }\n `\n ]\n\n @property({ attribute: true }) align?: string\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Number }) rowIndex: number = -1\n @property({ type: Object }) value?: object\n\n render(): TemplateResult {\n var { value, column, record, rowIndex } = this\n\n var {\n label,\n record: { renderer: recordRenderer }\n } = column\n\n if (typeof label == 'object') {\n let { renderer: labelRenderer } = label\n return html`<label>${labelRenderer(column)}</label>${recordRenderer(value, column, record, rowIndex, this)}`\n } else {\n return html`${recordRenderer(value, column, record, rowIndex, this)}`\n }\n }\n}\n"]}
@@ -5,6 +5,45 @@ import { css, html, LitElement } from 'lit';
5
5
  import { customElement, property, query } from 'lit/decorators.js';
6
6
  import { OxPopup } from '@operato/popup';
7
7
  let DataCardGutterMenu = class DataCardGutterMenu extends LitElement {
8
+ constructor() {
9
+ super(...arguments);
10
+ Object.defineProperty(this, "gutters", {
11
+ enumerable: true,
12
+ configurable: true,
13
+ writable: true,
14
+ value: void 0
15
+ });
16
+ Object.defineProperty(this, "rowIndex", {
17
+ enumerable: true,
18
+ configurable: true,
19
+ writable: true,
20
+ value: void 0
21
+ });
22
+ Object.defineProperty(this, "record", {
23
+ enumerable: true,
24
+ configurable: true,
25
+ writable: true,
26
+ value: void 0
27
+ });
28
+ Object.defineProperty(this, "clickHandler", {
29
+ enumerable: true,
30
+ configurable: true,
31
+ writable: true,
32
+ value: void 0
33
+ });
34
+ Object.defineProperty(this, "dblclickHandler", {
35
+ enumerable: true,
36
+ configurable: true,
37
+ writable: true,
38
+ value: void 0
39
+ });
40
+ Object.defineProperty(this, "icon", {
41
+ enumerable: true,
42
+ configurable: true,
43
+ writable: true,
44
+ value: void 0
45
+ });
46
+ }
8
47
  render() {
9
48
  return html `
10
49
  <md-icon @click=${(e) => this.open(e)}>more_horiz</md-icon>
@@ -46,7 +85,11 @@ let DataCardGutterMenu = class DataCardGutterMenu extends LitElement {
46
85
  });
47
86
  }
48
87
  };
49
- DataCardGutterMenu.styles = css `
88
+ Object.defineProperty(DataCardGutterMenu, "styles", {
89
+ enumerable: true,
90
+ configurable: true,
91
+ writable: true,
92
+ value: css `
50
93
  :host {
51
94
  position: relative;
52
95
  }
@@ -71,7 +114,8 @@ DataCardGutterMenu.styles = css `
71
114
  background-color: var(--md-sys-color-primary);
72
115
  color: var(--md-sys-color-on-primary);
73
116
  }
74
- `;
117
+ `
118
+ });
75
119
  __decorate([
76
120
  property({ type: Object })
77
121
  ], DataCardGutterMenu.prototype, "gutters", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"data-card-gutter-menu.js","sourceRoot":"","sources":["../../../src/data-card/data-card-gutter-menu.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AACnC,OAAO,uBAAuB,CAAA;AAE9B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAElE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AAKxC,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,UAAU;IAoCzC,MAAM;QACJ,OAAO,IAAI,CAAA;wBACS,CAAC,CAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;;KAE7C,CAAA;IACH,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAA;QACP,IAAI,CAAC,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,EAAE,CAAC,IAAI,CAAA;;wBAEE,IAAI,CAAC,QAAQ;sBACf,MAAM;sBACN,IAAI,CAAC,MAAM;qBACZ,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC;;;qBAGxB,CAAC,CAAQ,EAAE,EAAE;YACpB,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;YACpB,mBAAmB;QACrB,CAAC;wBACW,CAAC,CAAQ,EAAE,EAAE;YACvB,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAA;YACvB,mBAAmB;QACrB,CAAC;;SAEJ,CACF;KACF,CAAA;IACH,CAAC;IAED,IAAI,CAAC,CAAQ;QACX,CAAC,CAAC,eAAe,EAAE,CAAA;QAEnB,MAAM,MAAM,GAAI,IAAI,CAAC,IAAoB,CAAC,YAAY,CAAA;QACtD,MAAM,IAAI,GAAG,CAAC,CAAC,CAAA;QACf,MAAM,MAAM,GAAG,IAAI,CAAA;QAEnB,OAAO,CAAC,IAAI,CAAC;YACX,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE;YAC3B,MAAM;YACN,IAAI;YACJ,MAAM;SACP,CAAC,CAAA;IACJ,CAAC;;AAhFM,yBAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBlB,AAzBY,CAyBZ;AAE2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAyB;AACxB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;oDAAkB;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAAqB;AACpC;IAAX,QAAQ,EAAE;wDAA6B;AAC5B;IAAX,QAAQ,EAAE;2DAAgC;AAEzB;IAAjB,KAAK,CAAC,SAAS,CAAC;gDAAe;AAlC5B,kBAAkB;IADvB,aAAa,CAAC,qBAAqB,CAAC;GAC/B,kBAAkB,CAkFvB","sourcesContent":["import '@material/web/icon/icon.js'\nimport './data-card-gutter.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { OxPopup } from '@operato/popup'\n\nimport { ColumnConfig, GristRecord } from '../types.js'\n\n@customElement('ox-card-gutter-menu')\nclass DataCardGutterMenu extends LitElement {\n static styles = css`\n :host {\n position: relative;\n }\n\n ::slotted(ox-popup) {\n padding: var(--spacing-small);\n }\n\n md-icon {\n flex: 1;\n margin: var(--spacing-none);\n border: var(--data-card-item-btn-border);\n border-radius: var(--data-card-item-btn-border-radius);\n padding: var(--data-card-item-btn-padding);\n font-size: var(--md-sys-typescale-label-large-size, 0.875rem);\n background-color: transparent;\n color: var(--grid-record-color);\n }\n\n md-icon:hover {\n cursor: pointer;\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n }\n `\n\n @property({ type: Object }) gutters!: ColumnConfig[]\n @property({ type: Number }) rowIndex!: number\n @property({ type: Object }) record!: GristRecord\n @property() clickHandler!: EventListener\n @property() dblclickHandler!: EventListener\n\n @query('md-icon') icon!: Element\n\n render() {\n return html`\n <md-icon @click=${(e: Event) => this.open(e)}>more_horiz</md-icon>\n <slot></slot>\n `\n }\n\n menuRender() {\n return html`\n ${this.gutters.map(\n gutter => html`\n <ox-card-gutter\n .rowIndex=${this.rowIndex}\n .column=${gutter}\n .record=${this.record}\n .value=${this.record[gutter.name]}\n menu\n alive-on-select\n @click=${(e: Event) => {\n this.clickHandler(e)\n // TODO close popup\n }}\n @dblclick=${(e: Event) => {\n this.dblclickHandler(e)\n // TODO close popup\n }}\n ></ox-card-gutter>\n `\n )}\n `\n }\n\n open(e: Event) {\n e.stopPropagation()\n\n const bottom = (this.icon as HTMLElement).offsetHeight\n const left = -4\n const parent = this\n\n OxPopup.open({\n template: this.menuRender(),\n bottom,\n left,\n parent\n })\n }\n}\n"]}
1
+ {"version":3,"file":"data-card-gutter-menu.js","sourceRoot":"","sources":["../../../src/data-card/data-card-gutter-menu.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AACnC,OAAO,uBAAuB,CAAA;AAE9B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAElE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AAKxC,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,UAAU;IAA3C;;QA4B8B;;;;;WAAwB;QACxB;;;;;WAAiB;QACjB;;;;;WAAoB;QACpC;;;;;WAA4B;QAC5B;;;;;WAA+B;QAEzB;;;;;WAAc;IAgDlC,CAAC;IA9CC,MAAM;QACJ,OAAO,IAAI,CAAA;wBACS,CAAC,CAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;;KAE7C,CAAA;IACH,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAA;QACP,IAAI,CAAC,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,EAAE,CAAC,IAAI,CAAA;;wBAEE,IAAI,CAAC,QAAQ;sBACf,MAAM;sBACN,IAAI,CAAC,MAAM;qBACZ,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC;;;qBAGxB,CAAC,CAAQ,EAAE,EAAE;YACpB,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;YACpB,mBAAmB;QACrB,CAAC;wBACW,CAAC,CAAQ,EAAE,EAAE;YACvB,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAA;YACvB,mBAAmB;QACrB,CAAC;;SAEJ,CACF;KACF,CAAA;IACH,CAAC;IAED,IAAI,CAAC,CAAQ;QACX,CAAC,CAAC,eAAe,EAAE,CAAA;QAEnB,MAAM,MAAM,GAAI,IAAI,CAAC,IAAoB,CAAC,YAAY,CAAA;QACtD,MAAM,IAAI,GAAG,CAAC,CAAC,CAAA;QACf,MAAM,MAAM,GAAG,IAAI,CAAA;QAEnB,OAAO,CAAC,IAAI,CAAC;YACX,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE;YAC3B,MAAM;YACN,IAAI;YACJ,MAAM;SACP,CAAC,CAAA;IACJ,CAAC;;AAhFM;;;;WAAS,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBlB;EAzBY,CAyBZ;AAE2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAyB;AACxB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;oDAAkB;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAAqB;AACpC;IAAX,QAAQ,EAAE;wDAA6B;AAC5B;IAAX,QAAQ,EAAE;2DAAgC;AAEzB;IAAjB,KAAK,CAAC,SAAS,CAAC;gDAAe;AAlC5B,kBAAkB;IADvB,aAAa,CAAC,qBAAqB,CAAC;GAC/B,kBAAkB,CAkFvB","sourcesContent":["import '@material/web/icon/icon.js'\nimport './data-card-gutter.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { OxPopup } from '@operato/popup'\n\nimport { ColumnConfig, GristRecord } from '../types.js'\n\n@customElement('ox-card-gutter-menu')\nclass DataCardGutterMenu extends LitElement {\n static styles = css`\n :host {\n position: relative;\n }\n\n ::slotted(ox-popup) {\n padding: var(--spacing-small);\n }\n\n md-icon {\n flex: 1;\n margin: var(--spacing-none);\n border: var(--data-card-item-btn-border);\n border-radius: var(--data-card-item-btn-border-radius);\n padding: var(--data-card-item-btn-padding);\n font-size: var(--md-sys-typescale-label-large-size, 0.875rem);\n background-color: transparent;\n color: var(--grid-record-color);\n }\n\n md-icon:hover {\n cursor: pointer;\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n }\n `\n\n @property({ type: Object }) gutters!: ColumnConfig[]\n @property({ type: Number }) rowIndex!: number\n @property({ type: Object }) record!: GristRecord\n @property() clickHandler!: EventListener\n @property() dblclickHandler!: EventListener\n\n @query('md-icon') icon!: Element\n\n render() {\n return html`\n <md-icon @click=${(e: Event) => this.open(e)}>more_horiz</md-icon>\n <slot></slot>\n `\n }\n\n menuRender() {\n return html`\n ${this.gutters.map(\n gutter => html`\n <ox-card-gutter\n .rowIndex=${this.rowIndex}\n .column=${gutter}\n .record=${this.record}\n .value=${this.record[gutter.name]}\n menu\n alive-on-select\n @click=${(e: Event) => {\n this.clickHandler(e)\n // TODO close popup\n }}\n @dblclick=${(e: Event) => {\n this.dblclickHandler(e)\n // TODO close popup\n }}\n ></ox-card-gutter>\n `\n )}\n `\n }\n\n open(e: Event) {\n e.stopPropagation()\n\n const bottom = (this.icon as HTMLElement).offsetHeight\n const left = -4\n const parent = this\n\n OxPopup.open({\n template: this.menuRender(),\n bottom,\n left,\n parent\n })\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
- import { ColumnConfig, GristRecord } from '../types';
2
+ import { ColumnConfig, GristRecord } from '../types.js';
3
3
  export declare class DataCardGutter extends LitElement {
4
4
  static styles: import("lit").CSSResult[];
5
5
  align?: string;
@@ -1,13 +1,40 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { css, html, LitElement } from 'lit';
3
3
  import { customElement, property } from 'lit/decorators.js';
4
- import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config';
4
+ import { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js';
5
5
  let DataCardGutter = class DataCardGutter extends LitElement {
6
6
  constructor() {
7
7
  super(...arguments);
8
- this.record = ZERO_RECORD;
9
- this.column = ZERO_COLUMN;
10
- this.rowIndex = -1;
8
+ Object.defineProperty(this, "align", {
9
+ enumerable: true,
10
+ configurable: true,
11
+ writable: true,
12
+ value: void 0
13
+ });
14
+ Object.defineProperty(this, "record", {
15
+ enumerable: true,
16
+ configurable: true,
17
+ writable: true,
18
+ value: ZERO_RECORD
19
+ });
20
+ Object.defineProperty(this, "column", {
21
+ enumerable: true,
22
+ configurable: true,
23
+ writable: true,
24
+ value: ZERO_COLUMN
25
+ });
26
+ Object.defineProperty(this, "rowIndex", {
27
+ enumerable: true,
28
+ configurable: true,
29
+ writable: true,
30
+ value: -1
31
+ });
32
+ Object.defineProperty(this, "value", {
33
+ enumerable: true,
34
+ configurable: true,
35
+ writable: true,
36
+ value: void 0
37
+ });
11
38
  }
12
39
  render() {
13
40
  if (!this.column) {
@@ -36,8 +63,12 @@ let DataCardGutter = class DataCardGutter extends LitElement {
36
63
  }
37
64
  }
38
65
  };
39
- DataCardGutter.styles = [
40
- css `
66
+ Object.defineProperty(DataCardGutter, "styles", {
67
+ enumerable: true,
68
+ configurable: true,
69
+ writable: true,
70
+ value: [
71
+ css `
41
72
  :host {
42
73
  display: flex;
43
74
  background-color: transparent;
@@ -93,7 +124,8 @@ DataCardGutter.styles = [
93
124
  background-color: unset;
94
125
  }
95
126
  `
96
- ];
127
+ ]
128
+ });
97
129
  __decorate([
98
130
  property({ attribute: true })
99
131
  ], DataCardGutter.prototype, "align", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"data-card-gutter.js","sourceRoot":"","sources":["../../../src/data-card/data-card-gutter.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAkC,MAAM,KAAK,CAAA;AAC3E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AAI5D,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,UAAU;IAAvC;;QA6DuB,WAAM,GAAgB,WAAW,CAAA;QACjC,WAAM,GAAiB,WAAW,CAAA;QAClC,aAAQ,GAAW,CAAC,CAAC,CAAA;IAgCnD,CAAC;IA7BC,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,OAAO,IAAI,CAAA,EAAE,CAAA;QACf,CAAC;QAED,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAC9C,IAAI,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC,MAAM,CAAA;QAEhC,oEAAoE;QACpE,OAAO,IAAI,CAAA,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAA;IACnE,CAAC;IAED,OAAO,CAAC,OAA6B;QACnC,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAA;YAE1C,IAAI,UAAU,IAAI,cAAc,EAAE,CAAC;gBACjC,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,EAAE,CAAC,CAAA;YACvC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,CAAA;YACtC,CAAC;YAED,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAA;YACjC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;YAChC,CAAC;QACH,CAAC;IACH,CAAC;;AA7FM,qBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAuDF;CACF,AAzDY,CAyDZ;AAE8B;IAA9B,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;6CAAe;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAAkC;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAAmC;AAClC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;gDAAsB;AACrB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAe;AAhE/B,cAAc;IAD1B,aAAa,CAAC,gBAAgB,CAAC;GACnB,cAAc,CA+F1B","sourcesContent":["import { css, html, LitElement, PropertyValues, TemplateResult } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config'\nimport { ColumnConfig, GristRecord } from '../types'\n\n@customElement('ox-card-gutter')\nexport class DataCardGutter extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n background-color: transparent;\n align-content: center;\n align-items: center;\n text-overflow: ellipsis;\n }\n\n :host([row-selector]) {\n margin-right: auto;\n }\n\n * {\n border: 0;\n font-size: var(--md-sys-typescale-label-medium-size, 0.8rem);\n line-height: var(--md-sys-typescale-label-medium-size, 0.8rem);\n\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n border-radius: var(--data-card-item-btn-border-radius, var(--md-sys-shape-corner-tiny));\n\n padding: var(--spacing-small);\n }\n\n *:hover {\n cursor: pointer;\n color: var(--md-sys-color-on-secondary);\n background-color: var(--md-sys-color-secondary);\n }\n\n :host([danger]) button {\n color: var(--md-sys-color-on-error);\n background-color: var(--md-sys-color-error);\n border-color: var(--md-sys-color-error);\n }\n\n :host([danger]) button:hover {\n color: var(--md-sys-color-error);\n background-color: var(--md-sys-color-on-secondary);\n border-color: var(--md-sys-color-on-secondary);\n }\n\n button {\n display: flex;\n gap: var(--spacing-small);\n border: 0;\n align-items: center;\n }\n\n button md-icon {\n border: 0;\n padding: 0;\n background-color: unset;\n }\n `\n ]\n\n @property({ attribute: true }) align?: string\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Number }) rowIndex: number = -1\n @property({ type: Object }) value?: object\n\n render(): TemplateResult {\n if (!this.column) {\n return html``\n }\n\n var { value, column, record, rowIndex } = this\n var { renderer } = column.record\n\n /* renderer가 html template이 아니고 단순한 값인 경우가 있으므로, html 템플릿으로 감싸준다. */\n return html` ${renderer(value, column, record, rowIndex, this)} `\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('column')) {\n const { gutterName, danger } = this.column\n\n if (gutterName == 'row-selector') {\n this.setAttribute('row-selector', '')\n } else {\n this.removeAttribute('row-selector')\n }\n\n if (danger) {\n this.setAttribute('danger', '')\n } else {\n this.removeAttribute('danger')\n }\n }\n }\n}\n"]}
1
+ {"version":3,"file":"data-card-gutter.js","sourceRoot":"","sources":["../../../src/data-card/data-card-gutter.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAkC,MAAM,KAAK,CAAA;AAC3E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AAI/D,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,UAAU;IAAvC;;QA4D0B;;;;;WAAc;QACjB;;;;mBAAsB,WAAW;WAAA;QACjC;;;;mBAAuB,WAAW;WAAA;QAClC;;;;mBAAmB,CAAC,CAAC;WAAA;QACrB;;;;;WAAc;IA+B5C,CAAC;IA7BC,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,OAAO,IAAI,CAAA,EAAE,CAAA;QACf,CAAC;QAED,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAC9C,IAAI,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC,MAAM,CAAA;QAEhC,oEAAoE;QACpE,OAAO,IAAI,CAAA,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAA;IACnE,CAAC;IAED,OAAO,CAAC,OAA6B;QACnC,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAA;YAE1C,IAAI,UAAU,IAAI,cAAc,EAAE,CAAC;gBACjC,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,EAAE,CAAC,CAAA;YACvC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,CAAA;YACtC,CAAC;YAED,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAA;YACjC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;YAChC,CAAC;QACH,CAAC;IACH,CAAC;;AA7FM;;;;WAAS;QACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAuDF;KACF;EAzDY,CAyDZ;AAE8B;IAA9B,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;6CAAe;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAAkC;AACjC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAAmC;AAClC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;gDAAsB;AACrB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAe;AAhE/B,cAAc;IAD1B,aAAa,CAAC,gBAAgB,CAAC;GACnB,cAAc,CA+F1B","sourcesContent":["import { css, html, LitElement, PropertyValues, TemplateResult } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config.js'\nimport { ColumnConfig, GristRecord } from '../types.js'\n\n@customElement('ox-card-gutter')\nexport class DataCardGutter extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n background-color: transparent;\n align-content: center;\n align-items: center;\n text-overflow: ellipsis;\n }\n\n :host([row-selector]) {\n margin-right: auto;\n }\n\n * {\n border: 0;\n font-size: var(--md-sys-typescale-label-medium-size, 0.8rem);\n line-height: var(--md-sys-typescale-label-medium-size, 0.8rem);\n\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n border-radius: var(--data-card-item-btn-border-radius, var(--md-sys-shape-corner-tiny));\n\n padding: var(--spacing-small);\n }\n\n *:hover {\n cursor: pointer;\n color: var(--md-sys-color-on-secondary);\n background-color: var(--md-sys-color-secondary);\n }\n\n :host([danger]) button {\n color: var(--md-sys-color-on-error);\n background-color: var(--md-sys-color-error);\n border-color: var(--md-sys-color-error);\n }\n\n :host([danger]) button:hover {\n color: var(--md-sys-color-error);\n background-color: var(--md-sys-color-on-secondary);\n border-color: var(--md-sys-color-on-secondary);\n }\n\n button {\n display: flex;\n gap: var(--spacing-small);\n border: 0;\n align-items: center;\n }\n\n button md-icon {\n border: 0;\n padding: 0;\n background-color: unset;\n }\n `\n ]\n\n @property({ attribute: true }) align?: string\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Number }) rowIndex: number = -1\n @property({ type: Object }) value?: object\n\n render(): TemplateResult {\n if (!this.column) {\n return html``\n }\n\n var { value, column, record, rowIndex } = this\n var { renderer } = column.record\n\n /* renderer가 html template이 아니고 단순한 값인 경우가 있으므로, html 템플릿으로 감싸준다. */\n return html` ${renderer(value, column, record, rowIndex, this)} `\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('column')) {\n const { gutterName, danger } = this.column\n\n if (gutterName == 'row-selector') {\n this.setAttribute('row-selector', '')\n } else {\n this.removeAttribute('row-selector')\n }\n\n if (danger) {\n this.setAttribute('danger', '')\n } else {\n this.removeAttribute('danger')\n }\n }\n }\n}\n"]}
@@ -1,8 +1,8 @@
1
1
  import '@material/web/icon/icon.js';
2
- import '../empty-note';
3
- import './record-card';
2
+ import '../empty-note.js';
3
+ import './record-card.js';
4
4
  import { PropertyValues } from 'lit';
5
- import { DataManipulator } from '../data-manipulator';
5
+ import { DataManipulator } from '../data-manipulator.js';
6
6
  export declare class DataCard extends DataManipulator {
7
7
  static styles: import("lit").CSSResult[];
8
8
  empty?: boolean;
@@ -1,18 +1,49 @@
1
1
  import { __decorate } from "tslib";
2
2
  import '@material/web/icon/icon.js';
3
- import '../empty-note';
4
- import './record-card';
3
+ import '../empty-note.js';
4
+ import './record-card.js';
5
5
  import { css, html } from 'lit';
6
6
  import { customElement, property, state } from 'lit/decorators.js';
7
- import { DataManipulator } from '../data-manipulator';
7
+ import { DataManipulator } from '../data-manipulator.js';
8
8
  let DataCard = class DataCard extends DataManipulator {
9
9
  constructor() {
10
10
  super(...arguments);
11
- this._records = [];
12
- this.isTop = false;
13
- this._total = 0;
14
- this._limit = 20;
15
- this._page = 1;
11
+ Object.defineProperty(this, "empty", {
12
+ enumerable: true,
13
+ configurable: true,
14
+ writable: true,
15
+ value: void 0
16
+ });
17
+ Object.defineProperty(this, "_records", {
18
+ enumerable: true,
19
+ configurable: true,
20
+ writable: true,
21
+ value: []
22
+ });
23
+ Object.defineProperty(this, "isTop", {
24
+ enumerable: true,
25
+ configurable: true,
26
+ writable: true,
27
+ value: false
28
+ });
29
+ Object.defineProperty(this, "_total", {
30
+ enumerable: true,
31
+ configurable: true,
32
+ writable: true,
33
+ value: 0
34
+ });
35
+ Object.defineProperty(this, "_limit", {
36
+ enumerable: true,
37
+ configurable: true,
38
+ writable: true,
39
+ value: 20
40
+ });
41
+ Object.defineProperty(this, "_page", {
42
+ enumerable: true,
43
+ configurable: true,
44
+ writable: true,
45
+ value: 1
46
+ });
16
47
  }
17
48
  firstUpdated(changes) {
18
49
  this.isTop = true;
@@ -79,8 +110,12 @@ let DataCard = class DataCard extends DataManipulator {
79
110
  return this;
80
111
  }
81
112
  };
82
- DataCard.styles = [
83
- css `
113
+ Object.defineProperty(DataCard, "styles", {
114
+ enumerable: true,
115
+ configurable: true,
116
+ writable: true,
117
+ value: [
118
+ css `
84
119
  :host {
85
120
  overflow-y: auto;
86
121
  padding: var(--spacing-medium);
@@ -132,7 +167,8 @@ DataCard.styles = [
132
167
  }
133
168
  }
134
169
  `
135
- ];
170
+ ]
171
+ });
136
172
  __decorate([
137
173
  property({ type: Boolean })
138
174
  ], DataCard.prototype, "empty", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"data-card.js","sourceRoot":"","sources":["../../../src/data-card/data-card.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '../empty-note'\nimport './record-card'\n\nimport { PropertyValues, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { DataManipulator } from '../data-manipulator'\nimport { GristRecord } from '../types'\n\n@customElement('ox-card')\nexport class DataCard extends DataManipulator {\n static styles = [\n css`\n :host {\n overflow-y: auto;\n padding: var(--spacing-medium);\n\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));\n grid-template-rows: min-content;\n grid-gap: var(--spacing-large);\n }\n\n [selected-row] {\n background-color: var(--grid-record-selected-background-color);\n }\n\n #upward {\n --md-icon-size: var(--icon-size-large);\n position: absolute;\n top: var(--data-card-fab-position-vertical);\n right: var(--data-card-fab-position-horizontal);\n background-color: rgba(255, 255, 255, 0.7);\n border-radius: var(--md-sys-shape-corner-large);\n color: var(--data-card-fab-color);\n box-shadow: var(--data-card-fab-shadow);\n padding: var(--spacing-small);\n }\n\n slot {\n width: 100%;\n }\n\n ox-empty-note {\n display: block;\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n }\n\n [card][emphasized-row],\n [card][emphasized-row][focused] {\n background-color: var(--grid-record-emphasized-background-color);\n color: var(--grid-record-emphasized-color);\n }\n\n @media screen and (max-width: 460px) {\n #setting {\n grid-template-columns: 1fr;\n grid-template-rows: 1fr 1fr;\n }\n }\n `\n ]\n\n @property({ type: Boolean }) empty?: boolean\n\n @state() private _records: GristRecord[] = []\n @state() private isTop: boolean = false\n\n private _total: number = 0\n private _limit: number = 20\n private _page: number = 1\n\n firstUpdated(changes: PropertyValues<this>) {\n this.isTop = true\n\n /* infinite scrolling */\n this.addEventListener('scroll', e => {\n const totalScrollHeight = this.scrollHeight\n const screenHeight = this.offsetHeight\n const currentScrollTop = this.scrollTop\n\n if (totalScrollHeight <= screenHeight + currentScrollTop + 1) {\n /* 마지막 페이지까지 계속 페이지를 증가시킨다. */\n var lastPage = Math.ceil(this._total / this._limit)\n\n if (this._page < lastPage) {\n this.dispatchEvent(new CustomEvent('attach-page', { bubbles: true, composed: true }))\n }\n }\n\n this.isTop = this.scrollTop == 0\n })\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('config')) {\n this._records = []\n this._page = 1\n }\n\n if (changes.has('data')) {\n this._records = this.data.records\n this._total = this.data.total || 0\n this._limit = this.data.limit || 20\n this._page = this.data.page || 0\n }\n }\n\n render() {\n var { classifier } = this.config.rows\n var records = this._records || []\n\n if (this.config && this.config.rows.appendable) {\n records = [...records, { __dirty__: '+' }]\n }\n\n return html`\n ${records.map((record, rowIndex) => {\n var { emphasized } = classifier.call(null, record, rowIndex) || {}\n\n return html`\n <ox-record-card\n .config=${this.config}\n .data=${this.data}\n .record=${record}\n .rowIndex=${rowIndex}\n .emphasized=${emphasized}\n ?selected-row=${record['__selected__']}\n ?dirty=${record['__dirty__']}\n card\n ></ox-record-card>\n `\n })}\n ${this.empty ? html` <ox-empty-note title=\"NO RECORDS\"></ox-empty-note> ` : html``}\n ${this.isTop\n ? html``\n : html` <md-icon id=\"upward\" @click=${(e: Event) => this.gotoTop(e)}>arrow_upward</md-icon> `}\n `\n }\n\n gotoTop(e: Event) {\n this.scrollTop = 0\n\n e.stopPropagation()\n }\n\n get pullToRefreshTarget() {\n return this\n }\n}\n"]}
1
+ {"version":3,"file":"data-card.js","sourceRoot":"","sources":["../../../src/data-card/data-card.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '../empty-note.js'\nimport './record-card.js'\n\nimport { PropertyValues, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { DataManipulator } from '../data-manipulator.js'\nimport { GristRecord } from '../types.js'\n\n@customElement('ox-card')\nexport class DataCard extends DataManipulator {\n static styles = [\n css`\n :host {\n overflow-y: auto;\n padding: var(--spacing-medium);\n\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));\n grid-template-rows: min-content;\n grid-gap: var(--spacing-large);\n }\n\n [selected-row] {\n background-color: var(--grid-record-selected-background-color);\n }\n\n #upward {\n --md-icon-size: var(--icon-size-large);\n position: absolute;\n top: var(--data-card-fab-position-vertical);\n right: var(--data-card-fab-position-horizontal);\n background-color: rgba(255, 255, 255, 0.7);\n border-radius: var(--md-sys-shape-corner-large);\n color: var(--data-card-fab-color);\n box-shadow: var(--data-card-fab-shadow);\n padding: var(--spacing-small);\n }\n\n slot {\n width: 100%;\n }\n\n ox-empty-note {\n display: block;\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n }\n\n [card][emphasized-row],\n [card][emphasized-row][focused] {\n background-color: var(--grid-record-emphasized-background-color);\n color: var(--grid-record-emphasized-color);\n }\n\n @media screen and (max-width: 460px) {\n #setting {\n grid-template-columns: 1fr;\n grid-template-rows: 1fr 1fr;\n }\n }\n `\n ]\n\n @property({ type: Boolean }) empty?: boolean\n\n @state() private _records: GristRecord[] = []\n @state() private isTop: boolean = false\n\n private _total: number = 0\n private _limit: number = 20\n private _page: number = 1\n\n firstUpdated(changes: PropertyValues<this>) {\n this.isTop = true\n\n /* infinite scrolling */\n this.addEventListener('scroll', e => {\n const totalScrollHeight = this.scrollHeight\n const screenHeight = this.offsetHeight\n const currentScrollTop = this.scrollTop\n\n if (totalScrollHeight <= screenHeight + currentScrollTop + 1) {\n /* 마지막 페이지까지 계속 페이지를 증가시킨다. */\n var lastPage = Math.ceil(this._total / this._limit)\n\n if (this._page < lastPage) {\n this.dispatchEvent(new CustomEvent('attach-page', { bubbles: true, composed: true }))\n }\n }\n\n this.isTop = this.scrollTop == 0\n })\n }\n\n updated(changes: PropertyValues<this>) {\n if (changes.has('config')) {\n this._records = []\n this._page = 1\n }\n\n if (changes.has('data')) {\n this._records = this.data.records\n this._total = this.data.total || 0\n this._limit = this.data.limit || 20\n this._page = this.data.page || 0\n }\n }\n\n render() {\n var { classifier } = this.config.rows\n var records = this._records || []\n\n if (this.config && this.config.rows.appendable) {\n records = [...records, { __dirty__: '+' }]\n }\n\n return html`\n ${records.map((record, rowIndex) => {\n var { emphasized } = classifier.call(null, record, rowIndex) || {}\n\n return html`\n <ox-record-card\n .config=${this.config}\n .data=${this.data}\n .record=${record}\n .rowIndex=${rowIndex}\n .emphasized=${emphasized}\n ?selected-row=${record['__selected__']}\n ?dirty=${record['__dirty__']}\n card\n ></ox-record-card>\n `\n })}\n ${this.empty ? html` <ox-empty-note title=\"NO RECORDS\"></ox-empty-note> ` : html``}\n ${this.isTop\n ? html``\n : html` <md-icon id=\"upward\" @click=${(e: Event) => this.gotoTop(e)}>arrow_upward</md-icon> `}\n `\n }\n\n gotoTop(e: Event) {\n this.scrollTop = 0\n\n e.stopPropagation()\n }\n\n get pullToRefreshTarget() {\n return this\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { RecordCard } from '../record-card';
1
+ import { RecordCard } from '../record-card.js';
2
2
  /**
3
3
  * ox-record-card 의 click handler
4
4
  *
@@ -1 +1 @@
1
- {"version":3,"file":"record-card-click-handler.js","sourceRoot":"","sources":["../../../../src/data-card/event-handlers/record-card-click-handler.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,MAAM,UAAU,sBAAsB,CAAmB,CAAa;IACpE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,uEAAuE;IACvE,IAAI,MAAM,GAAI,CAAC,CAAC,MAAkB,CAAC,OAAO,CAAC,+BAA+B,CAAmC,CAAA;IAC7G,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,EAAE,CAAA;IAEvC,6BAA6B;IAC7B,IAAI,MAAM,EAAE,CAAC;QACX,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAA;QAC/B,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;YAC5E,OAAM;QACR,CAAC;IACH,CAAC;IAED,2BAA2B;IAC3B,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAA;IACpD,IAAI,SAAS,EAAE,CAAC;QACd,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IAClF,CAAC;SAAM,CAAC;QACN,uCAAuC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,EAAE,CAAA;IACrD,CAAC;AACH,CAAC","sourcesContent":["import { DataCardField } from '../data-card-field'\nimport { DataCardGutter } from '../data-card-gutter'\nimport { RecordCard } from '../record-card'\n\n/**\n * ox-record-card 의 click handler\n *\n * - handler의 this 는 ox-record-card임.\n */\nexport function recordCardClickHandler(this: RecordCard, e: MouseEvent): void {\n e.stopPropagation()\n\n /* target should be [content] or 'ox-card-field' or 'ox-card-gutter' */\n var target = (e.target as Element).closest('ox-card-field, ox-card-gutter') as DataCardField | DataCardGutter\n var { column, rowIndex } = target || {}\n\n /* do column click handler */\n if (column) {\n var { click } = column.handlers\n if (click) {\n click(this.config.columns, this.data, column, this.record, rowIndex, target)\n return\n }\n }\n\n /* do rows click handler */\n var { click: rowsClick } = this.config.rows.handlers\n if (rowsClick) {\n rowsClick(this.config.columns, this.data, column, this.record, rowIndex, target)\n } else {\n /* content 가 클릭된 경우 - 레코드뷰 팝업을 실행한다. */\n this.config.rows.editable && this.popupRecordView()\n }\n}\n"]}
1
+ {"version":3,"file":"record-card-click-handler.js","sourceRoot":"","sources":["../../../../src/data-card/event-handlers/record-card-click-handler.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,MAAM,UAAU,sBAAsB,CAAmB,CAAa;IACpE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,uEAAuE;IACvE,IAAI,MAAM,GAAI,CAAC,CAAC,MAAkB,CAAC,OAAO,CAAC,+BAA+B,CAAmC,CAAA;IAC7G,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,EAAE,CAAA;IAEvC,6BAA6B;IAC7B,IAAI,MAAM,EAAE,CAAC;QACX,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAA;QAC/B,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;YAC5E,OAAM;QACR,CAAC;IACH,CAAC;IAED,2BAA2B;IAC3B,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAA;IACpD,IAAI,SAAS,EAAE,CAAC;QACd,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IAClF,CAAC;SAAM,CAAC;QACN,uCAAuC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,EAAE,CAAA;IACrD,CAAC;AACH,CAAC","sourcesContent":["import { DataCardField } from '../data-card-field.js'\nimport { DataCardGutter } from '../data-card-gutter.js'\nimport { RecordCard } from '../record-card.js'\n\n/**\n * ox-record-card 의 click handler\n *\n * - handler의 this 는 ox-record-card임.\n */\nexport function recordCardClickHandler(this: RecordCard, e: MouseEvent): void {\n e.stopPropagation()\n\n /* target should be [content] or 'ox-card-field' or 'ox-card-gutter' */\n var target = (e.target as Element).closest('ox-card-field, ox-card-gutter') as DataCardField | DataCardGutter\n var { column, rowIndex } = target || {}\n\n /* do column click handler */\n if (column) {\n var { click } = column.handlers\n if (click) {\n click(this.config.columns, this.data, column, this.record, rowIndex, target)\n return\n }\n }\n\n /* do rows click handler */\n var { click: rowsClick } = this.config.rows.handlers\n if (rowsClick) {\n rowsClick(this.config.columns, this.data, column, this.record, rowIndex, target)\n } else {\n /* content 가 클릭된 경우 - 레코드뷰 팝업을 실행한다. */\n this.config.rows.editable && this.popupRecordView()\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { RecordCard } from '../record-card';
1
+ import { RecordCard } from '../record-card.js';
2
2
  /**
3
3
  * ox-record-card 의 dblclick handler
4
4
  *
@@ -1 +1 @@
1
- {"version":3,"file":"record-card-dblclick-handler.js","sourceRoot":"","sources":["../../../../src/data-card/event-handlers/record-card-dblclick-handler.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,MAAM,UAAU,yBAAyB,CAAmB,CAAa;IACvE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,uEAAuE;IACvE,IAAI,MAAM,GAAI,CAAC,CAAC,MAAkB,CAAC,OAAO,CAAC,+BAA+B,CAAmC,CAAA;IAE7G,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,EAAE,CAAA;IAE/C,IAAI,MAAM,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE,CAAC;QACtC;;;;WAIG;QACH,6BAA6B;QAC7B,qCAAqC;QACrC,kFAAkF;QAClF,SAAS;IACX,CAAC;SAAM,CAAC;QACN,IAAI,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAA;QAC1D,IAAI,YAAY,EAAE,CAAC;YACjB,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;QAChF,CAAC;IACH,CAAC;AACH,CAAC","sourcesContent":["import { DataCardField } from '../data-card-field'\nimport { DataCardGutter } from '../data-card-gutter'\nimport { RecordCard } from '../record-card'\n\n/**\n * ox-record-card 의 dblclick handler\n *\n * - handler의 this 는 ox-record-card임.\n */\nexport function recordCardDblClickHandler(this: RecordCard, e: MouseEvent): void {\n e.stopPropagation()\n\n /* target should be [content] or 'ox-card-field' or 'ox-card-gutter' */\n var target = (e.target as Element).closest('ox-card-field, ox-card-gutter') as DataCardField | DataCardGutter\n\n var { column, record, rowIndex } = target || {}\n\n if (column && column.type == 'gutter') {\n /*\n * Gutter가 클릭된 경우\n * TODO ox-record-card의 dblclick handling의 성능을 확인하고,\n * gutter에 dblclick를 적용할 수 있는 지 확인한 후에 활성화하자.\n */\n /* do column click handler */\n // var { dblclick } = column.handlers\n // dblclick && dblclick(this.columns, this.data, column, record, rowIndex, target)\n // return\n } else {\n var { dblclick: rowsDblClick } = this.config.rows.handlers\n if (rowsDblClick) {\n rowsDblClick(this.config.columns, this.data, column, record, rowIndex, target)\n }\n }\n}\n"]}
1
+ {"version":3,"file":"record-card-dblclick-handler.js","sourceRoot":"","sources":["../../../../src/data-card/event-handlers/record-card-dblclick-handler.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,MAAM,UAAU,yBAAyB,CAAmB,CAAa;IACvE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,uEAAuE;IACvE,IAAI,MAAM,GAAI,CAAC,CAAC,MAAkB,CAAC,OAAO,CAAC,+BAA+B,CAAmC,CAAA;IAE7G,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,EAAE,CAAA;IAE/C,IAAI,MAAM,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE,CAAC;QACtC;;;;WAIG;QACH,6BAA6B;QAC7B,qCAAqC;QACrC,kFAAkF;QAClF,SAAS;IACX,CAAC;SAAM,CAAC;QACN,IAAI,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAA;QAC1D,IAAI,YAAY,EAAE,CAAC;YACjB,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;QAChF,CAAC;IACH,CAAC;AACH,CAAC","sourcesContent":["import { DataCardField } from '../data-card-field.js'\nimport { DataCardGutter } from '../data-card-gutter.js'\nimport { RecordCard } from '../record-card.js'\n\n/**\n * ox-record-card 의 dblclick handler\n *\n * - handler의 this 는 ox-record-card임.\n */\nexport function recordCardDblClickHandler(this: RecordCard, e: MouseEvent): void {\n e.stopPropagation()\n\n /* target should be [content] or 'ox-card-field' or 'ox-card-gutter' */\n var target = (e.target as Element).closest('ox-card-field, ox-card-gutter') as DataCardField | DataCardGutter\n\n var { column, record, rowIndex } = target || {}\n\n if (column && column.type == 'gutter') {\n /*\n * Gutter가 클릭된 경우\n * TODO ox-record-card의 dblclick handling의 성능을 확인하고,\n * gutter에 dblclick를 적용할 수 있는 지 확인한 후에 활성화하자.\n */\n /* do column click handler */\n // var { dblclick } = column.handlers\n // dblclick && dblclick(this.columns, this.data, column, record, rowIndex, target)\n // return\n } else {\n var { dblclick: rowsDblClick } = this.config.rows.handlers\n if (rowsDblClick) {\n rowsDblClick(this.config.columns, this.data, column, record, rowIndex, target)\n }\n }\n}\n"]}
@@ -1,10 +1,10 @@
1
1
  import '@material/web/icon/icon.js';
2
- import './data-card-field';
3
- import '../record-view';
4
- import './data-card-gutter';
5
- import './data-card-gutter-menu';
6
- import { GristConfig, GristData, GristRecord } from '../types';
2
+ import '../record-view/record-view.js';
3
+ import './data-card-field.js';
4
+ import './data-card-gutter.js';
5
+ import './data-card-gutter-menu.js';
7
6
  import { LitElement, PropertyValues } from 'lit';
7
+ import { GristConfig, GristData, GristRecord } from '../types.js';
8
8
  export declare class RecordCard extends LitElement {
9
9
  static styles: import("lit").CSSResult[];
10
10
  config: GristConfig;
@@ -1,15 +1,15 @@
1
1
  import { __decorate } from "tslib";
2
2
  import '@material/web/icon/icon.js';
3
- import './data-card-field';
4
- import '../record-view';
5
- import './data-card-gutter';
6
- import './data-card-gutter-menu';
3
+ import '../record-view/record-view.js';
4
+ import './data-card-field.js';
5
+ import './data-card-gutter.js';
6
+ import './data-card-gutter-menu.js';
7
7
  import { LitElement, css, html } from 'lit';
8
- import { ZERO_CONFIG, ZERO_DATA, ZERO_RECORD } from '../configure/zero-config';
9
8
  import { customElement, property } from 'lit/decorators.js';
10
- import { RecordViewHandler } from '../record-view/record-view-handler';
11
- import { recordCardClickHandler } from './event-handlers/record-card-click-handler';
12
- import { recordCardDblClickHandler } from './event-handlers/record-card-dblclick-handler';
9
+ import { ZERO_CONFIG, ZERO_DATA, ZERO_RECORD } from '../configure/zero-config.js';
10
+ import { RecordViewHandler } from '../record-view/record-view-handler.js';
11
+ import { recordCardClickHandler } from './event-handlers/record-card-click-handler.js';
12
+ import { recordCardDblClickHandler } from './event-handlers/record-card-dblclick-handler.js';
13
13
  // TODO 로케일 설정에 따라서 포맷이 바뀌도록 해야한다.
14
14
  const OPTIONS = {
15
15
  year: 'numeric',
@@ -21,22 +21,77 @@ const OPTIONS = {
21
21
  hour12: false
22
22
  // timeZone: 'America/Los_Angeles'
23
23
  };
24
- const formatter = new Intl.DateTimeFormat(navigator.language, OPTIONS);
24
+ function getSafeFormatter(locale, options) {
25
+ try {
26
+ const safeLocale = locale || 'en-US';
27
+ return new Intl.DateTimeFormat(safeLocale, options);
28
+ }
29
+ catch (e) {
30
+ return new Intl.DateTimeFormat('en-US', options);
31
+ }
32
+ }
33
+ const formatter = getSafeFormatter(navigator.language, OPTIONS);
25
34
  let RecordCard = class RecordCard extends LitElement {
26
35
  constructor() {
27
36
  super(...arguments);
28
- this.config = ZERO_CONFIG;
29
- this.data = ZERO_DATA;
30
- this.record = ZERO_RECORD;
31
- this.rowIndex = -1;
37
+ Object.defineProperty(this, "config", {
38
+ enumerable: true,
39
+ configurable: true,
40
+ writable: true,
41
+ value: ZERO_CONFIG
42
+ });
43
+ Object.defineProperty(this, "data", {
44
+ enumerable: true,
45
+ configurable: true,
46
+ writable: true,
47
+ value: ZERO_DATA
48
+ });
49
+ Object.defineProperty(this, "record", {
50
+ enumerable: true,
51
+ configurable: true,
52
+ writable: true,
53
+ value: ZERO_RECORD
54
+ });
55
+ Object.defineProperty(this, "rowIndex", {
56
+ enumerable: true,
57
+ configurable: true,
58
+ writable: true,
59
+ value: -1
60
+ });
32
61
  /*
33
62
  * row-selector를 사용자가 변경할 때, record-card의 update를 유도하기 위해 selected-row attribute를 property에 추가함.
34
63
  * (이를 해주지 않으면, 리스트 refresh 경우에 selected-row checkbox가 클리어되지 않는 현상이 발생함.)
35
64
  */
36
- this.selectedRow = false;
37
- this.emphasized = false;
38
- this.clickHandler = recordCardClickHandler.bind(this);
39
- this.dblclickHandler = recordCardDblClickHandler.bind(this);
65
+ Object.defineProperty(this, "selectedRow", {
66
+ enumerable: true,
67
+ configurable: true,
68
+ writable: true,
69
+ value: false
70
+ });
71
+ Object.defineProperty(this, "emphasized", {
72
+ enumerable: true,
73
+ configurable: true,
74
+ writable: true,
75
+ value: false
76
+ });
77
+ Object.defineProperty(this, "_recordView", {
78
+ enumerable: true,
79
+ configurable: true,
80
+ writable: true,
81
+ value: void 0
82
+ });
83
+ Object.defineProperty(this, "clickHandler", {
84
+ enumerable: true,
85
+ configurable: true,
86
+ writable: true,
87
+ value: recordCardClickHandler.bind(this)
88
+ });
89
+ Object.defineProperty(this, "dblclickHandler", {
90
+ enumerable: true,
91
+ configurable: true,
92
+ writable: true,
93
+ value: recordCardDblClickHandler.bind(this)
94
+ });
40
95
  }
41
96
  firstUpdated() {
42
97
  /*
@@ -159,8 +214,12 @@ let RecordCard = class RecordCard extends LitElement {
159
214
  });
160
215
  }
161
216
  };
162
- RecordCard.styles = [
163
- css `
217
+ Object.defineProperty(RecordCard, "styles", {
218
+ enumerable: true,
219
+ configurable: true,
220
+ writable: true,
221
+ value: [
222
+ css `
164
223
  :host {
165
224
  display: flex;
166
225
  flex-direction: column;
@@ -253,7 +312,8 @@ RecordCard.styles = [
253
312
  color: var(--data-card-item-disc-color, var(--md-sys-color-tertiary));
254
313
  }
255
314
  `
256
- ];
315
+ ]
316
+ });
257
317
  __decorate([
258
318
  property({ type: Object })
259
319
  ], RecordCard.prototype, "config", void 0);