@sme.up/ketchup 8.0.2 → 8.1.0

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 (552) hide show
  1. package/dist/cjs/{GenericVariables-a9ed17ee.js → GenericVariables-9cd88034.js} +3 -3
  2. package/dist/cjs/{component-85c2bd4d.js → component-2c7ddef7.js} +91 -10
  3. package/dist/cjs/{f-button-9524bbf7.js → f-button-a5f661f2.js} +99 -99
  4. package/dist/cjs/{f-button-declarations-b611587f.js → f-button-declarations-76b4fb4c.js} +16 -16
  5. package/dist/cjs/{f-cell-bcb75ade.js → f-cell-ca9e4352.js} +472 -472
  6. package/dist/cjs/{f-checkbox-1148e791.js → f-checkbox-e2c6ecef.js} +23 -23
  7. package/dist/cjs/{f-chip-2249b386.js → f-chip-e941fa19.js} +125 -125
  8. package/dist/cjs/{f-image-47d74999.js → f-image-466b724f.js} +107 -107
  9. package/dist/cjs/{f-paginator-utils-b0a9ae5f.js → f-paginator-utils-f775ce67.js} +1548 -1548
  10. package/dist/cjs/{f-text-field-579c0fc0.js → f-text-field-ddb47dda.js} +172 -172
  11. package/dist/cjs/{f-text-field-mdc-0e22f3e3.js → f-text-field-mdc-d38d80b5.js} +59 -60
  12. package/dist/cjs/{index-1f177abc.js → index-26fb8571.js} +78 -24
  13. package/dist/cjs/ketchup.cjs.js +3 -3
  14. package/dist/cjs/kup-accordion.cjs.entry.js +199 -200
  15. package/dist/cjs/kup-autocomplete_27.cjs.entry.js +17546 -17508
  16. package/dist/cjs/kup-box.cjs.entry.js +1294 -1232
  17. package/dist/cjs/kup-calendar.cjs.entry.js +9542 -10035
  18. package/dist/cjs/kup-cell.cjs.entry.js +172 -172
  19. package/dist/cjs/kup-dash-list.cjs.entry.js +106 -106
  20. package/dist/cjs/kup-dash_2.cjs.entry.js +162 -162
  21. package/dist/cjs/kup-dashboard.cjs.entry.js +400 -401
  22. package/dist/cjs/kup-drawer.cjs.entry.js +138 -138
  23. package/dist/cjs/kup-echart.cjs.entry.js +7145 -6598
  24. package/dist/cjs/kup-family-tree.cjs.entry.js +439 -439
  25. package/dist/cjs/kup-iframe.cjs.entry.js +94 -94
  26. package/dist/cjs/kup-image-list.cjs.entry.js +255 -256
  27. package/dist/cjs/kup-lazy.cjs.entry.js +186 -186
  28. package/dist/cjs/kup-magic-box.cjs.entry.js +298 -298
  29. package/dist/cjs/{kup-manager-85b2a756.js → kup-manager-16b684bd.js} +7286 -7287
  30. package/dist/cjs/kup-nav-bar.cjs.entry.js +130 -130
  31. package/dist/cjs/kup-numeric-picker.cjs.entry.js +367 -368
  32. package/dist/cjs/kup-photo-frame.cjs.entry.js +144 -144
  33. package/dist/cjs/kup-planner.cjs.entry.js +1151 -1009
  34. package/dist/cjs/kup-probe.cjs.entry.js +246 -246
  35. package/dist/cjs/kup-qlik.cjs.entry.js +138 -138
  36. package/dist/cjs/kup-snackbar.cjs.entry.js +116 -116
  37. package/dist/cjs/loader.cjs.js +3 -3
  38. package/dist/collection/assets/dash-list.js +466 -293
  39. package/dist/collection/assets/index.js +4 -0
  40. package/dist/collection/assets/planner.js +8189 -0
  41. package/dist/collection/collection-manifest.json +2 -2
  42. package/dist/collection/components/kup-accordion/kup-accordion-declarations.js +10 -10
  43. package/dist/collection/components/kup-accordion/kup-accordion.js +445 -445
  44. package/dist/collection/components/kup-autocomplete/kup-autocomplete-declarations.js +27 -27
  45. package/dist/collection/components/kup-autocomplete/kup-autocomplete.js +908 -908
  46. package/dist/collection/components/kup-badge/kup-badge-declarations.js +10 -10
  47. package/dist/collection/components/kup-badge/kup-badge.js +276 -276
  48. package/dist/collection/components/kup-box/kup-box-declarations.js +34 -33
  49. package/dist/collection/components/kup-box/kup-box-state.js +15 -15
  50. package/dist/collection/components/kup-box/kup-box.js +2159 -2079
  51. package/dist/collection/components/kup-button/kup-button-declarations.js +18 -18
  52. package/dist/collection/components/kup-button/kup-button.js +580 -580
  53. package/dist/collection/components/kup-button-list/kup-button-list-declarations.js +13 -13
  54. package/dist/collection/components/kup-button-list/kup-button-list.e2e.js +144 -0
  55. package/dist/collection/components/kup-button-list/kup-button-list.js +527 -527
  56. package/dist/collection/components/kup-calendar/kup-calendar-declarations.js +35 -35
  57. package/dist/collection/components/kup-calendar/kup-calendar.css +0 -4
  58. package/dist/collection/components/kup-calendar/kup-calendar.js +690 -690
  59. package/dist/collection/components/kup-card/box/kup-card-box.js +227 -227
  60. package/dist/collection/components/kup-card/built-in/kup-card-built-in.js +56 -56
  61. package/dist/collection/components/kup-card/built-in/kup-card-calendar.js +393 -393
  62. package/dist/collection/components/kup-card/built-in/kup-card-clock.js +308 -308
  63. package/dist/collection/components/kup-card/built-in/kup-card-column-drop-menu.js +165 -165
  64. package/dist/collection/components/kup-card/built-in/kup-card-message-box.js +10 -10
  65. package/dist/collection/components/kup-card/built-in/kup-card-numeric.js +118 -118
  66. package/dist/collection/components/kup-card/collapsible/kup-card-collapsible.js +64 -64
  67. package/dist/collection/components/kup-card/dialog/kup-card-dialog.js +217 -217
  68. package/dist/collection/components/kup-card/free/kup-card-free.js +22 -22
  69. package/dist/collection/components/kup-card/kup-card-declarations.js +98 -98
  70. package/dist/collection/components/kup-card/kup-card-helper.js +196 -196
  71. package/dist/collection/components/kup-card/kup-card.js +809 -809
  72. package/dist/collection/components/kup-card/scalable/kup-card-scalable.js +251 -251
  73. package/dist/collection/components/kup-card/standard/kup-card-standard.js +593 -593
  74. package/dist/collection/components/kup-cell/kup-cell-declarations.js +11 -11
  75. package/dist/collection/components/kup-cell/kup-cell.js +401 -401
  76. package/dist/collection/components/kup-chart/kup-chart-builder.js +93 -93
  77. package/dist/collection/components/kup-chart/kup-chart-declarations.js +49 -49
  78. package/dist/collection/components/kup-chart/kup-chart.js +1080 -1080
  79. package/dist/collection/components/kup-checkbox/kup-checkbox-declarations.js +13 -13
  80. package/dist/collection/components/kup-checkbox/kup-checkbox.js +433 -433
  81. package/dist/collection/components/kup-chip/kup-chip-declarations.js +12 -12
  82. package/dist/collection/components/kup-chip/kup-chip.js +558 -558
  83. package/dist/collection/components/kup-color-picker/kup-color-picker-declarations.js +12 -12
  84. package/dist/collection/components/kup-color-picker/kup-color-picker.js +546 -546
  85. package/dist/collection/components/kup-combobox/kup-combobox-declarations.js +15 -15
  86. package/dist/collection/components/kup-combobox/kup-combobox.js +821 -821
  87. package/dist/collection/components/kup-dash/kup-dash.js +171 -171
  88. package/dist/collection/components/kup-dash-list/kup-dash-list.js +327 -327
  89. package/dist/collection/components/kup-dashboard/kup-dashboard-declarations.js +10 -10
  90. package/dist/collection/components/kup-dashboard/kup-dashboard.js +588 -588
  91. package/dist/collection/components/kup-data-table/kup-data-table-declarations.js +156 -156
  92. package/dist/collection/components/kup-data-table/kup-data-table-helper.js +808 -808
  93. package/dist/collection/components/kup-data-table/kup-data-table-state.js +36 -36
  94. package/dist/collection/components/kup-data-table/kup-data-table.js +5527 -5527
  95. package/dist/collection/components/kup-date-picker/kup-date-picker-declarations.js +18 -18
  96. package/dist/collection/components/kup-date-picker/kup-date-picker.js +816 -816
  97. package/dist/collection/components/kup-dialog/kup-dialog-declarations.js +14 -14
  98. package/dist/collection/components/kup-dialog/kup-dialog.js +467 -467
  99. package/dist/collection/components/kup-drawer/kup-drawer-declarations.js +10 -10
  100. package/dist/collection/components/kup-drawer/kup-drawer.e2e.js +9 -0
  101. package/dist/collection/components/kup-drawer/kup-drawer.js +383 -383
  102. package/dist/collection/components/kup-dropdown-button/kup-dropdown-button-declarations.js +18 -18
  103. package/dist/collection/components/kup-dropdown-button/kup-dropdown-button.js +800 -800
  104. package/dist/collection/components/kup-echart/kup-echart-declarations.js +52 -52
  105. package/dist/collection/components/kup-echart/kup-echart.js +1437 -1437
  106. package/dist/collection/components/kup-family-tree/kup-family-tree-declarations.js +15 -15
  107. package/dist/collection/components/kup-family-tree/kup-family-tree.js +829 -829
  108. package/dist/collection/components/kup-form/kup-form-declarations.js +29 -29
  109. package/dist/collection/components/kup-form/kup-form.js +731 -731
  110. package/dist/collection/components/kup-gauge/kup-gauge-declarations.js +26 -26
  111. package/dist/collection/components/kup-gauge/kup-gauge.js +764 -764
  112. package/dist/collection/components/kup-grid/kup-grid-declarations.js +10 -10
  113. package/dist/collection/components/kup-grid/kup-grid.js +253 -253
  114. package/dist/collection/components/kup-iframe/kup-iframe-declarations.js +10 -10
  115. package/dist/collection/components/kup-iframe/kup-iframe.js +281 -281
  116. package/dist/collection/components/kup-image/canvas/kup-image-canvas-declarations.js +184 -184
  117. package/dist/collection/components/kup-image/canvas/kup-image-canvas-helper.js +19 -19
  118. package/dist/collection/components/kup-image/canvas/kup-image-canvas.js +225 -225
  119. package/dist/collection/components/kup-image/kup-image-declarations.js +16 -16
  120. package/dist/collection/components/kup-image/kup-image.js +491 -491
  121. package/dist/collection/components/kup-image-list/kup-image-list-declarations.js +10 -10
  122. package/dist/collection/components/kup-image-list/kup-image-list-state.js +9 -9
  123. package/dist/collection/components/kup-image-list/kup-image-list.js +533 -533
  124. package/dist/collection/components/kup-lazy/kup-lazy-declarations.js +20 -20
  125. package/dist/collection/components/kup-lazy/kup-lazy.js +430 -430
  126. package/dist/collection/components/kup-list/kup-list-declarations.js +34 -34
  127. package/dist/collection/components/kup-list/kup-list-helper.js +121 -121
  128. package/dist/collection/components/kup-list/kup-list.js +949 -949
  129. package/dist/collection/components/kup-magic-box/kup-magic-box-declarations.js +23 -23
  130. package/dist/collection/components/kup-magic-box/kup-magic-box.js +431 -431
  131. package/dist/collection/components/kup-nav-bar/kup-nav-bar-declarations.js +21 -21
  132. package/dist/collection/components/kup-nav-bar/kup-nav-bar.js +315 -315
  133. package/dist/collection/components/kup-numeric-picker/kup-numeric-picker-declarations.js +16 -16
  134. package/dist/collection/components/kup-numeric-picker/kup-numeric-picker.js +864 -864
  135. package/dist/collection/components/kup-photo-frame/kup-photo-frame-declarations.js +10 -10
  136. package/dist/collection/components/kup-photo-frame/kup-photo-frame.js +372 -372
  137. package/dist/collection/components/kup-planner/kup-planner-declarations.js +83 -76
  138. package/dist/collection/components/kup-planner/kup-planner-helper.js +54 -54
  139. package/dist/collection/components/kup-planner/kup-planner-state.js +16 -0
  140. package/dist/collection/components/kup-planner/kup-planner.js +1725 -1352
  141. package/dist/collection/components/kup-probe/kup-probe.js +358 -358
  142. package/dist/collection/components/kup-progress-bar/kup-progress-bar-declarations.js +14 -14
  143. package/dist/collection/components/kup-progress-bar/kup-progress-bar.js +405 -405
  144. package/dist/collection/components/kup-qlik/kup-qlik-declarations.js +1 -1
  145. package/dist/collection/components/kup-qlik/kup-qlik.js +326 -326
  146. package/dist/collection/components/kup-radio/kup-radio-declarations.js +12 -12
  147. package/dist/collection/components/kup-radio/kup-radio.js +398 -398
  148. package/dist/collection/components/kup-rating/kup-rating-declarations.js +11 -11
  149. package/dist/collection/components/kup-rating/kup-rating.js +332 -332
  150. package/dist/collection/components/kup-snackbar/kup-snackbar-declarations.js +13 -13
  151. package/dist/collection/components/kup-snackbar/kup-snackbar.js +389 -389
  152. package/dist/collection/components/kup-spinner/kup-spinner-declarations.js +15 -15
  153. package/dist/collection/components/kup-spinner/kup-spinner.js +468 -468
  154. package/dist/collection/components/kup-state/kup-state.js +1 -1
  155. package/dist/collection/components/kup-state/kup-store.js +1 -1
  156. package/dist/collection/components/kup-state/mock-store.js +13 -13
  157. package/dist/collection/components/kup-switch/kup-switch-declarations.js +12 -12
  158. package/dist/collection/components/kup-switch/kup-switch.js +402 -402
  159. package/dist/collection/components/kup-tab-bar/kup-tab-bar-declarations.js +10 -10
  160. package/dist/collection/components/kup-tab-bar/kup-tab-bar.js +443 -443
  161. package/dist/collection/components/kup-text-field/kup-text-field-declarations.js +35 -35
  162. package/dist/collection/components/kup-text-field/kup-text-field.js +1193 -1189
  163. package/dist/collection/components/kup-time-picker/kup-time-picker-declarations.js +14 -14
  164. package/dist/collection/components/kup-time-picker/kup-time-picker.js +921 -921
  165. package/dist/collection/components/kup-tree/kup-tree-declarations.js +43 -43
  166. package/dist/collection/components/kup-tree/kup-tree-faker.js +305 -305
  167. package/dist/collection/components/kup-tree/kup-tree-state.js +15 -15
  168. package/dist/collection/components/kup-tree/kup-tree.js +2479 -2479
  169. package/dist/collection/f-components/f-button/f-button-declarations.js +17 -17
  170. package/dist/collection/f-components/f-button/f-button.js +91 -91
  171. package/dist/collection/f-components/f-cell/f-cell-declarations.js +158 -158
  172. package/dist/collection/f-components/f-cell/f-cell.js +429 -429
  173. package/dist/collection/f-components/f-checkbox/f-checkbox-declarations.js +1 -1
  174. package/dist/collection/f-components/f-checkbox/f-checkbox.js +16 -16
  175. package/dist/collection/f-components/f-chip/f-chip-declarations.js +15 -15
  176. package/dist/collection/f-components/f-chip/f-chip.js +101 -101
  177. package/dist/collection/f-components/f-image/f-image-declarations.js +8 -8
  178. package/dist/collection/f-components/f-image/f-image.js +100 -100
  179. package/dist/collection/f-components/f-paginator/f-paginator-declarations.js +5 -5
  180. package/dist/collection/f-components/f-paginator/f-paginator-utils.js +28 -28
  181. package/dist/collection/f-components/f-paginator/f-paginator.js +86 -86
  182. package/dist/collection/f-components/f-switch/f-switch-declarations.js +1 -1
  183. package/dist/collection/f-components/f-switch/f-switch.js +12 -12
  184. package/dist/collection/f-components/f-text-field/f-text-field-declarations.js +1 -1
  185. package/dist/collection/f-components/f-text-field/f-text-field-mdc.js +29 -29
  186. package/dist/collection/f-components/f-text-field/f-text-field.js +151 -151
  187. package/dist/collection/managers/kup-data/kup-data-cell-helper.js +86 -86
  188. package/dist/collection/managers/kup-data/kup-data-column-helper.js +300 -300
  189. package/dist/collection/managers/kup-data/kup-data-declarations.js +10 -10
  190. package/dist/collection/managers/kup-data/kup-data-node-helper.js +165 -165
  191. package/dist/collection/managers/kup-data/kup-data-row-helper.js +28 -28
  192. package/dist/collection/managers/kup-data/kup-data.js +499 -499
  193. package/dist/collection/managers/kup-dates/kup-dates-declarations.js +43 -43
  194. package/dist/collection/managers/kup-dates/kup-dates.js +654 -654
  195. package/dist/collection/managers/kup-debug/kup-debug-declarations.js +20 -20
  196. package/dist/collection/managers/kup-debug/kup-debug.js +670 -670
  197. package/dist/collection/managers/kup-dynamic-position/kup-dynamic-position-declarations.js +27 -27
  198. package/dist/collection/managers/kup-dynamic-position/kup-dynamic-position.js +244 -244
  199. package/dist/collection/managers/kup-interact/kup-interact-declarations.js +49 -49
  200. package/dist/collection/managers/kup-interact/kup-interact.js +397 -397
  201. package/dist/collection/managers/kup-language/kup-language-declarations.js +211 -211
  202. package/dist/collection/managers/kup-language/kup-language.js +151 -151
  203. package/dist/collection/managers/kup-manager/kup-manager-declarations.js +1 -1
  204. package/dist/collection/managers/kup-manager/kup-manager.js +303 -303
  205. package/dist/collection/managers/kup-math/kup-math-declarations.js +13 -13
  206. package/dist/collection/managers/kup-math/kup-math-helper.js +39 -39
  207. package/dist/collection/managers/kup-math/kup-math.js +413 -413
  208. package/dist/collection/managers/kup-objects/kup-objects-declarations.js +1 -1
  209. package/dist/collection/managers/kup-objects/kup-objects.js +387 -387
  210. package/dist/collection/managers/kup-scroll-on-hover/kup-scroll-on-hover-declarations.js +10 -10
  211. package/dist/collection/managers/kup-scroll-on-hover/kup-scroll-on-hover.js +334 -334
  212. package/dist/collection/managers/kup-search/kup-search-declarations.js +1 -1
  213. package/dist/collection/managers/kup-search/kup-search.js +75 -75
  214. package/dist/collection/managers/kup-theme/kup-theme-declarations.js +177 -177
  215. package/dist/collection/managers/kup-theme/kup-theme.js +715 -715
  216. package/dist/collection/managers/kup-toolbar/kup-toolbar-declarations.js +9 -9
  217. package/dist/collection/managers/kup-toolbar/kup-toolbar.js +111 -111
  218. package/dist/collection/managers/kup-tooltip/kup-tooltip-declarations.js +1 -1
  219. package/dist/collection/managers/kup-tooltip/kup-tooltip.js +229 -229
  220. package/dist/collection/types/GenericTypes.js +54 -54
  221. package/dist/collection/utils/cell-utils.js +156 -156
  222. package/dist/collection/utils/filters/filters-column-menu.js +360 -360
  223. package/dist/collection/utils/filters/filters-declarations.js +25 -25
  224. package/dist/collection/utils/filters/filters-rows.js +238 -238
  225. package/dist/collection/utils/filters/filters-tree-items.js +117 -117
  226. package/dist/collection/utils/filters/filters.js +287 -287
  227. package/dist/collection/utils/kup-column-menu/kup-column-menu-declarations.js +20 -20
  228. package/dist/collection/utils/kup-column-menu/kup-column-menu.js +751 -751
  229. package/dist/collection/utils/utils.js +84 -80
  230. package/dist/collection/variables/GenericVariables.js +4 -4
  231. package/dist/components/kup-accordion.js +355 -355
  232. package/dist/components/kup-autocomplete2.js +31799 -31760
  233. package/dist/components/kup-box2.js +1469 -1405
  234. package/dist/components/kup-calendar.js +9788 -10280
  235. package/dist/components/kup-card.js +1 -1
  236. package/dist/components/kup-cell.js +325 -325
  237. package/dist/components/kup-chart.js +1 -1
  238. package/dist/components/kup-checkbox.js +1 -1
  239. package/dist/components/kup-chip.js +1 -1
  240. package/dist/components/kup-color-picker.js +1 -1
  241. package/dist/components/kup-combobox.js +1 -1
  242. package/dist/components/kup-dash-list.js +276 -276
  243. package/dist/components/kup-dash2.js +220 -220
  244. package/dist/components/kup-dashboard.js +549 -549
  245. package/dist/components/kup-data-table.js +1 -1
  246. package/dist/components/kup-date-picker.js +1 -1
  247. package/dist/components/kup-dialog.js +1 -1
  248. package/dist/components/kup-drawer.js +295 -295
  249. package/dist/components/kup-dropdown-button.js +1 -1
  250. package/dist/components/kup-echart2.js +7312 -6765
  251. package/dist/components/kup-family-tree.js +604 -604
  252. package/dist/components/kup-form.js +1 -1
  253. package/dist/components/kup-gauge.js +1 -1
  254. package/dist/components/kup-grid2.js +251 -251
  255. package/dist/components/kup-iframe.js +249 -249
  256. package/dist/components/kup-image-list.js +407 -407
  257. package/dist/components/kup-image.js +1 -1
  258. package/dist/components/kup-lazy.js +344 -344
  259. package/dist/components/kup-list.js +1 -1
  260. package/dist/components/kup-magic-box.js +461 -461
  261. package/dist/components/kup-nav-bar.js +284 -284
  262. package/dist/components/kup-numeric-picker.js +529 -529
  263. package/dist/components/kup-photo-frame.js +300 -300
  264. package/dist/components/kup-planner.js +1342 -1189
  265. package/dist/components/kup-probe.js +399 -399
  266. package/dist/components/kup-progress-bar.js +1 -1
  267. package/dist/components/kup-qlik.js +296 -296
  268. package/dist/components/kup-radio.js +1 -1
  269. package/dist/components/kup-rating.js +1 -1
  270. package/dist/components/kup-snackbar.js +273 -273
  271. package/dist/components/kup-spinner.js +1 -1
  272. package/dist/components/kup-switch.js +1 -1
  273. package/dist/components/kup-tab-bar.js +1 -1
  274. package/dist/components/kup-text-field.js +1 -1
  275. package/dist/components/kup-time-picker.js +1 -1
  276. package/dist/components/kup-tree.js +1 -1
  277. package/dist/esm/{GenericVariables-665de00a.js → GenericVariables-6dfdd433.js} +3 -3
  278. package/dist/esm/{component-120651a0.js → component-e86c51ea.js} +81 -2
  279. package/dist/esm/{f-button-024f0cfe.js → f-button-c6a69f75.js} +99 -99
  280. package/dist/esm/{f-button-declarations-b1b4cac4.js → f-button-declarations-fd4965d1.js} +16 -16
  281. package/dist/esm/{f-cell-90240a8c.js → f-cell-5822ea68.js} +472 -472
  282. package/dist/esm/{f-checkbox-9b3f5f5b.js → f-checkbox-c15911de.js} +23 -23
  283. package/dist/esm/{f-chip-2238ad43.js → f-chip-f46a03f5.js} +125 -125
  284. package/dist/esm/{f-image-f2e9bf79.js → f-image-f57832fa.js} +107 -107
  285. package/dist/esm/{f-paginator-utils-8cb3c023.js → f-paginator-utils-bafc463d.js} +1548 -1548
  286. package/dist/esm/{f-text-field-d231982c.js → f-text-field-15850e05.js} +172 -172
  287. package/dist/esm/{f-text-field-mdc-cee583ea.js → f-text-field-mdc-a1b4a919.js} +27 -28
  288. package/dist/esm/{index-8bd38435.js → index-238342f2.js} +78 -24
  289. package/dist/esm/ketchup.js +4 -4
  290. package/dist/esm/kup-accordion.entry.js +199 -200
  291. package/dist/esm/kup-autocomplete_27.entry.js +17546 -17508
  292. package/dist/esm/kup-box.entry.js +1294 -1232
  293. package/dist/esm/kup-calendar.entry.js +9557 -10050
  294. package/dist/esm/kup-cell.entry.js +172 -172
  295. package/dist/esm/kup-dash-list.entry.js +106 -106
  296. package/dist/esm/kup-dash_2.entry.js +162 -162
  297. package/dist/esm/kup-dashboard.entry.js +400 -401
  298. package/dist/esm/kup-drawer.entry.js +138 -138
  299. package/dist/esm/kup-echart.entry.js +7145 -6598
  300. package/dist/esm/kup-family-tree.entry.js +439 -439
  301. package/dist/esm/kup-iframe.entry.js +94 -94
  302. package/dist/esm/kup-image-list.entry.js +255 -256
  303. package/dist/esm/kup-lazy.entry.js +186 -186
  304. package/dist/esm/kup-magic-box.entry.js +298 -298
  305. package/dist/esm/{kup-manager-d1da769e.js → kup-manager-89dd9137.js} +7287 -7287
  306. package/dist/esm/kup-nav-bar.entry.js +130 -130
  307. package/dist/esm/kup-numeric-picker.entry.js +367 -368
  308. package/dist/esm/kup-photo-frame.entry.js +144 -144
  309. package/dist/esm/kup-planner.entry.js +1151 -1009
  310. package/dist/esm/kup-probe.entry.js +246 -246
  311. package/dist/esm/kup-qlik.entry.js +138 -138
  312. package/dist/esm/kup-snackbar.entry.js +116 -116
  313. package/dist/esm/loader.js +4 -4
  314. package/dist/ketchup/ketchup.esm.js +1 -1
  315. package/dist/ketchup/{p-83435e6c.entry.js → p-01d44efe.entry.js} +1 -1
  316. package/dist/ketchup/{p-8b46e7ce.js → p-1a8a06de.js} +1 -1
  317. package/dist/ketchup/{p-eda7f130.js → p-206245c0.js} +1 -1
  318. package/dist/ketchup/p-4bd63e97.entry.js +25 -0
  319. package/dist/ketchup/{p-651d89c8.entry.js → p-4da77173.entry.js} +1 -1
  320. package/dist/ketchup/{p-e1f1e661.entry.js → p-514dcb7d.entry.js} +1 -1
  321. package/dist/ketchup/{p-37067ee6.entry.js → p-51573263.entry.js} +1 -1
  322. package/dist/ketchup/{p-9f9b6656.js → p-54248440.js} +1 -1
  323. package/dist/ketchup/{p-1ad628fb.entry.js → p-5dfa5c49.entry.js} +1 -1
  324. package/dist/ketchup/{p-10d84b1b.js → p-6507e9eb.js} +7 -6
  325. package/dist/ketchup/{p-410c102a.js → p-673bb93e.js} +1 -1
  326. package/dist/ketchup/{p-063d4c27.entry.js → p-688478e9.entry.js} +1 -1
  327. package/dist/ketchup/p-6a5d95df.entry.js +1 -0
  328. package/dist/ketchup/p-6ec8629e.js +30 -0
  329. package/dist/ketchup/{p-a84f1d24.entry.js → p-785e8d74.entry.js} +1 -1
  330. package/dist/ketchup/{p-43b67de4.entry.js → p-78cc5a2d.entry.js} +1 -1
  331. package/dist/ketchup/{p-c42b80c1.entry.js → p-799f7f10.entry.js} +1 -1
  332. package/dist/ketchup/p-7e757c27.entry.js +1 -0
  333. package/dist/ketchup/p-843253dd.entry.js +1 -0
  334. package/dist/ketchup/{p-0d7d59c7.entry.js → p-84d3f676.entry.js} +1 -1
  335. package/dist/ketchup/p-8c1edebd.js +2 -0
  336. package/dist/ketchup/{p-5f3680f2.js → p-a5f15864.js} +1 -1
  337. package/dist/ketchup/p-af7202ff.entry.js +1 -0
  338. package/dist/ketchup/{p-89743989.entry.js → p-ba959bb5.entry.js} +1 -1
  339. package/dist/ketchup/{p-39a55c47.js → p-c1931214.js} +1 -1
  340. package/dist/ketchup/{p-3cf64473.js → p-c354c5d0.js} +1 -1
  341. package/dist/ketchup/p-cd8512d9.entry.js +39 -0
  342. package/dist/ketchup/{p-3432ebaf.entry.js → p-d4f86197.entry.js} +2 -2
  343. package/dist/ketchup/{p-163b18b9.entry.js → p-e59c2bc0.entry.js} +1 -1
  344. package/dist/ketchup/{p-f876125d.entry.js → p-f2fda43b.entry.js} +1 -1
  345. package/dist/ketchup/p-f4b6aa3f.entry.js +1 -0
  346. package/dist/ketchup/p-f4f5170c.entry.js +1 -0
  347. package/dist/ketchup/{p-27a56c87.js → p-fb03f2f5.js} +2 -2
  348. package/dist/loader/index.d.ts +1 -1
  349. package/dist/types/components/kup-accordion/kup-accordion-declarations.d.ts +20 -20
  350. package/dist/types/components/kup-accordion/kup-accordion.d.ts +80 -80
  351. package/dist/types/components/kup-autocomplete/kup-autocomplete-declarations.d.ts +35 -35
  352. package/dist/types/components/kup-autocomplete/kup-autocomplete.d.ts +119 -119
  353. package/dist/types/components/kup-badge/kup-badge-declarations.d.ts +9 -9
  354. package/dist/types/components/kup-badge/kup-badge.d.ts +51 -51
  355. package/dist/types/components/kup-box/kup-box-declarations.d.ts +114 -113
  356. package/dist/types/components/kup-box/kup-box-state.d.ts +10 -10
  357. package/dist/types/components/kup-box/kup-box.d.ts +275 -270
  358. package/dist/types/components/kup-button/kup-button-declarations.d.ts +24 -24
  359. package/dist/types/components/kup-button/kup-button.d.ts +111 -111
  360. package/dist/types/components/kup-button-list/kup-button-list-declarations.d.ts +24 -24
  361. package/dist/types/components/kup-button-list/kup-button-list.d.ts +82 -82
  362. package/dist/types/components/kup-calendar/kup-calendar-declarations.d.ts +70 -70
  363. package/dist/types/components/kup-calendar/kup-calendar.d.ts +100 -100
  364. package/dist/types/components/kup-card/box/kup-card-box.d.ts +50 -50
  365. package/dist/types/components/kup-card/built-in/kup-card-built-in.d.ts +39 -39
  366. package/dist/types/components/kup-card/built-in/kup-card-calendar.d.ts +2 -2
  367. package/dist/types/components/kup-card/built-in/kup-card-clock.d.ts +2 -2
  368. package/dist/types/components/kup-card/built-in/kup-card-column-drop-menu.d.ts +3 -3
  369. package/dist/types/components/kup-card/built-in/kup-card-message-box.d.ts +3 -3
  370. package/dist/types/components/kup-card/built-in/kup-card-numeric.d.ts +2 -2
  371. package/dist/types/components/kup-card/collapsible/kup-card-collapsible.d.ts +14 -14
  372. package/dist/types/components/kup-card/dialog/kup-card-dialog.d.ts +44 -44
  373. package/dist/types/components/kup-card/free/kup-card-free.d.ts +14 -14
  374. package/dist/types/components/kup-card/kup-card-declarations.d.ts +236 -236
  375. package/dist/types/components/kup-card/kup-card-helper.d.ts +27 -27
  376. package/dist/types/components/kup-card/kup-card.d.ts +159 -159
  377. package/dist/types/components/kup-card/scalable/kup-card-scalable.d.ts +56 -56
  378. package/dist/types/components/kup-card/standard/kup-card-standard.d.ts +92 -92
  379. package/dist/types/components/kup-cell/kup-cell-declarations.d.ts +10 -10
  380. package/dist/types/components/kup-cell/kup-cell.d.ts +67 -67
  381. package/dist/types/components/kup-chart/kup-chart-builder.d.ts +7 -7
  382. package/dist/types/components/kup-chart/kup-chart-declarations.d.ts +135 -135
  383. package/dist/types/components/kup-chart/kup-chart.d.ts +170 -170
  384. package/dist/types/components/kup-checkbox/kup-checkbox-declarations.d.ts +17 -17
  385. package/dist/types/components/kup-checkbox/kup-checkbox.d.ts +85 -85
  386. package/dist/types/components/kup-chip/kup-chip-declarations.d.ts +22 -22
  387. package/dist/types/components/kup-chip/kup-chip.d.ts +89 -89
  388. package/dist/types/components/kup-color-picker/kup-color-picker-declarations.d.ts +15 -15
  389. package/dist/types/components/kup-color-picker/kup-color-picker.d.ts +89 -89
  390. package/dist/types/components/kup-combobox/kup-combobox-declarations.d.ts +24 -24
  391. package/dist/types/components/kup-combobox/kup-combobox.d.ts +95 -95
  392. package/dist/types/components/kup-dash/kup-dash.d.ts +33 -33
  393. package/dist/types/components/kup-dash-list/kup-dash-list.d.ts +22 -22
  394. package/dist/types/components/kup-dashboard/kup-dashboard-declarations.d.ts +61 -61
  395. package/dist/types/components/kup-dashboard/kup-dashboard.d.ts +80 -80
  396. package/dist/types/components/kup-data-table/kup-data-table-declarations.d.ts +254 -254
  397. package/dist/types/components/kup-data-table/kup-data-table-helper.d.ts +25 -25
  398. package/dist/types/components/kup-data-table/kup-data-table-state.d.ts +36 -36
  399. package/dist/types/components/kup-data-table/kup-data-table.d.ts +444 -444
  400. package/dist/types/components/kup-date-picker/kup-date-picker-declarations.d.ts +20 -20
  401. package/dist/types/components/kup-date-picker/kup-date-picker.d.ts +110 -110
  402. package/dist/types/components/kup-dialog/kup-dialog-declarations.d.ts +26 -26
  403. package/dist/types/components/kup-dialog/kup-dialog.d.ts +77 -77
  404. package/dist/types/components/kup-drawer/kup-drawer-declarations.d.ts +9 -9
  405. package/dist/types/components/kup-drawer/kup-drawer.d.ts +74 -74
  406. package/dist/types/components/kup-dropdown-button/kup-dropdown-button-declarations.d.ts +21 -21
  407. package/dist/types/components/kup-dropdown-button/kup-dropdown-button.d.ts +161 -161
  408. package/dist/types/components/kup-echart/kup-echart-declarations.d.ts +62 -62
  409. package/dist/types/components/kup-echart/kup-echart.d.ts +111 -111
  410. package/dist/types/components/kup-family-tree/kup-family-tree-declarations.d.ts +38 -38
  411. package/dist/types/components/kup-family-tree/kup-family-tree.d.ts +87 -87
  412. package/dist/types/components/kup-form/kup-form-declarations.d.ts +64 -64
  413. package/dist/types/components/kup-form/kup-form.d.ts +83 -83
  414. package/dist/types/components/kup-gauge/kup-gauge-declarations.d.ts +25 -25
  415. package/dist/types/components/kup-gauge/kup-gauge.d.ts +147 -147
  416. package/dist/types/components/kup-grid/kup-grid-declarations.d.ts +9 -9
  417. package/dist/types/components/kup-grid/kup-grid.d.ts +48 -48
  418. package/dist/types/components/kup-iframe/kup-iframe-declarations.d.ts +9 -9
  419. package/dist/types/components/kup-iframe/kup-iframe.d.ts +49 -49
  420. package/dist/types/components/kup-image/canvas/kup-image-canvas-declarations.d.ts +23 -23
  421. package/dist/types/components/kup-image/canvas/kup-image-canvas-helper.d.ts +2 -2
  422. package/dist/types/components/kup-image/canvas/kup-image-canvas.d.ts +28 -28
  423. package/dist/types/components/kup-image/kup-image-declarations.d.ts +19 -19
  424. package/dist/types/components/kup-image/kup-image.d.ts +103 -103
  425. package/dist/types/components/kup-image-list/kup-image-list-declarations.d.ts +14 -14
  426. package/dist/types/components/kup-image-list/kup-image-list-state.d.ts +6 -6
  427. package/dist/types/components/kup-image-list/kup-image-list.d.ts +73 -73
  428. package/dist/types/components/kup-lazy/kup-lazy-declarations.d.ts +18 -18
  429. package/dist/types/components/kup-lazy/kup-lazy.d.ts +78 -78
  430. package/dist/types/components/kup-list/kup-list-declarations.d.ts +48 -48
  431. package/dist/types/components/kup-list/kup-list-helper.d.ts +6 -6
  432. package/dist/types/components/kup-list/kup-list.d.ts +128 -128
  433. package/dist/types/components/kup-magic-box/kup-magic-box-declarations.d.ts +21 -21
  434. package/dist/types/components/kup-magic-box/kup-magic-box.d.ts +65 -65
  435. package/dist/types/components/kup-nav-bar/kup-nav-bar-declarations.d.ts +19 -19
  436. package/dist/types/components/kup-nav-bar/kup-nav-bar.d.ts +65 -65
  437. package/dist/types/components/kup-numeric-picker/kup-numeric-picker-declarations.d.ts +19 -19
  438. package/dist/types/components/kup-numeric-picker/kup-numeric-picker.d.ts +121 -121
  439. package/dist/types/components/kup-photo-frame/kup-photo-frame-declarations.d.ts +9 -9
  440. package/dist/types/components/kup-photo-frame/kup-photo-frame.d.ts +61 -61
  441. package/dist/types/components/kup-planner/kup-planner-declarations.d.ts +127 -106
  442. package/dist/types/components/kup-planner/kup-planner-helper.d.ts +6 -6
  443. package/dist/types/components/kup-planner/kup-planner-state.d.ts +13 -0
  444. package/dist/types/components/kup-planner/kup-planner.d.ts +266 -212
  445. package/dist/types/components/kup-probe/kup-probe.d.ts +72 -72
  446. package/dist/types/components/kup-progress-bar/kup-progress-bar-declarations.d.ts +13 -13
  447. package/dist/types/components/kup-progress-bar/kup-progress-bar.d.ts +69 -69
  448. package/dist/types/components/kup-qlik/kup-qlik-declarations.d.ts +19 -19
  449. package/dist/types/components/kup-qlik/kup-qlik.d.ts +100 -100
  450. package/dist/types/components/kup-radio/kup-radio-declarations.d.ts +23 -23
  451. package/dist/types/components/kup-radio/kup-radio.d.ts +80 -80
  452. package/dist/types/components/kup-rating/kup-rating-declarations.d.ts +14 -14
  453. package/dist/types/components/kup-rating/kup-rating.d.ts +62 -62
  454. package/dist/types/components/kup-snackbar/kup-snackbar-declarations.d.ts +12 -12
  455. package/dist/types/components/kup-snackbar/kup-snackbar.d.ts +84 -84
  456. package/dist/types/components/kup-spinner/kup-spinner-declarations.d.ts +14 -14
  457. package/dist/types/components/kup-spinner/kup-spinner.d.ts +79 -79
  458. package/dist/types/components/kup-state/kup-state.d.ts +3 -3
  459. package/dist/types/components/kup-state/kup-store.d.ts +4 -4
  460. package/dist/types/components/kup-state/mock-store.d.ts +8 -8
  461. package/dist/types/components/kup-switch/kup-switch-declarations.d.ts +15 -15
  462. package/dist/types/components/kup-switch/kup-switch.d.ts +80 -80
  463. package/dist/types/components/kup-tab-bar/kup-tab-bar-declarations.d.ts +21 -21
  464. package/dist/types/components/kup-tab-bar/kup-tab-bar.d.ts +77 -77
  465. package/dist/types/components/kup-text-field/kup-text-field-declarations.d.ts +38 -38
  466. package/dist/types/components/kup-text-field/kup-text-field.d.ts +253 -253
  467. package/dist/types/components/kup-time-picker/kup-time-picker-declarations.d.ts +17 -17
  468. package/dist/types/components/kup-time-picker/kup-time-picker.d.ts +125 -125
  469. package/dist/types/components/kup-tree/kup-tree-declarations.d.ts +97 -97
  470. package/dist/types/components/kup-tree/kup-tree-faker.d.ts +54 -54
  471. package/dist/types/components/kup-tree/kup-tree-state.d.ts +14 -14
  472. package/dist/types/components/kup-tree/kup-tree.d.ts +362 -362
  473. package/dist/types/components.d.ts +98 -2
  474. package/dist/types/f-components/f-button/f-button-declarations.d.ts +41 -41
  475. package/dist/types/f-components/f-button/f-button.d.ts +3 -3
  476. package/dist/types/f-components/f-cell/f-cell-declarations.d.ts +162 -162
  477. package/dist/types/f-components/f-cell/f-cell.d.ts +3 -3
  478. package/dist/types/f-components/f-checkbox/f-checkbox-declarations.d.ts +15 -15
  479. package/dist/types/f-components/f-checkbox/f-checkbox.d.ts +3 -3
  480. package/dist/types/f-components/f-chip/f-chip-declarations.d.ts +29 -29
  481. package/dist/types/f-components/f-chip/f-chip.d.ts +3 -3
  482. package/dist/types/f-components/f-image/f-image-declarations.d.ts +36 -36
  483. package/dist/types/f-components/f-image/f-image.d.ts +3 -3
  484. package/dist/types/f-components/f-paginator/f-paginator-declarations.d.ts +22 -22
  485. package/dist/types/f-components/f-paginator/f-paginator-utils.d.ts +2 -2
  486. package/dist/types/f-components/f-paginator/f-paginator.d.ts +3 -3
  487. package/dist/types/f-components/f-switch/f-switch-declarations.d.ts +14 -14
  488. package/dist/types/f-components/f-switch/f-switch.d.ts +3 -3
  489. package/dist/types/f-components/f-text-field/f-text-field-declarations.d.ts +42 -42
  490. package/dist/types/f-components/f-text-field/f-text-field-mdc.d.ts +6 -6
  491. package/dist/types/f-components/f-text-field/f-text-field.d.ts +3 -3
  492. package/dist/types/managers/kup-data/kup-data-cell-helper.d.ts +31 -31
  493. package/dist/types/managers/kup-data/kup-data-column-helper.d.ts +39 -39
  494. package/dist/types/managers/kup-data/kup-data-declarations.d.ts +173 -173
  495. package/dist/types/managers/kup-data/kup-data-node-helper.d.ts +44 -44
  496. package/dist/types/managers/kup-data/kup-data-row-helper.d.ts +14 -14
  497. package/dist/types/managers/kup-data/kup-data.d.ts +86 -86
  498. package/dist/types/managers/kup-dates/kup-dates-declarations.d.ts +39 -39
  499. package/dist/types/managers/kup-dates/kup-dates.d.ts +207 -207
  500. package/dist/types/managers/kup-debug/kup-debug-declarations.d.ts +38 -38
  501. package/dist/types/managers/kup-debug/kup-debug.d.ts +95 -95
  502. package/dist/types/managers/kup-dynamic-position/kup-dynamic-position-declarations.d.ts +50 -50
  503. package/dist/types/managers/kup-dynamic-position/kup-dynamic-position.d.ts +61 -61
  504. package/dist/types/managers/kup-interact/kup-interact-declarations.d.ts +128 -128
  505. package/dist/types/managers/kup-interact/kup-interact.d.ts +105 -105
  506. package/dist/types/managers/kup-language/kup-language-declarations.d.ts +225 -225
  507. package/dist/types/managers/kup-language/kup-language.d.ts +52 -52
  508. package/dist/types/managers/kup-manager/kup-manager-declarations.d.ts +162 -162
  509. package/dist/types/managers/kup-manager/kup-manager.d.ts +95 -95
  510. package/dist/types/managers/kup-math/kup-math-declarations.d.ts +33 -33
  511. package/dist/types/managers/kup-math/kup-math-helper.d.ts +17 -17
  512. package/dist/types/managers/kup-math/kup-math.d.ts +147 -146
  513. package/dist/types/managers/kup-objects/kup-objects-declarations.d.ts +15 -15
  514. package/dist/types/managers/kup-objects/kup-objects.d.ts +210 -210
  515. package/dist/types/managers/kup-scroll-on-hover/kup-scroll-on-hover-declarations.d.ts +28 -28
  516. package/dist/types/managers/kup-scroll-on-hover/kup-scroll-on-hover.d.ts +62 -62
  517. package/dist/types/managers/kup-search/kup-search-declarations.d.ts +7 -7
  518. package/dist/types/managers/kup-search/kup-search.d.ts +20 -20
  519. package/dist/types/managers/kup-theme/kup-theme-declarations.d.ts +185 -185
  520. package/dist/types/managers/kup-theme/kup-theme.d.ts +127 -127
  521. package/dist/types/managers/kup-toolbar/kup-toolbar-declarations.d.ts +8 -8
  522. package/dist/types/managers/kup-toolbar/kup-toolbar.d.ts +39 -39
  523. package/dist/types/managers/kup-tooltip/kup-tooltip-declarations.d.ts +8 -8
  524. package/dist/types/managers/kup-tooltip/kup-tooltip.d.ts +51 -51
  525. package/dist/types/stencil-public-runtime.d.ts +1 -0
  526. package/dist/types/types/GenericTypes.d.ts +110 -110
  527. package/dist/types/utils/cell-utils.d.ts +10 -10
  528. package/dist/types/utils/filters/filters-column-menu.d.ts +96 -96
  529. package/dist/types/utils/filters/filters-declarations.d.ts +39 -39
  530. package/dist/types/utils/filters/filters-rows.d.ts +30 -30
  531. package/dist/types/utils/filters/filters-tree-items.d.ts +19 -19
  532. package/dist/types/utils/filters/filters.d.ts +72 -72
  533. package/dist/types/utils/kup-column-menu/kup-column-menu-declarations.d.ts +19 -19
  534. package/dist/types/utils/kup-column-menu/kup-column-menu.d.ts +142 -142
  535. package/dist/types/utils/utils.d.ts +37 -35
  536. package/dist/types/variables/GenericVariables.d.ts +4 -4
  537. package/package.json +21 -16
  538. package/dist/cjs/tslib.es6-386654de.js +0 -87
  539. package/dist/esm/tslib.es6-8c2af864.js +0 -82
  540. package/dist/ketchup/p-0bcda0e2.entry.js +0 -1
  541. package/dist/ketchup/p-33aff1ca.entry.js +0 -25
  542. package/dist/ketchup/p-35b29b22.entry.js +0 -1
  543. package/dist/ketchup/p-36dac88e.js +0 -30
  544. package/dist/ketchup/p-489d55ff.entry.js +0 -39
  545. package/dist/ketchup/p-73c8d651.entry.js +0 -1
  546. package/dist/ketchup/p-7f59211b.js +0 -1
  547. package/dist/ketchup/p-9dcfbb1e.js +0 -2
  548. package/dist/ketchup/p-b2fd2dbf.entry.js +0 -1
  549. package/dist/ketchup/p-d1b050d0.entry.js +0 -27
  550. package/dist/ketchup/p-d6ea709e.entry.js +0 -1
  551. /package/dist/ketchup/{p-6c77a36c.js → p-0fd98ab4.js} +0 -0
  552. /package/dist/ketchup/{p-97e8ea42.js → p-ad2e21d2.js} +0 -0
