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

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 (474) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +3 -3
  4. package/dist/src/accumulator/accumulator.d.ts +0 -2
  5. package/dist/src/accumulator/accumulator.js +0 -42
  6. package/dist/src/accumulator/accumulator.js.map +0 -1
  7. package/dist/src/configure/column-builder.d.ts +0 -2
  8. package/dist/src/configure/column-builder.js +0 -99
  9. package/dist/src/configure/column-builder.js.map +0 -1
  10. package/dist/src/configure/config-builder.d.ts +0 -2
  11. package/dist/src/configure/config-builder.js +0 -36
  12. package/dist/src/configure/config-builder.js.map +0 -1
  13. package/dist/src/configure/filters-option-builder.d.ts +0 -2
  14. package/dist/src/configure/filters-option-builder.js +0 -7
  15. package/dist/src/configure/filters-option-builder.js.map +0 -1
  16. package/dist/src/configure/imex-option-builder.d.ts +0 -2
  17. package/dist/src/configure/imex-option-builder.js +0 -4
  18. package/dist/src/configure/imex-option-builder.js.map +0 -1
  19. package/dist/src/configure/list-option-builder.d.ts +0 -2
  20. package/dist/src/configure/list-option-builder.js +0 -8
  21. package/dist/src/configure/list-option-builder.js.map +0 -1
  22. package/dist/src/configure/rows-option-builder.d.ts +0 -2
  23. package/dist/src/configure/rows-option-builder.js +0 -26
  24. package/dist/src/configure/rows-option-builder.js.map +0 -1
  25. package/dist/src/configure/tree-option-builder.d.ts +0 -2
  26. package/dist/src/configure/tree-option-builder.js +0 -18
  27. package/dist/src/configure/tree-option-builder.js.map +0 -1
  28. package/dist/src/configure/zero-config.d.ts +0 -23
  29. package/dist/src/configure/zero-config.js +0 -59
  30. package/dist/src/configure/zero-config.js.map +0 -1
  31. package/dist/src/const.d.ts +0 -1
  32. package/dist/src/const.js +0 -2
  33. package/dist/src/const.js.map +0 -1
  34. package/dist/src/data-card/data-card-field.d.ts +0 -11
  35. package/dist/src/data-card/data-card-field.js +0 -106
  36. package/dist/src/data-card/data-card-field.js.map +0 -1
  37. package/dist/src/data-card/data-card-gutter-menu.d.ts +0 -2
  38. package/dist/src/data-card/data-card-gutter-menu.js +0 -96
  39. package/dist/src/data-card/data-card-gutter-menu.js.map +0 -1
  40. package/dist/src/data-card/data-card-gutter.d.ts +0 -12
  41. package/dist/src/data-card/data-card-gutter.js +0 -116
  42. package/dist/src/data-card/data-card-gutter.js.map +0 -1
  43. package/dist/src/data-card/data-card.d.ts +0 -19
  44. package/dist/src/data-card/data-card.js +0 -149
  45. package/dist/src/data-card/data-card.js.map +0 -1
  46. package/dist/src/data-card/event-handlers/record-card-click-handler.d.ts +0 -7
  47. package/dist/src/data-card/event-handlers/record-card-click-handler.js +0 -29
  48. package/dist/src/data-card/event-handlers/record-card-click-handler.js.map +0 -1
  49. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.d.ts +0 -7
  50. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js +0 -29
  51. package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js.map +0 -1
  52. package/dist/src/data-card/record-card.d.ts +0 -23
  53. package/dist/src/data-card/record-card.js +0 -288
  54. package/dist/src/data-card/record-card.js.map +0 -1
  55. package/dist/src/data-consumer.d.ts +0 -10
  56. package/dist/src/data-consumer.js +0 -2
  57. package/dist/src/data-consumer.js.map +0 -1
  58. package/dist/src/data-grid/data-grid-accum-field.d.ts +0 -16
  59. package/dist/src/data-grid/data-grid-accum-field.js +0 -133
  60. package/dist/src/data-grid/data-grid-accum-field.js.map +0 -1
  61. package/dist/src/data-grid/data-grid-body-style.d.ts +0 -1
  62. package/dist/src/data-grid/data-grid-body-style.js +0 -99
  63. package/dist/src/data-grid/data-grid-body-style.js.map +0 -1
  64. package/dist/src/data-grid/data-grid-body.d.ts +0 -52
  65. package/dist/src/data-grid/data-grid-body.js +0 -660
  66. package/dist/src/data-grid/data-grid-body.js.map +0 -1
  67. package/dist/src/data-grid/data-grid-field.d.ts +0 -25
  68. package/dist/src/data-grid/data-grid-field.js +0 -263
  69. package/dist/src/data-grid/data-grid-field.js.map +0 -1
  70. package/dist/src/data-grid/data-grid-footer.d.ts +0 -11
  71. package/dist/src/data-grid/data-grid-footer.js +0 -120
  72. package/dist/src/data-grid/data-grid-footer.js.map +0 -1
  73. package/dist/src/data-grid/data-grid-header.d.ts +0 -29
  74. package/dist/src/data-grid/data-grid-header.js +0 -531
  75. package/dist/src/data-grid/data-grid-header.js.map +0 -1
  76. package/dist/src/data-grid/data-grid.d.ts +0 -36
  77. package/dist/src/data-grid/data-grid.js +0 -260
  78. package/dist/src/data-grid/data-grid.js.map +0 -1
  79. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.d.ts +0 -7
  80. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js +0 -57
  81. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js.map +0 -1
  82. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.d.ts +0 -7
  83. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js +0 -25
  84. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js.map +0 -1
  85. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.d.ts +0 -7
  86. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js +0 -34
  87. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js.map +0 -1
  88. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.d.ts +0 -7
  89. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js +0 -19
  90. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js.map +0 -1
  91. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.d.ts +0 -7
  92. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js +0 -226
  93. package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js.map +0 -1
  94. package/dist/src/data-grist.d.ts +0 -367
  95. package/dist/src/data-grist.js +0 -1064
  96. package/dist/src/data-grist.js.map +0 -1
  97. package/dist/src/data-list/data-list-field.d.ts +0 -11
  98. package/dist/src/data-list/data-list-field.js +0 -95
  99. package/dist/src/data-list/data-list-field.js.map +0 -1
  100. package/dist/src/data-list/data-list-gutter.d.ts +0 -12
  101. package/dist/src/data-list/data-list-gutter.js +0 -121
  102. package/dist/src/data-list/data-list-gutter.js.map +0 -1
  103. package/dist/src/data-list/data-list.d.ts +0 -18
  104. package/dist/src/data-list/data-list.js +0 -139
  105. package/dist/src/data-list/data-list.js.map +0 -1
  106. package/dist/src/data-list/event-handlers/record-partial-click-handler.d.ts +0 -7
  107. package/dist/src/data-list/event-handlers/record-partial-click-handler.js +0 -29
  108. package/dist/src/data-list/event-handlers/record-partial-click-handler.js.map +0 -1
  109. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.d.ts +0 -7
  110. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js +0 -29
  111. package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js.map +0 -1
  112. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.d.ts +0 -7
  113. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js +0 -29
  114. package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js.map +0 -1
  115. package/dist/src/data-list/record-partial.d.ts +0 -21
  116. package/dist/src/data-list/record-partial.js +0 -252
  117. package/dist/src/data-list/record-partial.js.map +0 -1
  118. package/dist/src/data-manipulator.d.ts +0 -38
  119. package/dist/src/data-manipulator.js +0 -324
  120. package/dist/src/data-manipulator.js.map +0 -1
  121. package/dist/src/data-provider.d.ts +0 -50
  122. package/dist/src/data-provider.js +0 -200
  123. package/dist/src/data-provider.js.map +0 -1
  124. package/dist/src/data-report/data-report-body-style.d.ts +0 -1
  125. package/dist/src/data-report/data-report-body-style.js +0 -58
  126. package/dist/src/data-report/data-report-body-style.js.map +0 -1
  127. package/dist/src/data-report/data-report-body.d.ts +0 -18
  128. package/dist/src/data-report/data-report-body.js +0 -181
  129. package/dist/src/data-report/data-report-body.js.map +0 -1
  130. package/dist/src/data-report/data-report-component.d.ts +0 -21
  131. package/dist/src/data-report/data-report-component.js +0 -138
  132. package/dist/src/data-report/data-report-component.js.map +0 -1
  133. package/dist/src/data-report/data-report-field.d.ts +0 -13
  134. package/dist/src/data-report/data-report-field.js +0 -99
  135. package/dist/src/data-report/data-report-field.js.map +0 -1
  136. package/dist/src/data-report/data-report-header.d.ts +0 -1
  137. package/dist/src/data-report/data-report-header.js +0 -221
  138. package/dist/src/data-report/data-report-header.js.map +0 -1
  139. package/dist/src/data-report/event-handlers/data-report-body-click-handler.d.ts +0 -5
  140. package/dist/src/data-report/event-handlers/data-report-body-click-handler.js +0 -33
  141. package/dist/src/data-report/event-handlers/data-report-body-click-handler.js.map +0 -1
  142. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.d.ts +0 -5
  143. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js +0 -19
  144. package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js.map +0 -1
  145. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.d.ts +0 -5
  146. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js +0 -58
  147. package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js.map +0 -1
  148. package/dist/src/data-report.d.ts +0 -44
  149. package/dist/src/data-report.js +0 -386
  150. package/dist/src/data-report.js.map +0 -1
  151. package/dist/src/editors/index.d.ts +0 -3
  152. package/dist/src/editors/index.js +0 -4
  153. package/dist/src/editors/index.js.map +0 -1
  154. package/dist/src/editors/ox-grist-editor-checkbox.d.ts +0 -7
  155. package/dist/src/editors/ox-grist-editor-checkbox.js +0 -27
  156. package/dist/src/editors/ox-grist-editor-checkbox.js.map +0 -1
  157. package/dist/src/editors/ox-grist-editor-color.d.ts +0 -4
  158. package/dist/src/editors/ox-grist-editor-color.js +0 -14
  159. package/dist/src/editors/ox-grist-editor-color.js.map +0 -1
  160. package/dist/src/editors/ox-grist-editor-date.d.ts +0 -4
  161. package/dist/src/editors/ox-grist-editor-date.js +0 -14
  162. package/dist/src/editors/ox-grist-editor-date.js.map +0 -1
  163. package/dist/src/editors/ox-grist-editor-datetime.d.ts +0 -6
  164. package/dist/src/editors/ox-grist-editor-datetime.js +0 -26
  165. package/dist/src/editors/ox-grist-editor-datetime.js.map +0 -1
  166. package/dist/src/editors/ox-grist-editor-email.d.ts +0 -4
  167. package/dist/src/editors/ox-grist-editor-email.js +0 -14
  168. package/dist/src/editors/ox-grist-editor-email.js.map +0 -1
  169. package/dist/src/editors/ox-grist-editor-file.d.ts +0 -6
  170. package/dist/src/editors/ox-grist-editor-file.js +0 -25
  171. package/dist/src/editors/ox-grist-editor-file.js.map +0 -1
  172. package/dist/src/editors/ox-grist-editor-image.d.ts +0 -7
  173. package/dist/src/editors/ox-grist-editor-image.js +0 -31
  174. package/dist/src/editors/ox-grist-editor-image.js.map +0 -1
  175. package/dist/src/editors/ox-grist-editor-month.d.ts +0 -4
  176. package/dist/src/editors/ox-grist-editor-month.js +0 -14
  177. package/dist/src/editors/ox-grist-editor-month.js.map +0 -1
  178. package/dist/src/editors/ox-grist-editor-multiple-select.d.ts +0 -8
  179. package/dist/src/editors/ox-grist-editor-multiple-select.js +0 -52
  180. package/dist/src/editors/ox-grist-editor-multiple-select.js.map +0 -1
  181. package/dist/src/editors/ox-grist-editor-number.d.ts +0 -6
  182. package/dist/src/editors/ox-grist-editor-number.js +0 -27
  183. package/dist/src/editors/ox-grist-editor-number.js.map +0 -1
  184. package/dist/src/editors/ox-grist-editor-password.d.ts +0 -4
  185. package/dist/src/editors/ox-grist-editor-password.js +0 -14
  186. package/dist/src/editors/ox-grist-editor-password.js.map +0 -1
  187. package/dist/src/editors/ox-grist-editor-select.d.ts +0 -4
  188. package/dist/src/editors/ox-grist-editor-select.js +0 -53
  189. package/dist/src/editors/ox-grist-editor-select.js.map +0 -1
  190. package/dist/src/editors/ox-grist-editor-tel.d.ts +0 -4
  191. package/dist/src/editors/ox-grist-editor-tel.js +0 -14
  192. package/dist/src/editors/ox-grist-editor-tel.js.map +0 -1
  193. package/dist/src/editors/ox-grist-editor-text.d.ts +0 -5
  194. package/dist/src/editors/ox-grist-editor-text.js +0 -17
  195. package/dist/src/editors/ox-grist-editor-text.js.map +0 -1
  196. package/dist/src/editors/ox-grist-editor-textarea.d.ts +0 -6
  197. package/dist/src/editors/ox-grist-editor-textarea.js +0 -18
  198. package/dist/src/editors/ox-grist-editor-textarea.js.map +0 -1
  199. package/dist/src/editors/ox-grist-editor-time.d.ts +0 -4
  200. package/dist/src/editors/ox-grist-editor-time.js +0 -14
  201. package/dist/src/editors/ox-grist-editor-time.js.map +0 -1
  202. package/dist/src/editors/ox-grist-editor-tree.d.ts +0 -6
  203. package/dist/src/editors/ox-grist-editor-tree.js +0 -27
  204. package/dist/src/editors/ox-grist-editor-tree.js.map +0 -1
  205. package/dist/src/editors/ox-grist-editor-varname.d.ts +0 -6
  206. package/dist/src/editors/ox-grist-editor-varname.js +0 -36
  207. package/dist/src/editors/ox-grist-editor-varname.js.map +0 -1
  208. package/dist/src/editors/ox-grist-editor-week.d.ts +0 -4
  209. package/dist/src/editors/ox-grist-editor-week.js +0 -14
  210. package/dist/src/editors/ox-grist-editor-week.js.map +0 -1
  211. package/dist/src/editors/ox-grist-editor.d.ts +0 -27
  212. package/dist/src/editors/ox-grist-editor.js +0 -197
  213. package/dist/src/editors/ox-grist-editor.js.map +0 -1
  214. package/dist/src/editors/ox-input-tree.d.ts +0 -20
  215. package/dist/src/editors/ox-input-tree.js +0 -221
  216. package/dist/src/editors/ox-input-tree.js.map +0 -1
  217. package/dist/src/editors/registry.d.ts +0 -12
  218. package/dist/src/editors/registry.js +0 -71
  219. package/dist/src/editors/registry.js.map +0 -1
  220. package/dist/src/empty-note.d.ts +0 -9
  221. package/dist/src/empty-note.js +0 -53
  222. package/dist/src/empty-note.js.map +0 -1
  223. package/dist/src/filters/filter-checkbox.d.ts +0 -3
  224. package/dist/src/filters/filter-checkbox.js +0 -41
  225. package/dist/src/filters/filter-checkbox.js.map +0 -1
  226. package/dist/src/filters/filter-input-barcode.d.ts +0 -3
  227. package/dist/src/filters/filter-input-barcode.js +0 -28
  228. package/dist/src/filters/filter-input-barcode.js.map +0 -1
  229. package/dist/src/filters/filter-input.d.ts +0 -2
  230. package/dist/src/filters/filter-input.js +0 -25
  231. package/dist/src/filters/filter-input.js.map +0 -1
  232. package/dist/src/filters/filter-range-date.d.ts +0 -2
  233. package/dist/src/filters/filter-range-date.js +0 -66
  234. package/dist/src/filters/filter-range-date.js.map +0 -1
  235. package/dist/src/filters/filter-range-number.d.ts +0 -2
  236. package/dist/src/filters/filter-range-number.js +0 -54
  237. package/dist/src/filters/filter-range-number.js.map +0 -1
  238. package/dist/src/filters/filter-select-buttons.d.ts +0 -3
  239. package/dist/src/filters/filter-select-buttons.js +0 -50
  240. package/dist/src/filters/filter-select-buttons.js.map +0 -1
  241. package/dist/src/filters/filter-select.d.ts +0 -3
  242. package/dist/src/filters/filter-select.js +0 -52
  243. package/dist/src/filters/filter-select.js.map +0 -1
  244. package/dist/src/filters/filter-styles.d.ts +0 -1
  245. package/dist/src/filters/filter-styles.js +0 -119
  246. package/dist/src/filters/filter-styles.js.map +0 -1
  247. package/dist/src/filters/filters-form.d.ts +0 -40
  248. package/dist/src/filters/filters-form.js +0 -430
  249. package/dist/src/filters/filters-form.js.map +0 -1
  250. package/dist/src/filters/index.d.ts +0 -8
  251. package/dist/src/filters/index.js +0 -9
  252. package/dist/src/filters/index.js.map +0 -1
  253. package/dist/src/filters/registry.d.ts +0 -7
  254. package/dist/src/filters/registry.js +0 -48
  255. package/dist/src/filters/registry.js.map +0 -1
  256. package/dist/src/formatters/date-formatter.d.ts +0 -1
  257. package/dist/src/formatters/date-formatter.js +0 -4
  258. package/dist/src/formatters/date-formatter.js.map +0 -1
  259. package/dist/src/formatters/index.d.ts +0 -1
  260. package/dist/src/formatters/index.js +0 -2
  261. package/dist/src/formatters/index.js.map +0 -1
  262. package/dist/src/formatters/number-formatter.d.ts +0 -1
  263. package/dist/src/formatters/number-formatter.js +0 -4
  264. package/dist/src/formatters/number-formatter.js.map +0 -1
  265. package/dist/src/formatters/registry.d.ts +0 -6
  266. package/dist/src/formatters/registry.js +0 -25
  267. package/dist/src/formatters/registry.js.map +0 -1
  268. package/dist/src/formatters/text-formatter.d.ts +0 -1
  269. package/dist/src/formatters/text-formatter.js +0 -4
  270. package/dist/src/formatters/text-formatter.js.map +0 -1
  271. package/dist/src/gutters/gutter-button.d.ts +0 -21
  272. package/dist/src/gutters/gutter-button.js +0 -40
  273. package/dist/src/gutters/gutter-button.js.map +0 -1
  274. package/dist/src/gutters/gutter-dirty.d.ts +0 -23
  275. package/dist/src/gutters/gutter-dirty.js +0 -87
  276. package/dist/src/gutters/gutter-dirty.js.map +0 -1
  277. package/dist/src/gutters/gutter-row-selector.d.ts +0 -21
  278. package/dist/src/gutters/gutter-row-selector.js +0 -70
  279. package/dist/src/gutters/gutter-row-selector.js.map +0 -1
  280. package/dist/src/gutters/gutter-sequence.d.ts +0 -35
  281. package/dist/src/gutters/gutter-sequence.js +0 -48
  282. package/dist/src/gutters/gutter-sequence.js.map +0 -1
  283. package/dist/src/gutters/index.d.ts +0 -1
  284. package/dist/src/gutters/index.js +0 -2
  285. package/dist/src/gutters/index.js.map +0 -1
  286. package/dist/src/gutters/registry.d.ts +0 -7
  287. package/dist/src/gutters/registry.js +0 -26
  288. package/dist/src/gutters/registry.js.map +0 -1
  289. package/dist/src/handlers/contextmenu-tree-mutation.d.ts +0 -3
  290. package/dist/src/handlers/contextmenu-tree-mutation.js +0 -64
  291. package/dist/src/handlers/contextmenu-tree-mutation.js.map +0 -1
  292. package/dist/src/handlers/index.d.ts +0 -1
  293. package/dist/src/handlers/index.js +0 -2
  294. package/dist/src/handlers/index.js.map +0 -1
  295. package/dist/src/handlers/move-down.d.ts +0 -3
  296. package/dist/src/handlers/move-down.js +0 -26
  297. package/dist/src/handlers/move-down.js.map +0 -1
  298. package/dist/src/handlers/move-up.d.ts +0 -3
  299. package/dist/src/handlers/move-up.js +0 -26
  300. package/dist/src/handlers/move-up.js.map +0 -1
  301. package/dist/src/handlers/record-copy.d.ts +0 -3
  302. package/dist/src/handlers/record-copy.js +0 -23
  303. package/dist/src/handlers/record-copy.js.map +0 -1
  304. package/dist/src/handlers/record-delete.d.ts +0 -3
  305. package/dist/src/handlers/record-delete.js +0 -16
  306. package/dist/src/handlers/record-delete.js.map +0 -1
  307. package/dist/src/handlers/record-view-handler.d.ts +0 -3
  308. package/dist/src/handlers/record-view-handler.js +0 -15
  309. package/dist/src/handlers/record-view-handler.js.map +0 -1
  310. package/dist/src/handlers/registry.d.ts +0 -7
  311. package/dist/src/handlers/registry.js +0 -34
  312. package/dist/src/handlers/registry.js.map +0 -1
  313. package/dist/src/handlers/select-row-toggle.d.ts +0 -3
  314. package/dist/src/handlers/select-row-toggle.js +0 -18
  315. package/dist/src/handlers/select-row-toggle.js.map +0 -1
  316. package/dist/src/handlers/select-row.d.ts +0 -3
  317. package/dist/src/handlers/select-row.js +0 -14
  318. package/dist/src/handlers/select-row.js.map +0 -1
  319. package/dist/src/index.d.ts +0 -14
  320. package/dist/src/index.js +0 -15
  321. package/dist/src/index.js.map +0 -1
  322. package/dist/src/personalizer/index.d.ts +0 -1
  323. package/dist/src/personalizer/index.js +0 -2
  324. package/dist/src/personalizer/index.js.map +0 -1
  325. package/dist/src/personalizer/ox-grist-filter-personalizer.d.ts +0 -8
  326. package/dist/src/personalizer/ox-grist-filter-personalizer.js +0 -178
  327. package/dist/src/personalizer/ox-grist-filter-personalizer.js.map +0 -1
  328. package/dist/src/personalizer/ox-grist-personalizer.d.ts +0 -8
  329. package/dist/src/personalizer/ox-grist-personalizer.js +0 -212
  330. package/dist/src/personalizer/ox-grist-personalizer.js.map +0 -1
  331. package/dist/src/record-view/event-handlers/record-view-body-click-handler.d.ts +0 -7
  332. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js +0 -27
  333. package/dist/src/record-view/event-handlers/record-view-body-click-handler.js.map +0 -1
  334. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.d.ts +0 -7
  335. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js +0 -22
  336. package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js.map +0 -1
  337. package/dist/src/record-view/index.d.ts +0 -2
  338. package/dist/src/record-view/index.js +0 -3
  339. package/dist/src/record-view/index.js.map +0 -1
  340. package/dist/src/record-view/ox-record-creator.d.ts +0 -26
  341. package/dist/src/record-view/ox-record-creator.js +0 -247
  342. package/dist/src/record-view/ox-record-creator.js.map +0 -1
  343. package/dist/src/record-view/record-view-body.d.ts +0 -21
  344. package/dist/src/record-view/record-view-body.js +0 -252
  345. package/dist/src/record-view/record-view-body.js.map +0 -1
  346. package/dist/src/record-view/record-view-handler.d.ts +0 -9
  347. package/dist/src/record-view/record-view-handler.js +0 -57
  348. package/dist/src/record-view/record-view-handler.js.map +0 -1
  349. package/dist/src/record-view/record-view.d.ts +0 -23
  350. package/dist/src/record-view/record-view.js +0 -117
  351. package/dist/src/record-view/record-view.js.map +0 -1
  352. package/dist/src/renderers/index.d.ts +0 -13
  353. package/dist/src/renderers/index.js +0 -14
  354. package/dist/src/renderers/index.js.map +0 -1
  355. package/dist/src/renderers/ox-grist-renderer-boolean.d.ts +0 -2
  356. package/dist/src/renderers/ox-grist-renderer-boolean.js +0 -39
  357. package/dist/src/renderers/ox-grist-renderer-boolean.js.map +0 -1
  358. package/dist/src/renderers/ox-grist-renderer-color.d.ts +0 -2
  359. package/dist/src/renderers/ox-grist-renderer-color.js +0 -12
  360. package/dist/src/renderers/ox-grist-renderer-color.js.map +0 -1
  361. package/dist/src/renderers/ox-grist-renderer-date.d.ts +0 -2
  362. package/dist/src/renderers/ox-grist-renderer-date.js +0 -53
  363. package/dist/src/renderers/ox-grist-renderer-date.js.map +0 -1
  364. package/dist/src/renderers/ox-grist-renderer-file.d.ts +0 -2
  365. package/dist/src/renderers/ox-grist-renderer-file.js +0 -27
  366. package/dist/src/renderers/ox-grist-renderer-file.js.map +0 -1
  367. package/dist/src/renderers/ox-grist-renderer-image.d.ts +0 -2
  368. package/dist/src/renderers/ox-grist-renderer-image.js +0 -24
  369. package/dist/src/renderers/ox-grist-renderer-image.js.map +0 -1
  370. package/dist/src/renderers/ox-grist-renderer-json5.d.ts +0 -2
  371. package/dist/src/renderers/ox-grist-renderer-json5.js +0 -30
  372. package/dist/src/renderers/ox-grist-renderer-json5.js.map +0 -1
  373. package/dist/src/renderers/ox-grist-renderer-link.d.ts +0 -2
  374. package/dist/src/renderers/ox-grist-renderer-link.js +0 -12
  375. package/dist/src/renderers/ox-grist-renderer-link.js.map +0 -1
  376. package/dist/src/renderers/ox-grist-renderer-password.d.ts +0 -2
  377. package/dist/src/renderers/ox-grist-renderer-password.js +0 -5
  378. package/dist/src/renderers/ox-grist-renderer-password.js.map +0 -1
  379. package/dist/src/renderers/ox-grist-renderer-progress.d.ts +0 -5
  380. package/dist/src/renderers/ox-grist-renderer-progress.js +0 -46
  381. package/dist/src/renderers/ox-grist-renderer-progress.js.map +0 -1
  382. package/dist/src/renderers/ox-grist-renderer-select.d.ts +0 -2
  383. package/dist/src/renderers/ox-grist-renderer-select.js +0 -50
  384. package/dist/src/renderers/ox-grist-renderer-select.js.map +0 -1
  385. package/dist/src/renderers/ox-grist-renderer-text.d.ts +0 -2
  386. package/dist/src/renderers/ox-grist-renderer-text.js +0 -11
  387. package/dist/src/renderers/ox-grist-renderer-text.js.map +0 -1
  388. package/dist/src/renderers/ox-grist-renderer-textarea.d.ts +0 -2
  389. package/dist/src/renderers/ox-grist-renderer-textarea.js +0 -5
  390. package/dist/src/renderers/ox-grist-renderer-textarea.js.map +0 -1
  391. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +0 -12
  392. package/dist/src/renderers/ox-grist-renderer-tree.js +0 -183
  393. package/dist/src/renderers/ox-grist-renderer-tree.js.map +0 -1
  394. package/dist/src/renderers/ox-grist-renderer.d.ts +0 -15
  395. package/dist/src/renderers/ox-grist-renderer.js +0 -48
  396. package/dist/src/renderers/ox-grist-renderer.js.map +0 -1
  397. package/dist/src/renderers/registry.d.ts +0 -12
  398. package/dist/src/renderers/registry.js +0 -70
  399. package/dist/src/renderers/registry.js.map +0 -1
  400. package/dist/src/sorters/sorters-control.d.ts +0 -12
  401. package/dist/src/sorters/sorters-control.js +0 -138
  402. package/dist/src/sorters/sorters-control.js.map +0 -1
  403. package/dist/src/types.d.ts +0 -696
  404. package/dist/src/types.js +0 -23
  405. package/dist/src/types.js.map +0 -1
  406. package/dist/src/utils/index.d.ts +0 -2
  407. package/dist/src/utils/index.js +0 -3
  408. package/dist/src/utils/index.js.map +0 -1
  409. package/dist/src/utils/list-param.d.ts +0 -16
  410. package/dist/src/utils/list-param.js +0 -40
  411. package/dist/src/utils/list-param.js.map +0 -1
  412. package/dist/src/utils/supports-passive.d.ts +0 -1
  413. package/dist/src/utils/supports-passive.js +0 -13
  414. package/dist/src/utils/supports-passive.js.map +0 -1
  415. package/dist/stories/accumulator-format.stories.d.ts +0 -41
  416. package/dist/stories/accumulator-format.stories.js +0 -237
  417. package/dist/stories/accumulator-format.stories.js.map +0 -1
  418. package/dist/stories/append-position.stories.d.ts +0 -8
  419. package/dist/stories/append-position.stories.js +0 -183
  420. package/dist/stories/append-position.stories.js.map +0 -1
  421. package/dist/stories/barcode-input-filter.stories.d.ts +0 -33
  422. package/dist/stories/barcode-input-filter.stories.js +0 -185
  423. package/dist/stories/barcode-input-filter.stories.js.map +0 -1
  424. package/dist/stories/bounded-select-filters.stories.d.ts +0 -25
  425. package/dist/stories/bounded-select-filters.stories.js +0 -283
  426. package/dist/stories/bounded-select-filters.stories.js.map +0 -1
  427. package/dist/stories/bounded-select-record.stories.d.ts +0 -25
  428. package/dist/stories/bounded-select-record.stories.js +0 -286
  429. package/dist/stories/bounded-select-record.stories.js.map +0 -1
  430. package/dist/stories/click-event-custom.stories.d.ts +0 -45
  431. package/dist/stories/click-event-custom.stories.js +0 -248
  432. package/dist/stories/click-event-custom.stories.js.map +0 -1
  433. package/dist/stories/click-event.stories.d.ts +0 -45
  434. package/dist/stories/click-event.stories.js +0 -243
  435. package/dist/stories/click-event.stories.js.map +0 -1
  436. package/dist/stories/creatable-only-column.stories.d.ts +0 -29
  437. package/dist/stories/creatable-only-column.stories.js +0 -232
  438. package/dist/stories/creatable-only-column.stories.js.map +0 -1
  439. package/dist/stories/default-filters.stories.d.ts +0 -26
  440. package/dist/stories/default-filters.stories.js +0 -219
  441. package/dist/stories/default-filters.stories.js.map +0 -1
  442. package/dist/stories/dynamic-editable.stories.d.ts +0 -25
  443. package/dist/stories/dynamic-editable.stories.js +0 -293
  444. package/dist/stories/dynamic-editable.stories.js.map +0 -1
  445. package/dist/stories/empty-sorters.stories.d.ts +0 -25
  446. package/dist/stories/empty-sorters.stories.js +0 -162
  447. package/dist/stories/empty-sorters.stories.js.map +0 -1
  448. package/dist/stories/explicit-fetch.stories.d.ts +0 -25
  449. package/dist/stories/explicit-fetch.stories.js +0 -166
  450. package/dist/stories/explicit-fetch.stories.js.map +0 -1
  451. package/dist/stories/fixed-column.stories.d.ts +0 -26
  452. package/dist/stories/fixed-column.stories.js +0 -383
  453. package/dist/stories/fixed-column.stories.js.map +0 -1
  454. package/dist/stories/grid-setting.stories.d.ts +0 -47
  455. package/dist/stories/grid-setting.stories.js +0 -453
  456. package/dist/stories/grid-setting.stories.js.map +0 -1
  457. package/dist/stories/grist-modes.stories.d.ts +0 -37
  458. package/dist/stories/grist-modes.stories.js +0 -416
  459. package/dist/stories/grist-modes.stories.js.map +0 -1
  460. package/dist/stories/group-header.stories.d.ts +0 -26
  461. package/dist/stories/group-header.stories.js +0 -410
  462. package/dist/stories/group-header.stories.js.map +0 -1
  463. package/dist/stories/record-view.stories.d.ts +0 -24
  464. package/dist/stories/record-view.stories.js +0 -125
  465. package/dist/stories/record-view.stories.js.map +0 -1
  466. package/dist/stories/textarea.stories.d.ts +0 -37
  467. package/dist/stories/textarea.stories.js +0 -229
  468. package/dist/stories/textarea.stories.js.map +0 -1
  469. package/dist/stories/tree-column-with-checkbox.stories.d.ts +0 -26
  470. package/dist/stories/tree-column-with-checkbox.stories.js +0 -267
  471. package/dist/stories/tree-column-with-checkbox.stories.js.map +0 -1
  472. package/dist/stories/tree-column.stories.d.ts +0 -26
  473. package/dist/stories/tree-column.stories.js +0 -266
  474. package/dist/stories/tree-column.stories.js.map +0 -1
