@ui5/webcomponents 2.12.0 → 2.13.0-rc.1

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 (530) hide show
  1. package/CHANGELOG.md +43 -0
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/Breadcrumbs.d.ts +1 -0
  4. package/dist/Breadcrumbs.js +3 -0
  5. package/dist/Breadcrumbs.js.map +1 -1
  6. package/dist/ComboBox.d.ts +23 -6
  7. package/dist/ComboBox.js +128 -54
  8. package/dist/ComboBox.js.map +1 -1
  9. package/dist/ComboBoxPopoverTemplate.js +0 -1
  10. package/dist/ComboBoxPopoverTemplate.js.map +1 -1
  11. package/dist/ComboBoxTemplate.js +2 -1
  12. package/dist/ComboBoxTemplate.js.map +1 -1
  13. package/dist/DateComponentBase.d.ts +3 -3
  14. package/dist/DateComponentBase.js +3 -3
  15. package/dist/DateComponentBase.js.map +1 -1
  16. package/dist/DateTimePicker.d.ts +3 -1
  17. package/dist/DateTimePicker.js +12 -1
  18. package/dist/DateTimePicker.js.map +1 -1
  19. package/dist/FileUploader.d.ts +52 -13
  20. package/dist/FileUploader.js +165 -48
  21. package/dist/FileUploader.js.map +1 -1
  22. package/dist/FileUploaderPopoverTemplate.js +1 -3
  23. package/dist/FileUploaderPopoverTemplate.js.map +1 -1
  24. package/dist/FileUploaderTemplate.js +5 -4
  25. package/dist/FileUploaderTemplate.js.map +1 -1
  26. package/dist/Input.d.ts +19 -5
  27. package/dist/Input.js +115 -17
  28. package/dist/Input.js.map +1 -1
  29. package/dist/InputTemplate.js +2 -1
  30. package/dist/InputTemplate.js.map +1 -1
  31. package/dist/List.js +3 -0
  32. package/dist/List.js.map +1 -1
  33. package/dist/ListItemBase.d.ts +1 -0
  34. package/dist/ListItemBase.js +3 -0
  35. package/dist/ListItemBase.js.map +1 -1
  36. package/dist/ListItemStandard.d.ts +12 -8
  37. package/dist/ListItemStandard.js +3 -8
  38. package/dist/ListItemStandard.js.map +1 -1
  39. package/dist/MultiComboBox.d.ts +23 -1
  40. package/dist/MultiComboBox.js +135 -23
  41. package/dist/MultiComboBox.js.map +1 -1
  42. package/dist/MultiComboBoxPopoverTemplate.js +1 -1
  43. package/dist/MultiComboBoxPopoverTemplate.js.map +1 -1
  44. package/dist/MultiComboBoxTemplate.js +2 -1
  45. package/dist/MultiComboBoxTemplate.js.map +1 -1
  46. package/dist/MultiInput.js +1 -1
  47. package/dist/MultiInput.js.map +1 -1
  48. package/dist/RangeSlider.d.ts +0 -7
  49. package/dist/RangeSlider.js +0 -7
  50. package/dist/RangeSlider.js.map +1 -1
  51. package/dist/Slider.d.ts +0 -7
  52. package/dist/Slider.js +0 -7
  53. package/dist/Slider.js.map +1 -1
  54. package/dist/SliderBase.d.ts +0 -4
  55. package/dist/SliderBase.js +7 -3
  56. package/dist/SliderBase.js.map +1 -1
  57. package/dist/SliderBaseTemplate.js +1 -1
  58. package/dist/SliderBaseTemplate.js.map +1 -1
  59. package/dist/SplitButtonTemplate.js +1 -1
  60. package/dist/SplitButtonTemplate.js.map +1 -1
  61. package/dist/TimeSelectionClocksTemplate.js +1 -1
  62. package/dist/TimeSelectionClocksTemplate.js.map +1 -1
  63. package/dist/Tokenizer.js +4 -0
  64. package/dist/Tokenizer.js.map +1 -1
  65. package/dist/TokenizerPopoverTemplate.js +1 -1
  66. package/dist/TokenizerPopoverTemplate.js.map +1 -1
  67. package/dist/css/themes/Avatar.css +1 -1
  68. package/dist/css/themes/AvatarGroup.css +1 -1
  69. package/dist/css/themes/Bar.css +1 -1
  70. package/dist/css/themes/Breadcrumbs.css +1 -1
  71. package/dist/css/themes/BusyIndicator.css +1 -1
  72. package/dist/css/themes/Button.css +1 -1
  73. package/dist/css/themes/ButtonBadge.css +1 -1
  74. package/dist/css/themes/Calendar.css +1 -1
  75. package/dist/css/themes/CalendarHeader.css +1 -1
  76. package/dist/css/themes/CalendarLegend.css +1 -1
  77. package/dist/css/themes/CalendarLegendItem.css +1 -1
  78. package/dist/css/themes/Card.css +1 -1
  79. package/dist/css/themes/CardHeader.css +1 -1
  80. package/dist/css/themes/Carousel.css +1 -1
  81. package/dist/css/themes/CheckBox.css +1 -1
  82. package/dist/css/themes/ColorPalette.css +1 -1
  83. package/dist/css/themes/ColorPaletteItem.css +1 -1
  84. package/dist/css/themes/ColorPalettePopover.css +1 -1
  85. package/dist/css/themes/ColorPicker.css +1 -1
  86. package/dist/css/themes/ComboBox.css +1 -1
  87. package/dist/css/themes/ComboBoxItem.css +1 -1
  88. package/dist/css/themes/DatePicker.css +1 -1
  89. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  90. package/dist/css/themes/DayPicker.css +1 -1
  91. package/dist/css/themes/Dialog.css +1 -1
  92. package/dist/css/themes/DynamicDateRange.css +1 -1
  93. package/dist/css/themes/DynamicDateRangePopover.css +1 -1
  94. package/dist/css/themes/FileUploader.css +1 -1
  95. package/dist/css/themes/Form.css +1 -1
  96. package/dist/css/themes/FormItem.css +1 -1
  97. package/dist/css/themes/FormItemSpan.css +1 -1
  98. package/dist/css/themes/GrowingButton.css +1 -1
  99. package/dist/css/themes/Icon.css +1 -1
  100. package/dist/css/themes/Input.css +1 -1
  101. package/dist/css/themes/InputIcon.css +1 -1
  102. package/dist/css/themes/InputSharedStyles.css +1 -1
  103. package/dist/css/themes/Link.css +1 -1
  104. package/dist/css/themes/List.css +1 -1
  105. package/dist/css/themes/ListItem.css +1 -1
  106. package/dist/css/themes/ListItemBase.css +1 -1
  107. package/dist/css/themes/ListItemCustom.css +1 -1
  108. package/dist/css/themes/ListItemGroup.css +1 -1
  109. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  110. package/dist/css/themes/ListItemIcon.css +1 -1
  111. package/dist/css/themes/Menu.css +1 -1
  112. package/dist/css/themes/MenuItem.css +1 -1
  113. package/dist/css/themes/MessageStrip.css +1 -1
  114. package/dist/css/themes/MonthPicker.css +1 -1
  115. package/dist/css/themes/MultiComboBox.css +1 -1
  116. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  117. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  118. package/dist/css/themes/MultiInput.css +1 -1
  119. package/dist/css/themes/OptionBase.css +1 -1
  120. package/dist/css/themes/Panel.css +1 -1
  121. package/dist/css/themes/Popover.css +1 -1
  122. package/dist/css/themes/PopupsCommon.css +1 -1
  123. package/dist/css/themes/ProgressIndicator.css +1 -1
  124. package/dist/css/themes/RadioButton.css +1 -1
  125. package/dist/css/themes/RangeSlider.css +1 -1
  126. package/dist/css/themes/RatingIndicator.css +1 -1
  127. package/dist/css/themes/ResponsivePopover.css +1 -1
  128. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  129. package/dist/css/themes/SegmentedButton.css +1 -1
  130. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  131. package/dist/css/themes/Select.css +1 -1
  132. package/dist/css/themes/SliderBase.css +1 -1
  133. package/dist/css/themes/SplitButton.css +1 -1
  134. package/dist/css/themes/StepInput.css +1 -1
  135. package/dist/css/themes/SuggestionItem.css +1 -1
  136. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  137. package/dist/css/themes/Switch.css +1 -1
  138. package/dist/css/themes/TabContainer.css +1 -1
  139. package/dist/css/themes/TabInOverflow.css +1 -1
  140. package/dist/css/themes/TabInStrip.css +1 -1
  141. package/dist/css/themes/TabSemanticIcon.css +1 -1
  142. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  143. package/dist/css/themes/TableCellBase.css +1 -1
  144. package/dist/css/themes/TableHeaderRow.css +1 -1
  145. package/dist/css/themes/TableRow.css +1 -1
  146. package/dist/css/themes/TableRowActionBase.css +1 -1
  147. package/dist/css/themes/TableRowBase.css +1 -1
  148. package/dist/css/themes/Tag.css +1 -1
  149. package/dist/css/themes/Text.css +1 -1
  150. package/dist/css/themes/TextArea.css +1 -1
  151. package/dist/css/themes/TimePicker.css +1 -1
  152. package/dist/css/themes/Toast.css +1 -1
  153. package/dist/css/themes/ToggleButton.css +1 -1
  154. package/dist/css/themes/Token.css +1 -1
  155. package/dist/css/themes/Tokenizer.css +1 -1
  156. package/dist/css/themes/TokenizerPopover.css +1 -1
  157. package/dist/css/themes/Toolbar.css +1 -1
  158. package/dist/css/themes/ToolbarPopover.css +1 -1
  159. package/dist/css/themes/ToolbarSeparator.css +1 -1
  160. package/dist/css/themes/TreeItem.css +1 -1
  161. package/dist/css/themes/ValueStateMessage.css +1 -1
  162. package/dist/css/themes/ValueStateVariables.css +1 -0
  163. package/dist/css/themes/YearPicker.css +1 -1
  164. package/dist/css/themes/YearRangePicker.css +1 -1
  165. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  166. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  167. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  168. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  169. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  170. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  171. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  172. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  173. package/dist/custom-elements-internal.json +91 -33
  174. package/dist/custom-elements.json +89 -32
  175. package/dist/features/InputSuggestions.d.ts +0 -3
  176. package/dist/features/InputSuggestions.js +4 -50
  177. package/dist/features/InputSuggestions.js.map +1 -1
  178. package/dist/features/InputSuggestionsTemplate.js +0 -1
  179. package/dist/features/InputSuggestionsTemplate.js.map +1 -1
  180. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  181. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  182. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  183. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  184. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  185. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  186. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  187. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  188. package/dist/generated/i18n/i18n-defaults.d.ts +11 -3
  189. package/dist/generated/i18n/i18n-defaults.js +11 -3
  190. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  191. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  192. package/dist/generated/themes/Avatar.css.js +1 -1
  193. package/dist/generated/themes/Avatar.css.js.map +1 -1
  194. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  195. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  196. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  197. package/dist/generated/themes/Bar.css.d.ts +1 -1
  198. package/dist/generated/themes/Bar.css.js +1 -1
  199. package/dist/generated/themes/Bar.css.js.map +1 -1
  200. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  201. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  202. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  203. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  204. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  205. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  206. package/dist/generated/themes/Button.css.d.ts +1 -1
  207. package/dist/generated/themes/Button.css.js +1 -1
  208. package/dist/generated/themes/Button.css.js.map +1 -1
  209. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  210. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  211. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  212. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  213. package/dist/generated/themes/Calendar.css.js +1 -1
  214. package/dist/generated/themes/Calendar.css.js.map +1 -1
  215. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  216. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  217. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  218. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  219. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  220. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  221. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  222. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  223. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  224. package/dist/generated/themes/Card.css.d.ts +1 -1
  225. package/dist/generated/themes/Card.css.js +1 -1
  226. package/dist/generated/themes/Card.css.js.map +1 -1
  227. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  228. package/dist/generated/themes/CardHeader.css.js +1 -1
  229. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  230. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  231. package/dist/generated/themes/Carousel.css.js +1 -1
  232. package/dist/generated/themes/Carousel.css.js.map +1 -1
  233. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  234. package/dist/generated/themes/CheckBox.css.js +1 -1
  235. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  236. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  237. package/dist/generated/themes/ColorPalette.css.js +1 -1
  238. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  239. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  240. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  241. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  242. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  243. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  244. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  245. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  246. package/dist/generated/themes/ColorPicker.css.js +1 -1
  247. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  248. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  249. package/dist/generated/themes/ComboBox.css.js +1 -1
  250. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  251. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  252. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  253. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  254. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  255. package/dist/generated/themes/DatePicker.css.js +1 -1
  256. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  257. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  258. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  259. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  260. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  261. package/dist/generated/themes/DayPicker.css.js +1 -1
  262. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  263. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  264. package/dist/generated/themes/Dialog.css.js +1 -1
  265. package/dist/generated/themes/Dialog.css.js.map +1 -1
  266. package/dist/generated/themes/DynamicDateRange.css.d.ts +1 -1
  267. package/dist/generated/themes/DynamicDateRange.css.js +1 -1
  268. package/dist/generated/themes/DynamicDateRange.css.js.map +1 -1
  269. package/dist/generated/themes/DynamicDateRangePopover.css.d.ts +1 -1
  270. package/dist/generated/themes/DynamicDateRangePopover.css.js +1 -1
  271. package/dist/generated/themes/DynamicDateRangePopover.css.js.map +1 -1
  272. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  273. package/dist/generated/themes/FileUploader.css.js +1 -1
  274. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  275. package/dist/generated/themes/Form.css.d.ts +1 -1
  276. package/dist/generated/themes/Form.css.js +1 -1
  277. package/dist/generated/themes/Form.css.js.map +1 -1
  278. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  279. package/dist/generated/themes/FormItem.css.js +1 -1
  280. package/dist/generated/themes/FormItem.css.js.map +1 -1
  281. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  282. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  283. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  284. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  285. package/dist/generated/themes/GrowingButton.css.js +1 -1
  286. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  287. package/dist/generated/themes/Icon.css.d.ts +1 -1
  288. package/dist/generated/themes/Icon.css.js +1 -1
  289. package/dist/generated/themes/Icon.css.js.map +1 -1
  290. package/dist/generated/themes/Input.css.d.ts +1 -1
  291. package/dist/generated/themes/Input.css.js +1 -1
  292. package/dist/generated/themes/Input.css.js.map +1 -1
  293. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  294. package/dist/generated/themes/InputIcon.css.js +1 -1
  295. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  296. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  297. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  298. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  299. package/dist/generated/themes/Link.css.d.ts +1 -1
  300. package/dist/generated/themes/Link.css.js +1 -1
  301. package/dist/generated/themes/Link.css.js.map +1 -1
  302. package/dist/generated/themes/List.css.d.ts +1 -1
  303. package/dist/generated/themes/List.css.js +1 -1
  304. package/dist/generated/themes/List.css.js.map +1 -1
  305. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  306. package/dist/generated/themes/ListItem.css.js +1 -1
  307. package/dist/generated/themes/ListItem.css.js.map +1 -1
  308. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  309. package/dist/generated/themes/ListItemBase.css.js +1 -1
  310. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  311. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  312. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  313. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  314. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  315. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  316. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  317. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  318. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  319. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  320. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  321. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  322. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  323. package/dist/generated/themes/Menu.css.d.ts +1 -1
  324. package/dist/generated/themes/Menu.css.js +1 -1
  325. package/dist/generated/themes/Menu.css.js.map +1 -1
  326. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  327. package/dist/generated/themes/MenuItem.css.js +1 -1
  328. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  329. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  330. package/dist/generated/themes/MessageStrip.css.js +1 -1
  331. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  332. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  333. package/dist/generated/themes/MonthPicker.css.js +1 -1
  334. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  335. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  336. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  337. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  338. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  339. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  340. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  341. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  342. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  343. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  344. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  345. package/dist/generated/themes/MultiInput.css.js +1 -1
  346. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  347. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  348. package/dist/generated/themes/OptionBase.css.js +1 -1
  349. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  350. package/dist/generated/themes/Panel.css.d.ts +1 -1
  351. package/dist/generated/themes/Panel.css.js +1 -1
  352. package/dist/generated/themes/Panel.css.js.map +1 -1
  353. package/dist/generated/themes/Popover.css.d.ts +1 -1
  354. package/dist/generated/themes/Popover.css.js +1 -1
  355. package/dist/generated/themes/Popover.css.js.map +1 -1
  356. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  357. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  358. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  359. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  360. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  361. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  362. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  363. package/dist/generated/themes/RadioButton.css.js +1 -1
  364. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  365. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  366. package/dist/generated/themes/RangeSlider.css.js +1 -1
  367. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  368. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  369. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  370. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  371. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  372. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  373. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  374. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  375. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  376. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  377. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  378. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  379. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  380. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  381. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  382. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  383. package/dist/generated/themes/Select.css.d.ts +1 -1
  384. package/dist/generated/themes/Select.css.js +1 -1
  385. package/dist/generated/themes/Select.css.js.map +1 -1
  386. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  387. package/dist/generated/themes/SliderBase.css.js +1 -1
  388. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  389. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  390. package/dist/generated/themes/SplitButton.css.js +1 -1
  391. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  392. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  393. package/dist/generated/themes/StepInput.css.js +1 -1
  394. package/dist/generated/themes/StepInput.css.js.map +1 -1
  395. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  396. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  397. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  398. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  399. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  400. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  401. package/dist/generated/themes/Switch.css.d.ts +1 -1
  402. package/dist/generated/themes/Switch.css.js +1 -1
  403. package/dist/generated/themes/Switch.css.js.map +1 -1
  404. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  405. package/dist/generated/themes/TabContainer.css.js +1 -1
  406. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  407. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  408. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  409. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  410. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  411. package/dist/generated/themes/TabInStrip.css.js +1 -1
  412. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  413. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  414. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  415. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  416. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  417. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  418. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  419. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  420. package/dist/generated/themes/TableCellBase.css.js +1 -1
  421. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  422. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  423. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  424. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  425. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  426. package/dist/generated/themes/TableRow.css.js +1 -1
  427. package/dist/generated/themes/TableRow.css.js.map +1 -1
  428. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  429. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  430. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  431. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  432. package/dist/generated/themes/TableRowBase.css.js +1 -1
  433. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  434. package/dist/generated/themes/Tag.css.d.ts +1 -1
  435. package/dist/generated/themes/Tag.css.js +1 -1
  436. package/dist/generated/themes/Tag.css.js.map +1 -1
  437. package/dist/generated/themes/Text.css.d.ts +1 -1
  438. package/dist/generated/themes/Text.css.js +1 -1
  439. package/dist/generated/themes/Text.css.js.map +1 -1
  440. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  441. package/dist/generated/themes/TextArea.css.js +1 -1
  442. package/dist/generated/themes/TextArea.css.js.map +1 -1
  443. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  444. package/dist/generated/themes/TimePicker.css.js +1 -1
  445. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  446. package/dist/generated/themes/Toast.css.d.ts +1 -1
  447. package/dist/generated/themes/Toast.css.js +1 -1
  448. package/dist/generated/themes/Toast.css.js.map +1 -1
  449. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  450. package/dist/generated/themes/ToggleButton.css.js +1 -1
  451. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  452. package/dist/generated/themes/Token.css.d.ts +1 -1
  453. package/dist/generated/themes/Token.css.js +1 -1
  454. package/dist/generated/themes/Token.css.js.map +1 -1
  455. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  456. package/dist/generated/themes/Tokenizer.css.js +1 -1
  457. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  458. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  459. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  460. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  461. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  462. package/dist/generated/themes/Toolbar.css.js +1 -1
  463. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  464. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  465. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  466. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  467. package/dist/generated/themes/ToolbarSeparator.css.d.ts +1 -1
  468. package/dist/generated/themes/ToolbarSeparator.css.js +1 -1
  469. package/dist/generated/themes/ToolbarSeparator.css.js.map +1 -1
  470. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  471. package/dist/generated/themes/TreeItem.css.js +1 -1
  472. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  473. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  474. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  475. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  476. package/dist/generated/themes/ValueStateVariables.css.d.ts +2 -0
  477. package/dist/generated/themes/ValueStateVariables.css.js +8 -0
  478. package/dist/generated/themes/ValueStateVariables.css.js.map +1 -0
  479. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  480. package/dist/generated/themes/YearPicker.css.js +1 -1
  481. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  482. package/dist/generated/themes/YearRangePicker.css.d.ts +1 -1
  483. package/dist/generated/themes/YearRangePicker.css.js +1 -1
  484. package/dist/generated/themes/YearRangePicker.css.js.map +1 -1
  485. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  486. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  487. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  488. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  489. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  490. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  491. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  492. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  493. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  494. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  495. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  496. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  497. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  498. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  499. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  500. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  501. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  502. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  503. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  504. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  505. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  506. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  507. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  508. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  509. package/dist/vscode.html-custom-data.json +32 -17
  510. package/dist/web-types.json +54 -24
  511. package/package.json +9 -9
  512. package/src/ComboBoxPopoverTemplate.tsx +0 -1
  513. package/src/ComboBoxTemplate.tsx +4 -1
  514. package/src/FileUploaderPopoverTemplate.tsx +1 -3
  515. package/src/FileUploaderTemplate.tsx +77 -25
  516. package/src/InputTemplate.tsx +4 -0
  517. package/src/MultiComboBoxPopoverTemplate.tsx +1 -1
  518. package/src/MultiComboBoxTemplate.tsx +4 -0
  519. package/src/SliderBaseTemplate.tsx +9 -10
  520. package/src/SplitButtonTemplate.tsx +1 -1
  521. package/src/TimeSelectionClocksTemplate.tsx +1 -0
  522. package/src/TokenizerPopoverTemplate.tsx +1 -1
  523. package/src/features/InputSuggestionsTemplate.tsx +0 -1
  524. package/src/i18n/messagebundle.properties +28 -3
  525. package/src/themes/Button.css +2 -2
  526. package/src/themes/FileUploader.css +140 -32
  527. package/src/themes/SliderBase.css +20 -10
  528. package/src/themes/ValueStateMessage.css +1 -1
  529. package/src/themes/ValueStateVariables.css +27 -0
  530. package/src/themes/base/FileUploader-parameters.css +2 -0
