@web-atoms/web-controls 2.6.4 → 2.6.6

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 (304) hide show
  1. package/dist/tsconfig.tsbuildinfo +1 -1
  2. package/dist-esm/ArrayLike.js +14 -12
  3. package/dist-esm/DataAttributes.js +18 -19
  4. package/dist-esm/Focusable.js +10 -11
  5. package/dist-esm/ModuleFiles.js +43 -42
  6. package/dist-esm/NumberFormats.js +60 -56
  7. package/dist-esm/PageNavigator.js +28 -30
  8. package/dist-esm/animations/Animations.global.css +2 -0
  9. package/dist-esm/animations/Animations.global.css.map +1 -0
  10. package/dist-esm/animations/Animations.js +36 -33
  11. package/dist-esm/basic/AtomChips.js +312 -305
  12. package/dist-esm/basic/AtomRepeater.js +1070 -1035
  13. package/dist-esm/basic/AtomSuggestions.js +97 -107
  14. package/dist-esm/basic/AttachedPopup.js +0 -1
  15. package/dist-esm/basic/Button.js +45 -19
  16. package/dist-esm/basic/Button.local.css +2 -0
  17. package/dist-esm/basic/Button.local.css.map +1 -0
  18. package/dist-esm/basic/ButtonBar.global.css +2 -0
  19. package/dist-esm/basic/ButtonBar.global.css.map +1 -0
  20. package/dist-esm/basic/ButtonBar.js +84 -64
  21. package/dist-esm/basic/Calendar.js +211 -203
  22. package/dist-esm/basic/CheckBoxList.js +90 -70
  23. package/dist-esm/basic/Checkbox.js +16 -8
  24. package/dist-esm/basic/Chip.js +36 -12
  25. package/dist-esm/basic/ComboBox.js +47 -51
  26. package/dist-esm/basic/DataGrid.js +258 -252
  27. package/dist-esm/basic/DateField.js +149 -127
  28. package/dist-esm/basic/DropDown.js +91 -103
  29. package/dist-esm/basic/DropDownInput.global.css +2 -0
  30. package/dist-esm/basic/DropDownInput.global.css.map +1 -0
  31. package/dist-esm/basic/DropDownInput.js +78 -106
  32. package/dist-esm/basic/Editable.js +82 -77
  33. package/dist-esm/basic/Expander.js +104 -86
  34. package/dist-esm/basic/FilesDragDrop.global.css +2 -0
  35. package/dist-esm/basic/FilesDragDrop.global.css.map +1 -0
  36. package/dist-esm/basic/FilesDragDrop.js +84 -80
  37. package/dist-esm/basic/Form.js +80 -52
  38. package/dist-esm/basic/FormField.js +164 -106
  39. package/dist-esm/basic/IElement.js +1 -2
  40. package/dist-esm/basic/InlinePopup.js +263 -234
  41. package/dist-esm/basic/InlinePopupButton.js +99 -88
  42. package/dist-esm/basic/InlinePopupControl.js +24 -23
  43. package/dist-esm/basic/ItemPath.js +59 -60
  44. package/dist-esm/basic/LimitedText.js +49 -38
  45. package/dist-esm/basic/ListRepeater.js +13 -14
  46. package/dist-esm/basic/MaskedInput.js +37 -29
  47. package/dist-esm/basic/MaskedInputDiv.js +55 -48
  48. package/dist-esm/basic/MergeNode.js +64 -35
  49. package/dist-esm/basic/PasswordBox.js +32 -17
  50. package/dist-esm/basic/PinchZoomView.js +221 -199
  51. package/dist-esm/basic/PopupButton.js +39 -16
  52. package/dist-esm/basic/PopupMenu.js +3 -4
  53. package/dist-esm/basic/RadioButtonList.js +35 -25
  54. package/dist-esm/basic/RefreshLock.js +41 -42
  55. package/dist-esm/basic/Resizable.js +43 -33
  56. package/dist-esm/basic/Select.js +72 -65
  57. package/dist-esm/basic/SortByButton.global.css +2 -0
  58. package/dist-esm/basic/SortByButton.global.css.map +1 -0
  59. package/dist-esm/basic/SortByButton.js +41 -31
  60. package/dist-esm/basic/Swipe.js +91 -84
  61. package/dist-esm/basic/Switch.js +22 -8
  62. package/dist-esm/basic/TableRepeater.js +29 -33
  63. package/dist-esm/basic/TimeEditor.js +97 -52
  64. package/dist-esm/basic/TitleEditor.js +115 -95
  65. package/dist-esm/basic/ToggleButtonBar.js +21 -22
  66. package/dist-esm/basic/Tooltip.js +49 -47
  67. package/dist-esm/basic/TypeWriter.js +45 -42
  68. package/dist-esm/basic/UploadEvent.js +211 -178
  69. package/dist-esm/basic/ZoomView.js +229 -198
  70. package/dist-esm/basic/combineClasses.js +2 -3
  71. package/dist-esm/basic/elements/AtomPopover.css +2 -0
  72. package/dist-esm/basic/elements/AtomPopover.css.map +1 -0
  73. package/dist-esm/basic/elements/AtomPopover.js +270 -253
  74. package/dist-esm/basic/elements/getContainingBlock.js +34 -35
  75. package/dist-esm/basic/elements/relativeRect.js +40 -21
  76. package/dist-esm/basic/styles/calendar.global.css +2 -0
  77. package/dist-esm/basic/styles/calendar.global.css.map +1 -0
  78. package/dist-esm/basic/styles/check-box-list.global.css +2 -0
  79. package/dist-esm/basic/styles/check-box-list.global.css.map +1 -0
  80. package/dist-esm/basic/styles/checkbox.global.css +2 -0
  81. package/dist-esm/basic/styles/checkbox.global.css.map +1 -0
  82. package/dist-esm/basic/styles/chip.global.css +2 -0
  83. package/dist-esm/basic/styles/chip.global.css.map +1 -0
  84. package/dist-esm/basic/styles/chips.global.css +2 -0
  85. package/dist-esm/basic/styles/chips.global.css.map +1 -0
  86. package/dist-esm/basic/styles/data-grid.global.css +2 -0
  87. package/dist-esm/basic/styles/data-grid.global.css.map +1 -0
  88. package/dist-esm/basic/styles/date-field.global.css +2 -0
  89. package/dist-esm/basic/styles/date-field.global.css.map +1 -0
  90. package/dist-esm/basic/styles/drop-down.global.css +2 -0
  91. package/dist-esm/basic/styles/drop-down.global.css.map +1 -0
  92. package/dist-esm/basic/styles/expander.global.css +2 -0
  93. package/dist-esm/basic/styles/expander.global.css.map +1 -0
  94. package/dist-esm/basic/styles/form-field.global.css +2 -0
  95. package/dist-esm/basic/styles/form-field.global.css.map +1 -0
  96. package/dist-esm/basic/styles/inline-popup.global.css +2 -0
  97. package/dist-esm/basic/styles/inline-popup.global.css.map +1 -0
  98. package/dist-esm/basic/styles/item-suggestion.global.css +2 -0
  99. package/dist-esm/basic/styles/item-suggestion.global.css.map +1 -0
  100. package/dist-esm/basic/styles/list-repeater.global.css +2 -0
  101. package/dist-esm/basic/styles/list-repeater.global.css.map +1 -0
  102. package/dist-esm/basic/styles/masked-input.global.css +2 -0
  103. package/dist-esm/basic/styles/masked-input.global.css.map +1 -0
  104. package/dist-esm/basic/styles/password-box.global.css +2 -0
  105. package/dist-esm/basic/styles/password-box.global.css.map +1 -0
  106. package/dist-esm/basic/styles/pinch-zoom-view.global.css +2 -0
  107. package/dist-esm/basic/styles/pinch-zoom-view.global.css.map +1 -0
  108. package/dist-esm/basic/styles/popup-button.global.css +2 -0
  109. package/dist-esm/basic/styles/popup-button.global.css.map +1 -0
  110. package/dist-esm/basic/styles/popup.global.css +2 -0
  111. package/dist-esm/basic/styles/popup.global.css.map +1 -0
  112. package/dist-esm/basic/styles/radio-button-list.global.css +2 -0
  113. package/dist-esm/basic/styles/radio-button-list.global.css.map +1 -0
  114. package/dist-esm/basic/styles/repeater.global.css +2 -0
  115. package/dist-esm/basic/styles/repeater.global.css.map +1 -0
  116. package/dist-esm/basic/styles/scale.svg +4 -0
  117. package/dist-esm/basic/styles/suggestion-popup.global.css +2 -0
  118. package/dist-esm/basic/styles/suggestion-popup.global.css.map +1 -0
  119. package/dist-esm/basic/styles/suggestion.global.css +2 -0
  120. package/dist-esm/basic/styles/suggestion.global.css.map +1 -0
  121. package/dist-esm/basic/styles/swipe.global.css +2 -0
  122. package/dist-esm/basic/styles/swipe.global.css.map +1 -0
  123. package/dist-esm/basic/styles/switch.global.css +2 -0
  124. package/dist-esm/basic/styles/switch.global.css.map +1 -0
  125. package/dist-esm/basic/styles/time-editor.global.css +2 -0
  126. package/dist-esm/basic/styles/time-editor.global.css.map +1 -0
  127. package/dist-esm/basic/styles/title-editor.global.css +2 -0
  128. package/dist-esm/basic/styles/title-editor.global.css.map +1 -0
  129. package/dist-esm/basic/styles/toggle-button-bar.global.css +2 -0
  130. package/dist-esm/basic/styles/toggle-button-bar.global.css.map +1 -0
  131. package/dist-esm/basic/styles/toggle-view.global.css +2 -0
  132. package/dist-esm/basic/styles/toggle-view.global.css.map +1 -0
  133. package/dist-esm/basic/styles/tooltip.global.css +2 -0
  134. package/dist-esm/basic/styles/tooltip.global.css.map +1 -0
  135. package/dist-esm/basic/styles/zoom-view.global.css +2 -0
  136. package/dist-esm/basic/styles/zoom-view.global.css.map +1 -0
  137. package/dist-esm/desktop-app/DesktopApp.js +65 -80
  138. package/dist-esm/desktop-app/MobileDesktopApp.js +20 -23
  139. package/dist-esm/html-editor/AtomHtmlEditor.js +243 -268
  140. package/dist-esm/html-editor/HtmlEditorCommands.js +6 -4
  141. package/dist-esm/html-editor/InlineHtmlEditor.js +174 -166
  142. package/dist-esm/html-editor/RangeEditor.js +49 -51
  143. package/dist-esm/html-editor/commands/AddImage.js +40 -35
  144. package/dist-esm/html-editor/commands/AddLink.js +56 -54
  145. package/dist-esm/html-editor/commands/AddLink.local.css +2 -0
  146. package/dist-esm/html-editor/commands/AddLink.local.css.map +1 -0
  147. package/dist-esm/html-editor/commands/Align.js +24 -7
  148. package/dist-esm/html-editor/commands/AttachFile.js +23 -13
  149. package/dist-esm/html-editor/commands/AttachImage.js +35 -25
  150. package/dist-esm/html-editor/commands/Bold.js +10 -11
  151. package/dist-esm/html-editor/commands/ChangeColor.js +31 -107
  152. package/dist-esm/html-editor/commands/ChangeColor.local.css +2 -0
  153. package/dist-esm/html-editor/commands/ChangeColor.local.css.map +1 -0
  154. package/dist-esm/html-editor/commands/ChangeFont.js +42 -42
  155. package/dist-esm/html-editor/commands/ChangeFont.local.css +2 -0
  156. package/dist-esm/html-editor/commands/ChangeFont.local.css.map +1 -0
  157. package/dist-esm/html-editor/commands/ChangeFontSize.js +15 -5
  158. package/dist-esm/html-editor/commands/Command.js +34 -16
  159. package/dist-esm/html-editor/commands/CommandButton.js +51 -32
  160. package/dist-esm/html-editor/commands/Headings.js +25 -9
  161. package/dist-esm/html-editor/commands/HorizontalRule.js +9 -10
  162. package/dist-esm/html-editor/commands/HtmlCommands.js +160 -65
  163. package/dist-esm/html-editor/commands/IndentLess.js +10 -11
  164. package/dist-esm/html-editor/commands/IndentMore.js +10 -11
  165. package/dist-esm/html-editor/commands/Italic.js +10 -11
  166. package/dist-esm/html-editor/commands/NumberedList.js +10 -11
  167. package/dist-esm/html-editor/commands/Quote.js +10 -11
  168. package/dist-esm/html-editor/commands/RemoveFormat.js +10 -11
  169. package/dist-esm/html-editor/commands/Separator.global.css +2 -0
  170. package/dist-esm/html-editor/commands/Separator.global.css.map +1 -0
  171. package/dist-esm/html-editor/commands/Separator.js +5 -4
  172. package/dist-esm/html-editor/commands/Source.js +29 -25
  173. package/dist-esm/html-editor/commands/Source.local.css +2 -0
  174. package/dist-esm/html-editor/commands/Source.local.css.map +1 -0
  175. package/dist-esm/html-editor/commands/StrikeThrough.js +10 -11
  176. package/dist-esm/html-editor/commands/Toolbar.js +6 -4
  177. package/dist-esm/html-editor/commands/Underline.js +10 -11
  178. package/dist-esm/html-editor/commands/Unlink.js +10 -9
  179. package/dist-esm/html-editor/commands/UnorderedList.js +10 -11
  180. package/dist-esm/mobile-app/BottomPopup.js +137 -148
  181. package/dist-esm/mobile-app/MasterDetailPage.global.css +2 -0
  182. package/dist-esm/mobile-app/MasterDetailPage.global.css.map +1 -0
  183. package/dist-esm/mobile-app/MasterDetailPage.js +153 -152
  184. package/dist-esm/mobile-app/MobileApp.global.css +2 -0
  185. package/dist-esm/mobile-app/MobileApp.global.css.map +1 -0
  186. package/dist-esm/mobile-app/MobileApp.js +577 -569
  187. package/dist-esm/mobile-app/bottom-popup.global.css +2 -0
  188. package/dist-esm/mobile-app/bottom-popup.global.css.map +1 -0
  189. package/dist-esm/player/AtomVideoPlayer.global.css +2 -0
  190. package/dist-esm/player/AtomVideoPlayer.global.css.map +1 -0
  191. package/dist-esm/player/AtomVideoPlayer.js +316 -270
  192. package/dist-esm/player/TrackProgress.js +11 -7
  193. package/dist-esm/player/input-range-style.js +97 -98
  194. package/dist-esm/styles/atom-html-editor.global.css +2 -0
  195. package/dist-esm/styles/atom-html-editor.global.css.map +1 -0
  196. package/dist-esm/styles/button-bar.global.css +2 -0
  197. package/dist-esm/styles/button-bar.global.css.map +1 -0
  198. package/dist-esm/styles/desktop-app.global.css +2 -0
  199. package/dist-esm/styles/desktop-app.global.css.map +1 -0
  200. package/dist-esm/styles/form.global.css +2 -0
  201. package/dist-esm/styles/form.global.css.map +1 -0
  202. package/dist-esm/styles/html-editor-toolbar.global.css +2 -0
  203. package/dist-esm/styles/html-editor-toolbar.global.css.map +1 -0
  204. package/dist-esm/styles/inline-html-editor.global.css +2 -0
  205. package/dist-esm/styles/inline-html-editor.global.css.map +1 -0
  206. package/dist-esm/styles/limited-text.global.css +2 -0
  207. package/dist-esm/styles/limited-text.global.css.map +1 -0
  208. package/dist-esm/styles/resizable.global.css +2 -0
  209. package/dist-esm/styles/resizable.global.css.map +1 -0
  210. package/dist-esm/styles/track-progress.global.css +2 -0
  211. package/dist-esm/styles/track-progress.global.css.map +1 -0
  212. package/dist-esm/styles/type-writer.global.css +2 -0
  213. package/dist-esm/styles/type-writer.global.css.map +1 -0
  214. package/dist-esm/tests/app-test/AppTestApp.js +12 -15
  215. package/dist-esm/tests/app-test/AppTestApp.pack.js +54 -0
  216. package/dist-esm/tests/app-test/commands/AppCommands.js +14 -11
  217. package/dist-esm/tests/app-test/drawer/AppDrawer.js +4 -6
  218. package/dist-esm/tests/app-test/model/model.js +1 -2
  219. package/dist-esm/tests/app-test/pages/detail/DetailPage.js +21 -15
  220. package/dist-esm/tests/app-test/pages/home/HomePage.js +7 -8
  221. package/dist-esm/tests/app-test/pages/list/ListPage.js +79 -62
  222. package/dist-esm/tests/app-test/pages/list/ListPage.local.css +2 -0
  223. package/dist-esm/tests/app-test/pages/list/ListPage.local.css.map +1 -0
  224. package/dist-esm/tests/basic/PopupTest.js +9 -7
  225. package/dist-esm/tests/basic/TimeEditorTest.js +5 -9
  226. package/dist-esm/tests/basic/TimeEditorTest.pack.js +39 -0
  227. package/dist-esm/tests/basic/TimerTest.js +27 -37
  228. package/dist-esm/tests/basic/TimerTest.pack.js +40 -0
  229. package/dist-esm/tests/basic/basic-form/BasicForm.js +47 -27
  230. package/dist-esm/tests/basic/basic-form/BasicForm.pack.js +44 -0
  231. package/dist-esm/tests/basic/calendar/BasicCalendarTest.js +5 -9
  232. package/dist-esm/tests/basic/calendar/BasicCalendarTest.pack.js +53 -0
  233. package/dist-esm/tests/basic/chips/ChipsTest.js +25 -15
  234. package/dist-esm/tests/basic/chips/ChipsTest.local.css +2 -0
  235. package/dist-esm/tests/basic/chips/ChipsTest.local.css.map +1 -0
  236. package/dist-esm/tests/basic/chips/ChipsTest.pack.js +56 -0
  237. package/dist-esm/tests/basic/data-grid/DataGridTest.js +55 -60
  238. package/dist-esm/tests/basic/data-grid/DataGridTest.pack.js +58 -0
  239. package/dist-esm/tests/basic/date/DateFieldTest.js +21 -96
  240. package/dist-esm/tests/basic/date/DateFieldTest.pack.js +57 -0
  241. package/dist-esm/tests/basic/drop-down/DropDownTest.js +25 -19
  242. package/dist-esm/tests/basic/drop-down/DropDownTest.pack.js +52 -0
  243. package/dist-esm/tests/basic/drop-down-input/DropDownTest.js +32 -32
  244. package/dist-esm/tests/basic/drop-down-input/DropDownTest.pack.js +54 -0
  245. package/dist-esm/tests/basic/expander/ExpanderMenuTest.js +20 -14
  246. package/dist-esm/tests/basic/expander/ExpanderMenuTest.pack.js +38 -0
  247. package/dist-esm/tests/basic/expander/ExpanderTest.js +11 -12
  248. package/dist-esm/tests/basic/expander/ExpanderTest.pack.js +38 -0
  249. package/dist-esm/tests/basic/form2/Form2Test.js +26 -24
  250. package/dist-esm/tests/basic/form2/Form2Test.pack.js +46 -0
  251. package/dist-esm/tests/basic/limited-text/LimitedTextTest.js +14 -11
  252. package/dist-esm/tests/basic/limited-text/LimitedTextTest.pack.js +38 -0
  253. package/dist-esm/tests/basic/pinch-zoom/PinchZoomViewTest.global.css +2 -0
  254. package/dist-esm/tests/basic/pinch-zoom/PinchZoomViewTest.global.css.map +1 -0
  255. package/dist-esm/tests/basic/pinch-zoom/PinchZoomViewTest.js +14 -14
  256. package/dist-esm/tests/basic/pinch-zoom/PinchZoomViewTest.pack.js +38 -0
  257. package/dist-esm/tests/basic/repeater/DragDropRepater.js +30 -12
  258. package/dist-esm/tests/basic/repeater/DragDropRepater.pack.js +51 -0
  259. package/dist-esm/tests/basic/repeater/RepeaterTest.js +45 -35
  260. package/dist-esm/tests/basic/repeater/RepeaterTest.pack.js +52 -0
  261. package/dist-esm/tests/basic/swipe/SwipeTest.js +13 -13
  262. package/dist-esm/tests/basic/swipe/SwipeTest.local.css +2 -0
  263. package/dist-esm/tests/basic/swipe/SwipeTest.local.css.map +1 -0
  264. package/dist-esm/tests/basic/swipe/SwipeTest.pack.js +52 -0
  265. package/dist-esm/tests/basic/switch-test/SwitchTest.js +8 -10
  266. package/dist-esm/tests/basic/switch-test/SwitchTest.pack.js +38 -0
  267. package/dist-esm/tests/basic/title-editor/TitleEditorTest.js +8 -9
  268. package/dist-esm/tests/basic/title-editor/TitleEditorTest.pack.js +38 -0
  269. package/dist-esm/tests/basic/tooltip/TooltipTest.js +30 -24
  270. package/dist-esm/tests/basic/tooltip/TooltipTest.pack.js +52 -0
  271. package/dist-esm/tests/basic/typewriter/TypeWriter.js +10 -9
  272. package/dist-esm/tests/basic/typewriter/TypeWriter.pack.js +39 -0
  273. package/dist-esm/tests/basic/video/AtomVideoTest.js +13 -10
  274. package/dist-esm/tests/basic/video/AtomVideoTest.local.css +2 -0
  275. package/dist-esm/tests/basic/video/AtomVideoTest.local.css.map +1 -0
  276. package/dist-esm/tests/basic/video/AtomVideoTest.pack.js +38 -0
  277. package/dist-esm/tests/basic/zoom/ZoomViewTest.js +13 -13
  278. package/dist-esm/tests/basic/zoom/ZoomViewTest.local.css +2 -0
  279. package/dist-esm/tests/basic/zoom/ZoomViewTest.local.css.map +1 -0
  280. package/dist-esm/tests/basic/zoom/ZoomViewTest.pack.js +38 -0
  281. package/dist-esm/tests/check-box-list/CheckBoxListSample.js +13 -12
  282. package/dist-esm/tests/check-box-list/CheckBoxListSample.pack.js +52 -0
  283. package/dist-esm/tests/data-grid/GridTestViewModel.js +203 -227
  284. package/dist-esm/tests/form/CustomHelp.js +6 -9
  285. package/dist-esm/tests/form/FormViewModel.js +21 -28
  286. package/dist-esm/tests/html-editor/HtmlEditorTest.js +7 -37
  287. package/dist-esm/tests/html-editor/HtmlEditorTest.pack.js +83 -0
  288. package/dist-esm/tests/html-editor/InlineHtmlEdiorTest.js +9 -38
  289. package/dist-esm/tests/html-editor/InlineHtmlEdiorTest.pack.js +85 -0
  290. package/dist-esm/tests/mask/MaskedInputTest.js +11 -12
  291. package/dist-esm/tests/mask/MaskedInputTest.pack.js +38 -0
  292. package/dist-esm/tests/mobile-app/DesktopAppTest.js +8 -9
  293. package/dist-esm/tests/mobile-app/DesktopAppTest.pack.js +60 -0
  294. package/dist-esm/tests/mobile-app/MobileAppTest.js +64 -53
  295. package/dist-esm/tests/mobile-app/MobileAppTest.pack.js +55 -0
  296. package/dist-esm/tests/pop-over/PopOverTest.js +37 -77
  297. package/dist-esm/tests/switch/SwitchTest.js +9 -8
  298. package/dist-esm/tests/toggle-view/ToggleView.local.css +2 -0
  299. package/dist-esm/tests/toggle-view/ToggleView.local.css.map +1 -0
  300. package/dist-esm/tests/toggle-view/ToggleViewTest.js +15 -22
  301. package/dist-esm/tests/toggle-view/ToggleViewTest.pack.js +45 -0
  302. package/dist-esm/toggle-view/AtomToggleView.js +77 -73
  303. package/dist-esm/tsconfig.esm.tsbuildinfo +1 -1
  304. package/package.json +3 -3