@@ -1,212 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import '@material/web/button/outlined-button.js';
3
- import { css, html, LitElement } from 'lit';
4
- import { customElement, property, state } from 'lit/decorators.js';
5
- import { i18next } from '@operato/i18n';
6
- import { OxPopupList } from '@operato/popup';
7
- let OxGristPersonalizer = class OxGristPersonalizer extends LitElement {
8
- constructor() {
9
- super(...arguments);
10
- this.debug = false;
11
- }
12
- render() {
13
- return html `
14
- <md-icon
15
- @click=${(e) => {
16
- const grist = this.closest('ox-grist');
17
- const { config, compiledConfig, sorters, pagination, mode } = grist;
18
- const { columns: compiledColumns } = compiledConfig;
19
- const columns = compiledColumns
20
- .filter(ccolumn => {
21
- const column = config.columns.find((column) => column.name == ccolumn.name);
22
- return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable;
23
- })
24
- .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name));
25
- this.preference = {
26
- columns: columns.map(column => {
27
- return {
28
- name: column.name,
29
- hidden: column.hidden,
30
- width: column.width
31
- };
32
- }),
33
- sorters,
34
- pagination: {
35
- ...pagination,
36
- limit: grist.getCurrentLimit()
37
- },
38
- mode
39
- };
40
- const template = html `
41
- <div class="personalizer-header" slot="header">
42
- <div
43
- style=${`
44
- display: flex;
45
- align-items: center;
46
- margin: 0 0 0 auto;
47
- min-height: 1.4em;
48
- color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
49
- background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
50
- border-radius: var(--md-sys-shape-corner-small);
51
- padding: 0 var(--spacing-small);
52
- cursor: pointer;
53
- `}
54
- @click=${async (e) => {
55
- if (grist.personalConfigProvider) {
56
- const { mode, columns, sorters, pagination } = this.preference || {};
57
- grist.personalConfig = this.preference = await grist.personalConfigProvider.save({
58
- mode,
59
- columns,
60
- sorters,
61
- pagination
62
- });
63
- }
64
- popup.close();
65
- }}
66
- >
67
- ${String(i18next.t('button.save'))}
68
- </div>
69
- <div
70
- style=${`
71
- display: flex;
72
- align-items: center;
73
- margin: 0 0 0 var(--spacing-small, 4px);
74
- min-height: 1.4em;
75
- color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
76
- background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
77
- border-radius: var(--md-sys-shape-corner-small);
78
- padding: 0 var(--spacing-small);
79
- cursor: pointer;
80
- `}
81
- @click=${async (e) => {
82
- if (grist.personalConfigProvider) {
83
- grist.personalConfig = this.preference = {};
84
- await grist.personalConfigProvider.reset();
85
- }
86
- popup.close();
87
- }}
88
- >
89
- ${String(i18next.t('button.delete'))}
90
- </div>
91
- <md-icon
92
- style=${`
93
- --md-icon-size: 1.2em;
94
- margin-left: var(--spacing-tiny, 2px);
95
- cursor: pointer;
96
- `}
97
- @click=${async (e) => popup.close()}
98
- title=${String(i18next.t('button.close'))}
99
- >close</md-icon
100
- >
101
- </div>
102
-
103
- ${columns.map(column => html `
104
- <ox-checkbox label="checkbox" ?checked=${!column.hidden} value=${column.name} option
105
- >${column.header.renderer(column)}<span
106
- style="position: absolute; right: 10px; cursor: row-resize;opacity:.5"
107
- handle
108
- >☰</span
109
- ></ox-checkbox
110
- >
111
- `)}
112
- `;
113
- const popup = OxPopupList.open({
114
- template,
115
- multiple: true,
116
- sortable: true,
117
- debug: this.debug,
118
- attrSelected: 'checked',
119
- top: e.pageY,
120
- left: e.pageX,
121
- styles: css `
122
- :host {
123
- width: 240px;
124
- min-height: 300px;
125
- max-height: 80%;
126
- overflow: auto;
127
- }
128
-
129
- ::slotted(.personalizer-header) {
130
- --md-icon-size: 1.4em;
131
-
132
- display: flex;
133
- flex-direction: row;
134
- align-items: center;
135
- text-transform: capitalize;
136
- box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
137
- }
138
-
139
- ::slotted([option]) {
140
- position: relative;
141
- user-select: none;
142
- }
143
- `
144
- });
145
- popup.onselect = (e) => {
146
- var _a;
147
- const selected = e.detail;
148
- const pconfig = grist.personalConfig || {};
149
- const pcolumns = ((_a = this.preference) === null || _a === void 0 ? void 0 : _a.columns) || columns;
150
- pconfig.columns = pcolumns.map(column => {
151
- return {
152
- name: column.name,
153
- hidden: selected.indexOf(column.name) == -1,
154
- width: column.width
155
- };
156
- });
157
- this.preference = pconfig;
158
- grist.personalConfig = this.preference;
159
- grist.applyUpdatedConfiguration();
160
- };
161
- popup.addEventListener('sorted', (e) => {
162
- const sorted = e.detail;
163
- const pconfig = grist.personalConfig || {};
164
- pconfig.columns = sorted.map(element => {
165
- var _a;
166
- const name = element.value;
167
- return {
168
- name,
169
- hidden: !element.hasAttribute('checked'),
170
- width: (_a = columns.find(column => column.name == name)) === null || _a === void 0 ? void 0 : _a.width
171
- };
172
- });
173
- this.preference = pconfig;
174
- grist.personalConfig = this.preference;
175
- grist.applyUpdatedConfiguration();
176
- });
177
- }}
178
- >settings</md-icon
179
- >
180
- `;
181
- }
182
- };
183
- OxGristPersonalizer.styles = [
184
- css `
185
- md-icon {
186
- --md-icon-size: 14px;
187
- width: 16px;
188
- height: 16px;
189
- color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));
190
- background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));
191
- border-radius: 0px 0px 7px 7px;
192
- cursor: pointer;
193
- padding-top: var(--spacing-small);
194
-
195
- &:hover {
196
- color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));
197
- background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));
198
- }
199
- }
200
- `
201
- ];
202
- __decorate([
203
- property({ type: Boolean, attribute: true })
204
- ], OxGristPersonalizer.prototype, "debug", void 0);
205
- __decorate([
206
- state()
207
- ], OxGristPersonalizer.prototype, "preference", void 0);
208
- OxGristPersonalizer = __decorate([
209
- customElement('ox-grist-personalizer')
210
- ], OxGristPersonalizer);
211
- export { OxGristPersonalizer };
212
- //# sourceMappingURL=ox-grist-personalizer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ox-grist-personalizer.js","sourceRoot":"","sources":["../../../src/personalizer/ox-grist-personalizer.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/button/outlined-button.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { i18next } from '@operato/i18n'\nimport { OxPopupList } from '@operato/popup'\nimport { OxCheckbox } from '@operato/input'\n\nimport { ColumnConfig, PersonalGristPreference } from '../types.js'\nimport { DataGrist } from '../data-grist.js'\n\n@customElement('ox-grist-personalizer')\nexport class OxGristPersonalizer extends LitElement {\n static styles = [\n css`\n md-icon {\n --md-icon-size: 14px;\n width: 16px;\n height: 16px;\n color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));\n border-radius: 0px 0px 7px 7px;\n cursor: pointer;\n padding-top: var(--spacing-small);\n\n &:hover {\n color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));\n }\n }\n `\n ]\n\n @property({ type: Boolean, attribute: true }) debug: boolean = false\n\n @state() private preference?: PersonalGristPreference\n\n render() {\n return html`\n <md-icon\n @click=${(e: MouseEvent) => {\n const grist = this.closest('ox-grist') as DataGrist\n\n const { config, compiledConfig, sorters, pagination, mode } = grist\n const { columns: compiledColumns } = compiledConfig\n\n const columns = compiledColumns\n .filter(ccolumn => {\n const column = config.columns.find((column: Partial<ColumnConfig>) => column.name == ccolumn.name)\n return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable\n })\n .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name)!)\n\n this.preference = {\n columns: columns.map(column => {\n return {\n name: column.name,\n hidden: column.hidden,\n width: column.width\n }\n }),\n sorters,\n pagination: {\n ...pagination,\n limit: grist.getCurrentLimit()\n },\n mode\n }\n\n const template = html`\n <div class=\"personalizer-header\" slot=\"header\">\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 auto;\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n const { mode, columns, sorters, pagination } = this.preference || {}\n grist.personalConfig = this.preference = await grist.personalConfigProvider.save({\n mode,\n columns,\n sorters,\n pagination\n })\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.save'))}\n </div>\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 var(--spacing-small, 4px);\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n grist.personalConfig = this.preference = {}\n await grist.personalConfigProvider.reset()\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.delete'))}\n </div>\n <md-icon\n style=${`\n --md-icon-size: 1.2em;\n margin-left: var(--spacing-tiny, 2px);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => popup.close()}\n title=${String(i18next.t('button.close'))}\n >close</md-icon\n >\n </div>\n\n ${columns.map(\n column => html`\n <ox-checkbox label=\"checkbox\" ?checked=${!column.hidden} value=${column.name} option\n >${column.header.renderer(column)}<span\n style=\"position: absolute; right: 10px; cursor: row-resize;opacity:.5\"\n handle\n >☰</span\n ></ox-checkbox\n >\n `\n )}\n `\n\n const popup = OxPopupList.open({\n template,\n multiple: true,\n sortable: true,\n debug: this.debug,\n attrSelected: 'checked',\n top: e.pageY,\n left: e.pageX,\n styles: css`\n :host {\n width: 240px;\n min-height: 300px;\n max-height: 80%;\n overflow: auto;\n }\n\n ::slotted(.personalizer-header) {\n --md-icon-size: 1.4em;\n\n display: flex;\n flex-direction: row;\n align-items: center;\n text-transform: capitalize;\n box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);\n }\n\n ::slotted([option]) {\n position: relative;\n user-select: none;\n }\n `\n })\n\n popup.onselect = (e: Event) => {\n const selected = (e as CustomEvent).detail\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n const pcolumns = this.preference?.columns || columns\n\n pconfig.columns = pcolumns.map(column => {\n return {\n name: column.name,\n hidden: selected.indexOf(column.name) == -1,\n width: column.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n }\n\n popup.addEventListener('sorted', (e: Event) => {\n const sorted = (e as CustomEvent).detail as HTMLElement[]\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n\n pconfig.columns = sorted.map(element => {\n const name = (element as OxCheckbox).value\n return {\n name,\n hidden: !element.hasAttribute('checked'),\n width: columns.find(column => column.name == name)?.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n })\n }}\n >settings</md-icon\n >\n `\n }\n}\n"]}
@@ -1,7 +0,0 @@
1
- import { RecordViewBody } from '../record-view-body.js';
2
- /**
3
- * ox-record-view-body 의 click handler
4
- *
5
- * - handler의 this 는 ox-record-view-body임.
6
- */
7
- export declare function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void;
@@ -1,27 +0,0 @@
1
- /**
2
- * ox-record-view-body 의 click handler
3
- *
4
- * - handler의 this 는 ox-record-view-body임.
5
- */
6
- export function recordViewBodyClickHandler(e) {
7
- var _a;
8
- e.stopPropagation();
9
- /* target should be 'ox-grid-field' */
10
- var target = e.target;
11
- if (this.currentTarget) {
12
- this.focus();
13
- this.currentTarget.removeAttribute('editing');
14
- }
15
- let editable = (_a = target === null || target === void 0 ? void 0 : target.column) === null || _a === void 0 ? void 0 : _a.record.editable;
16
- if (typeof editable === 'function') {
17
- editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this);
18
- }
19
- if (target.tagName !== 'OX-GRID-FIELD' || !editable) {
20
- this.focus();
21
- this.currentTarget = null;
22
- return;
23
- }
24
- this.currentTarget = target;
25
- target.setAttribute('editing', 'true');
26
- }
27
- //# sourceMappingURL=record-view-body-click-handler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"record-view-body-click-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-click-handler.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,0BAA0B,CAAuB,CAAQ;;IACvE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,sCAAsC;IACtC,IAAI,MAAM,GAAG,CAAC,CAAC,MAAuB,CAAA;IAEtC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;IAC/C,CAAC;IAED,IAAI,QAAQ,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,0CAAE,MAAM,CAAC,QAAQ,CAAA;IAC9C,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;QACnC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAA;IACnG,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,KAAK,eAAe,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;QACzB,OAAM;IACR,CAAC;IAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAA;IAC3B,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAA;AACxC,CAAC","sourcesContent":["import { DataGridField } from '../../data-grid/data-grid-field.js'\nimport { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 click handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void {\n e.stopPropagation()\n\n /* target should be 'ox-grid-field' */\n var target = e.target as DataGridField\n\n if (this.currentTarget) {\n this.focus()\n this.currentTarget.removeAttribute('editing')\n }\n\n let editable = target?.column?.record.editable\n if (typeof editable === 'function') {\n editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this)\n }\n\n if (target.tagName !== 'OX-GRID-FIELD' || !editable) {\n this.focus()\n this.currentTarget = null\n return\n }\n\n this.currentTarget = target\n target.setAttribute('editing', 'true')\n}\n"]}
@@ -1,7 +0,0 @@
1
- import { RecordViewBody } from '../record-view-body.js';
2
- /**
3
- * ox-record-view-body 의 keydown handler
4
- *
5
- * - handler의 this 는 ox-record-view-body임.
6
- */
7
- export declare function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void>;
@@ -1,22 +0,0 @@
1
- /**
2
- * ox-record-view-body 의 keydown handler
3
- *
4
- * - handler의 this 는 ox-record-view-body임.
5
- */
6
- export async function recordViewBodyKeydownHandler(e) {
7
- switch (e.key) {
8
- case 'Esc':
9
- case 'Escape':
10
- /* TODO 편집이 취소되어야 한다. */
11
- case 'Enter':
12
- /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */
13
- this.focus();
14
- if (this.currentTarget) {
15
- this.currentTarget.removeAttribute('editing');
16
- }
17
- this.currentTarget = null;
18
- break;
19
- default:
20
- }
21
- }
22
- //# sourceMappingURL=record-view-body-keydown-handler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"record-view-body-keydown-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-keydown-handler.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAuB,CAAQ;IAC/E,QAAS,CAAmB,CAAC,GAAG,EAAE,CAAC;QACjC,KAAK,KAAK,CAAC;QACX,KAAK,QAAQ,CAAC;QACd,wBAAwB;QACxB,KAAK,OAAO;YACV,+DAA+D;YAC/D,IAAI,CAAC,KAAK,EAAE,CAAA;YAEZ,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;YAC/C,CAAC;YAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;YAEzB,MAAK;QACP,QAAQ;IACV,CAAC;AACH,CAAC","sourcesContent":["import { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 keydown handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport async function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void> {\n switch ((e as KeyboardEvent).key) {\n case 'Esc':\n case 'Escape':\n /* TODO 편집이 취소되어야 한다. */\n case 'Enter':\n /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */\n this.focus()\n\n if (this.currentTarget) {\n this.currentTarget.removeAttribute('editing')\n }\n\n this.currentTarget = null\n\n break\n default:\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export * from './record-view.js';
2
- export * from './ox-record-creator.js';
@@ -1,3 +0,0 @@
1
- export * from './record-view.js';
2
- export * from './ox-record-creator.js';
3
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/record-view/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA","sourcesContent":["export * from './record-view.js'\nexport * from './ox-record-creator.js'\n"]}
@@ -1,26 +0,0 @@
1
- import '@material/web/icon/icon.js';
2
- import './record-view.js';
3
- import { LitElement } from 'lit';
4
- import { DataGrist } from '../data-grist.js';
5
- import { GristRecord, ValidationReason } from '../types.js';
6
- export declare class OxRecordCreator extends LitElement {
7
- static styles: import("lit").CSSResult[];
8
- grist?: DataGrist;
9
- callback?: (record: GristRecord) => boolean;
10
- customPopupCallback?: (popup: any) => boolean;
11
- lightPopup: boolean;
12
- preventCloseOnBlur: boolean;
13
- constructor();
14
- connectedCallback(): void;
15
- render(): import("lit-html").TemplateResult<1>;
16
- validateRecord(record: GristRecord): {
17
- field: string;
18
- reason: ValidationReason;
19
- }[];
20
- openLightPopup(): void;
21
- openPopup(): void;
22
- lightPopupRecordView(): void;
23
- popupRecordView(): void;
24
- lightPopupCustomCreator(originalContent: HTMLElement): void;
25
- popupCustomCreator(originalContent: HTMLElement): void;
26
- }
@@ -1,247 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import '@material/web/icon/icon.js';
3
- import './record-view.js';
4
- import { css, html, LitElement } from 'lit';
5
- import { customElement, property, state } from 'lit/decorators.js';
6
- import { OxPopup } from '@operato/popup';
7
- import { ValidationReason } from '../types.js';
8
- let OxRecordCreator = class OxRecordCreator extends LitElement {
9
- constructor() {
10
- super();
11
- this.lightPopup = false;
12
- this.preventCloseOnBlur = false;
13
- this.addEventListener('click', (e) => {
14
- e.preventDefault();
15
- e.stopPropagation();
16
- if (this.lightPopup) {
17
- this.openLightPopup();
18
- }
19
- else {
20
- this.openPopup();
21
- }
22
- });
23
- }
24
- connectedCallback() {
25
- super.connectedCallback();
26
- this.grist = this.closest('ox-grist');
27
- }
28
- render() {
29
- return html `
30
- <slot></slot>
31
- <slot name="popup"></slot>
32
- `;
33
- }
34
- validateRecord(record) {
35
- const columns = this.grist.compiledConfig.columns;
36
- const invalidFields = [];
37
- columns
38
- .filter(column => !column.hidden)
39
- .forEach(column => {
40
- var _a;
41
- if (((_a = column.record) === null || _a === void 0 ? void 0 : _a.mandatory) &&
42
- (record[column.name] === undefined || record[column.name] === null || record[column.name] === '')) {
43
- invalidFields.push({
44
- field: column.name,
45
- reason: ValidationReason.MANDATORY
46
- });
47
- }
48
- });
49
- return invalidFields;
50
- }
51
- openLightPopup() {
52
- var _a;
53
- const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
54
- const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
55
- const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
56
- if (originalContent) {
57
- this.lightPopupCustomCreator(originalContent);
58
- }
59
- else {
60
- this.lightPopupRecordView();
61
- }
62
- }
63
- openPopup() {
64
- var _a;
65
- const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
66
- const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
67
- const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
68
- if (originalContent) {
69
- this.popupCustomCreator(originalContent);
70
- }
71
- else {
72
- this.popupRecordView();
73
- }
74
- }
75
- lightPopupRecordView() {
76
- const config = this.grist.compiledConfig;
77
- var title = 'create';
78
- const rowIndex = -1;
79
- var record = {};
80
- const columns = config.columns;
81
- var popup = OxPopup.open({
82
- template: html `
83
- <div title>${title}</div>
84
- <ox-record-view
85
- @field-change=${(e) => {
86
- const view = e.currentTarget;
87
- var { after, before, column, record, row } = e.detail;
88
- var validation = column.validation;
89
- if (validation && typeof validation == 'function') {
90
- if (!validation.call(this, after, before, record, column)) {
91
- return;
92
- }
93
- }
94
- view.record = {
95
- ...record,
96
- [column.name]: after
97
- };
98
- }}
99
- .columns=${columns}
100
- .record=${record}
101
- .rowIndex=${rowIndex}
102
- @reset=${(e) => {
103
- const view = e.currentTarget;
104
- view.record = {};
105
- }}
106
- @cancel=${(e) => {
107
- popup.close();
108
- }}
109
- @ok=${async (e) => {
110
- const view = e.currentTarget;
111
- const invalidFields = await this.validateRecord(view.record);
112
- if (invalidFields.length > 0) {
113
- view.setFocusOnInvalid(invalidFields);
114
- return false;
115
- }
116
- popup.close();
117
- this.dispatchEvent(new CustomEvent('ok', {
118
- bubbles: true,
119
- composed: true,
120
- detail: view.record
121
- }));
122
- }}
123
- ></ox-record-view>
124
- `,
125
- parent: document.body,
126
- preventCloseOnBlur: this.preventCloseOnBlur
127
- });
128
- }
129
- popupRecordView() {
130
- const config = this.grist.compiledConfig;
131
- const rowIndex = -1;
132
- var record = {};
133
- const columns = config.columns;
134
- var title = 'create';
135
- var recordView = document.createElement('ox-record-view');
136
- recordView.columns = columns;
137
- recordView.record = record;
138
- recordView.rowIndex = rowIndex;
139
- document.dispatchEvent(new CustomEvent('open-popup', {
140
- detail: {
141
- template: recordView,
142
- options: {
143
- backdrop: true,
144
- size: 'large',
145
- title
146
- },
147
- callback: (popup) => {
148
- recordView.addEventListener('reset', (e) => {
149
- const view = e.currentTarget;
150
- view.record = {};
151
- });
152
- recordView.addEventListener('cancel', (e) => {
153
- popup.close();
154
- });
155
- recordView.addEventListener('ok', async (e) => {
156
- var _a;
157
- const view = e.currentTarget;
158
- const invalidFields = await this.validateRecord(view.record);
159
- if (invalidFields.length > 0) {
160
- view.setFocusOnInvalid(invalidFields);
161
- return false;
162
- }
163
- if (await ((_a = this.callback) === null || _a === void 0 ? void 0 : _a.call(this, view.record))) {
164
- popup.close();
165
- }
166
- else {
167
- console.error('validation failed');
168
- }
169
- });
170
- recordView.addEventListener('field-change', async (e) => {
171
- const view = e.currentTarget;
172
- var { after, before, column, record, row } = e.detail;
173
- var validation = column.validation;
174
- if (validation && typeof validation == 'function') {
175
- if (!(await validation.call(this, after, before, record, column))) {
176
- return;
177
- }
178
- }
179
- view.record = {
180
- ...record,
181
- [column.name]: after
182
- };
183
- });
184
- popup.onclosed = () => { };
185
- }
186
- }
187
- }));
188
- }
189
- lightPopupCustomCreator(originalContent) {
190
- var _a;
191
- const title = 'create';
192
- const popupContent = originalContent.cloneNode(true);
193
- popupContent.removeAttribute('slot');
194
- OxPopup.open({
195
- template: html `
196
- <div title>${title}</div>
197
- ${popupContent}
198
- `,
199
- parent: document.body,
200
- preventCloseOnBlur: this.preventCloseOnBlur
201
- });
202
- (_a = this.customPopupCallback) === null || _a === void 0 ? void 0 : _a.call(this, popupContent); // 사용자 정의 팝업용 콜백 실행
203
- }
204
- popupCustomCreator(originalContent) {
205
- const title = 'create';
206
- const popupContent = originalContent.cloneNode(true);
207
- popupContent.removeAttribute('slot');
208
- document.dispatchEvent(new CustomEvent('open-popup', {
209
- detail: {
210
- template: popupContent,
211
- options: {
212
- backdrop: true,
213
- size: 'large',
214
- title
215
- },
216
- callback: this.customPopupCallback
217
- }
218
- }));
219
- }
220
- };
221
- OxRecordCreator.styles = [
222
- css `
223
- ::slotted([slot='popup']) {
224
- display: none;
225
- }
226
- `
227
- ];
228
- __decorate([
229
- state()
230
- ], OxRecordCreator.prototype, "grist", void 0);
231
- __decorate([
232
- property({ type: Object })
233
- ], OxRecordCreator.prototype, "callback", void 0);
234
- __decorate([
235
- property({ type: Object })
236
- ], OxRecordCreator.prototype, "customPopupCallback", void 0);
237
- __decorate([
238
- property({ type: Boolean, attribute: 'light-popup' })
239
- ], OxRecordCreator.prototype, "lightPopup", void 0);
240
- __decorate([
241
- property({ type: Boolean, attribute: 'prevent-close-on-blur' })
242
- ], OxRecordCreator.prototype, "preventCloseOnBlur", void 0);
243
- OxRecordCreator = __decorate([
244
- customElement('ox-record-creator')
245
- ], OxRecordCreator);
246
- export { OxRecordCreator };
247
- //# sourceMappingURL=ox-record-creator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ox-record-creator.js","sourceRoot":"","sources":["../../../src/record-view/ox-record-creator.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport './record-view.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxPopup } from '@operato/popup'\n\nimport { DataGrist } from '../data-grist.js'\nimport { ColumnConfig, GristRecord, ValidationReason } from '../types.js'\nimport { RecordView } from './record-view.js'\n\n@customElement('ox-record-creator')\nexport class OxRecordCreator extends LitElement {\n static styles = [\n css`\n ::slotted([slot='popup']) {\n display: none;\n }\n `\n ]\n\n @state() grist?: DataGrist\n\n @property({ type: Object }) callback?: (record: GristRecord) => boolean\n @property({ type: Object }) customPopupCallback?: (popup: any) => boolean\n @property({ type: Boolean, attribute: 'light-popup' }) lightPopup: boolean = false\n @property({ type: Boolean, attribute: 'prevent-close-on-blur' }) preventCloseOnBlur = false\n\n constructor() {\n super()\n\n this.addEventListener('click', (e: Event) => {\n e.preventDefault()\n e.stopPropagation()\n\n if (this.lightPopup) {\n this.openLightPopup()\n } else {\n this.openPopup()\n }\n })\n }\n\n connectedCallback(): void {\n super.connectedCallback()\n\n this.grist = this.closest('ox-grist') as DataGrist\n }\n\n render() {\n return html`\n <slot></slot>\n <slot name=\"popup\"></slot>\n `\n }\n\n validateRecord(record: GristRecord): { field: string; reason: ValidationReason }[] {\n const columns = this.grist!.compiledConfig.columns\n const invalidFields: { field: string; reason: ValidationReason }[] = []\n\n columns\n .filter(column => !column.hidden)\n .forEach(column => {\n if (\n column.record?.mandatory &&\n (record[column.name] === undefined || record[column.name] === null || record[column.name] === '')\n ) {\n invalidFields.push({\n field: column.name,\n reason: ValidationReason.MANDATORY\n })\n }\n })\n\n return invalidFields\n }\n\n openLightPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.lightPopupCustomCreator(originalContent)\n } else {\n this.lightPopupRecordView()\n }\n }\n\n openPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.popupCustomCreator(originalContent)\n } else {\n this.popupRecordView()\n }\n }\n\n lightPopupRecordView() {\n const config = this.grist!.compiledConfig\n var title = 'create'\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var popup = OxPopup.open({\n template: html`\n <div title>${title}</div>\n <ox-record-view\n @field-change=${(e: CustomEvent) => {\n const view = e.currentTarget as RecordView\n\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n view.record = {\n ...record,\n [column.name]: after\n }\n }}\n .columns=${columns}\n .record=${record}\n .rowIndex=${rowIndex}\n @reset=${(e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n }}\n @cancel=${(e: Event) => {\n popup.close()\n }}\n @ok=${async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n popup.close()\n\n this.dispatchEvent(\n new CustomEvent('ok', {\n bubbles: true,\n composed: true,\n detail: view.record\n })\n )\n }}\n ></ox-record-view>\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n }\n\n popupRecordView() {\n const config = this.grist!.compiledConfig\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var title = 'create'\n\n var recordView = document.createElement('ox-record-view') as RecordView\n\n recordView.columns = columns\n recordView.record = record\n recordView.rowIndex = rowIndex\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: recordView,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: (popup: any) => {\n recordView.addEventListener('reset', (e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n })\n\n recordView.addEventListener('cancel', (e: Event) => {\n popup.close()\n })\n\n recordView.addEventListener('ok', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n if (await this.callback?.(view.record)) {\n popup.close()\n } else {\n console.error('validation failed')\n }\n })\n\n recordView.addEventListener('field-change', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!(await validation.call(this, after, before, record, column))) {\n return\n }\n }\n\n view.record = {\n ...record,\n [column.name]: after\n }\n })\n\n popup.onclosed = () => {}\n }\n }\n })\n )\n }\n\n lightPopupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n OxPopup.open({\n template: html`\n <div title>${title}</div>\n ${popupContent}\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n\n this.customPopupCallback?.(popupContent) // 사용자 정의 팝업용 콜백 실행\n }\n\n popupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: popupContent,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: this.customPopupCallback\n }\n })\n )\n }\n}\n"]}