@@ -1,751 +1,751 @@
1
- import { KupDynamicPositionPlacement, } from '../../managers/kup-dynamic-position/kup-dynamic-position-declarations';
2
- import { FiltersColumnMenu } from '../filters/filters-column-menu';
3
- import { FilterInterval, } from '../filters/filters-declarations';
4
- import { getValueForDisplay, getValueForDisplay2 } from '../cell-utils';
5
- import { FiltersRows } from '../filters/filters-rows';
6
- import { Filters } from '../filters/filters';
7
- import { KupLanguageColumn, KupLanguageSearch, KupLanguageGrouping, KupLanguageCheckbox, KupLanguageGeneric, KupLanguageRow, KupLanguageTotals, } from '../../managers/kup-language/kup-language-declarations';
8
- import { FButtonStyling } from '../../f-components/f-button/f-button-declarations';
9
- import { KupColumnMenuIds } from './kup-column-menu-declarations';
10
- import { KupDebugCategory } from '../../managers/kup-debug/kup-debug-declarations';
11
- import { FChipType, } from '../../f-components/f-chip/f-chip-declarations';
12
- import { KupDataNewColumnTypes, } from '../../managers/kup-data/kup-data-declarations';
13
- const dom = document.documentElement;
14
- /**
15
- * Definition and events of the column menu card.
16
- * @module KupColumnMenu
17
- */
18
- export class KupColumnMenu {
19
- constructor() {
20
- this.clickCb = null;
21
- this.filtersColumnMenuInstance = new FiltersColumnMenu();
22
- this.filtersRowsInstance = new FiltersRows();
23
- }
24
- /**
25
- * Function called by the component when the column menu must be opened.
26
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
27
- * @param {string} column - Name of the column.
28
- */
29
- open(comp, column) {
30
- this.filtersColumnMenuInstance.resetTextualFilters(comp.filters, column);
31
- }
32
- /**
33
- * Function called by the component when the column menu must be closed.
34
- * @param {HTMLKupCardElement} card - Column menu card.
35
- */
36
- close(card) {
37
- card.menuVisible = false;
38
- dom.ketchup.removeClickCallback(this.clickCb);
39
- dom.ketchup.dynamicPosition.stop(card);
40
- }
41
- /**
42
- * Function called to reposition the column menu card to the appropriate column.
43
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
44
- */
45
- reposition(comp, card) {
46
- const root = comp.rootElement.shadowRoot;
47
- if (root) {
48
- if (card) {
49
- const column = card.dataset.column;
50
- const wrapper = root.querySelector('th[data-column="' + column + '"]');
51
- if (dom.ketchup.dynamicPosition.isRegistered(card)) {
52
- dom.ketchup.dynamicPosition.changeAnchor(card, wrapper);
53
- }
54
- else {
55
- dom.ketchup.dynamicPosition.register(card, wrapper, 0, KupDynamicPositionPlacement.BOTTOM, true);
56
- }
57
- if (!this.clickCb) {
58
- this.clickCb = {
59
- cb: () => {
60
- this.close(card);
61
- },
62
- el: card,
63
- };
64
- }
65
- dom.ketchup.addClickCallback(this.clickCb, true);
66
- dom.ketchup.dynamicPosition.start(card);
67
- card.menuVisible = true;
68
- }
69
- }
70
- }
71
- /**
72
- * Function called by the column menu card to prepare its 'data' prop.
73
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
74
- * @param {KupDataColumn} column - Column of the menu.
75
- * @param {KupCardData} currentData - 'data' prop of the column menu card when it's already initialized.
76
- * @returns {GenericObject} 'data' prop of the column menu card.
77
- */
78
- prepData(comp, column, currentData) {
79
- const data = currentData ? Object.assign({}, currentData) : {};
80
- data.button = this.prepButton(comp, column);
81
- data.checkbox = this.prepCheckbox(comp, column);
82
- data.chip = this.prepChip(comp, column);
83
- data.datepicker = this.prepIntervalDatePicker(comp, column);
84
- data.object = column.objs
85
- ? column.objs
86
- : column.obj
87
- ? [column.obj]
88
- : null;
89
- data.switch = this.prepSwitch(comp, column, data.object);
90
- if (!currentData) {
91
- data.tabbar = this.prepTabBar(comp, column);
92
- data.text = [column.title];
93
- }
94
- data.textfield = this.prepTextfield(comp, column);
95
- data.timepicker = this.prepIntervalTimePicker(comp, column);
96
- return data;
97
- }
98
- /**
99
- * Handles the column menu's button prop.
100
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
101
- * @param {KupDataColumn} column - Column of the menu.
102
- * @returns {GenericObject[]} Buttons props.
103
- */
104
- prepButton(comp, column) {
105
- const props = [];
106
- if (!FiltersColumnMenu.isTree(comp) &&
107
- comp.showGroups) {
108
- props.push({
109
- className: 'printable',
110
- 'data-storage': {
111
- columnName: column.name,
112
- },
113
- icon: 'book',
114
- id: KupColumnMenuIds.BUTTON_GROUP,
115
- title: comp.getGroupByName(column.name) != null
116
- ? dom.ketchup.language.translate(KupLanguageGrouping.DISABLE)
117
- : dom.ketchup.language.translate(KupLanguageGrouping.ENABLE),
118
- });
119
- }
120
- if (comp.removableColumns) {
121
- props.push({
122
- className: 'printable',
123
- 'data-storage': {
124
- column: column,
125
- },
126
- icon: 'table-column-remove',
127
- id: KupColumnMenuIds.BUTTON_REMOVE,
128
- title: dom.ketchup.language.translate(KupLanguageColumn.HIDE),
129
- });
130
- }
131
- if (comp.enableExtraColumns &&
132
- (dom.ketchup.objects.canObjHaveExtraColumns(column.obj) ||
133
- dom.ketchup.objects.canObjsHaveExtraColumns(column.objs))) {
134
- props.push({
135
- className: 'printable',
136
- 'data-storage': {
137
- columnName: column.name,
138
- },
139
- icon: 'table-column-plus-after',
140
- id: KupColumnMenuIds.BUTTON_ADD_COLUMNS,
141
- title: dom.ketchup.language.translate(KupLanguageColumn.ADD),
142
- });
143
- props.push({
144
- className: 'printable',
145
- label: dom.ketchup.language.translate(KupLanguageGeneric.APPLY),
146
- id: KupColumnMenuIds.BUTTON_APPLY,
147
- styling: FButtonStyling.OUTLINED,
148
- title: dom.ketchup.language.translate(KupLanguageGeneric.APPLY),
149
- });
150
- }
151
- return props;
152
- }
153
- /**
154
- * Handles the column menu's checkbox prop.
155
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
156
- * @param {KupDataColumn} column - Column of the menu.
157
- * @returns {GenericObject[]} Checkboxes props.
158
- */
159
- prepCheckbox(comp, column) {
160
- const props = [];
161
- if (comp.showFilters &&
162
- (dom.ketchup.objects.isStringObject(column.obj) ||
163
- dom.ketchup.objects.isCheckbox(column.obj))) {
164
- const checkBoxesFilter = this.filtersColumnMenuInstance.getCheckBoxFilterValues(comp.filters, column.name);
165
- const columnValues = comp.getColumnValues(column);
166
- if (columnValues.length > 0) {
167
- props.push({
168
- checked: checkBoxesFilter.length == 0,
169
- 'data-storage': {
170
- column: column,
171
- value: null,
172
- },
173
- id: KupColumnMenuIds.CHECKBOX_GLOBAL,
174
- label: dom.ketchup.language.translate(KupLanguageCheckbox.ALL),
175
- });
176
- }
177
- for (let index = 0; index < columnValues.length; index++) {
178
- let label = getValueForDisplay2(columnValues[index], column);
179
- if (dom.ketchup.objects.isCheckbox(column.obj)) {
180
- if (columnValues[index].value == '1') {
181
- label = dom.ketchup.language.translate(KupLanguageCheckbox.CHECKED);
182
- }
183
- else {
184
- label = dom.ketchup.language.translate(KupLanguageCheckbox.UNCHECKED);
185
- }
186
- }
187
- props.push({
188
- checked: Filters.valuesArrayContainsValue(checkBoxesFilter, columnValues[index].value),
189
- 'data-storage': {
190
- column: column,
191
- value: columnValues[index].value,
192
- displayedValue: getValueForDisplay2(columnValues[index], column),
193
- },
194
- label: label,
195
- });
196
- }
197
- }
198
- return props;
199
- }
200
- /**
201
- * Handles the column menu's chip prop.
202
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
203
- * @param {KupDataColumn} column - Column of the menu.
204
- * @returns {GenericObject[]} Chips props (only 1 is handled).
205
- */
206
- prepChip(comp, column) {
207
- let props = [];
208
- const chipProps = { data: [] };
209
- if (column.children) {
210
- const chipData = [];
211
- for (let index = 0; index < column.children.length; index++) {
212
- const child = column.children[index];
213
- let childColumn = null;
214
- try {
215
- if (FiltersColumnMenu.isTree(comp)) {
216
- comp.columns;
217
- childColumn = comp.columns.find((x) => x.name === child.name);
218
- }
219
- else {
220
- childColumn = comp.data.columns.find((x) => x.name === child.name);
221
- }
222
- }
223
- catch (error) {
224
- dom.ketchup.debug.logMessage(this, 'Child column not found (' + child.name + ')!' + error, KupDebugCategory.ERROR);
225
- }
226
- chipData.push({
227
- icon: child.icon ? child.icon : null,
228
- value: childColumn ? childColumn.title : '*Not found!',
229
- obj: child.obj ? child.obj : null,
230
- id: childColumn ? childColumn.name : '*NOTFND',
231
- });
232
- }
233
- chipProps.dataSet = { initialData: [...chipData] };
234
- chipProps.data = chipData;
235
- }
236
- chipProps.type = FChipType.INPUT;
237
- props.push(chipProps);
238
- return props;
239
- }
240
- /**
241
- * Handles the column menu's switch prop.
242
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
243
- * @param {KupDataColumn} column - Column of the menu.
244
- * @param {KupObj[]} objs - Column's objs.
245
- * @returns {GenericObject[]} Switches props.
246
- */
247
- prepSwitch(comp, column, objs) {
248
- const props = [];
249
- if (!FiltersColumnMenu.isTree(comp)) {
250
- if (objs &&
251
- objs.length > 0 &&
252
- !dom.ketchup.objects.isEmptyKupObj(objs[0])) {
253
- props.push({
254
- 'data-storage': {
255
- columnName: column.name,
256
- },
257
- checked: column.isKey ? true : false,
258
- id: KupColumnMenuIds.SWITCH_KEY,
259
- label: dom.ketchup.language.translate(KupLanguageRow.KEY),
260
- leadingLabel: true,
261
- });
262
- }
263
- if (comp.showGroups) {
264
- const isGroupActive = comp.getGroupByName(column.name) != null;
265
- props.push({
266
- 'data-storage': {
267
- columnName: column.name,
268
- },
269
- checked: isGroupActive ? true : false,
270
- id: KupColumnMenuIds.SWITCH_GROUP,
271
- label: dom.ketchup.language.translate(KupLanguageGrouping.GROUPS),
272
- leadingLabel: true,
273
- });
274
- }
275
- }
276
- return props;
277
- }
278
- /**
279
- * Handles the column menu's tabbar prop.
280
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
281
- * @returns {GenericObject[]} Tab bar props.
282
- */
283
- prepTabBar(comp, column) {
284
- const props = [{ data: [] }];
285
- const data = props[0].data;
286
- if (comp.showFilters) {
287
- data.push({
288
- id: KupLanguageGeneric.FILTERS,
289
- value: dom.ketchup.language.translate(KupLanguageGeneric.FILTERS),
290
- });
291
- }
292
- if ((comp.enableExtraColumns &&
293
- (dom.ketchup.objects.canObjHaveExtraColumns(column.obj) ||
294
- dom.ketchup.objects.canObjsHaveExtraColumns(column.objs))) ||
295
- comp.removableColumns) {
296
- data.push({
297
- id: KupLanguageColumn.COLUMNS,
298
- value: dom.ketchup.language.translate(KupLanguageColumn.COLUMNS),
299
- });
300
- }
301
- if (!FiltersColumnMenu.isTree(comp)) {
302
- data.push({
303
- icon: 'settings',
304
- id: KupLanguageGeneric.SETTINGS,
305
- value: '',
306
- });
307
- }
308
- if (data.length > 0) {
309
- data[0].active = true;
310
- }
311
- return props;
312
- }
313
- /**
314
- * Handles the column menu's textfield prop.
315
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
316
- * @param {KupDataColumn} column - Column of the menu.
317
- * @returns {GenericObject[]} Text fields props.
318
- */
319
- prepTextfield(comp, column) {
320
- let props = [];
321
- if (comp.showFilters) {
322
- if (this.filtersColumnMenuInstance.isColumnFiltrableByInterval(column)) {
323
- props = props.concat(this.prepIntervalTextfield(comp, column));
324
- }
325
- else if (dom.ketchup.objects.isStringObject(column.obj)) {
326
- let filterInitialValue = this.filtersColumnMenuInstance.getTextFilterValue(comp.filters, column.name);
327
- filterInitialValue = getValueForDisplay(filterInitialValue, column.obj, column.decimals);
328
- props.push({
329
- 'data-storage': {
330
- column: column,
331
- },
332
- fullWidth: true,
333
- icon: 'magnify',
334
- id: KupColumnMenuIds.TEXTFIELD_FILTER,
335
- initialValue: filterInitialValue,
336
- isClearable: true,
337
- label: dom.ketchup.language.translate(KupLanguageSearch.SEARCH),
338
- trailingIcon: true,
339
- });
340
- }
341
- }
342
- if (!FiltersColumnMenu.isTree(comp)) {
343
- if (dom.ketchup.objects.isNumber(column.obj) &&
344
- comp.enableColumnsFormula) {
345
- props.push({
346
- fullWidth: true,
347
- icon: 'functions',
348
- id: KupColumnMenuIds.TEXTFIELD_FORMULA,
349
- helper: `i.e.: [${column.name}] * 2`,
350
- label: dom.ketchup.language.translate(KupLanguageTotals.FORMULA),
351
- trailingIcon: true,
352
- });
353
- }
354
- }
355
- return props;
356
- }
357
- /**
358
- * Handles the column menu's interval textfields props (number column type).
359
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
360
- * @param {Column} column - Column of the menu.
361
- * @returns {GenericObject[]} Text fields props.
362
- */
363
- prepIntervalTextfield(comp, column) {
364
- let props = [];
365
- if (!comp.showFilters) {
366
- return props;
367
- }
368
- if (!dom.ketchup.objects.isNumber(column.obj)) {
369
- return props;
370
- }
371
- let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
372
- let initialValueFrom = interval[FilterInterval.FROM];
373
- let initialValueTo = interval[FilterInterval.TO];
374
- props.push({
375
- 'data-storage': {
376
- column: column,
377
- intervalIndex: FilterInterval.FROM,
378
- isInterval: true,
379
- },
380
- fullWidth: true,
381
- helperWhenFocused: true,
382
- id: KupColumnMenuIds.TEXTFIELD_FROM,
383
- initialValue: initialValueFrom,
384
- isClearable: true,
385
- label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
386
- icon: 'magnify',
387
- trailingIcon: true,
388
- });
389
- props.push({
390
- 'data-storage': {
391
- column: column,
392
- intervalIndex: FilterInterval.TO,
393
- isInterval: true,
394
- },
395
- fullWidth: true,
396
- helperWhenFocused: true,
397
- id: KupColumnMenuIds.TEXTFIELD_TO,
398
- initialValue: initialValueTo,
399
- isClearable: true,
400
- label: dom.ketchup.language.translate(KupLanguageSearch.TO),
401
- icon: 'magnify',
402
- trailingIcon: true,
403
- });
404
- return props;
405
- }
406
- /**
407
- * Handles the column menu's interval timepicker props (time column type).
408
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
409
- * @param {KupDataColumn} column - Column of the menu.
410
- * @returns {GenericObject[]} Time picker fields props.
411
- */
412
- prepIntervalTimePicker(comp, column) {
413
- let props = [];
414
- if (!comp.showFilters) {
415
- return props;
416
- }
417
- if (!dom.ketchup.objects.isTime(column.obj)) {
418
- return props;
419
- }
420
- let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
421
- let initialValueFrom = interval[FilterInterval.FROM];
422
- let initialValueTo = interval[FilterInterval.TO];
423
- props.push({
424
- 'data-storage': {
425
- column: column,
426
- intervalIndex: FilterInterval.FROM,
427
- isInterval: true,
428
- },
429
- data: {
430
- 'kup-text-field': {
431
- fullWidth: true,
432
- helperWhenFocused: true,
433
- id: KupColumnMenuIds.TEXTFIELD_FROM,
434
- isClearable: true,
435
- label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
436
- },
437
- },
438
- initialValue: initialValueFrom,
439
- manageSeconds: dom.ketchup.objects.isTimeWithSeconds(column.obj),
440
- });
441
- props.push({
442
- 'data-storage': {
443
- column: column,
444
- intervalIndex: FilterInterval.TO,
445
- isInterval: true,
446
- },
447
- data: {
448
- 'kup-text-field': {
449
- fullWidth: true,
450
- helperWhenFocused: true,
451
- id: KupColumnMenuIds.TEXTFIELD_TO,
452
- isClearable: true,
453
- label: dom.ketchup.language.translate(KupLanguageSearch.TO),
454
- },
455
- },
456
- initialValue: initialValueTo,
457
- manageSeconds: dom.ketchup.objects.isTimeWithSeconds(column.obj),
458
- });
459
- return props;
460
- }
461
- /**
462
- * Handles the column menu's interval datepicker props (date/timestamp column type).
463
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
464
- * @param {KupDataColumn} column - Column of the menu.
465
- * @returns {GenericObject[]} Date picker fields props.
466
- */
467
- prepIntervalDatePicker(comp, column) {
468
- let props = [];
469
- if (!comp.showFilters) {
470
- return props;
471
- }
472
- if (!dom.ketchup.objects.isDate(column.obj) &&
473
- !dom.ketchup.objects.isTimestamp(column.obj)) {
474
- return props;
475
- }
476
- let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
477
- let initialValueFrom = interval[FilterInterval.FROM];
478
- let initialValueTo = interval[FilterInterval.TO];
479
- let suffixFrom = null;
480
- let suffixTo = null;
481
- if (dom.ketchup.objects.isTimestamp(column.obj)) {
482
- suffixFrom = ' 00:00:00';
483
- suffixTo = ' 23:59:59';
484
- if (initialValueFrom && initialValueFrom.length >= 10) {
485
- initialValueFrom = initialValueFrom.substring(0, 10);
486
- }
487
- else {
488
- initialValueFrom = '';
489
- }
490
- if (initialValueTo && initialValueTo.length >= 10) {
491
- initialValueTo = initialValueTo.substring(0, 10);
492
- }
493
- else {
494
- initialValueTo = '';
495
- }
496
- }
497
- props.push({
498
- 'data-storage': {
499
- column: column,
500
- suffix: suffixFrom,
501
- intervalIndex: FilterInterval.FROM,
502
- isInterval: true,
503
- },
504
- data: {
505
- 'kup-text-field': {
506
- fullWidth: true,
507
- helperWhenFocused: true,
508
- id: KupColumnMenuIds.TEXTFIELD_FROM,
509
- isClearable: true,
510
- label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
511
- },
512
- },
513
- initialValue: initialValueFrom,
514
- });
515
- props.push({
516
- 'data-storage': {
517
- column: column,
518
- suffix: suffixTo,
519
- intervalIndex: FilterInterval.TO,
520
- isInterval: true,
521
- },
522
- data: {
523
- 'kup-text-field': {
524
- fullWidth: true,
525
- helperWhenFocused: true,
526
- id: KupColumnMenuIds.TEXTFIELD_TO,
527
- isClearable: true,
528
- label: dom.ketchup.language.translate(KupLanguageSearch.TO),
529
- },
530
- },
531
- initialValue: initialValueTo,
532
- });
533
- return props;
534
- }
535
- /**
536
- * Function called by the column menu card when a kup-card-event is received.
537
- * @param {CustomEvent} cardEvent - kup-card-event emitted by the column menu.
538
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
539
- */
540
- eventHandlers(cardEvent, comp) {
541
- const card = cardEvent.detail.card
542
- ? cardEvent.detail.card
543
- : cardEvent.detail.comp.rootElement;
544
- const compEvent = cardEvent.detail.event;
545
- const compID = compEvent.detail.id;
546
- const subcomp = compEvent.target;
547
- const dataStorage = subcomp['data-storage'];
548
- const compEventType = compEvent.type;
549
- const isClickEvent = compEventType
550
- .toLowerCase()
551
- .endsWith('click');
552
- switch (compEvent.type) {
553
- case 'kup-button-click':
554
- switch (compID) {
555
- case KupColumnMenuIds.BUTTON_GROUP:
556
- this.toggleGroup(comp, dataStorage['columnName']);
557
- break;
558
- case KupColumnMenuIds.BUTTON_REMOVE:
559
- comp.closeColumnMenu().then(() => {
560
- comp.hideColumn(dataStorage['column']);
561
- });
562
- break;
563
- }
564
- break;
565
- case 'kup-checkbox-change':
566
- this.checkboxChange(comp, compEvent.detail.checked, dataStorage['column'], {
567
- value: dataStorage['value'],
568
- displayedValue: dataStorage['displayedValue'],
569
- });
570
- break;
571
- case 'kup-switch-change':
572
- switch (compID) {
573
- case KupColumnMenuIds.SWITCH_GROUP:
574
- this.toggleGroup(comp, dataStorage['columnName']);
575
- break;
576
- case KupColumnMenuIds.SWITCH_KEY:
577
- this.setKey(comp, dataStorage['columnName'], compEvent.detail.value);
578
- break;
579
- }
580
- break;
581
- case 'kup-textfield-submit':
582
- case 'kup-datepicker-textfieldsubmit':
583
- case 'kup-timepicker-textfieldsubmit':
584
- switch (compID) {
585
- case KupColumnMenuIds.TEXTFIELD_FORMULA:
586
- break;
587
- default:
588
- this.saveTextualFilters(comp, dataStorage['column']);
589
- this.close(card);
590
- break;
591
- }
592
- break;
593
- case 'kup-textfield-cleariconclick':
594
- case 'kup-datepicker-cleariconclick':
595
- case 'kup-timepicker-cleariconclick':
596
- if (dataStorage['isInterval'] == true) {
597
- this.intervalChange(comp, null, dataStorage['column'], dataStorage['intervalIndex'], false);
598
- }
599
- else {
600
- this.textfieldChange(comp, null, dataStorage['column']);
601
- }
602
- this.saveTextualFilters(comp, dataStorage['column']);
603
- break;
604
- case 'kup-textfield-change':
605
- switch (compID) {
606
- case KupColumnMenuIds.TEXTFIELD_FORMULA:
607
- comp
608
- .newColumn(KupDataNewColumnTypes.MATH, {
609
- operation: compEvent.detail.value,
610
- })
611
- .then((res) => {
612
- if (typeof res === 'string' ||
613
- res instanceof String) {
614
- const textField = compEvent.detail.comp;
615
- textField.rootElement.classList.add('kup-danger');
616
- textField.helper = res;
617
- }
618
- else {
619
- this.close(card);
620
- }
621
- });
622
- break;
623
- }
624
- break;
625
- case 'kup-textfield-input':
626
- case 'kup-datepicker-input':
627
- case 'kup-datepicker-itemclick':
628
- case 'kup-timepicker-input':
629
- case 'kup-timepicker-itemclick':
630
- switch (compID) {
631
- case KupColumnMenuIds.TEXTFIELD_FORMULA:
632
- break;
633
- default:
634
- window.clearTimeout(comp.columnFilterTimeout);
635
- comp.columnFilterTimeout = window.setTimeout(() => {
636
- if (dataStorage['isInterval'] == true) {
637
- this.intervalChange(comp, compEvent.detail.value, dataStorage['column'], dataStorage['intervalIndex'], !isClickEvent, dataStorage['suffix']);
638
- }
639
- else {
640
- this.textfieldChange(comp, compEvent.detail.value, dataStorage['column']);
641
- }
642
- if (isClickEvent) {
643
- this.saveTextualFilters(comp, dataStorage['column']);
644
- }
645
- }, 300);
646
- break;
647
- }
648
- break;
649
- }
650
- }
651
- /**
652
- * Triggered when the text filter changes.
653
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
654
- * @param {string} value - New value of the filter.
655
- * @param {KupDataColumn} column - Column of the menu.
656
- */
657
- textfieldChange(comp, value, column) {
658
- if (!FiltersColumnMenu.isTree(comp)) {
659
- comp.resetCurrentPage();
660
- }
661
- let newFilter = '';
662
- if (value) {
663
- newFilter = this.filtersColumnMenuInstance.normalizeValue(value.trim(), column.obj);
664
- }
665
- const newFilters = Object.assign({}, comp.filters);
666
- this.filtersColumnMenuInstance.setTextFieldFilterValue(newFilters, column.name, newFilter);
667
- comp.filters = newFilters;
668
- }
669
- intervalChange(comp, value, column, index, needNormalize, suffix) {
670
- if (!FiltersColumnMenu.isTree(comp)) {
671
- comp.resetCurrentPage();
672
- }
673
- let newFilter = '';
674
- if (value) {
675
- newFilter = value.trim();
676
- if (needNormalize) {
677
- newFilter = this.filtersColumnMenuInstance.normalizeValue(newFilter, column.obj);
678
- }
679
- if (suffix != null && newFilter != '') {
680
- newFilter = newFilter + suffix;
681
- }
682
- }
683
- const newFilters = Object.assign({}, comp.filters);
684
- this.filtersColumnMenuInstance.setIntervalTextFieldFilterValue(newFilters, column.name, newFilter, index);
685
- comp.filters = newFilters;
686
- }
687
- saveTextualFilters(comp, column) {
688
- const newFilters = Object.assign({}, comp.filters);
689
- this.filtersColumnMenuInstance.saveTextualFilters(newFilters, column.name);
690
- comp.filters = newFilters;
691
- }
692
- /**
693
- * Triggered when the checkbox list changes.
694
- * @param {KupDataTable | KupTree} comp - Component using the column menu.
695
- * @param {boolean} checked - State of the changed checkbox.
696
- * @param {KupDataColumn} column - Column of the menu.
697
- * @param {string} filterValue - Value used to filter.
698
- */
699
- checkboxChange(comp, checked, column, filterValueItem) {
700
- if (!FiltersColumnMenu.isTree(comp)) {
701
- comp.resetCurrentPage();
702
- }
703
- const newFilters = Object.assign({}, comp.filters);
704
- if (checked ||
705
- filterValueItem == null ||
706
- filterValueItem.value == null) {
707
- this.filtersColumnMenuInstance.addCheckboxFilter(newFilters, column.name, filterValueItem);
708
- }
709
- else {
710
- this.filtersColumnMenuInstance.removeCheckboxFilter(newFilters, column.name, filterValueItem.value);
711
- }
712
- comp.filters = newFilters;
713
- }
714
- /**
715
- * Toggles the grouping of the given column.
716
- * @param {KupDataTable} comp - Component using the column menu.
717
- * @param {Column} column - Column of the menu.
718
- */
719
- toggleGroup(comp, column) {
720
- const group = comp.getGroupByName(column);
721
- if (group !== null) {
722
- const index = comp.groups.indexOf(group);
723
- comp.groups.splice(index, 1);
724
- comp.groups = [...comp.groups];
725
- }
726
- else {
727
- comp.groups = [...comp.groups, { column, visible: true }];
728
- }
729
- comp.refresh();
730
- }
731
- /**
732
- * Sets the given column as key for the table.
733
- * @param {KupDataTable} comp - Component using the column menu.
734
- * @param {KupDataColumn} column - Column of the menu.
735
- * @param {string} value - The status of the switch.
736
- */
737
- setKey(comp, column, value) {
738
- const columns = comp.data.columns;
739
- const switchOn = value === 'on' ? true : false;
740
- for (let index = 0; index < columns.length; index++) {
741
- const col = columns[index];
742
- if (col.name === column) {
743
- col.isKey = switchOn;
744
- }
745
- else if (switchOn) {
746
- col.isKey = false;
747
- }
748
- }
749
- comp.refresh();
750
- }
751
- }
1
+ import { KupDynamicPositionPlacement, } from '../../managers/kup-dynamic-position/kup-dynamic-position-declarations';
2
+ import { FiltersColumnMenu } from '../filters/filters-column-menu';
3
+ import { FilterInterval, } from '../filters/filters-declarations';
4
+ import { getValueForDisplay, getValueForDisplay2 } from '../cell-utils';
5
+ import { FiltersRows } from '../filters/filters-rows';
6
+ import { Filters } from '../filters/filters';
7
+ import { KupLanguageColumn, KupLanguageSearch, KupLanguageGrouping, KupLanguageCheckbox, KupLanguageGeneric, KupLanguageRow, KupLanguageTotals, } from '../../managers/kup-language/kup-language-declarations';
8
+ import { FButtonStyling } from '../../f-components/f-button/f-button-declarations';
9
+ import { KupColumnMenuIds } from './kup-column-menu-declarations';
10
+ import { KupDebugCategory } from '../../managers/kup-debug/kup-debug-declarations';
11
+ import { FChipType, } from '../../f-components/f-chip/f-chip-declarations';
12
+ import { KupDataNewColumnTypes, } from '../../managers/kup-data/kup-data-declarations';
13
+ const dom = document.documentElement;
14
+ /**
15
+ * Definition and events of the column menu card.
16
+ * @module KupColumnMenu
17
+ */
18
+ export class KupColumnMenu {
19
+ constructor() {
20
+ this.clickCb = null;
21
+ this.filtersColumnMenuInstance = new FiltersColumnMenu();
22
+ this.filtersRowsInstance = new FiltersRows();
23
+ }
24
+ /**
25
+ * Function called by the component when the column menu must be opened.
26
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
27
+ * @param {string} column - Name of the column.
28
+ */
29
+ open(comp, column) {
30
+ this.filtersColumnMenuInstance.resetTextualFilters(comp.filters, column);
31
+ }
32
+ /**
33
+ * Function called by the component when the column menu must be closed.
34
+ * @param {HTMLKupCardElement} card - Column menu card.
35
+ */
36
+ close(card) {
37
+ card.menuVisible = false;
38
+ dom.ketchup.removeClickCallback(this.clickCb);
39
+ dom.ketchup.dynamicPosition.stop(card);
40
+ }
41
+ /**
42
+ * Function called to reposition the column menu card to the appropriate column.
43
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
44
+ */
45
+ reposition(comp, card) {
46
+ const root = comp.rootElement.shadowRoot;
47
+ if (root) {
48
+ if (card) {
49
+ const column = card.dataset.column;
50
+ const wrapper = root.querySelector('th[data-column="' + column + '"]');
51
+ if (dom.ketchup.dynamicPosition.isRegistered(card)) {
52
+ dom.ketchup.dynamicPosition.changeAnchor(card, wrapper);
53
+ }
54
+ else {
55
+ dom.ketchup.dynamicPosition.register(card, wrapper, 0, KupDynamicPositionPlacement.BOTTOM, true);
56
+ }
57
+ if (!this.clickCb) {
58
+ this.clickCb = {
59
+ cb: () => {
60
+ this.close(card);
61
+ },
62
+ el: card,
63
+ };
64
+ }
65
+ dom.ketchup.addClickCallback(this.clickCb, true);
66
+ dom.ketchup.dynamicPosition.start(card);
67
+ card.menuVisible = true;
68
+ }
69
+ }
70
+ }
71
+ /**
72
+ * Function called by the column menu card to prepare its 'data' prop.
73
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
74
+ * @param {KupDataColumn} column - Column of the menu.
75
+ * @param {KupCardData} currentData - 'data' prop of the column menu card when it's already initialized.
76
+ * @returns {GenericObject} 'data' prop of the column menu card.
77
+ */
78
+ prepData(comp, column, currentData) {
79
+ const data = currentData ? Object.assign({}, currentData) : {};
80
+ data.button = this.prepButton(comp, column);
81
+ data.checkbox = this.prepCheckbox(comp, column);
82
+ data.chip = this.prepChip(comp, column);
83
+ data.datepicker = this.prepIntervalDatePicker(comp, column);
84
+ data.object = column.objs
85
+ ? column.objs
86
+ : column.obj
87
+ ? [column.obj]
88
+ : null;
89
+ data.switch = this.prepSwitch(comp, column, data.object);
90
+ if (!currentData) {
91
+ data.tabbar = this.prepTabBar(comp, column);
92
+ data.text = [column.title];
93
+ }
94
+ data.textfield = this.prepTextfield(comp, column);
95
+ data.timepicker = this.prepIntervalTimePicker(comp, column);
96
+ return data;
97
+ }
98
+ /**
99
+ * Handles the column menu's button prop.
100
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
101
+ * @param {KupDataColumn} column - Column of the menu.
102
+ * @returns {GenericObject[]} Buttons props.
103
+ */
104
+ prepButton(comp, column) {
105
+ const props = [];
106
+ if (!FiltersColumnMenu.isTree(comp) &&
107
+ comp.showGroups) {
108
+ props.push({
109
+ className: 'printable',
110
+ 'data-storage': {
111
+ columnName: column.name,
112
+ },
113
+ icon: 'book',
114
+ id: KupColumnMenuIds.BUTTON_GROUP,
115
+ title: comp.getGroupByName(column.name) != null
116
+ ? dom.ketchup.language.translate(KupLanguageGrouping.DISABLE)
117
+ : dom.ketchup.language.translate(KupLanguageGrouping.ENABLE),
118
+ });
119
+ }
120
+ if (comp.removableColumns) {
121
+ props.push({
122
+ className: 'printable',
123
+ 'data-storage': {
124
+ column: column,
125
+ },
126
+ icon: 'table-column-remove',
127
+ id: KupColumnMenuIds.BUTTON_REMOVE,
128
+ title: dom.ketchup.language.translate(KupLanguageColumn.HIDE),
129
+ });
130
+ }
131
+ if (comp.enableExtraColumns &&
132
+ (dom.ketchup.objects.canObjHaveExtraColumns(column.obj) ||
133
+ dom.ketchup.objects.canObjsHaveExtraColumns(column.objs))) {
134
+ props.push({
135
+ className: 'printable',
136
+ 'data-storage': {
137
+ columnName: column.name,
138
+ },
139
+ icon: 'table-column-plus-after',
140
+ id: KupColumnMenuIds.BUTTON_ADD_COLUMNS,
141
+ title: dom.ketchup.language.translate(KupLanguageColumn.ADD),
142
+ });
143
+ props.push({
144
+ className: 'printable',
145
+ label: dom.ketchup.language.translate(KupLanguageGeneric.APPLY),
146
+ id: KupColumnMenuIds.BUTTON_APPLY,
147
+ styling: FButtonStyling.OUTLINED,
148
+ title: dom.ketchup.language.translate(KupLanguageGeneric.APPLY),
149
+ });
150
+ }
151
+ return props;
152
+ }
153
+ /**
154
+ * Handles the column menu's checkbox prop.
155
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
156
+ * @param {KupDataColumn} column - Column of the menu.
157
+ * @returns {GenericObject[]} Checkboxes props.
158
+ */
159
+ prepCheckbox(comp, column) {
160
+ const props = [];
161
+ if (comp.showFilters &&
162
+ (dom.ketchup.objects.isStringObject(column.obj) ||
163
+ dom.ketchup.objects.isCheckbox(column.obj))) {
164
+ const checkBoxesFilter = this.filtersColumnMenuInstance.getCheckBoxFilterValues(comp.filters, column.name);
165
+ const columnValues = comp.getColumnValues(column);
166
+ if (columnValues.length > 0) {
167
+ props.push({
168
+ checked: checkBoxesFilter.length == 0,
169
+ 'data-storage': {
170
+ column: column,
171
+ value: null,
172
+ },
173
+ id: KupColumnMenuIds.CHECKBOX_GLOBAL,
174
+ label: dom.ketchup.language.translate(KupLanguageCheckbox.ALL),
175
+ });
176
+ }
177
+ for (let index = 0; index < columnValues.length; index++) {
178
+ let label = getValueForDisplay2(columnValues[index], column);
179
+ if (dom.ketchup.objects.isCheckbox(column.obj)) {
180
+ if (columnValues[index].value == '1') {
181
+ label = dom.ketchup.language.translate(KupLanguageCheckbox.CHECKED);
182
+ }
183
+ else {
184
+ label = dom.ketchup.language.translate(KupLanguageCheckbox.UNCHECKED);
185
+ }
186
+ }
187
+ props.push({
188
+ checked: Filters.valuesArrayContainsValue(checkBoxesFilter, columnValues[index].value),
189
+ 'data-storage': {
190
+ column: column,
191
+ value: columnValues[index].value,
192
+ displayedValue: getValueForDisplay2(columnValues[index], column),
193
+ },
194
+ label: label,
195
+ });
196
+ }
197
+ }
198
+ return props;
199
+ }
200
+ /**
201
+ * Handles the column menu's chip prop.
202
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
203
+ * @param {KupDataColumn} column - Column of the menu.
204
+ * @returns {GenericObject[]} Chips props (only 1 is handled).
205
+ */
206
+ prepChip(comp, column) {
207
+ let props = [];
208
+ const chipProps = { data: [] };
209
+ if (column.children) {
210
+ const chipData = [];
211
+ for (let index = 0; index < column.children.length; index++) {
212
+ const child = column.children[index];
213
+ let childColumn = null;
214
+ try {
215
+ if (FiltersColumnMenu.isTree(comp)) {
216
+ comp.columns;
217
+ childColumn = comp.columns.find((x) => x.name === child.name);
218
+ }
219
+ else {
220
+ childColumn = comp.data.columns.find((x) => x.name === child.name);
221
+ }
222
+ }
223
+ catch (error) {
224
+ dom.ketchup.debug.logMessage(this, 'Child column not found (' + child.name + ')!' + error, KupDebugCategory.ERROR);
225
+ }
226
+ chipData.push({
227
+ icon: child.icon ? child.icon : null,
228
+ value: childColumn ? childColumn.title : '*Not found!',
229
+ obj: child.obj ? child.obj : null,
230
+ id: childColumn ? childColumn.name : '*NOTFND',
231
+ });
232
+ }
233
+ chipProps.dataSet = { initialData: [...chipData] };
234
+ chipProps.data = chipData;
235
+ }
236
+ chipProps.type = FChipType.INPUT;
237
+ props.push(chipProps);
238
+ return props;
239
+ }
240
+ /**
241
+ * Handles the column menu's switch prop.
242
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
243
+ * @param {KupDataColumn} column - Column of the menu.
244
+ * @param {KupObj[]} objs - Column's objs.
245
+ * @returns {GenericObject[]} Switches props.
246
+ */
247
+ prepSwitch(comp, column, objs) {
248
+ const props = [];
249
+ if (!FiltersColumnMenu.isTree(comp)) {
250
+ if (objs &&
251
+ objs.length > 0 &&
252
+ !dom.ketchup.objects.isEmptyKupObj(objs[0])) {
253
+ props.push({
254
+ 'data-storage': {
255
+ columnName: column.name,
256
+ },
257
+ checked: column.isKey ? true : false,
258
+ id: KupColumnMenuIds.SWITCH_KEY,
259
+ label: dom.ketchup.language.translate(KupLanguageRow.KEY),
260
+ leadingLabel: true,
261
+ });
262
+ }
263
+ if (comp.showGroups) {
264
+ const isGroupActive = comp.getGroupByName(column.name) != null;
265
+ props.push({
266
+ 'data-storage': {
267
+ columnName: column.name,
268
+ },
269
+ checked: isGroupActive ? true : false,
270
+ id: KupColumnMenuIds.SWITCH_GROUP,
271
+ label: dom.ketchup.language.translate(KupLanguageGrouping.GROUPS),
272
+ leadingLabel: true,
273
+ });
274
+ }
275
+ }
276
+ return props;
277
+ }
278
+ /**
279
+ * Handles the column menu's tabbar prop.
280
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
281
+ * @returns {GenericObject[]} Tab bar props.
282
+ */
283
+ prepTabBar(comp, column) {
284
+ const props = [{ data: [] }];
285
+ const data = props[0].data;
286
+ if (comp.showFilters) {
287
+ data.push({
288
+ id: KupLanguageGeneric.FILTERS,
289
+ value: dom.ketchup.language.translate(KupLanguageGeneric.FILTERS),
290
+ });
291
+ }
292
+ if ((comp.enableExtraColumns &&
293
+ (dom.ketchup.objects.canObjHaveExtraColumns(column.obj) ||
294
+ dom.ketchup.objects.canObjsHaveExtraColumns(column.objs))) ||
295
+ comp.removableColumns) {
296
+ data.push({
297
+ id: KupLanguageColumn.COLUMNS,
298
+ value: dom.ketchup.language.translate(KupLanguageColumn.COLUMNS),
299
+ });
300
+ }
301
+ if (!FiltersColumnMenu.isTree(comp)) {
302
+ data.push({
303
+ icon: 'settings',
304
+ id: KupLanguageGeneric.SETTINGS,
305
+ value: '',
306
+ });
307
+ }
308
+ if (data.length > 0) {
309
+ data[0].active = true;
310
+ }
311
+ return props;
312
+ }
313
+ /**
314
+ * Handles the column menu's textfield prop.
315
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
316
+ * @param {KupDataColumn} column - Column of the menu.
317
+ * @returns {GenericObject[]} Text fields props.
318
+ */
319
+ prepTextfield(comp, column) {
320
+ let props = [];
321
+ if (comp.showFilters) {
322
+ if (this.filtersColumnMenuInstance.isColumnFiltrableByInterval(column)) {
323
+ props = props.concat(this.prepIntervalTextfield(comp, column));
324
+ }
325
+ else if (dom.ketchup.objects.isStringObject(column.obj)) {
326
+ let filterInitialValue = this.filtersColumnMenuInstance.getTextFilterValue(comp.filters, column.name);
327
+ filterInitialValue = getValueForDisplay(filterInitialValue, column.obj, column.decimals);
328
+ props.push({
329
+ 'data-storage': {
330
+ column: column,
331
+ },
332
+ fullWidth: true,
333
+ icon: 'magnify',
334
+ id: KupColumnMenuIds.TEXTFIELD_FILTER,
335
+ initialValue: filterInitialValue,
336
+ isClearable: true,
337
+ label: dom.ketchup.language.translate(KupLanguageSearch.SEARCH),
338
+ trailingIcon: true,
339
+ });
340
+ }
341
+ }
342
+ if (!FiltersColumnMenu.isTree(comp)) {
343
+ if (dom.ketchup.objects.isNumber(column.obj) &&
344
+ comp.enableColumnsFormula) {
345
+ props.push({
346
+ fullWidth: true,
347
+ icon: 'functions',
348
+ id: KupColumnMenuIds.TEXTFIELD_FORMULA,
349
+ helper: `i.e.: [${column.name}] * 2`,
350
+ label: dom.ketchup.language.translate(KupLanguageTotals.FORMULA),
351
+ trailingIcon: true,
352
+ });
353
+ }
354
+ }
355
+ return props;
356
+ }
357
+ /**
358
+ * Handles the column menu's interval textfields props (number column type).
359
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
360
+ * @param {Column} column - Column of the menu.
361
+ * @returns {GenericObject[]} Text fields props.
362
+ */
363
+ prepIntervalTextfield(comp, column) {
364
+ let props = [];
365
+ if (!comp.showFilters) {
366
+ return props;
367
+ }
368
+ if (!dom.ketchup.objects.isNumber(column.obj)) {
369
+ return props;
370
+ }
371
+ let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
372
+ let initialValueFrom = interval[FilterInterval.FROM];
373
+ let initialValueTo = interval[FilterInterval.TO];
374
+ props.push({
375
+ 'data-storage': {
376
+ column: column,
377
+ intervalIndex: FilterInterval.FROM,
378
+ isInterval: true,
379
+ },
380
+ fullWidth: true,
381
+ helperWhenFocused: true,
382
+ id: KupColumnMenuIds.TEXTFIELD_FROM,
383
+ initialValue: initialValueFrom,
384
+ isClearable: true,
385
+ label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
386
+ icon: 'magnify',
387
+ trailingIcon: true,
388
+ });
389
+ props.push({
390
+ 'data-storage': {
391
+ column: column,
392
+ intervalIndex: FilterInterval.TO,
393
+ isInterval: true,
394
+ },
395
+ fullWidth: true,
396
+ helperWhenFocused: true,
397
+ id: KupColumnMenuIds.TEXTFIELD_TO,
398
+ initialValue: initialValueTo,
399
+ isClearable: true,
400
+ label: dom.ketchup.language.translate(KupLanguageSearch.TO),
401
+ icon: 'magnify',
402
+ trailingIcon: true,
403
+ });
404
+ return props;
405
+ }
406
+ /**
407
+ * Handles the column menu's interval timepicker props (time column type).
408
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
409
+ * @param {KupDataColumn} column - Column of the menu.
410
+ * @returns {GenericObject[]} Time picker fields props.
411
+ */
412
+ prepIntervalTimePicker(comp, column) {
413
+ let props = [];
414
+ if (!comp.showFilters) {
415
+ return props;
416
+ }
417
+ if (!dom.ketchup.objects.isTime(column.obj)) {
418
+ return props;
419
+ }
420
+ let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
421
+ let initialValueFrom = interval[FilterInterval.FROM];
422
+ let initialValueTo = interval[FilterInterval.TO];
423
+ props.push({
424
+ 'data-storage': {
425
+ column: column,
426
+ intervalIndex: FilterInterval.FROM,
427
+ isInterval: true,
428
+ },
429
+ data: {
430
+ 'kup-text-field': {
431
+ fullWidth: true,
432
+ helperWhenFocused: true,
433
+ id: KupColumnMenuIds.TEXTFIELD_FROM,
434
+ isClearable: true,
435
+ label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
436
+ },
437
+ },
438
+ initialValue: initialValueFrom,
439
+ manageSeconds: dom.ketchup.objects.isTimeWithSeconds(column.obj),
440
+ });
441
+ props.push({
442
+ 'data-storage': {
443
+ column: column,
444
+ intervalIndex: FilterInterval.TO,
445
+ isInterval: true,
446
+ },
447
+ data: {
448
+ 'kup-text-field': {
449
+ fullWidth: true,
450
+ helperWhenFocused: true,
451
+ id: KupColumnMenuIds.TEXTFIELD_TO,
452
+ isClearable: true,
453
+ label: dom.ketchup.language.translate(KupLanguageSearch.TO),
454
+ },
455
+ },
456
+ initialValue: initialValueTo,
457
+ manageSeconds: dom.ketchup.objects.isTimeWithSeconds(column.obj),
458
+ });
459
+ return props;
460
+ }
461
+ /**
462
+ * Handles the column menu's interval datepicker props (date/timestamp column type).
463
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
464
+ * @param {KupDataColumn} column - Column of the menu.
465
+ * @returns {GenericObject[]} Date picker fields props.
466
+ */
467
+ prepIntervalDatePicker(comp, column) {
468
+ let props = [];
469
+ if (!comp.showFilters) {
470
+ return props;
471
+ }
472
+ if (!dom.ketchup.objects.isDate(column.obj) &&
473
+ !dom.ketchup.objects.isTimestamp(column.obj)) {
474
+ return props;
475
+ }
476
+ let interval = this.filtersColumnMenuInstance.getIntervalTextFieldFilterValues(comp.filters, column);
477
+ let initialValueFrom = interval[FilterInterval.FROM];
478
+ let initialValueTo = interval[FilterInterval.TO];
479
+ let suffixFrom = null;
480
+ let suffixTo = null;
481
+ if (dom.ketchup.objects.isTimestamp(column.obj)) {
482
+ suffixFrom = ' 00:00:00';
483
+ suffixTo = ' 23:59:59';
484
+ if (initialValueFrom && initialValueFrom.length >= 10) {
485
+ initialValueFrom = initialValueFrom.substring(0, 10);
486
+ }
487
+ else {
488
+ initialValueFrom = '';
489
+ }
490
+ if (initialValueTo && initialValueTo.length >= 10) {
491
+ initialValueTo = initialValueTo.substring(0, 10);
492
+ }
493
+ else {
494
+ initialValueTo = '';
495
+ }
496
+ }
497
+ props.push({
498
+ 'data-storage': {
499
+ column: column,
500
+ suffix: suffixFrom,
501
+ intervalIndex: FilterInterval.FROM,
502
+ isInterval: true,
503
+ },
504
+ data: {
505
+ 'kup-text-field': {
506
+ fullWidth: true,
507
+ helperWhenFocused: true,
508
+ id: KupColumnMenuIds.TEXTFIELD_FROM,
509
+ isClearable: true,
510
+ label: dom.ketchup.language.translate(KupLanguageSearch.FROM),
511
+ },
512
+ },
513
+ initialValue: initialValueFrom,
514
+ });
515
+ props.push({
516
+ 'data-storage': {
517
+ column: column,
518
+ suffix: suffixTo,
519
+ intervalIndex: FilterInterval.TO,
520
+ isInterval: true,
521
+ },
522
+ data: {
523
+ 'kup-text-field': {
524
+ fullWidth: true,
525
+ helperWhenFocused: true,
526
+ id: KupColumnMenuIds.TEXTFIELD_TO,
527
+ isClearable: true,
528
+ label: dom.ketchup.language.translate(KupLanguageSearch.TO),
529
+ },
530
+ },
531
+ initialValue: initialValueTo,
532
+ });
533
+ return props;
534
+ }
535
+ /**
536
+ * Function called by the column menu card when a kup-card-event is received.
537
+ * @param {CustomEvent} cardEvent - kup-card-event emitted by the column menu.
538
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
539
+ */
540
+ eventHandlers(cardEvent, comp) {
541
+ const card = cardEvent.detail.card
542
+ ? cardEvent.detail.card
543
+ : cardEvent.detail.comp.rootElement;
544
+ const compEvent = cardEvent.detail.event;
545
+ const compID = compEvent.detail.id;
546
+ const subcomp = compEvent.target;
547
+ const dataStorage = subcomp['data-storage'];
548
+ const compEventType = compEvent.type;
549
+ const isClickEvent = compEventType
550
+ .toLowerCase()
551
+ .endsWith('click');
552
+ switch (compEvent.type) {
553
+ case 'kup-button-click':
554
+ switch (compID) {
555
+ case KupColumnMenuIds.BUTTON_GROUP:
556
+ this.toggleGroup(comp, dataStorage['columnName']);
557
+ break;
558
+ case KupColumnMenuIds.BUTTON_REMOVE:
559
+ comp.closeColumnMenu().then(() => {
560
+ comp.hideColumn(dataStorage['column']);
561
+ });
562
+ break;
563
+ }
564
+ break;
565
+ case 'kup-checkbox-change':
566
+ this.checkboxChange(comp, compEvent.detail.checked, dataStorage['column'], {
567
+ value: dataStorage['value'],
568
+ displayedValue: dataStorage['displayedValue'],
569
+ });
570
+ break;
571
+ case 'kup-switch-change':
572
+ switch (compID) {
573
+ case KupColumnMenuIds.SWITCH_GROUP:
574
+ this.toggleGroup(comp, dataStorage['columnName']);
575
+ break;
576
+ case KupColumnMenuIds.SWITCH_KEY:
577
+ this.setKey(comp, dataStorage['columnName'], compEvent.detail.value);
578
+ break;
579
+ }
580
+ break;
581
+ case 'kup-textfield-submit':
582
+ case 'kup-datepicker-textfieldsubmit':
583
+ case 'kup-timepicker-textfieldsubmit':
584
+ switch (compID) {
585
+ case KupColumnMenuIds.TEXTFIELD_FORMULA:
586
+ break;
587
+ default:
588
+ this.saveTextualFilters(comp, dataStorage['column']);
589
+ this.close(card);
590
+ break;
591
+ }
592
+ break;
593
+ case 'kup-textfield-cleariconclick':
594
+ case 'kup-datepicker-cleariconclick':
595
+ case 'kup-timepicker-cleariconclick':
596
+ if (dataStorage['isInterval'] == true) {
597
+ this.intervalChange(comp, null, dataStorage['column'], dataStorage['intervalIndex'], false);
598
+ }
599
+ else {
600
+ this.textfieldChange(comp, null, dataStorage['column']);
601
+ }
602
+ this.saveTextualFilters(comp, dataStorage['column']);
603
+ break;
604
+ case 'kup-textfield-change':
605
+ switch (compID) {
606
+ case KupColumnMenuIds.TEXTFIELD_FORMULA:
607
+ comp
608
+ .newColumn(KupDataNewColumnTypes.MATH, {
609
+ operation: compEvent.detail.value,
610
+ })
611
+ .then((res) => {
612
+ if (typeof res === 'string' ||
613
+ res instanceof String) {
614
+ const textField = compEvent.detail.comp;
615
+ textField.rootElement.classList.add('kup-danger');
616
+ textField.helper = res;
617
+ }
618
+ else {
619
+ this.close(card);
620
+ }
621
+ });
622
+ break;
623
+ }
624
+ break;
625
+ case 'kup-textfield-input':
626
+ case 'kup-datepicker-input':
627
+ case 'kup-datepicker-itemclick':
628
+ case 'kup-timepicker-input':
629
+ case 'kup-timepicker-itemclick':
630
+ switch (compID) {
631
+ case KupColumnMenuIds.TEXTFIELD_FORMULA:
632
+ break;
633
+ default:
634
+ window.clearTimeout(comp.columnFilterTimeout);
635
+ comp.columnFilterTimeout = window.setTimeout(() => {
636
+ if (dataStorage['isInterval'] == true) {
637
+ this.intervalChange(comp, compEvent.detail.value, dataStorage['column'], dataStorage['intervalIndex'], !isClickEvent, dataStorage['suffix']);
638
+ }
639
+ else {
640
+ this.textfieldChange(comp, compEvent.detail.value, dataStorage['column']);
641
+ }
642
+ if (isClickEvent) {
643
+ this.saveTextualFilters(comp, dataStorage['column']);
644
+ }
645
+ }, 300);
646
+ break;
647
+ }
648
+ break;
649
+ }
650
+ }
651
+ /**
652
+ * Triggered when the text filter changes.
653
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
654
+ * @param {string} value - New value of the filter.
655
+ * @param {KupDataColumn} column - Column of the menu.
656
+ */
657
+ textfieldChange(comp, value, column) {
658
+ if (!FiltersColumnMenu.isTree(comp)) {
659
+ comp.resetCurrentPage();
660
+ }
661
+ let newFilter = '';
662
+ if (value) {
663
+ newFilter = this.filtersColumnMenuInstance.normalizeValue(value.trim(), column.obj);
664
+ }
665
+ const newFilters = Object.assign({}, comp.filters);
666
+ this.filtersColumnMenuInstance.setTextFieldFilterValue(newFilters, column.name, newFilter);
667
+ comp.filters = newFilters;
668
+ }
669
+ intervalChange(comp, value, column, index, needNormalize, suffix) {
670
+ if (!FiltersColumnMenu.isTree(comp)) {
671
+ comp.resetCurrentPage();
672
+ }
673
+ let newFilter = '';
674
+ if (value) {
675
+ newFilter = value.trim();
676
+ if (needNormalize) {
677
+ newFilter = this.filtersColumnMenuInstance.normalizeValue(newFilter, column.obj);
678
+ }
679
+ if (suffix != null && newFilter != '') {
680
+ newFilter = newFilter + suffix;
681
+ }
682
+ }
683
+ const newFilters = Object.assign({}, comp.filters);
684
+ this.filtersColumnMenuInstance.setIntervalTextFieldFilterValue(newFilters, column.name, newFilter, index);
685
+ comp.filters = newFilters;
686
+ }
687
+ saveTextualFilters(comp, column) {
688
+ const newFilters = Object.assign({}, comp.filters);
689
+ this.filtersColumnMenuInstance.saveTextualFilters(newFilters, column.name);
690
+ comp.filters = newFilters;
691
+ }
692
+ /**
693
+ * Triggered when the checkbox list changes.
694
+ * @param {KupDataTable | KupTree} comp - Component using the column menu.
695
+ * @param {boolean} checked - State of the changed checkbox.
696
+ * @param {KupDataColumn} column - Column of the menu.
697
+ * @param {string} filterValue - Value used to filter.
698
+ */
699
+ checkboxChange(comp, checked, column, filterValueItem) {
700
+ if (!FiltersColumnMenu.isTree(comp)) {
701
+ comp.resetCurrentPage();
702
+ }
703
+ const newFilters = Object.assign({}, comp.filters);
704
+ if (checked ||
705
+ filterValueItem == null ||
706
+ filterValueItem.value == null) {
707
+ this.filtersColumnMenuInstance.addCheckboxFilter(newFilters, column.name, filterValueItem);
708
+ }
709
+ else {
710
+ this.filtersColumnMenuInstance.removeCheckboxFilter(newFilters, column.name, filterValueItem.value);
711
+ }
712
+ comp.filters = newFilters;
713
+ }
714
+ /**
715
+ * Toggles the grouping of the given column.
716
+ * @param {KupDataTable} comp - Component using the column menu.
717
+ * @param {Column} column - Column of the menu.
718
+ */
719
+ toggleGroup(comp, column) {
720
+ const group = comp.getGroupByName(column);
721
+ if (group !== null) {
722
+ const index = comp.groups.indexOf(group);
723
+ comp.groups.splice(index, 1);
724
+ comp.groups = [...comp.groups];
725
+ }
726
+ else {
727
+ comp.groups = [...comp.groups, { column, visible: true }];
728
+ }
729
+ comp.refresh();
730
+ }
731
+ /**
732
+ * Sets the given column as key for the table.
733
+ * @param {KupDataTable} comp - Component using the column menu.
734
+ * @param {KupDataColumn} column - Column of the menu.
735
+ * @param {string} value - The status of the switch.
736
+ */
737
+ setKey(comp, column, value) {
738
+ const columns = comp.data.columns;
739
+ const switchOn = value === 'on' ? true : false;
740
+ for (let index = 0; index < columns.length; index++) {
741
+ const col = columns[index];
742
+ if (col.name === column) {
743
+ col.isKey = switchOn;
744
+ }
745
+ else if (switchOn) {
746
+ col.isKey = false;
747
+ }
748
+ }
749
+ comp.refresh();
750
+ }
751
+ }