@@ -6,283 +6,289 @@ import XNode from "@web-atoms/core/dist/core/XNode.js";
6
6
  import { SelectorCheckBox } from "./AtomRepeater.js";
7
7
  import { EditableInput, getPropertyInfo } from "./Editable.js";
8
8
  import TableRepeater from "./TableRepeater.js";
9
- import "./styles/data-grid.global.css";
9
+ ESMPack.installStyleSheet(import.meta.resolve("./styles/data-grid.global.css"));
10
10
  const cellEventName = Symbol("cell-event-name");
11
11
  const headerEventName = Symbol("header-event-name");
12
12
  const footerEventName = Symbol("footer-event-name");
13
- const fromHyphenToCamel = (input) => input.replace(/-([a-z])/ig, (g) => g[1].toUpperCase());
14
- const toEventName = (name) => {
15
- const r = fromHyphenToCamel(name.replace(/\s+/, "-"));
16
- return r[0].toLowerCase() + r.substring(1);
13
+ const fromHyphenToCamel = input => input.replace(/-([a-z])/ig, g => g[1].toUpperCase());
14
+ const toEventName = name => {
15
+ const r = fromHyphenToCamel(name.replace(/\s+/, "-"));
16
+ return r[0].toLowerCase() + r.substring(1);
17
17
  };
18
- const getCellEventName = (d) => {
19
- let name = d[cellEventName];
20
- if (name !== void 0) {
21
- return name;
22
- }
23
- name = toEventName(d.cellClickEvent ?? `cell-${d.header}-click`);
24
- d[cellEventName] = name;
18
+ const getCellEventName = d => {
19
+ let name = d[cellEventName];
20
+ if (name !== void 0) {
25
21
  return name;
22
+ }
23
+ name = toEventName(d.cellClickEvent ?? `cell-${d.header}-click`);
24
+ d[cellEventName] = name;
25
+ return name;
26
26
  };
27
- const getHeaderEventName = (d) => {
28
- let name = d[headerEventName];
29
- if (name !== void 0) {
30
- return name;
31
- }
32
- name = toEventName(d.headerClickEvent ?? `header-${d.header}-click`);
33
- d[headerEventName] = name;
27
+ const getHeaderEventName = d => {
28
+ let name = d[headerEventName];
29
+ if (name !== void 0) {
34
30
  return name;
31
+ }
32
+ name = toEventName(d.headerClickEvent ?? `header-${d.header}-click`);
33
+ d[headerEventName] = name;
34
+ return name;
35
35
  };
36
- const getFooterEventName = (d) => {
37
- let name = d[footerEventName];
38
- if (name !== void 0) {
39
- return name;
40
- }
41
- name = toEventName(d.footerClickEvent ?? `footer-${d.header}-click`);
42
- d[footerEventName] = name;
36
+ const getFooterEventName = d => {
37
+ let name = d[footerEventName];
38
+ if (name !== void 0) {
43
39
  return name;
40
+ }
41
+ name = toEventName(d.footerClickEvent ?? `footer-${d.header}-click`);
42
+ d[footerEventName] = name;
43
+ return name;
44
44
  };
45
45
  export const SelectAllColumn = {
46
- header: "Select All",
47
- headerRenderer: () => XNode.create("th", null,
48
- XNode.create("input", { type: "checkbox", checked: Bind.oneTime((x) => x.allSelected) })),
49
- headerClickHandler: (e) => {
50
- const s = e.detail.repeater;
51
- const items = s.items;
52
- if (!(items)) {
53
- return;
54
- }
55
- const selectedItems = s.selectedItems ??= [];
56
- if (s.allSelected) {
57
- selectedItems.clear();
58
- return;
59
- }
60
- selectedItems.length = 0;
61
- selectedItems.push(...items);
62
- selectedItems.refresh();
63
- },
64
- cellRenderer: () => XNode.create(SelectorCheckBox, null)
46
+ header: "Select All",
47
+ headerRenderer: () => XNode.create("th", null, XNode.create("input", {
48
+ type: "checkbox",
49
+ checked: Bind.oneTime(x => x.allSelected)
50
+ })),
51
+ headerClickHandler: e => {
52
+ const s = e.detail.repeater;
53
+ const items = s.items;
54
+ if (!items) {
55
+ return;
56
+ }
57
+ const selectedItems = s.selectedItems ??= [];
58
+ if (s.allSelected) {
59
+ selectedItems.clear();
60
+ return;
61
+ }
62
+ selectedItems.length = 0;
63
+ selectedItems.push(...items);
64
+ selectedItems.refresh();
65
+ },
66
+ cellRenderer: () => XNode.create(SelectorCheckBox, null)
65
67
  };
66
- export function InputColumn({ type = "text", header, propertyPath }) {
67
- const property = getPropertyInfo(propertyPath);
68
- return ({
69
- header,
70
- cellRenderer: (item) => XNode.create(EditableInput, { propertyPath: propertyPath, value: property.getter(item), type: type }),
71
- });
68
+ export function InputColumn({
69
+ type = "text",
70
+ header,
71
+ propertyPath
72
+ }) {
73
+ const property = getPropertyInfo(propertyPath);
74
+ return {
75
+ header,
76
+ cellRenderer: item => XNode.create(EditableInput, {
77
+ propertyPath: propertyPath,
78
+ value: property.getter(item),
79
+ type: type
80
+ })
81
+ };
72
82
  }
73
83
  export default class DataGrid extends TableRepeater {
74
- constructor(app, e = document.createElement("table")) {
75
- super(app, e);
84
+ constructor(app, e = document.createElement("table")) {
85
+ super(app, e);
86
+ }
87
+ onPropertyChanged(name) {
88
+ super.onPropertyChanged(name);
89
+ if (name === "columns") {
90
+ super.onPropertyChanged("header");
91
+ super.onPropertyChanged("footer");
92
+ super.onPropertyChanged("items");
76
93
  }
77
- onPropertyChanged(name) {
78
- super.onPropertyChanged(name);
79
- if (name === "columns") {
80
- super.onPropertyChanged("header");
81
- super.onPropertyChanged("footer");
82
- super.onPropertyChanged("items");
83
- }
84
- if (name === "orderBy") {
85
- if (!this.orderBySet) {
86
- this.onPropertyChanged("header");
87
- }
88
- this.orderBySet = true;
89
- }
90
- }
91
- preCreate() {
92
- super.preCreate();
93
- this.header = true;
94
- this.footer = null;
95
- this.element.dataset.dataGrid = "data-grid";
96
- this.headerRenderer = (item) => XNode.create("tr", null, ...this.columns?.map?.((x) => {
97
- if (x.headerRenderer === void 0) {
98
- x.headerRenderer = (_) => {
99
- let order = this.orderBy;
100
- if (order !== void 0) {
101
- if (order === x.headerSort) {
102
- order = true;
103
- }
104
- else if (order === x.headerSortDescending) {
105
- order = false;
106
- }
107
- }
108
- return XNode.create("th", null,
109
- XNode.create("span", { "data-recreate": "true", text: x.header, title: x.header }),
110
- typeof order === "boolean" &&
111
- (order
112
- ? XNode.create("i", { "data-sort": "up", class: "fa-solid fa-arrow-up-short-wide" })
113
- : XNode.create("i", { "data-sort": "down", class: "fa-solid fa-arrow-down-wide-short" })));
114
- };
115
- }
116
- const node = x.headerRenderer(item);
117
- const na = node.attributes ??= {};
118
- na["data-click-event"] ??= getHeaderEventName(x);
119
- if (x.width !== void 0) {
120
- na["style-width"] ??= x.width;
121
- }
122
- else {
123
- if (x.maxWidth !== void 0) {
124
- na["style-max-width"] ??= x.maxWidth;
125
- }
126
- if (x.minWidth !== void 0) {
127
- na["style-min-width"] ??= x.minWidth;
128
- }
129
- }
130
- return node;
131
- }) ?? []);
132
- this.itemRenderer = (item) => XNode.create("tr", null, ...this.columns?.map?.((x) => {
133
- x.ellipsis ??= true;
134
- if (x.cellRenderer === void 0) {
135
- x.labelPath ??= (i) => i[x.label];
136
- if (x.ellipsis) {
137
- x.cellRenderer = (i) => XNode.create("td", { text: x.labelPath(i) });
138
- }
139
- else {
140
- x.cellRenderer = (i) => XNode.create("td", { text: x.labelPath(i), title: x.labelPath(i) });
141
- }
142
- }
143
- const node = x.cellRenderer?.(item);
144
- const na = node.attributes ??= {};
145
- if (x.ellipsis) {
146
- na["data-ellipsis"] = "true";
147
- }
148
- na["data-click-event"] ??= getCellEventName(x);
149
- if (x.width !== void 0) {
150
- na["style-width"] ??= x.width;
151
- }
152
- else {
153
- if (x.maxWidth !== void 0) {
154
- na["style-max-width"] ??= x.maxWidth;
155
- }
156
- if (x.minWidth !== void 0) {
157
- na["style-min-width"] ??= x.minWidth;
158
- }
159
- }
160
- return node;
161
- }) ?? []);
162
- this.footerRenderer = (item) => XNode.create("tr", null, ...this.columns?.map?.((x) => {
163
- const node = x.footerRenderer?.(item);
164
- if (node === void 0) {
165
- return node;
166
- }
167
- const na = node.attributes ??= {};
168
- if (na["data-click-event"] === void 0) {
169
- na["data-click-event"] = getFooterEventName(x);
170
- }
171
- return node;
172
- }) ?? []);
94
+ if (name === "orderBy") {
95
+ if (!this.orderBySet) {
96
+ this.onPropertyChanged("header");
97
+ }
98
+ this.orderBySet = true;
173
99
  }
174
- dispatchHeaderFooterEvent(eventName, type, recreate, originalTarget) {
175
- let detail = this[type];
176
- const column = this.columns.find((x) => getHeaderEventName(x) === eventName
177
- || getFooterEventName(x) === eventName);
178
- let order = this.orderBy;
179
- const originalOrder = this.orderBy;
180
- const isHeader = type === "header";
181
- const setOrderBy = isHeader && column.headerSort !== void 0;
182
- if (isHeader) {
183
- if (setOrderBy) {
184
- if (order === column.headerSortDescending) {
185
- order = column.headerSort;
186
- }
187
- else if (order === column.headerSort) {
188
- order = column.headerSortDescending;
189
- }
190
- else {
191
- order = column.headerSortDefault ?? column.headerSort;
192
- }
100
+ }
101
+ preCreate() {
102
+ super.preCreate();
103
+ this.header = true;
104
+ this.footer = null;
105
+ this.element.dataset.dataGrid = "data-grid";
106
+ this.headerRenderer = item => XNode.create("tr", null, ...(this.columns?.map?.(x => {
107
+ if (x.headerRenderer === void 0) {
108
+ x.headerRenderer = _ => {
109
+ let order = this.orderBy;
110
+ if (order !== void 0) {
111
+ if (order === x.headerSort) {
112
+ order = true;
113
+ } else if (order === x.headerSortDescending) {
114
+ order = false;
193
115
  }
194
- detail = {
195
- repeater: this,
196
- detail,
197
- type,
198
- order
199
- };
116
+ }
117
+ return XNode.create("th", null, XNode.create("span", {
118
+ "data-recreate": "true",
119
+ text: x.header,
120
+ title: x.header
121
+ }), typeof order === "boolean" && (order ? XNode.create("i", {
122
+ "data-sort": "up",
123
+ class: "fa-solid fa-arrow-up-short-wide"
124
+ }) : XNode.create("i", {
125
+ "data-sort": "down",
126
+ class: "fa-solid fa-arrow-down-wide-short"
127
+ })));
128
+ };
129
+ }
130
+ const node = x.headerRenderer(item);
131
+ const na = node.attributes ??= {};
132
+ na["data-click-event"] ??= getHeaderEventName(x);
133
+ if (x.width !== void 0) {
134
+ na["style-width"] ??= x.width;
135
+ } else {
136
+ if (x.maxWidth !== void 0) {
137
+ na["style-max-width"] ??= x.maxWidth;
200
138
  }
201
- const ce = new CustomEvent(eventName ?? `${type}Click`, {
202
- detail,
203
- bubbles: this.bubbleEvents,
204
- cancelable: true
205
- });
206
- originalTarget.dispatchEvent(ce);
207
- if (ce.defaultPrevented) {
208
- return;
139
+ if (x.minWidth !== void 0) {
140
+ na["style-min-width"] ??= x.minWidth;
209
141
  }
210
- this.invokeHandler(isHeader ? column.headerClickHandler : column.footerClickHandler, ce);
211
- if (ce.defaultPrevented) {
212
- return;
142
+ }
143
+ return node;
144
+ }) ?? []));
145
+ this.itemRenderer = item => XNode.create("tr", null, ...(this.columns?.map?.(x => {
146
+ x.ellipsis ??= true;
147
+ if (x.cellRenderer === void 0) {
148
+ x.labelPath ??= i => i[x.label];
149
+ if (x.ellipsis) {
150
+ x.cellRenderer = i => XNode.create("td", {
151
+ text: x.labelPath(i)
152
+ });
153
+ } else {
154
+ x.cellRenderer = i => XNode.create("td", {
155
+ text: x.labelPath(i),
156
+ title: x.labelPath(i)
157
+ });
213
158
  }
214
- if (setOrderBy && this.orderBy === originalOrder) {
215
- this.orderBy = order;
216
- ce.executed = true;
159
+ }
160
+ const node = x.cellRenderer?.(item);
161
+ const na = node.attributes ??= {};
162
+ if (x.ellipsis) {
163
+ na["data-ellipsis"] = "true";
164
+ }
165
+ na["data-click-event"] ??= getCellEventName(x);
166
+ if (x.width !== void 0) {
167
+ na["style-width"] ??= x.width;
168
+ } else {
169
+ if (x.maxWidth !== void 0) {
170
+ na["style-max-width"] ??= x.maxWidth;
217
171
  }
218
- if (ce.executed) {
219
- this.onPropertyChanged(type);
172
+ if (x.minWidth !== void 0) {
173
+ na["style-min-width"] ??= x.minWidth;
220
174
  }
221
- }
222
- dispatchItemEvent(eventName, item, recreate, originalTarget) {
223
- const ce = new CustomEvent(eventName ?? "itemClick", {
224
- detail: item,
225
- bubbles: this.bubbleEvents,
226
- cancelable: true
227
- });
228
- originalTarget.dispatchEvent(ce);
229
- if (ce.defaultPrevented) {
230
- return;
231
- }
232
- for (const iterator of this.columns) {
233
- if (getCellEventName(iterator) === eventName) {
234
- this.invokeHandler(iterator.cellClickHandler, ce);
235
- break;
236
- }
237
- }
238
- if (ce.defaultPrevented) {
239
- return;
240
- }
241
- if (eventName === "itemSelect" || eventName === "itemDeselect") {
242
- const si = this.selectedItems ??= [];
243
- if (si) {
244
- const index = si.indexOf(item);
245
- if (index === -1) {
246
- if (this.allowMultipleSelection) {
247
- si.add(item);
248
- }
249
- else {
250
- si.set(0, item);
251
- }
252
- }
253
- else {
254
- si.removeAt(index);
255
- }
256
- }
257
- }
258
- if (recreate && ce.executed) {
259
- this.refreshItem(item, ce.promise);
175
+ }
176
+ return node;
177
+ }) ?? []));
178
+ this.footerRenderer = item => XNode.create("tr", null, ...(this.columns?.map?.(x => {
179
+ const node = x.footerRenderer?.(item);
180
+ if (node === void 0) {
181
+ return node;
182
+ }
183
+ const na = node.attributes ??= {};
184
+ if (na["data-click-event"] === void 0) {
185
+ na["data-click-event"] = getFooterEventName(x);
186
+ }
187
+ return node;
188
+ }) ?? []));
189
+ }
190
+ dispatchHeaderFooterEvent(eventName, type, recreate, originalTarget) {
191
+ let detail = this[type];
192
+ const column = this.columns.find(x => getHeaderEventName(x) === eventName || getFooterEventName(x) === eventName);
193
+ let order = this.orderBy;
194
+ const originalOrder = this.orderBy;
195
+ const isHeader = type === "header";
196
+ const setOrderBy = isHeader && column.headerSort !== void 0;
197
+ if (isHeader) {
198
+ if (setOrderBy) {
199
+ if (order === column.headerSortDescending) {
200
+ order = column.headerSort;
201
+ } else if (order === column.headerSort) {
202
+ order = column.headerSortDescending;
203
+ } else {
204
+ order = column.headerSortDefault ?? column.headerSort;
260
205
  }
206
+ }
207
+ detail = {
208
+ repeater: this,
209
+ detail,
210
+ type,
211
+ order
212
+ };
213
+ }
214
+ const ce = new CustomEvent(eventName ?? `${type}Click`, {
215
+ detail,
216
+ bubbles: this.bubbleEvents,
217
+ cancelable: true
218
+ });
219
+ originalTarget.dispatchEvent(ce);
220
+ if (ce.defaultPrevented) {
221
+ return;
222
+ }
223
+ this.invokeHandler(isHeader ? column.headerClickHandler : column.footerClickHandler, ce);
224
+ if (ce.defaultPrevented) {
225
+ return;
226
+ }
227
+ if (setOrderBy && this.orderBy === originalOrder) {
228
+ this.orderBy = order;
229
+ ce.executed = true;
261
230
  }
262
- invokeHandler(h, e) {
263
- if (!h) {
264
- return;
231
+ if (ce.executed) {
232
+ this.onPropertyChanged(type);
233
+ }
234
+ }
235
+ dispatchItemEvent(eventName, item, recreate, originalTarget) {
236
+ const ce = new CustomEvent(eventName ?? "itemClick", {
237
+ detail: item,
238
+ bubbles: this.bubbleEvents,
239
+ cancelable: true
240
+ });
241
+ originalTarget.dispatchEvent(ce);
242
+ if (ce.defaultPrevented) {
243
+ return;
244
+ }
245
+ for (const iterator of this.columns) {
246
+ if (getCellEventName(iterator) === eventName) {
247
+ this.invokeHandler(iterator.cellClickHandler, ce);
248
+ break;
249
+ }
250
+ }
251
+ if (ce.defaultPrevented) {
252
+ return;
253
+ }
254
+ if (eventName === "itemSelect" || eventName === "itemDeselect") {
255
+ const si = this.selectedItems ??= [];
256
+ if (si) {
257
+ const index = si.indexOf(item);
258
+ if (index === -1) {
259
+ if (this.allowMultipleSelection) {
260
+ si.add(item);
261
+ } else {
262
+ si.set(0, item);
263
+ }
264
+ } else {
265
+ si.removeAt(index);
265
266
  }
266
- const p = h(e);
267
- e.executed = true;
268
- if (p && p.then) {
269
- if (e.promise) {
270
- e.promise = Promise.all([e.promise, p]);
271
- }
272
- else {
273
- e.promise = p;
274
- }
275
- p?.catch((error) => {
276
- if (CancelToken.isCancelled(error)) {
277
- return;
278
- }
279
- console.error(error);
280
- });
267
+ }
268
+ }
269
+ if (recreate && ce.executed) {
270
+ this.refreshItem(item, ce.promise);
271
+ }
272
+ }
273
+ invokeHandler(h, e) {
274
+ if (!h) {
275
+ return;
276
+ }
277
+ const p = h(e);
278
+ e.executed = true;
279
+ if (p && p.then) {
280
+ if (e.promise) {
281
+ e.promise = Promise.all([e.promise, p]);
282
+ } else {
283
+ e.promise = p;
284
+ }
285
+ p?.catch(error => {
286
+ if (CancelToken.isCancelled(error)) {
287
+ return;
281
288
  }
289
+ console.error(error);
290
+ });
282
291
  }
292
+ }
283
293
  }
284
- __decorate([
285
- BindableProperty,
286
- __metadata("design:type", Array)
287
- ], DataGrid.prototype, "columns", void 0);
288
- //# sourceMappingURL=DataGrid.js.map
294
+ __decorate([BindableProperty, __metadata("design:type", Array)], DataGrid.prototype, "columns", void 0);