@@ -7,6 +7,7 @@ import DatePicker from "./DatePicker.js";
7
7
  import type { DatePickerChangeEventDetail as DateTimePickerChangeEventDetail, DatePickerInputEventDetail as DateTimePickerInputEventDetail } from "./DatePicker.js";
8
8
  import type { TimeSelectionChangeEventDetail } from "./TimePickerInternals.js";
9
9
  import CalendarPickersMode from "./types/CalendarPickersMode.js";
10
+ import type TimeSelectionClocks from "./TimeSelectionClocks.js";
10
11
  type PreviewValues = {
11
12
  timeSelectionValue?: string;
12
13
  calendarTimestamp?: number;
@@ -98,6 +99,7 @@ declare class DateTimePicker extends DatePicker implements IFormInputElement {
98
99
  * @private
99
100
  */
100
101
  _previewValues: PreviewValues;
102
+ _clocks: TimeSelectionClocks;
101
103
  _handleResizeBound: ResizeObserverCallback;
102
104
  constructor();
103
105
  /**
@@ -146,7 +148,7 @@ declare class DateTimePicker extends DatePicker implements IFormInputElement {
146
148
  /**
147
149
  * @override
148
150
  */
149
- onSelectedDatesChange(e: CustomEvent<CalendarSelectionChangeEventDetail>): void;
151
+ onSelectedDatesChange(e: CustomEvent<CalendarSelectionChangeEventDetail>): Promise<void>;
150
152
  onTimeSelectionChange(e: CustomEvent<TimeSelectionChangeEventDetail>): void;
151
153
  /**
152
154
  * Handles document resize to switch between `phoneMode` and normal appearance.
@@ -25,6 +25,8 @@ import DateTimePickerTemplate from "./DateTimePickerTemplate.js";
25
25
  import DateTimePickerCss from "./generated/themes/DateTimePicker.css.js";
26
26
  import DateTimePickerPopoverCss from "./generated/themes/DateTimePickerPopover.css.js";
27
27
  import CalendarPickersMode from "./types/CalendarPickersMode.js";
28
+ import query from "@ui5/webcomponents-base/dist/decorators/query.js";
29
+ import { renderFinished } from "@ui5/webcomponents-base";
28
30
  const PHONE_MODE_BREAKPOINT = 640; // px
29
31
  /**
30
32
  * @class
@@ -213,7 +215,7 @@ let DateTimePicker = DateTimePicker_1 = class DateTimePicker extends DatePicker
213
215
  /**
214
216
  * @override
215
217
  */
216
- onSelectedDatesChange(e) {
218
+ async onSelectedDatesChange(e) {
217
219
  e.preventDefault();
218
220
  // @ts-ignore Needed for FF
219
221
  const dateTimePickerContent = e.path ? e.path[1] : e.composedPath()[1];
@@ -223,6 +225,12 @@ let DateTimePicker = DateTimePicker_1 = class DateTimePicker extends DatePicker
223
225
  calendarValue: e.detail.selectedValues[0],
224
226
  timeSelectionValue: dateTimePickerContent.lastChild.value,
225
227
  };
228
+ this._showTimeView = true;
229
+ if (this.showDateView) {
230
+ return;
231
+ }
232
+ await renderFinished();
233
+ this._clocks.focus();
226
234
  }
227
235
  onTimeSelectionChange(e) {
228
236
  this._previewValues = {
@@ -325,6 +333,9 @@ __decorate([
325
333
  __decorate([
326
334
  property({ type: Object })
327
335
  ], DateTimePicker.prototype, "_previewValues", void 0);
336
+ __decorate([
337
+ query("[ui5-time-selection-clocks]")
338
+ ], DateTimePicker.prototype, "_clocks", void 0);
328
339
  DateTimePicker = DateTimePicker_1 = __decorate([
329
340
  customElement({
330
341
  tag: "ui5-datetime-picker",
@@ -1 +1 @@
1
- {"version":3,"file":"DateTimePicker.js","sourceRoot":"","sources":["../src/DateTimePicker.ts"],"names":[],"mappings":"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","sourcesContent":["import property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport ResizeHandler from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport type { ResizeObserverCallback } from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport getLocale from \"@ui5/webcomponents-base/dist/locale/getLocale.js\";\nimport getCachedLocaleDataInstance from \"@ui5/webcomponents-localization/dist/getCachedLocaleDataInstance.js\";\nimport modifyDateBy from \"@ui5/webcomponents-localization/dist/dates/modifyDateBy.js\";\nimport CalendarDate from \"@ui5/webcomponents-localization/dist/dates/CalendarDate.js\";\nimport type { IFormInputElement } from \"@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js\";\nimport \"@ui5/webcomponents-icons/dist/date-time.js\";\nimport UI5Date from \"@ui5/webcomponents-localization/dist/dates/UI5Date.js\";\nimport DateFormat from \"@ui5/webcomponents-localization/dist/DateFormat.js\";\nimport type { SegmentedButtonSelectionChangeEventDetail } from \"./SegmentedButton.js\";\nimport type { CalendarSelectionChangeEventDetail } from \"./Calendar.js\";\nimport DatePicker from \"./DatePicker.js\";\nimport { isPhone } from \"@ui5/webcomponents-base/dist/Device.js\";\nimport type {\n\tDatePickerChangeEventDetail as DateTimePickerChangeEventDetail,\n\tDatePickerInputEventDetail as DateTimePickerInputEventDetail,\n} from \"./DatePicker.js\";\nimport type { TimeSelectionChangeEventDetail } from \"./TimePickerInternals.js\";\n\n// i18n texts\nimport {\n\tTIMEPICKER_SUBMIT_BUTTON,\n\tTIMEPICKER_CANCEL_BUTTON,\n\tDATETIME_DESCRIPTION,\n\tDATETIME_PICKER_DATE_BUTTON,\n\tDATETIME_PICKER_TIME_BUTTON,\n\tDATETIMEPICKER_POPOVER_ACCESSIBLE_NAME,\n} from \"./generated/i18n/i18n-defaults.js\";\n\n// Template\nimport DateTimePickerTemplate from \"./DateTimePickerTemplate.js\";\n\n// Styles\nimport DateTimePickerCss from \"./generated/themes/DateTimePicker.css.js\";\nimport DateTimePickerPopoverCss from \"./generated/themes/DateTimePickerPopover.css.js\";\nimport CalendarPickersMode from \"./types/CalendarPickersMode.js\";\n\nconst PHONE_MODE_BREAKPOINT = 640; // px\n\ntype PreviewValues = {\n\ttimeSelectionValue?: string,\n\tcalendarTimestamp?: number,\n\tcalendarValue?: string,\n}\n\n/**\n * @class\n *\n * ### Overview\n * The `DateTimePicker` component alows users to select both date (day, month and year) and time (hours, minutes and seconds)\n * and for the purpose it consists of input field and Date/Time picker.\n *\n * ### Usage\n *\n * Use the `DateTimePicker` if you need a combined date and time input component.\n * Don't use it if you want to use either date, or time value.\n * In this case, use the `DatePicker` or the `TimePicker` components instead.\n *\n * The user can set date/time by:\n *\n * - using the calendar and the time selectors\n * - typing in the input field\n *\n * Programmatically, to set date/time for the `DateTimePicker`, use the `value` property\n *\n * ### Formatting\n *\n * The value entered by typing into the input field must fit to the used date/time format.\n *\n * Supported format options are pattern-based on Unicode LDML Date Format notation.\n * For more information, see [UTS #35: Unicode Locale Data Markup Language](https://unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table).\n *\n * **Example:** the following format `dd/MM/yyyy, hh:mm:ss aa`\n * corresponds the `13/04/2020, 03:16:16 AM` value.\n *\n * The small 'h' defines \"12\" hours format and the \"aa\" symbols - \"AM/PM\" time periods.\n *\n * **Example:** the following format `dd/MM/yyyy, HH:mm:ss`\n * corresponds the `13/04/2020, 15:16:16` value.\n *\n * The capital 'H' indicates \"24\" hours format.\n *\n * **Note:** If the `formatPattern` does NOT include time,\n * the `DateTimePicker` will fallback to the default time format according to the locale.\n *\n * **Note:** If no placeholder is set to the `DateTimePicker`,\n * the current `formatPattern` is displayed as a placeholder.\n * If another placeholder is needed, it must be set or in case no placeholder is needed - it can be set to an empty string.\n *\n * **Note:** If the user input does NOT match the `formatPattern`,\n * the `DateTimePicker` makes an attempt to parse it based on the\n * locale settings.\n *\n * ### Responsive behavior\n *\n * The `DateTimePicker` is responsive and fully adapts to all devices.\n * For larger screens, such as tablet or desktop, it is displayed as a popover, while\n * on phone devices, it is displayed full screen.\n *\n * ### ES6 Module Import\n *\n * `import \"@ui5/webcomponents/dist/DateTimePicker.js\";`\n * @constructor\n * @extends DatePicker\n * @since 1.0.0-rc.7\n * @public\n */\n@customElement({\n\ttag: \"ui5-datetime-picker\",\n\ttemplate: DateTimePickerTemplate,\n\tstyles: [\n\t\tDatePicker.styles,\n\t\tDateTimePickerCss,\n\t\tDateTimePickerPopoverCss,\n\t],\n})\nclass DateTimePicker extends DatePicker implements IFormInputElement {\n\t/**\n\t * Defines the visibility of the time view in `phoneMode`.\n\t * For more information, see the `phoneMode` property.\n\t *\n\t * **Note:** The date view would be displayed by default.\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean, noAttribute: true })\n\t_showTimeView = false\n\n\t/**\n\t * Defines if the `DateTimePicker` should be displayed in phone mode.\n\t * The phone mode turns on when the component is used on small screens or phone devices.\n\t * In phone mode the user can see either the calendar view, or the time view\n\t * and can switch between the views via toggle buttons.\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_phoneMode = false;\n\n\t/**\n\t * Selected, but not yet confirmed date/time\n\t * @private\n\t */\n\t@property({ type: Object })\n\t_previewValues: PreviewValues = {};\n\n\t_handleResizeBound: ResizeObserverCallback;\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis._handleResizeBound = this._handleResize.bind(this);\n\t}\n\n\t/**\n\t * @override\n\t */\n\tonResponsivePopoverAfterClose() {\n\t\tsuper.onResponsivePopoverAfterClose();\n\t\tthis._showTimeView = false;\n\t\tthis._previewValues = {};\n\t}\n\n\t/**\n\t * LIFECYCLE METHODS\n\t */\n\n\tonEnterDOM() {\n\t\tResizeHandler.register(document.body, this._handleResizeBound);\n\t}\n\n\tonExitDOM() {\n\t\tResizeHandler.deregister(document.body, this._handleResizeBound);\n\t}\n\n\t/**\n\t * @override\n\t * @private\n\t */\n\t_togglePicker() {\n\t\tsuper._togglePicker();\n\n\t\tif (this.open) {\n\t\t\tthis._previewValues = {\n\t\t\t\t...this._previewValues,\n\t\t\t\ttimeSelectionValue: this.value || this.getFormat().format(UI5Date.getInstance()),\n\t\t\t};\n\t\t}\n\t}\n\n\tget _formatPattern() {\n\t\tconst hasHours = !!(this.formatPattern || \"\").match(/H/i);\n\t\tconst fallback = !this.formatPattern || !hasHours;\n\n\t\tconst localeData = getCachedLocaleDataInstance(getLocale());\n\t\treturn fallback ? localeData.getCombinedDateTimePattern(\"medium\", \"medium\", this._primaryCalendarType) : (this.formatPattern || \"\");\n\t}\n\n\tget _calendarTimestamp() {\n\t\treturn this._previewValues.calendarTimestamp ? this._previewValues.calendarTimestamp : super._calendarTimestamp;\n\t}\n\n\tget _calendarSelectedDates() {\n\t\treturn this._previewValues.calendarValue ? [this._previewValues.calendarValue] : super._calendarSelectedDates;\n\t}\n\n\tget _timeSelectionValue() {\n\t\treturn this._previewValues.timeSelectionValue ? this._previewValues.timeSelectionValue : this.value;\n\t}\n\n\tget openIconName() {\n\t\treturn \"date-time\";\n\t}\n\n\tget btnOKLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(TIMEPICKER_SUBMIT_BUTTON);\n\t}\n\n\tget btnCancelLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(TIMEPICKER_CANCEL_BUTTON);\n\t}\n\n\tget btnDateLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PICKER_DATE_BUTTON);\n\t}\n\n\tget btnTimeLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PICKER_TIME_BUTTON);\n\t}\n\n\tget showFooter() {\n\t\treturn true;\n\t}\n\n\tget showDateView() {\n\t\treturn this._phoneView ? !this._showTimeView : true;\n\t}\n\n\tget showTimeView() {\n\t\treturn this._phoneView ? this._showTimeView : true;\n\t}\n\n\tget _phoneView() {\n\t\treturn isPhone() || this._phoneMode;\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget dateAriaDescription() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_DESCRIPTION);\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget pickerAccessibleName() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIMEPICKER_POPOVER_ACCESSIBLE_NAME);\n\t}\n\n\t/**\n\t * Defines whether the dialog on mobile should have header\n\t * @private\n\t */\n\tget _shouldHideHeader() {\n\t\treturn true;\n\t}\n\n\t/**\n\t * EVENT HANDLERS\n\t */\n\n\t/**\n\t * @override\n\t */\n\tonSelectedDatesChange(e: CustomEvent<CalendarSelectionChangeEventDetail>) {\n\t\te.preventDefault();\n\t\t// @ts-ignore Needed for FF\n\t\tconst dateTimePickerContent = e.path ? e.path[1] : e.composedPath()[1];\n\t\tthis._previewValues = {\n\t\t\t...this._previewValues,\n\t\t\tcalendarTimestamp: e.detail.timestamp,\n\t\t\tcalendarValue: e.detail.selectedValues[0],\n\t\t\ttimeSelectionValue: dateTimePickerContent.lastChild.value,\n\t\t};\n\t}\n\n\tonTimeSelectionChange(e: CustomEvent<TimeSelectionChangeEventDetail>) {\n\t\tthis._previewValues = {\n\t\t\t...this._previewValues,\n\t\t\ttimeSelectionValue: e.detail.value,\n\t\t};\n\t}\n\n\t/**\n\t * Handles document resize to switch between `phoneMode` and normal appearance.\n\t */\n\t_handleResize() {\n\t\tconst documentWidth = document.body.offsetWidth;\n\t\tconst toPhoneMode = documentWidth <= PHONE_MODE_BREAKPOINT;\n\t\tconst modeChange = (toPhoneMode && !this._phoneMode) || (!toPhoneMode && this._phoneMode); // XOR not allowed by lint\n\n\t\tif (modeChange) {\n\t\t\tthis._phoneMode = toPhoneMode;\n\t\t}\n\t}\n\n\tget _submitDisabled() {\n\t\treturn !this._calendarSelectedDates || !this._calendarSelectedDates.length;\n\t}\n\n\t/**\n\t * Handles clicking on the `submit` button, within the picker`s footer.\n\t */\n\t_submitClick() {\n\t\tconst selectedDate = this.getSelectedDateTime();\n\n\t\tconst value = this.getFormat().format(selectedDate);\n\t\tif (this.value !== value) {\n\t\t\tthis._updateValueAndFireEvents(value, true, [\"change\", \"value-changed\"]);\n\t\t}\n\n\t\tthis._togglePicker();\n\t}\n\n\t/**\n\t * Handles clicking on the `cancel` button, within the picker`s footer,\n\t * that would disregard the user selection.\n\t */\n\t_cancelClick() {\n\t\tthis._togglePicker();\n\t}\n\n\t/**\n\t * Handles the date/time switch available in `phoneMode` to switch\n\t * between the date and time views.\n\t * @param e\n\t */\n\t_dateTimeSwitchChange(e: CustomEvent<SegmentedButtonSelectionChangeEventDetail>) { // Note: fix when SegmentedButton is implemented in TS\n\t\tconst selectedItem = e.detail.selectedItems[0];\n\t\tthis._showTimeView = selectedItem.getAttribute(\"data-ui5-key\") === \"Time\";\n\t}\n\n\t/**\n\t * @override\n\t */\n\t_modifyDateValue(amount: number, unit: string, preserveDate: boolean) {\n\t\tif (!this.dateValue) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst modifiedDate = modifyDateBy(CalendarDate.fromLocalJSDate(this.dateValue), amount, unit, preserveDate, this._minDate, this._maxDate);\n\t\tconst modifiedLocalDate = modifiedDate.toLocalJSDate();\n\t\tmodifiedLocalDate.setHours(this.dateValue.getHours());\n\t\tmodifiedLocalDate.setMinutes(this.dateValue.getMinutes());\n\t\tmodifiedLocalDate.setSeconds(this.dateValue.getSeconds());\n\n\t\tconst newValue = this.formatValue(modifiedLocalDate);\n\t\tthis._updateValueAndFireEvents(newValue, true, [\"change\", \"value-changed\"]);\n\t}\n\n\tgetSelectedDateTime() {\n\t\tconst selectedDate = this.getFormat().parse(this._calendarSelectedDates[0]) as Date;\n\t\tconst selectedTime = this.getFormat().parse(this._timeSelectionValue) as Date;\n\t\tif (selectedTime) {\n\t\t\tselectedDate.setHours(selectedTime.getHours());\n\t\t\tselectedDate.setMinutes(selectedTime.getMinutes());\n\t\t\tselectedDate.setSeconds(selectedTime.getSeconds());\n\t\t}\n\n\t\treturn selectedDate;\n\t}\n\n\tgetFormat() {\n\t\treturn this._isPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._formatPattern,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t})\n\t\t\t: DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tstyle: this._formatPattern,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget _calendarPickersMode() {\n\t\treturn CalendarPickersMode.DAY_MONTH_YEAR;\n\t}\n}\n\nDateTimePicker.define();\n\nexport default DateTimePicker;\nexport type {\n\tDateTimePickerChangeEventDetail,\n\tDateTimePickerInputEventDetail,\n};\n"]}
1
+ {"version":3,"file":"DateTimePicker.js","sourceRoot":"","sources":["../src/DateTimePicker.ts"],"names":[],"mappings":"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","sourcesContent":["import property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport ResizeHandler from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport type { ResizeObserverCallback } from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport getLocale from \"@ui5/webcomponents-base/dist/locale/getLocale.js\";\nimport getCachedLocaleDataInstance from \"@ui5/webcomponents-localization/dist/getCachedLocaleDataInstance.js\";\nimport modifyDateBy from \"@ui5/webcomponents-localization/dist/dates/modifyDateBy.js\";\nimport CalendarDate from \"@ui5/webcomponents-localization/dist/dates/CalendarDate.js\";\nimport type { IFormInputElement } from \"@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js\";\nimport \"@ui5/webcomponents-icons/dist/date-time.js\";\nimport UI5Date from \"@ui5/webcomponents-localization/dist/dates/UI5Date.js\";\nimport DateFormat from \"@ui5/webcomponents-localization/dist/DateFormat.js\";\nimport type { SegmentedButtonSelectionChangeEventDetail } from \"./SegmentedButton.js\";\nimport type { CalendarSelectionChangeEventDetail } from \"./Calendar.js\";\nimport DatePicker from \"./DatePicker.js\";\nimport { isPhone } from \"@ui5/webcomponents-base/dist/Device.js\";\nimport type {\n\tDatePickerChangeEventDetail as DateTimePickerChangeEventDetail,\n\tDatePickerInputEventDetail as DateTimePickerInputEventDetail,\n} from \"./DatePicker.js\";\nimport type { TimeSelectionChangeEventDetail } from \"./TimePickerInternals.js\";\n\n// i18n texts\nimport {\n\tTIMEPICKER_SUBMIT_BUTTON,\n\tTIMEPICKER_CANCEL_BUTTON,\n\tDATETIME_DESCRIPTION,\n\tDATETIME_PICKER_DATE_BUTTON,\n\tDATETIME_PICKER_TIME_BUTTON,\n\tDATETIMEPICKER_POPOVER_ACCESSIBLE_NAME,\n} from \"./generated/i18n/i18n-defaults.js\";\n\n// Template\nimport DateTimePickerTemplate from \"./DateTimePickerTemplate.js\";\n\n// Styles\nimport DateTimePickerCss from \"./generated/themes/DateTimePicker.css.js\";\nimport DateTimePickerPopoverCss from \"./generated/themes/DateTimePickerPopover.css.js\";\nimport CalendarPickersMode from \"./types/CalendarPickersMode.js\";\nimport type TimeSelectionClocks from \"./TimeSelectionClocks.js\";\nimport query from \"@ui5/webcomponents-base/dist/decorators/query.js\";\nimport { renderFinished } from \"@ui5/webcomponents-base\";\n\nconst PHONE_MODE_BREAKPOINT = 640; // px\n\ntype PreviewValues = {\n\ttimeSelectionValue?: string,\n\tcalendarTimestamp?: number,\n\tcalendarValue?: string,\n}\n\n/**\n * @class\n *\n * ### Overview\n * The `DateTimePicker` component alows users to select both date (day, month and year) and time (hours, minutes and seconds)\n * and for the purpose it consists of input field and Date/Time picker.\n *\n * ### Usage\n *\n * Use the `DateTimePicker` if you need a combined date and time input component.\n * Don't use it if you want to use either date, or time value.\n * In this case, use the `DatePicker` or the `TimePicker` components instead.\n *\n * The user can set date/time by:\n *\n * - using the calendar and the time selectors\n * - typing in the input field\n *\n * Programmatically, to set date/time for the `DateTimePicker`, use the `value` property\n *\n * ### Formatting\n *\n * The value entered by typing into the input field must fit to the used date/time format.\n *\n * Supported format options are pattern-based on Unicode LDML Date Format notation.\n * For more information, see [UTS #35: Unicode Locale Data Markup Language](https://unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table).\n *\n * **Example:** the following format `dd/MM/yyyy, hh:mm:ss aa`\n * corresponds the `13/04/2020, 03:16:16 AM` value.\n *\n * The small 'h' defines \"12\" hours format and the \"aa\" symbols - \"AM/PM\" time periods.\n *\n * **Example:** the following format `dd/MM/yyyy, HH:mm:ss`\n * corresponds the `13/04/2020, 15:16:16` value.\n *\n * The capital 'H' indicates \"24\" hours format.\n *\n * **Note:** If the `formatPattern` does NOT include time,\n * the `DateTimePicker` will fallback to the default time format according to the locale.\n *\n * **Note:** If no placeholder is set to the `DateTimePicker`,\n * the current `formatPattern` is displayed as a placeholder.\n * If another placeholder is needed, it must be set or in case no placeholder is needed - it can be set to an empty string.\n *\n * **Note:** If the user input does NOT match the `formatPattern`,\n * the `DateTimePicker` makes an attempt to parse it based on the\n * locale settings.\n *\n * ### Responsive behavior\n *\n * The `DateTimePicker` is responsive and fully adapts to all devices.\n * For larger screens, such as tablet or desktop, it is displayed as a popover, while\n * on phone devices, it is displayed full screen.\n *\n * ### ES6 Module Import\n *\n * `import \"@ui5/webcomponents/dist/DateTimePicker.js\";`\n * @constructor\n * @extends DatePicker\n * @since 1.0.0-rc.7\n * @public\n */\n@customElement({\n\ttag: \"ui5-datetime-picker\",\n\ttemplate: DateTimePickerTemplate,\n\tstyles: [\n\t\tDatePicker.styles,\n\t\tDateTimePickerCss,\n\t\tDateTimePickerPopoverCss,\n\t],\n})\nclass DateTimePicker extends DatePicker implements IFormInputElement {\n\t/**\n\t * Defines the visibility of the time view in `phoneMode`.\n\t * For more information, see the `phoneMode` property.\n\t *\n\t * **Note:** The date view would be displayed by default.\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean, noAttribute: true })\n\t_showTimeView = false\n\n\t/**\n\t * Defines if the `DateTimePicker` should be displayed in phone mode.\n\t * The phone mode turns on when the component is used on small screens or phone devices.\n\t * In phone mode the user can see either the calendar view, or the time view\n\t * and can switch between the views via toggle buttons.\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_phoneMode = false;\n\n\t/**\n\t * Selected, but not yet confirmed date/time\n\t * @private\n\t */\n\t@property({ type: Object })\n\t_previewValues: PreviewValues = {};\n\n\t@query(\"[ui5-time-selection-clocks]\")\n\t_clocks!: TimeSelectionClocks;\n\n\t_handleResizeBound: ResizeObserverCallback;\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis._handleResizeBound = this._handleResize.bind(this);\n\t}\n\n\t/**\n\t * @override\n\t */\n\tonResponsivePopoverAfterClose() {\n\t\tsuper.onResponsivePopoverAfterClose();\n\t\tthis._showTimeView = false;\n\t\tthis._previewValues = {};\n\t}\n\n\t/**\n\t * LIFECYCLE METHODS\n\t */\n\n\tonEnterDOM() {\n\t\tResizeHandler.register(document.body, this._handleResizeBound);\n\t}\n\n\tonExitDOM() {\n\t\tResizeHandler.deregister(document.body, this._handleResizeBound);\n\t}\n\n\t/**\n\t * @override\n\t * @private\n\t */\n\t_togglePicker() {\n\t\tsuper._togglePicker();\n\n\t\tif (this.open) {\n\t\t\tthis._previewValues = {\n\t\t\t\t...this._previewValues,\n\t\t\t\ttimeSelectionValue: this.value || this.getFormat().format(UI5Date.getInstance()),\n\t\t\t};\n\t\t}\n\t}\n\n\tget _formatPattern() {\n\t\tconst hasHours = !!(this.formatPattern || \"\").match(/H/i);\n\t\tconst fallback = !this.formatPattern || !hasHours;\n\n\t\tconst localeData = getCachedLocaleDataInstance(getLocale());\n\t\treturn fallback ? localeData.getCombinedDateTimePattern(\"medium\", \"medium\", this._primaryCalendarType) : (this.formatPattern || \"\");\n\t}\n\n\tget _calendarTimestamp() {\n\t\treturn this._previewValues.calendarTimestamp ? this._previewValues.calendarTimestamp : super._calendarTimestamp;\n\t}\n\n\tget _calendarSelectedDates() {\n\t\treturn this._previewValues.calendarValue ? [this._previewValues.calendarValue] : super._calendarSelectedDates;\n\t}\n\n\tget _timeSelectionValue() {\n\t\treturn this._previewValues.timeSelectionValue ? this._previewValues.timeSelectionValue : this.value;\n\t}\n\n\tget openIconName() {\n\t\treturn \"date-time\";\n\t}\n\n\tget btnOKLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(TIMEPICKER_SUBMIT_BUTTON);\n\t}\n\n\tget btnCancelLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(TIMEPICKER_CANCEL_BUTTON);\n\t}\n\n\tget btnDateLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PICKER_DATE_BUTTON);\n\t}\n\n\tget btnTimeLabel() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PICKER_TIME_BUTTON);\n\t}\n\n\tget showFooter() {\n\t\treturn true;\n\t}\n\n\tget showDateView() {\n\t\treturn this._phoneView ? !this._showTimeView : true;\n\t}\n\n\tget showTimeView() {\n\t\treturn this._phoneView ? this._showTimeView : true;\n\t}\n\n\tget _phoneView() {\n\t\treturn isPhone() || this._phoneMode;\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget dateAriaDescription() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_DESCRIPTION);\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget pickerAccessibleName() {\n\t\treturn DateTimePicker.i18nBundle.getText(DATETIMEPICKER_POPOVER_ACCESSIBLE_NAME);\n\t}\n\n\t/**\n\t * Defines whether the dialog on mobile should have header\n\t * @private\n\t */\n\tget _shouldHideHeader() {\n\t\treturn true;\n\t}\n\n\t/**\n\t * EVENT HANDLERS\n\t */\n\n\t/**\n\t * @override\n\t */\n\tasync onSelectedDatesChange(e: CustomEvent<CalendarSelectionChangeEventDetail>) {\n\t\te.preventDefault();\n\t\t// @ts-ignore Needed for FF\n\t\tconst dateTimePickerContent = e.path ? e.path[1] : e.composedPath()[1];\n\t\tthis._previewValues = {\n\t\t\t...this._previewValues,\n\t\t\tcalendarTimestamp: e.detail.timestamp,\n\t\t\tcalendarValue: e.detail.selectedValues[0],\n\t\t\ttimeSelectionValue: dateTimePickerContent.lastChild.value,\n\t\t};\n\t\tthis._showTimeView = true;\n\n\t\tif (this.showDateView) {\n\t\t\treturn;\n\t\t}\n\n\t\tawait renderFinished();\n\t\tthis._clocks.focus();\n\t}\n\n\tonTimeSelectionChange(e: CustomEvent<TimeSelectionChangeEventDetail>) {\n\t\tthis._previewValues = {\n\t\t\t...this._previewValues,\n\t\t\ttimeSelectionValue: e.detail.value,\n\t\t};\n\t}\n\n\t/**\n\t * Handles document resize to switch between `phoneMode` and normal appearance.\n\t */\n\t_handleResize() {\n\t\tconst documentWidth = document.body.offsetWidth;\n\t\tconst toPhoneMode = documentWidth <= PHONE_MODE_BREAKPOINT;\n\t\tconst modeChange = (toPhoneMode && !this._phoneMode) || (!toPhoneMode && this._phoneMode); // XOR not allowed by lint\n\n\t\tif (modeChange) {\n\t\t\tthis._phoneMode = toPhoneMode;\n\t\t}\n\t}\n\n\tget _submitDisabled() {\n\t\treturn !this._calendarSelectedDates || !this._calendarSelectedDates.length;\n\t}\n\n\t/**\n\t * Handles clicking on the `submit` button, within the picker`s footer.\n\t */\n\t_submitClick() {\n\t\tconst selectedDate = this.getSelectedDateTime();\n\n\t\tconst value = this.getFormat().format(selectedDate);\n\t\tif (this.value !== value) {\n\t\t\tthis._updateValueAndFireEvents(value, true, [\"change\", \"value-changed\"]);\n\t\t}\n\n\t\tthis._togglePicker();\n\t}\n\n\t/**\n\t * Handles clicking on the `cancel` button, within the picker`s footer,\n\t * that would disregard the user selection.\n\t */\n\t_cancelClick() {\n\t\tthis._togglePicker();\n\t}\n\n\t/**\n\t * Handles the date/time switch available in `phoneMode` to switch\n\t * between the date and time views.\n\t * @param e\n\t */\n\t_dateTimeSwitchChange(e: CustomEvent<SegmentedButtonSelectionChangeEventDetail>) { // Note: fix when SegmentedButton is implemented in TS\n\t\tconst selectedItem = e.detail.selectedItems[0];\n\t\tthis._showTimeView = selectedItem.getAttribute(\"data-ui5-key\") === \"Time\";\n\t}\n\n\t/**\n\t * @override\n\t */\n\t_modifyDateValue(amount: number, unit: string, preserveDate: boolean) {\n\t\tif (!this.dateValue) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst modifiedDate = modifyDateBy(CalendarDate.fromLocalJSDate(this.dateValue), amount, unit, preserveDate, this._minDate, this._maxDate);\n\t\tconst modifiedLocalDate = modifiedDate.toLocalJSDate();\n\t\tmodifiedLocalDate.setHours(this.dateValue.getHours());\n\t\tmodifiedLocalDate.setMinutes(this.dateValue.getMinutes());\n\t\tmodifiedLocalDate.setSeconds(this.dateValue.getSeconds());\n\n\t\tconst newValue = this.formatValue(modifiedLocalDate);\n\t\tthis._updateValueAndFireEvents(newValue, true, [\"change\", \"value-changed\"]);\n\t}\n\n\tgetSelectedDateTime() {\n\t\tconst selectedDate = this.getFormat().parse(this._calendarSelectedDates[0]) as Date;\n\t\tconst selectedTime = this.getFormat().parse(this._timeSelectionValue) as Date;\n\t\tif (selectedTime) {\n\t\t\tselectedDate.setHours(selectedTime.getHours());\n\t\t\tselectedDate.setMinutes(selectedTime.getMinutes());\n\t\t\tselectedDate.setSeconds(selectedTime.getSeconds());\n\t\t}\n\n\t\treturn selectedDate;\n\t}\n\n\tgetFormat() {\n\t\treturn this._isPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._formatPattern,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t})\n\t\t\t: DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tstyle: this._formatPattern,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\t/**\n\t * @override\n\t */\n\tget _calendarPickersMode() {\n\t\treturn CalendarPickersMode.DAY_MONTH_YEAR;\n\t}\n}\n\nDateTimePicker.define();\n\nexport default DateTimePicker;\nexport type {\n\tDateTimePickerChangeEventDetail,\n\tDateTimePickerInputEventDetail,\n};\n"]}
@@ -2,8 +2,9 @@ import UI5Element from "@ui5/webcomponents-base/dist/UI5Element.js";
2
2
  import ValueState from "@ui5/webcomponents-base/dist/types/ValueState.js";
3
3
  import type I18nBundle from "@ui5/webcomponents-base/dist/i18nBundle.js";
4
4
  import type { IFormInputElement } from "@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js";
5
- import type Input from "./Input.js";
5
+ import type { InputAccInfo } from "./Input.js";
6
6
  import type Popover from "./Popover.js";
7
+ import type Tokenizer from "./Tokenizer.js";
7
8
  type FileData = {
8
9
  fileName: string;
9
10
  fileSize: number;
@@ -53,6 +54,8 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
53
54
  accept?: string;
54
55
  /**
55
56
  * If set to "true", the input field of component will not be rendered. Only the default slot that is passed will be rendered.
57
+ *
58
+ * **Note:** Use this property in combination with the default slot to achieve a button-only file uploader design.
56
59
  * @default false
57
60
  * @public
58
61
  */
@@ -106,15 +109,35 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
106
109
  * @public
107
110
  */
108
111
  valueState: `${ValueState}`;
112
+ /**
113
+ * Defines whether the component is required.
114
+ * @default false
115
+ * @public
116
+ */
117
+ required: boolean;
118
+ /**
119
+ * Defines the accessible ARIA name of the component.
120
+ * @default undefined
121
+ * @public
122
+ */
123
+ accessibleName?: string;
124
+ /**
125
+ * Receives id(or many ids) of the elements that label the input.
126
+ * @default undefined
127
+ * @public
128
+ */
129
+ accessibleNameRef?: string;
109
130
  /**
110
131
  * @private
111
132
  */
112
133
  focused: boolean;
113
134
  /**
114
- * By default the component contains a single input field. With this slot you can pass any content that you wish to add. See the samples for more information.
135
+ * This slot allows you to add custom content to the component, such as a button or any other interactive element to trigger the file selection dialog.
115
136
  *
116
- * **Note:** If no content is provided in this slot, the component will only consist of an input field and will not be interactable using the keyboard.
117
- * Also it is not recommended to use any non-interactable components, as it may lead to poor accessibility experience.
137
+ * **Note:** For best accessibility experience, set a `tabindex` of "-1" on your interactive element, or it will be set automatically.
138
+ * This slot is intended for use cases where you want a button-only file uploader.
139
+ * It is recommended to set the `hideInput` property to "true" when using this slot.
140
+ * Not setting `hideInput` may negatively impact the screen reader users.
118
141
  * @public
119
142
  */
120
143
  content: Array<HTMLElement>;
@@ -129,6 +152,13 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
129
152
  * @public
130
153
  */
131
154
  valueStateMessage: Array<HTMLElement>;
155
+ _form: HTMLFormElement;
156
+ _input: HTMLInputElement;
157
+ _tokenizer: Tokenizer;
158
+ _messagePopover: Popover;
159
+ _selectedFilesNames: Array<string>;
160
+ _tokenizerOpen: boolean;
161
+ _tokenizerExpanded: boolean;
132
162
  static emptyInput: HTMLInputElement;
133
163
  static i18nBundle: I18nBundle;
134
164
  formElementAnchor(): Promise<HTMLElement | undefined>;
@@ -137,15 +167,23 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
137
167
  */
138
168
  getFocusDomRef(): HTMLElement | undefined;
139
169
  get formFormattedValue(): FormData | null;
140
- _onmouseover(): void;
141
- _onmouseout(): void;
142
170
  _onclick(): void;
171
+ _onNativeInputClick(e: MouseEvent): void;
172
+ _onmousedown(e: MouseEvent): void;
143
173
  _onkeydown(e: KeyboardEvent): void;
144
174
  _onkeyup(e: KeyboardEvent): void;
145
175
  _ondrag(e: DragEvent): void;
146
176
  _ondrop(e: DragEvent): void;
147
177
  _onfocusin(): void;
148
178
  _onfocusout(): void;
179
+ _onTokenizerKeyUp(e: KeyboardEvent): void;
180
+ _onTokenizerKeyDown(e: KeyboardEvent): void;
181
+ _onTokenizerClick(e: MouseEvent): void;
182
+ _onTokenizerMouseDown(e: MouseEvent): void;
183
+ _onClearIconClick(e: CustomEvent): void;
184
+ _onFormSubmit(e: SubmitEvent): void;
185
+ _openFileBrowser(): void;
186
+ _clearFileSelection(): void;
149
187
  /**
150
188
  * FileList of all selected files.
151
189
  * @public
@@ -153,8 +191,10 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
153
191
  */
154
192
  get files(): FileList | null;
155
193
  onAfterRendering(): void;
194
+ get computedValue(): string;
195
+ get _formWidth(): number;
156
196
  _onChange(e: Event): void;
157
- _updateValue(files: FileList | null): void;
197
+ _fileNamesList(files: FileList): Array<string>;
158
198
  /**
159
199
  * Checks whether all files are below `maxFileSize` (if set),
160
200
  * and fires a `file-size-exceed` event if any file exceeds it.
@@ -165,26 +205,25 @@ declare class FileUploader extends UI5Element implements IFormInputElement {
165
205
  toggleValueStatePopover(open: boolean): void;
166
206
  openValueStatePopover(): void;
167
207
  closeValueStatePopover(): void;
168
- _getPopover(): Popover;
169
208
  /**
170
209
  * in case when the component is not placed in the DOM, return empty FileList, like native input would do
171
210
  * @private
172
211
  */
173
212
  static get _emptyFilesList(): FileList | null;
174
- get browseText(): string;
175
- get titleText(): string;
176
- get _input(): HTMLInputElement;
213
+ get accInfo(): InputAccInfo;
214
+ get inputTitle(): string;
215
+ get valueHelpTitle(): string;
216
+ get clearIconTitle(): string;
217
+ get resolvedPlaceholder(): string;
177
218
  get valueStateTextMappings(): Record<string, string>;
178
219
  get valueStateText(): string;
179
220
  get hasValueState(): boolean;
180
- get hasValueStateText(): boolean;
181
221
  get shouldDisplayDefaultValueStateMessage(): boolean;
182
222
  get shouldOpenValueStateMessagePopover(): boolean;
183
223
  /**
184
224
  * This method is relevant for sap_horizon theme only
185
225
  */
186
226
  get _valueStateMessageInputIcon(): string;
187
- get ui5Input(): Input | null;
188
227
  }
189
228
  export default FileUploader;
190
229
  export type { FileData, FileUploaderChangeEventDetail, FileUploaderFileSizeExceedEventDetail, };
@@ -10,11 +10,13 @@ import customElement from "@ui5/webcomponents-base/dist/decorators/customElement
10
10
  import property from "@ui5/webcomponents-base/dist/decorators/property.js";
11
11
  import event from "@ui5/webcomponents-base/dist/decorators/event-strict.js";
12
12
  import slot from "@ui5/webcomponents-base/dist/decorators/slot.js";
13
+ import query from "@ui5/webcomponents-base/dist/decorators/query.js";
13
14
  import ValueState from "@ui5/webcomponents-base/dist/types/ValueState.js";
15
+ import { getEffectiveAriaLabelText, getAssociatedLabelForTexts, getAllAccessibleNameRefTexts, } from "@ui5/webcomponents-base/dist/util/AccessibilityTextsHelper.js";
14
16
  import jsxRenderer from "@ui5/webcomponents-base/dist/renderer/JsxRenderer.js";
15
17
  import i18n from "@ui5/webcomponents-base/dist/decorators/i18n.js";
16
- import { isEnter, isSpace } from "@ui5/webcomponents-base/dist/Keys.js";
17
- import { FILEUPLOAD_BROWSE, FILEUPLOADER_TITLE, VALUE_STATE_SUCCESS, VALUE_STATE_INFORMATION, VALUE_STATE_ERROR, VALUE_STATE_WARNING, } from "./generated/i18n/i18n-defaults.js";
18
+ import { isUpAlt, isDownAlt, isEnter, isDelete, isF4, isSpace, isRight, isLeft, } from "@ui5/webcomponents-base/dist/Keys.js";
19
+ import { FILEUPLOADER_INPUT_TOOLTIP, FILEUPLOADER_VALUE_HELP_TOOLTIP, FILEUPLOADER_CLEAR_ICON_TOOLTIP, VALUE_STATE_SUCCESS, VALUE_STATE_INFORMATION, VALUE_STATE_ERROR, VALUE_STATE_WARNING, FILEUPLOADER_DEFAULT_PLACEHOLDER, FILEUPLOADER_DEFAULT_MULTIPLE_PLACEHOLDER, FILEUPLOADER_ROLE_DESCRIPTION, } from "./generated/i18n/i18n-defaults.js";
18
20
  // Template
19
21
  import FileUploaderTemplate from "./FileUploaderTemplate.js";
20
22
  // Styles
@@ -51,6 +53,8 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
51
53
  super(...arguments);
52
54
  /**
53
55
  * If set to "true", the input field of component will not be rendered. Only the default slot that is passed will be rendered.
56
+ *
57
+ * **Note:** Use this property in combination with the default slot to achieve a button-only file uploader design.
54
58
  * @default false
55
59
  * @public
56
60
  */
@@ -83,10 +87,19 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
83
87
  * @public
84
88
  */
85
89
  this.valueState = "None";
90
+ /**
91
+ * Defines whether the component is required.
92
+ * @default false
93
+ * @public
94
+ */
95
+ this.required = false;
86
96
  /**
87
97
  * @private
88
98
  */
89
99
  this.focused = false;
100
+ this._selectedFilesNames = [];
101
+ this._tokenizerOpen = false;
102
+ this._tokenizerExpanded = true;
90
103
  }
91
104
  async formElementAnchor() {
92
105
  return this.getFocusDomRefAsync();
@@ -95,7 +108,7 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
95
108
  * @override
96
109
  */
97
110
  getFocusDomRef() {
98
- return this.content[0];
111
+ return this._input;
99
112
  }
100
113
  get formFormattedValue() {
101
114
  if (this.files && this.name) {
@@ -107,32 +120,47 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
107
120
  }
108
121
  return null;
109
122
  }
110
- _onmouseover() {
111
- this.content.forEach(item => {
112
- item.classList.add("ui5_hovered");
113
- });
114
- }
115
- _onmouseout() {
116
- this.content.forEach(item => {
117
- item.classList.remove("ui5_hovered");
118
- });
119
- }
120
123
  _onclick() {
121
124
  if (this.getFocusDomRef()?.matches(":focus-within")) {
122
- this._input.click();
125
+ this._openFileBrowser();
123
126
  }
124
127
  }
128
+ _onNativeInputClick(e) {
129
+ e.stopPropagation();
130
+ }
131
+ _onmousedown(e) {
132
+ e.preventDefault();
133
+ this._input.focus();
134
+ }
125
135
  _onkeydown(e) {
136
+ const firstToken = this._tokenizer?.tokens.find(token => !token.hasAttribute("overflows"));
137
+ const isToken = e.target.hasAttribute("ui5-token");
138
+ const isArrowNavigation = this.effectiveDir === "ltr" ? isRight(e) : isLeft(e);
139
+ if (this.hideInput) {
140
+ return;
141
+ }
126
142
  if (isEnter(e)) {
127
- this._input.click();
128
143
  e.preventDefault();
144
+ this._openFileBrowser();
129
145
  }
130
- }
131
- _onkeyup(e) {
132
146
  if (isSpace(e)) {
133
- this._input.click();
134
147
  e.preventDefault();
135
148
  }
149
+ if (isArrowNavigation && !isToken) {
150
+ e.preventDefault();
151
+ firstToken?.focus();
152
+ }
153
+ }
154
+ _onkeyup(e) {
155
+ if (this.hideInput) {
156
+ return;
157
+ }
158
+ if (isSpace(e) || isF4(e) || isUpAlt(e) || isDownAlt(e)) {
159
+ this._openFileBrowser();
160
+ }
161
+ else if (isDelete(e)) {
162
+ this._clearFileSelection();
163
+ }
136
164
  }
137
165
  _ondrag(e) {
138
166
  e.preventDefault();
@@ -150,16 +178,59 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
150
178
  return;
151
179
  }
152
180
  this._input.files = validatedFiles;
153
- this._updateValue(validatedFiles);
181
+ this._selectedFilesNames = this._fileNamesList(files);
182
+ this.value = this.computedValue;
154
183
  this.fireDecoratorEvent("change", {
155
184
  files: validatedFiles,
156
185
  });
157
186
  }
158
187
  _onfocusin() {
159
188
  this.focused = true;
189
+ this._tokenizerExpanded = true;
160
190
  }
161
191
  _onfocusout() {
162
192
  this.focused = false;
193
+ this._tokenizerExpanded = this._tokenizerOpen || false;
194
+ }
195
+ _onTokenizerKeyUp(e) {
196
+ if (isSpace(e) || isDelete(e)) {
197
+ e.stopPropagation();
198
+ }
199
+ }
200
+ _onTokenizerKeyDown(e) {
201
+ const firstToken = this._tokenizer?.tokens.find(token => !token.hasAttribute("overflows"));
202
+ const isArrowNavigation = this.effectiveDir === "ltr" ? isLeft(e) : isRight(e);
203
+ if (isEnter(e)) {
204
+ e.stopPropagation();
205
+ }
206
+ if (e.target === firstToken && isArrowNavigation) {
207
+ this._input.focus();
208
+ e.preventDefault();
209
+ }
210
+ }
211
+ _onTokenizerClick(e) {
212
+ e.stopPropagation();
213
+ }
214
+ _onTokenizerMouseDown(e) {
215
+ e.stopPropagation();
216
+ }
217
+ _onClearIconClick(e) {
218
+ e.stopPropagation();
219
+ this._clearFileSelection();
220
+ }
221
+ _onFormSubmit(e) {
222
+ e.preventDefault();
223
+ }
224
+ _openFileBrowser() {
225
+ this._input.click();
226
+ }
227
+ _clearFileSelection() {
228
+ this._selectedFilesNames = [];
229
+ this.value = "";
230
+ this._form?.reset();
231
+ this.fireDecoratorEvent("change", {
232
+ files: this.files,
233
+ });
163
234
  }
164
235
  /**
165
236
  * FileList of all selected files.
@@ -176,8 +247,20 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
176
247
  if (!this.value) {
177
248
  this._input.value = "";
178
249
  }
250
+ this._tokenizerOpen = this._tokenizer?.open || false;
251
+ if (this.hideInput && this.content.length > 0) {
252
+ this.content.forEach(element => {
253
+ element.setAttribute("tabindex", "-1");
254
+ });
255
+ }
179
256
  this.toggleValueStatePopover(this.shouldOpenValueStateMessagePopover);
180
257
  }
258
+ get computedValue() {
259
+ return this._selectedFilesNames.join(" ");
260
+ }
261
+ get _formWidth() {
262
+ return this._form ? this._form.offsetWidth : 0;
263
+ }
181
264
  _onChange(e) {
182
265
  let changedFiles = e.target.files;
183
266
  if (changedFiles) {
@@ -186,15 +269,16 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
186
269
  if (!this.value && !changedFiles?.length) {
187
270
  return;
188
271
  }
189
- this._updateValue(changedFiles);
272
+ this._selectedFilesNames = this._fileNamesList(changedFiles);
273
+ this.value = this.computedValue;
190
274
  this.fireDecoratorEvent("change", {
191
275
  files: changedFiles,
192
276
  });
193
277
  }
194
- _updateValue(files) {
195
- this.value = Array.from(files || []).reduce((acc, currFile) => {
196
- return `${acc}"${currFile.name}" `;
197
- }, "");
278
+ _fileNamesList(files) {
279
+ return Array.from(files)
280
+ .map(file => file.name)
281
+ .sort((a, b) => a.length - b.length); // workaround for incident #11824
198
282
  }
199
283
  /**
200
284
  * Checks whether all files are below `maxFileSize` (if set),
@@ -234,21 +318,16 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
234
318
  }
235
319
  }
236
320
  openValueStatePopover() {
237
- const popover = this._getPopover();
238
- if (popover) {
239
- popover.opener = this;
240
- popover.open = true;
321
+ if (this._messagePopover) {
322
+ this._messagePopover.opener = this;
323
+ this._messagePopover.open = true;
241
324
  }
242
325
  }
243
326
  closeValueStatePopover() {
244
- const popover = this._getPopover();
245
- if (popover) {
246
- popover.open = false;
327
+ if (this._messagePopover) {
328
+ this._messagePopover.open = false;
247
329
  }
248
330
  }
249
- _getPopover() {
250
- return this.shadowRoot.querySelector(".ui5-valuestatemessage-popover");
251
- }
252
331
  /**
253
332
  * in case when the component is not placed in the DOM, return empty FileList, like native input would do
254
333
  * @private
@@ -260,14 +339,28 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
260
339
  }
261
340
  return this.emptyInput.files;
262
341
  }
263
- get browseText() {
264
- return FileUploader_1.i18nBundle.getText(FILEUPLOAD_BROWSE);
342
+ get accInfo() {
343
+ return {
344
+ "ariaRoledescription": FileUploader_1.i18nBundle.getText(FILEUPLOADER_ROLE_DESCRIPTION),
345
+ "ariaRequired": this.required || undefined,
346
+ "ariaInvalid": this.valueState === ValueState.Negative || undefined,
347
+ "ariaHasPopup": "dialog",
348
+ "ariaLabel": getAllAccessibleNameRefTexts(this) || getEffectiveAriaLabelText(this) || getAssociatedLabelForTexts(this) || undefined,
349
+ };
350
+ }
351
+ get inputTitle() {
352
+ return FileUploader_1.i18nBundle.getText(FILEUPLOADER_INPUT_TOOLTIP);
353
+ }
354
+ get valueHelpTitle() {
355
+ return FileUploader_1.i18nBundle.getText(FILEUPLOADER_VALUE_HELP_TOOLTIP);
265
356
  }
266
- get titleText() {
267
- return FileUploader_1.i18nBundle.getText(FILEUPLOADER_TITLE);
357
+ get clearIconTitle() {
358
+ return FileUploader_1.i18nBundle.getText(FILEUPLOADER_CLEAR_ICON_TOOLTIP);
268
359
  }
269
- get _input() {
270
- return (this.shadowRoot.querySelector("input[type=file]") || this.querySelector("input[type=file][data-ui5-form-support]"));
360
+ get resolvedPlaceholder() {
361
+ const singlePlaceholder = FileUploader_1.i18nBundle.getText(FILEUPLOADER_DEFAULT_PLACEHOLDER);
362
+ const multiplePlaceholder = FileUploader_1.i18nBundle.getText(FILEUPLOADER_DEFAULT_MULTIPLE_PLACEHOLDER);
363
+ return this.placeholder ?? (this.multiple ? multiplePlaceholder : singlePlaceholder);
271
364
  }
272
365
  get valueStateTextMappings() {
273
366
  return {
@@ -283,14 +376,11 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
283
376
  get hasValueState() {
284
377
  return this.valueState !== ValueState.None;
285
378
  }
286
- get hasValueStateText() {
287
- return this.hasValueState && this.valueState !== ValueState.Positive;
288
- }
289
379
  get shouldDisplayDefaultValueStateMessage() {
290
- return !this.valueStateMessage.length && this.hasValueStateText;
380
+ return !this.valueStateMessage.length && this.hasValueState;
291
381
  }
292
382
  get shouldOpenValueStateMessagePopover() {
293
- return this.focused && this.hasValueStateText && !this.hideInput;
383
+ return this.focused && this.hasValueState && !this.hideInput && !this._tokenizerOpen;
294
384
  }
295
385
  /**
296
386
  * This method is relevant for sap_horizon theme only
@@ -304,9 +394,6 @@ let FileUploader = FileUploader_1 = class FileUploader extends UI5Element {
304
394
  };
305
395
  return this.valueState !== ValueState.None ? iconPerValueState[this.valueState] : "";
306
396
  }
307
- get ui5Input() {
308
- return this.shadowRoot.querySelector(".ui5-file-uploader-input");
309
- }
310
397
  };
311
398
  __decorate([
312
399
  property()
@@ -335,6 +422,15 @@ __decorate([
335
422
  __decorate([
336
423
  property()
337
424
  ], FileUploader.prototype, "valueState", void 0);
425
+ __decorate([
426
+ property({ type: Boolean })
427
+ ], FileUploader.prototype, "required", void 0);
428
+ __decorate([
429
+ property()
430
+ ], FileUploader.prototype, "accessibleName", void 0);
431
+ __decorate([
432
+ property()
433
+ ], FileUploader.prototype, "accessibleNameRef", void 0);
338
434
  __decorate([
339
435
  property({ type: Boolean })
340
436
  ], FileUploader.prototype, "focused", void 0);
@@ -344,6 +440,27 @@ __decorate([
344
440
  __decorate([
345
441
  slot()
346
442
  ], FileUploader.prototype, "valueStateMessage", void 0);
443
+ __decorate([
444
+ query(".ui5-file-uploader-form")
445
+ ], FileUploader.prototype, "_form", void 0);
446
+ __decorate([
447
+ query("input[type=file]")
448
+ ], FileUploader.prototype, "_input", void 0);
449
+ __decorate([
450
+ query("[ui5-tokenizer]")
451
+ ], FileUploader.prototype, "_tokenizer", void 0);
452
+ __decorate([
453
+ query(".ui5-valuestatemessage-popover")
454
+ ], FileUploader.prototype, "_messagePopover", void 0);
455
+ __decorate([
456
+ property({ type: Array, noAttribute: true })
457
+ ], FileUploader.prototype, "_selectedFilesNames", void 0);
458
+ __decorate([
459
+ property({ type: Boolean, noAttribute: true })
460
+ ], FileUploader.prototype, "_tokenizerOpen", void 0);
461
+ __decorate([
462
+ property({ type: Boolean, noAttribute: true })
463
+ ], FileUploader.prototype, "_tokenizerExpanded", void 0);
347
464
  __decorate([
348
465
  i18n("@ui5/webcomponents")
349
466
  ], FileUploader, "i18nBundle", void 0);