@ui5/webcomponents 2.19.0-rc.0 → 2.19.0-rc.2

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 (653) hide show
  1. package/CHANGELOG.md +47 -0
  2. package/README.md +1 -1
  3. package/dist/.tsbuildinfo +1 -1
  4. package/dist/Calendar.js +1 -1
  5. package/dist/Calendar.js.map +1 -1
  6. package/dist/ColorPicker.d.ts +5 -0
  7. package/dist/ColorPicker.js +12 -0
  8. package/dist/ColorPicker.js.map +1 -1
  9. package/dist/ColorPickerTemplate.js +1 -1
  10. package/dist/ColorPickerTemplate.js.map +1 -1
  11. package/dist/DateTimePicker.js +4 -3
  12. package/dist/DateTimePicker.js.map +1 -1
  13. package/dist/Input.d.ts +12 -9
  14. package/dist/Input.js +94 -57
  15. package/dist/Input.js.map +1 -1
  16. package/dist/InputTemplate.js +1 -1
  17. package/dist/InputTemplate.js.map +1 -1
  18. package/dist/Link.d.ts +0 -7
  19. package/dist/Link.js +1 -5
  20. package/dist/Link.js.map +1 -1
  21. package/dist/ListBoxItemGroupTemplate.js +1 -1
  22. package/dist/ListBoxItemGroupTemplate.js.map +1 -1
  23. package/dist/ListItemGroup.d.ts +2 -1
  24. package/dist/ListItemGroup.js +2 -0
  25. package/dist/ListItemGroup.js.map +1 -1
  26. package/dist/Menu.d.ts +1 -1
  27. package/dist/Menu.js +3 -3
  28. package/dist/Menu.js.map +1 -1
  29. package/dist/MenuItem.d.ts +1 -1
  30. package/dist/MenuItem.js +3 -3
  31. package/dist/MenuItem.js.map +1 -1
  32. package/dist/MenuItemTemplate.js +1 -2
  33. package/dist/MenuItemTemplate.js.map +1 -1
  34. package/dist/MenuTemplate.js +3 -3
  35. package/dist/MenuTemplate.js.map +1 -1
  36. package/dist/MultiComboBox.d.ts +6 -1
  37. package/dist/MultiComboBox.js +29 -5
  38. package/dist/MultiComboBox.js.map +1 -1
  39. package/dist/Popover.d.ts +23 -2
  40. package/dist/Popover.js +77 -12
  41. package/dist/Popover.js.map +1 -1
  42. package/dist/PopoverResize.d.ts +62 -0
  43. package/dist/PopoverResize.js +276 -0
  44. package/dist/PopoverResize.js.map +1 -0
  45. package/dist/PopoverTemplate.js +5 -2
  46. package/dist/PopoverTemplate.js.map +1 -1
  47. package/dist/SegmentedButtonItem.js +1 -0
  48. package/dist/SegmentedButtonItem.js.map +1 -1
  49. package/dist/StepInput.d.ts +17 -0
  50. package/dist/StepInput.js +79 -16
  51. package/dist/StepInput.js.map +1 -1
  52. package/dist/StepInputTemplate.js +1 -1
  53. package/dist/StepInputTemplate.js.map +1 -1
  54. package/dist/Table.js +4 -6
  55. package/dist/Table.js.map +1 -1
  56. package/dist/TableCell.d.ts +1 -1
  57. package/dist/TableCell.js +15 -13
  58. package/dist/TableCell.js.map +1 -1
  59. package/dist/TableCustomAnnouncement.js.map +1 -1
  60. package/dist/TableHeaderCell.d.ts +0 -1
  61. package/dist/TableHeaderCell.js +1 -8
  62. package/dist/TableHeaderCell.js.map +1 -1
  63. package/dist/TableHeaderCellActionBase.js.map +1 -1
  64. package/dist/TreeItemBaseTemplate.js +2 -2
  65. package/dist/TreeItemBaseTemplate.js.map +1 -1
  66. package/dist/bundle.common.bootstrap.d.ts +0 -1
  67. package/dist/bundle.common.bootstrap.js +2 -1
  68. package/dist/bundle.common.bootstrap.js.map +1 -1
  69. package/dist/css/themes/Avatar.css +1 -1
  70. package/dist/css/themes/AvatarGroup.css +1 -1
  71. package/dist/css/themes/Bar.css +1 -1
  72. package/dist/css/themes/Breadcrumbs.css +1 -1
  73. package/dist/css/themes/BusyIndicator.css +1 -1
  74. package/dist/css/themes/Button.css +1 -1
  75. package/dist/css/themes/ButtonBadge.css +1 -1
  76. package/dist/css/themes/Calendar.css +1 -1
  77. package/dist/css/themes/CalendarHeader.css +1 -1
  78. package/dist/css/themes/CalendarLegend.css +1 -1
  79. package/dist/css/themes/CalendarLegendItem.css +1 -1
  80. package/dist/css/themes/Card.css +1 -1
  81. package/dist/css/themes/CardHeader.css +1 -1
  82. package/dist/css/themes/Carousel.css +1 -1
  83. package/dist/css/themes/CheckBox.css +1 -1
  84. package/dist/css/themes/ColorPalette.css +1 -1
  85. package/dist/css/themes/ColorPaletteItem.css +1 -1
  86. package/dist/css/themes/ColorPalettePopover.css +1 -1
  87. package/dist/css/themes/ColorPicker.css +1 -1
  88. package/dist/css/themes/ComboBox.css +1 -1
  89. package/dist/css/themes/ComboBoxItem.css +1 -1
  90. package/dist/css/themes/DatePicker.css +1 -1
  91. package/dist/css/themes/DatePickerPopover.css +1 -1
  92. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  93. package/dist/css/themes/DayPicker.css +1 -1
  94. package/dist/css/themes/Dialog.css +1 -1
  95. package/dist/css/themes/DynamicDateRange.css +1 -1
  96. package/dist/css/themes/DynamicDateRangePopover.css +1 -1
  97. package/dist/css/themes/FileUploader.css +1 -1
  98. package/dist/css/themes/Form.css +1 -1
  99. package/dist/css/themes/FormItem.css +1 -1
  100. package/dist/css/themes/FormItemSpan.css +1 -1
  101. package/dist/css/themes/GrowingButton.css +1 -1
  102. package/dist/css/themes/Icon.css +1 -1
  103. package/dist/css/themes/Input.css +1 -1
  104. package/dist/css/themes/InputIcon.css +1 -1
  105. package/dist/css/themes/InputSharedStyles.css +1 -1
  106. package/dist/css/themes/Link.css +1 -1
  107. package/dist/css/themes/List.css +1 -1
  108. package/dist/css/themes/ListItem.css +1 -1
  109. package/dist/css/themes/ListItemBase.css +1 -1
  110. package/dist/css/themes/ListItemCustom.css +1 -1
  111. package/dist/css/themes/ListItemGroup.css +1 -1
  112. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  113. package/dist/css/themes/ListItemIcon.css +1 -1
  114. package/dist/css/themes/Menu.css +1 -1
  115. package/dist/css/themes/MenuItem.css +1 -1
  116. package/dist/css/themes/MessageStrip.css +1 -1
  117. package/dist/css/themes/MonthPicker.css +1 -1
  118. package/dist/css/themes/MultiComboBox.css +1 -1
  119. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  120. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  121. package/dist/css/themes/MultiInput.css +1 -1
  122. package/dist/css/themes/OptionBase.css +1 -1
  123. package/dist/css/themes/Panel.css +1 -1
  124. package/dist/css/themes/Popover.css +1 -1
  125. package/dist/css/themes/PopupsCommon.css +1 -1
  126. package/dist/css/themes/ProgressIndicator.css +1 -1
  127. package/dist/css/themes/RadioButton.css +1 -1
  128. package/dist/css/themes/RangeSlider.css +1 -1
  129. package/dist/css/themes/RatingIndicator.css +1 -1
  130. package/dist/css/themes/ResponsivePopover.css +1 -1
  131. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  132. package/dist/css/themes/SegmentedButton.css +1 -1
  133. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  134. package/dist/css/themes/Select.css +1 -1
  135. package/dist/css/themes/SliderBase.css +1 -1
  136. package/dist/css/themes/SplitButton.css +1 -1
  137. package/dist/css/themes/StepInput.css +1 -1
  138. package/dist/css/themes/SuggestionItem.css +1 -1
  139. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  140. package/dist/css/themes/Switch.css +1 -1
  141. package/dist/css/themes/TabContainer.css +1 -1
  142. package/dist/css/themes/TabInOverflow.css +1 -1
  143. package/dist/css/themes/TabInStrip.css +1 -1
  144. package/dist/css/themes/TabSemanticIcon.css +1 -1
  145. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  146. package/dist/css/themes/TableCellBase.css +1 -1
  147. package/dist/css/themes/TableHeaderRow.css +1 -1
  148. package/dist/css/themes/TableRow.css +1 -1
  149. package/dist/css/themes/TableRowActionBase.css +1 -1
  150. package/dist/css/themes/TableRowBase.css +1 -1
  151. package/dist/css/themes/Tag.css +1 -1
  152. package/dist/css/themes/Text.css +1 -1
  153. package/dist/css/themes/TextArea.css +1 -1
  154. package/dist/css/themes/TimePicker.css +1 -1
  155. package/dist/css/themes/Toast.css +1 -1
  156. package/dist/css/themes/ToggleButton.css +1 -1
  157. package/dist/css/themes/Token.css +1 -1
  158. package/dist/css/themes/Tokenizer.css +1 -1
  159. package/dist/css/themes/TokenizerPopover.css +1 -1
  160. package/dist/css/themes/Toolbar.css +1 -1
  161. package/dist/css/themes/ToolbarButton.css +1 -1
  162. package/dist/css/themes/ToolbarPopover.css +1 -1
  163. package/dist/css/themes/ToolbarSeparator.css +1 -1
  164. package/dist/css/themes/TreeItem.css +1 -1
  165. package/dist/css/themes/ValueStateMessage.css +1 -1
  166. package/dist/css/themes/ValueStateVariables.css +1 -1
  167. package/dist/css/themes/YearPicker.css +1 -1
  168. package/dist/css/themes/YearRangePicker.css +1 -1
  169. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  170. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  171. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  172. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  173. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  174. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  175. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  176. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  177. package/dist/custom-elements-internal.json +218 -13
  178. package/dist/custom-elements.json +154 -8
  179. package/dist/features/InputSuggestions.d.ts +1 -0
  180. package/dist/features/InputSuggestions.js +9 -6
  181. package/dist/features/InputSuggestions.js.map +1 -1
  182. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  183. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  184. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  185. package/dist/generated/assets/i18n/messagebundle_cnr.json +1 -1
  186. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  187. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -1
  188. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  189. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  190. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  191. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  192. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -1
  193. package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -1
  194. package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -1
  195. package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -1
  196. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  197. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -1
  198. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  199. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  200. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  201. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -1
  202. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  203. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  204. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  205. package/dist/generated/assets/i18n/messagebundle_id.json +1 -1
  206. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  207. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  208. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  209. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  210. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  211. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  212. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  213. package/dist/generated/assets/i18n/messagebundle_mk.json +1 -1
  214. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  215. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  216. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  217. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  218. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  219. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -1
  220. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  221. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  222. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  223. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  224. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  225. package/dist/generated/assets/i18n/messagebundle_sr.json +1 -1
  226. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  227. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  228. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  229. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  230. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  231. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  232. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  233. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  234. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  235. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  236. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  237. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  238. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  239. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  240. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  241. package/dist/generated/i18n/i18n-defaults.d.ts +2 -2
  242. package/dist/generated/i18n/i18n-defaults.js +2 -2
  243. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  244. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  245. package/dist/generated/themes/Avatar.css.js +1 -1
  246. package/dist/generated/themes/Avatar.css.js.map +1 -1
  247. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  248. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  249. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  250. package/dist/generated/themes/Bar.css.d.ts +1 -1
  251. package/dist/generated/themes/Bar.css.js +1 -1
  252. package/dist/generated/themes/Bar.css.js.map +1 -1
  253. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  254. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  255. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  256. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  257. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  258. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  259. package/dist/generated/themes/Button.css.d.ts +1 -1
  260. package/dist/generated/themes/Button.css.js +1 -1
  261. package/dist/generated/themes/Button.css.js.map +1 -1
  262. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  263. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  264. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  265. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  266. package/dist/generated/themes/Calendar.css.js +1 -1
  267. package/dist/generated/themes/Calendar.css.js.map +1 -1
  268. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  269. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  270. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  271. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  272. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  273. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  274. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  275. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  276. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  277. package/dist/generated/themes/Card.css.d.ts +1 -1
  278. package/dist/generated/themes/Card.css.js +1 -1
  279. package/dist/generated/themes/Card.css.js.map +1 -1
  280. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  281. package/dist/generated/themes/CardHeader.css.js +1 -1
  282. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  283. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  284. package/dist/generated/themes/Carousel.css.js +1 -1
  285. package/dist/generated/themes/Carousel.css.js.map +1 -1
  286. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  287. package/dist/generated/themes/CheckBox.css.js +1 -1
  288. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  289. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  290. package/dist/generated/themes/ColorPalette.css.js +1 -1
  291. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  292. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  293. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  294. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  295. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  296. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  297. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  298. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  299. package/dist/generated/themes/ColorPicker.css.js +1 -1
  300. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  301. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  302. package/dist/generated/themes/ComboBox.css.js +1 -1
  303. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  304. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  305. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  306. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  307. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  308. package/dist/generated/themes/DatePicker.css.js +1 -1
  309. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  310. package/dist/generated/themes/DatePickerPopover.css.d.ts +1 -1
  311. package/dist/generated/themes/DatePickerPopover.css.js +1 -1
  312. package/dist/generated/themes/DatePickerPopover.css.js.map +1 -1
  313. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  314. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  315. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  316. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  317. package/dist/generated/themes/DayPicker.css.js +1 -1
  318. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  319. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  320. package/dist/generated/themes/Dialog.css.js +1 -1
  321. package/dist/generated/themes/Dialog.css.js.map +1 -1
  322. package/dist/generated/themes/DynamicDateRange.css.d.ts +1 -1
  323. package/dist/generated/themes/DynamicDateRange.css.js +1 -1
  324. package/dist/generated/themes/DynamicDateRange.css.js.map +1 -1
  325. package/dist/generated/themes/DynamicDateRangePopover.css.d.ts +1 -1
  326. package/dist/generated/themes/DynamicDateRangePopover.css.js +1 -1
  327. package/dist/generated/themes/DynamicDateRangePopover.css.js.map +1 -1
  328. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  329. package/dist/generated/themes/FileUploader.css.js +1 -1
  330. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  331. package/dist/generated/themes/Form.css.d.ts +1 -1
  332. package/dist/generated/themes/Form.css.js +1 -1
  333. package/dist/generated/themes/Form.css.js.map +1 -1
  334. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  335. package/dist/generated/themes/FormItem.css.js +1 -1
  336. package/dist/generated/themes/FormItem.css.js.map +1 -1
  337. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  338. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  339. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  340. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  341. package/dist/generated/themes/GrowingButton.css.js +1 -1
  342. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  343. package/dist/generated/themes/Icon.css.d.ts +1 -1
  344. package/dist/generated/themes/Icon.css.js +1 -1
  345. package/dist/generated/themes/Icon.css.js.map +1 -1
  346. package/dist/generated/themes/Input.css.d.ts +1 -1
  347. package/dist/generated/themes/Input.css.js +1 -1
  348. package/dist/generated/themes/Input.css.js.map +1 -1
  349. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  350. package/dist/generated/themes/InputIcon.css.js +1 -1
  351. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  352. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  353. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  354. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  355. package/dist/generated/themes/Link.css.d.ts +1 -1
  356. package/dist/generated/themes/Link.css.js +1 -1
  357. package/dist/generated/themes/Link.css.js.map +1 -1
  358. package/dist/generated/themes/List.css.d.ts +1 -1
  359. package/dist/generated/themes/List.css.js +1 -1
  360. package/dist/generated/themes/List.css.js.map +1 -1
  361. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  362. package/dist/generated/themes/ListItem.css.js +1 -1
  363. package/dist/generated/themes/ListItem.css.js.map +1 -1
  364. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  365. package/dist/generated/themes/ListItemBase.css.js +1 -1
  366. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  367. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  368. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  369. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  370. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  371. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  372. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  373. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  374. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  375. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  376. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  377. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  378. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  379. package/dist/generated/themes/Menu.css.d.ts +1 -1
  380. package/dist/generated/themes/Menu.css.js +1 -1
  381. package/dist/generated/themes/Menu.css.js.map +1 -1
  382. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  383. package/dist/generated/themes/MenuItem.css.js +1 -1
  384. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  385. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  386. package/dist/generated/themes/MessageStrip.css.js +1 -1
  387. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  388. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  389. package/dist/generated/themes/MonthPicker.css.js +1 -1
  390. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  391. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  392. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  393. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  394. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  395. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  396. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  397. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  398. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  399. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  400. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  401. package/dist/generated/themes/MultiInput.css.js +1 -1
  402. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  403. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  404. package/dist/generated/themes/OptionBase.css.js +1 -1
  405. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  406. package/dist/generated/themes/Panel.css.d.ts +1 -1
  407. package/dist/generated/themes/Panel.css.js +1 -1
  408. package/dist/generated/themes/Panel.css.js.map +1 -1
  409. package/dist/generated/themes/Popover.css.d.ts +1 -1
  410. package/dist/generated/themes/Popover.css.js +1 -1
  411. package/dist/generated/themes/Popover.css.js.map +1 -1
  412. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  413. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  414. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  415. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  416. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  417. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  418. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  419. package/dist/generated/themes/RadioButton.css.js +1 -1
  420. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  421. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  422. package/dist/generated/themes/RangeSlider.css.js +1 -1
  423. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  424. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  425. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  426. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  427. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  428. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  429. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  430. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  431. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  432. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  433. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  434. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  435. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  436. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  437. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  438. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  439. package/dist/generated/themes/Select.css.d.ts +1 -1
  440. package/dist/generated/themes/Select.css.js +1 -1
  441. package/dist/generated/themes/Select.css.js.map +1 -1
  442. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  443. package/dist/generated/themes/SliderBase.css.js +1 -1
  444. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  445. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  446. package/dist/generated/themes/SplitButton.css.js +1 -1
  447. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  448. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  449. package/dist/generated/themes/StepInput.css.js +1 -1
  450. package/dist/generated/themes/StepInput.css.js.map +1 -1
  451. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  452. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  453. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  454. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  455. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  456. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  457. package/dist/generated/themes/Switch.css.d.ts +1 -1
  458. package/dist/generated/themes/Switch.css.js +1 -1
  459. package/dist/generated/themes/Switch.css.js.map +1 -1
  460. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  461. package/dist/generated/themes/TabContainer.css.js +1 -1
  462. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  463. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  464. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  465. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  466. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  467. package/dist/generated/themes/TabInStrip.css.js +1 -1
  468. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  469. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  470. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  471. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  472. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  473. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  474. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  475. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  476. package/dist/generated/themes/TableCellBase.css.js +1 -1
  477. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  478. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  479. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  480. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  481. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  482. package/dist/generated/themes/TableRow.css.js +1 -1
  483. package/dist/generated/themes/TableRow.css.js.map +1 -1
  484. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  485. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  486. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  487. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  488. package/dist/generated/themes/TableRowBase.css.js +1 -1
  489. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  490. package/dist/generated/themes/Tag.css.d.ts +1 -1
  491. package/dist/generated/themes/Tag.css.js +1 -1
  492. package/dist/generated/themes/Tag.css.js.map +1 -1
  493. package/dist/generated/themes/Text.css.d.ts +1 -1
  494. package/dist/generated/themes/Text.css.js +1 -1
  495. package/dist/generated/themes/Text.css.js.map +1 -1
  496. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  497. package/dist/generated/themes/TextArea.css.js +1 -1
  498. package/dist/generated/themes/TextArea.css.js.map +1 -1
  499. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  500. package/dist/generated/themes/TimePicker.css.js +1 -1
  501. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  502. package/dist/generated/themes/Toast.css.d.ts +1 -1
  503. package/dist/generated/themes/Toast.css.js +1 -1
  504. package/dist/generated/themes/Toast.css.js.map +1 -1
  505. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  506. package/dist/generated/themes/ToggleButton.css.js +1 -1
  507. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  508. package/dist/generated/themes/Token.css.d.ts +1 -1
  509. package/dist/generated/themes/Token.css.js +1 -1
  510. package/dist/generated/themes/Token.css.js.map +1 -1
  511. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  512. package/dist/generated/themes/Tokenizer.css.js +1 -1
  513. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  514. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  515. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  516. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  517. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  518. package/dist/generated/themes/Toolbar.css.js +1 -1
  519. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  520. package/dist/generated/themes/ToolbarButton.css.d.ts +1 -1
  521. package/dist/generated/themes/ToolbarButton.css.js +1 -1
  522. package/dist/generated/themes/ToolbarButton.css.js.map +1 -1
  523. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  524. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  525. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  526. package/dist/generated/themes/ToolbarSeparator.css.d.ts +1 -1
  527. package/dist/generated/themes/ToolbarSeparator.css.js +1 -1
  528. package/dist/generated/themes/ToolbarSeparator.css.js.map +1 -1
  529. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  530. package/dist/generated/themes/TreeItem.css.js +1 -1
  531. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  532. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  533. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  534. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  535. package/dist/generated/themes/ValueStateVariables.css.d.ts +1 -1
  536. package/dist/generated/themes/ValueStateVariables.css.js +1 -1
  537. package/dist/generated/themes/ValueStateVariables.css.js.map +1 -1
  538. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  539. package/dist/generated/themes/YearPicker.css.js +1 -1
  540. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  541. package/dist/generated/themes/YearRangePicker.css.d.ts +1 -1
  542. package/dist/generated/themes/YearRangePicker.css.js +1 -1
  543. package/dist/generated/themes/YearRangePicker.css.js.map +1 -1
  544. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  545. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  546. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  547. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  548. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  549. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  550. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  551. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  552. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  553. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  554. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  555. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  556. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  557. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  558. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  559. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  560. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  561. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  562. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  563. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  564. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  565. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  566. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  567. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  568. package/dist/popup-utils/PopoverRegistry.js +6 -4
  569. package/dist/popup-utils/PopoverRegistry.js.map +1 -1
  570. package/dist/types/InputSuggestionsFilter.d.ts +27 -0
  571. package/dist/types/InputSuggestionsFilter.js +29 -0
  572. package/dist/types/InputSuggestionsFilter.js.map +1 -0
  573. package/dist/vscode.html-custom-data.json +34 -4
  574. package/dist/web-types.json +65 -11
  575. package/package.json +9 -9
  576. package/src/ColorPickerTemplate.tsx +1 -1
  577. package/src/InputTemplate.tsx +1 -1
  578. package/src/ListBoxItemGroupTemplate.tsx +1 -1
  579. package/src/MenuItemTemplate.tsx +16 -8
  580. package/src/MenuTemplate.tsx +11 -7
  581. package/src/PopoverTemplate.tsx +10 -0
  582. package/src/StepInputTemplate.tsx +1 -0
  583. package/src/TreeItemBaseTemplate.tsx +2 -2
  584. package/src/i18n/messagebundle.properties +2 -2
  585. package/src/i18n/messagebundle_ar.properties +24 -0
  586. package/src/i18n/messagebundle_bg.properties +24 -0
  587. package/src/i18n/messagebundle_ca.properties +24 -0
  588. package/src/i18n/messagebundle_cnr.properties +24 -0
  589. package/src/i18n/messagebundle_cs.properties +24 -0
  590. package/src/i18n/messagebundle_cy.properties +24 -0
  591. package/src/i18n/messagebundle_da.properties +24 -0
  592. package/src/i18n/messagebundle_de.properties +25 -1
  593. package/src/i18n/messagebundle_el.properties +27 -3
  594. package/src/i18n/messagebundle_en.properties +8 -326
  595. package/src/i18n/messagebundle_en_GB.properties +24 -0
  596. package/src/i18n/messagebundle_en_US_sappsd.properties +8 -0
  597. package/src/i18n/messagebundle_en_US_saprigi.properties +8 -0
  598. package/src/i18n/messagebundle_en_US_saptrc.properties +8 -0
  599. package/src/i18n/messagebundle_es.properties +24 -0
  600. package/src/i18n/messagebundle_es_MX.properties +34 -10
  601. package/src/i18n/messagebundle_et.properties +24 -0
  602. package/src/i18n/messagebundle_fi.properties +24 -0
  603. package/src/i18n/messagebundle_fr.properties +24 -0
  604. package/src/i18n/messagebundle_fr_CA.properties +24 -0
  605. package/src/i18n/messagebundle_hi.properties +24 -0
  606. package/src/i18n/messagebundle_hr.properties +24 -0
  607. package/src/i18n/messagebundle_hu.properties +24 -0
  608. package/src/i18n/messagebundle_id.properties +24 -0
  609. package/src/i18n/messagebundle_it.properties +25 -1
  610. package/src/i18n/messagebundle_iw.properties +24 -0
  611. package/src/i18n/messagebundle_ja.properties +24 -0
  612. package/src/i18n/messagebundle_kk.properties +24 -0
  613. package/src/i18n/messagebundle_ko.properties +24 -0
  614. package/src/i18n/messagebundle_lt.properties +24 -0
  615. package/src/i18n/messagebundle_lv.properties +24 -0
  616. package/src/i18n/messagebundle_mk.properties +26 -2
  617. package/src/i18n/messagebundle_ms.properties +24 -0
  618. package/src/i18n/messagebundle_nl.properties +24 -0
  619. package/src/i18n/messagebundle_no.properties +24 -0
  620. package/src/i18n/messagebundle_pl.properties +24 -0
  621. package/src/i18n/messagebundle_pt.properties +24 -0
  622. package/src/i18n/messagebundle_pt_PT.properties +24 -0
  623. package/src/i18n/messagebundle_ro.properties +24 -0
  624. package/src/i18n/messagebundle_ru.properties +25 -1
  625. package/src/i18n/messagebundle_sh.properties +24 -0
  626. package/src/i18n/messagebundle_sk.properties +24 -0
  627. package/src/i18n/messagebundle_sl.properties +24 -0
  628. package/src/i18n/messagebundle_sr.properties +24 -0
  629. package/src/i18n/messagebundle_sv.properties +24 -0
  630. package/src/i18n/messagebundle_th.properties +24 -0
  631. package/src/i18n/messagebundle_tr.properties +24 -0
  632. package/src/i18n/messagebundle_uk.properties +24 -0
  633. package/src/i18n/messagebundle_vi.properties +24 -0
  634. package/src/i18n/messagebundle_zh_CN.properties +24 -0
  635. package/src/i18n/messagebundle_zh_TW.properties +24 -0
  636. package/src/themes/Button.css +3 -2
  637. package/src/themes/Dialog.css +0 -16
  638. package/src/themes/Form.css +1 -1
  639. package/src/themes/FormItem.css +0 -1
  640. package/src/themes/FormItemSpan.css +2 -2
  641. package/src/themes/Menu.css +17 -0
  642. package/src/themes/MenuItem.css +9 -0
  643. package/src/themes/Popover.css +77 -0
  644. package/src/themes/PopupsCommon.css +16 -0
  645. package/src/themes/SegmentedButton.css +2 -2
  646. package/src/themes/SegmentedButtonItem.css +0 -4
  647. package/src/themes/TableCellBase.css +4 -0
  648. package/src/themes/TreeItem.css +10 -2
  649. package/src/themes/base/sizes-parameters.css +6 -58
  650. package/src/themes/sap_fiori_3/sizes-parameters.css +0 -8
  651. package/src/themes/sap_fiori_3_dark/sizes-parameters.css +0 -5
  652. package/src/themes/sap_fiori_3_hcb/sizes-parameters.css +0 -5
  653. package/src/themes/sap_fiori_3_hcw/sizes-parameters.css +0 -5
@@ -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\tDATETIME_VALUE_MISSING,\n\tDATETIME_PATTERN_MISMATCH,\n\tDATETIME_RANGEUNDERFLOW,\n\tDATETIME_RANGEOVERFLOW,\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/dist/Render.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/**\n\t * Stores the last valid value to preserve time when entering invalid values\n\t * @private\n\t */\n\t@property()\n\t_lastValidValue: string = \"\";\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\tlet timeSelectionValue = this.value;\n\n\t\t\t// If current value is invalid, use the last valid value for time selection\n\t\t\tif (!timeSelectionValue || !this.isValidValue(timeSelectionValue)) {\n\t\t\t\ttimeSelectionValue = this._lastValidValue || this.getValueFormat().format(UI5Date.getInstance());\n\t\t\t}\n\n\t\t\tthis._previewValues = {\n\t\t\t\t...this._previewValues,\n\t\t\t\ttimeSelectionValue,\n\t\t\t};\n\t\t}\n\t}\n\n\tget formValidityMessage() {\n\t\tconst validity = this.formValidity;\n\n\t\tif (validity.valueMissing) {\n\t\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_VALUE_MISSING, this.getFormat().oFormatOptions.pattern as string);\n\t\t}\n\t\tif (validity.patternMismatch) {\n\t\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PATTERN_MISMATCH, this.getFormat().oFormatOptions.pattern as string);\n\t\t}\n\t\tif (validity.rangeUnderflow) {\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_RANGEUNDERFLOW, this.minDate);\n\t\t}\n\t\tif (validity.rangeOverflow) {\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_RANGEOVERFLOW, this.maxDate);\n\t\t}\n\n\t\treturn \"\";\n\t}\n\n\tget formValidity(): ValidityStateFlags {\n\t\treturn {\n\t\t\tvalueMissing: this.required && !this.value,\n\t\t\tpatternMismatch: !this.isValidValue(this.value),\n\t\t\trangeUnderflow: !this.isValidMin(this.value),\n\t\t\trangeOverflow: !this.isValidMax(this.value),\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 roleDescription() {\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, this.ariaLabelText);\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 false;\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\n\t\t// Try to get the current time value from the time picker,\n\t\t// but fallback to last valid value if current picker time is empty or invalid\n\t\tlet timeValue = this._clocks?.value || \"\";\n\t\tif (!timeValue || !this.isValidValue(timeValue)) {\n\t\t\ttimeValue = this._lastValidValue || this.getValueFormat().format(UI5Date.getInstance());\n\t\t}\n\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: timeValue,\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.getValueFormat().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\t/**\n\t * @override\n\t */\n\t_updateValueAndFireEvents(value: string, normalizeValue: boolean, events: Array<\"change\" | \"value-changed\" | \"input\">, updateValue = true) {\n\t\tsuper._updateValueAndFireEvents(value, normalizeValue, events, updateValue);\n\n\t\t// Always store the current value if it's valid (handles both updates and initial values)\n\t\tif (this.value && this.isValidValue(this.value)) {\n\t\t\tthis._lastValidValue = this.value;\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the provided value is valid and within valid range.\n\t * @override\n\t * @param value\n\t */\n\t_checkValueValidity(value: string): boolean {\n\t\tif (value === \"\") {\n\t\t\treturn true;\n\t\t}\n\t\treturn this.isValidValue(value);\n\t}\n\n\tgetSelectedDateTime() {\n\t\tconst selectedDate = this.getValueFormat().parse(this._calendarSelectedDates[0]) as Date;\n\t\tconst selectedTime = this.getValueFormat().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\tgetDisplayFormat() {\n\t\treturn this._isDisplayFormatPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._displayFormat,\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._displayFormat,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\tgetValueFormat() {\n\t\tif (!this._valueFormat) {\n\t\t\treturn this.getISOFormat();\n\t\t}\n\n\t\treturn this._isValueFormatPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._valueFormat,\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._valueFormat,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\tgetISOFormat() {\n\t\tif (!this._isoFormatInstance) {\n\t\t\tthis._isoFormatInstance = DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: \"YYYY-MM-dd hh:mm:ss\",\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t\t}\n\t\treturn this._isoFormatInstance;\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\tDATETIME_VALUE_MISSING,\n\tDATETIME_PATTERN_MISMATCH,\n\tDATETIME_RANGEUNDERFLOW,\n\tDATETIME_RANGEOVERFLOW,\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/dist/Render.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/**\n\t * Stores the last valid value to preserve time when entering invalid values\n\t * @private\n\t */\n\t@property()\n\t_lastValidValue: string = \"\";\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\tlet timeSelectionValue = this.value;\n\n\t\t\t// If current value is invalid, use the last valid value for time selection\n\t\t\tif (!timeSelectionValue || !this.isValidValue(timeSelectionValue)) {\n\t\t\t\ttimeSelectionValue = this._lastValidValue || this.getValueFormat().format(UI5Date.getInstance());\n\t\t\t}\n\n\t\t\tthis._previewValues = {\n\t\t\t\t...this._previewValues,\n\t\t\t\ttimeSelectionValue,\n\t\t\t};\n\t\t}\n\t}\n\n\tget formValidityMessage() {\n\t\tconst validity = this.formValidity;\n\n\t\tif (validity.valueMissing) {\n\t\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_VALUE_MISSING, this.getFormat().oFormatOptions.pattern as string);\n\t\t}\n\t\tif (validity.patternMismatch) {\n\t\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_PATTERN_MISMATCH, this.getFormat().oFormatOptions.pattern as string);\n\t\t}\n\t\tif (validity.rangeUnderflow) {\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_RANGEUNDERFLOW, this.minDate);\n\t\t}\n\t\tif (validity.rangeOverflow) {\n\t\t\treturn DateTimePicker.i18nBundle.getText(DATETIME_RANGEOVERFLOW, this.maxDate);\n\t\t}\n\n\t\treturn \"\";\n\t}\n\n\tget formValidity(): ValidityStateFlags {\n\t\treturn {\n\t\t\tvalueMissing: this.required && !this.value,\n\t\t\tpatternMismatch: !this.isValidValue(this.value),\n\t\t\trangeUnderflow: !this.isValidMin(this.value),\n\t\t\trangeOverflow: !this.isValidMax(this.value),\n\t\t};\n\t}\n\n\tget _formatPattern() {\n\t\tconst formatPattern = this.formatPattern || this.valueFormat || \"medium\";\n\t\tconst hasHours = !!(formatPattern || \"\").match(/H/i);\n\t\tconst fallback = !formatPattern || !hasHours;\n\n\t\tconst localeData = getCachedLocaleDataInstance(getLocale());\n\t\treturn fallback ? localeData.getCombinedDateTimePattern(\"medium\", \"medium\", this._primaryCalendarType) : (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 roleDescription() {\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, this.ariaLabelText);\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 false;\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\n\t\t// Try to get the current time value from the time picker,\n\t\t// but fallback to last valid value if current picker time is empty or invalid\n\t\tlet timeValue = this._clocks?.value || \"\";\n\t\tif (!timeValue || !this.isValidValue(timeValue)) {\n\t\t\ttimeValue = this._lastValidValue || this.getValueFormat().format(UI5Date.getInstance());\n\t\t}\n\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: timeValue,\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.getValueFormat().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\t/**\n\t * @override\n\t */\n\t_updateValueAndFireEvents(value: string, normalizeValue: boolean, events: Array<\"change\" | \"value-changed\" | \"input\">, updateValue = true) {\n\t\tsuper._updateValueAndFireEvents(value, normalizeValue, events, updateValue);\n\n\t\t// Always store the current value if it's valid (handles both updates and initial values)\n\t\tif (this.value && this.isValidValue(this.value)) {\n\t\t\tthis._lastValidValue = this.value;\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the provided value is valid and within valid range.\n\t * @override\n\t * @param value\n\t */\n\t_checkValueValidity(value: string): boolean {\n\t\tif (value === \"\") {\n\t\t\treturn true;\n\t\t}\n\t\treturn this.isValidValue(value);\n\t}\n\n\tgetSelectedDateTime() {\n\t\tconst selectedDate = this.getValueFormat().parse(this._calendarSelectedDates[0]) as Date;\n\t\tconst selectedTime = this.getValueFormat().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\tgetDisplayFormat() {\n\t\treturn this._isDisplayFormatPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._displayFormat,\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._displayFormat,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\tgetValueFormat() {\n\t\tif (!this._valueFormat) {\n\t\t\treturn this.getISOFormat();\n\t\t}\n\n\t\treturn this._isValueFormatPattern\n\t\t\t? DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: this._valueFormat,\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._valueFormat,\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t}\n\n\tgetISOFormat() {\n\t\tif (!this._isoFormatInstance) {\n\t\t\tthis._isoFormatInstance = DateFormat.getDateTimeInstance({\n\t\t\t\tstrictParsing: true,\n\t\t\t\tpattern: \"YYYY-MM-dd hh:mm:ss\",\n\t\t\t\tcalendarType: this._primaryCalendarType,\n\t\t\t});\n\t\t}\n\t\treturn this._isoFormatInstance;\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"]}
package/dist/Input.d.ts CHANGED
@@ -15,6 +15,7 @@ import type { ListItemClickEventDetail, ListSelectionChangeEventDetail } from ".
15
15
  import type ResponsivePopover from "./ResponsivePopover.js";
16
16
  import type InputKeyHint from "./types/InputKeyHint.js";
17
17
  import type InputComposition from "./features/InputComposition.js";
18
+ import InputSuggestionsFilter from "./types/InputSuggestionsFilter.js";
18
19
  /**
19
20
  * Interface for components that represent a suggestion item, usable in `ui5-input`
20
21
  * @public
@@ -181,14 +182,6 @@ declare class Input extends UI5Element implements SuggestionComponent, IFormInpu
181
182
  * @public
182
183
  */
183
184
  value: string;
184
- /**
185
- * Defines the inner stored value of the component.
186
- *
187
- * **Note:** The property is updated upon typing. In some special cases the old value is kept (e.g. deleting the value after the dot in a float)
188
- * @default ""
189
- * @private
190
- */
191
- _innerValue: string;
192
185
  /**
193
186
  * Defines the value state of the component.
194
187
  * @default "None"
@@ -263,6 +256,13 @@ declare class Input extends UI5Element implements SuggestionComponent, IFormInpu
263
256
  * @since 2.0.0
264
257
  */
265
258
  open: boolean;
259
+ /**
260
+ * Defines the filter type of the component.
261
+ * @default "None"
262
+ * @public
263
+ * @since 2.19.0
264
+ */
265
+ filter: `${InputSuggestionsFilter}`;
266
266
  /**
267
267
  * Defines whether the clear icon is visible.
268
268
  * @default false
@@ -356,7 +356,6 @@ declare class Input extends UI5Element implements SuggestionComponent, IFormInpu
356
356
  lastConfirmedValue: string;
357
357
  isTyping: boolean;
358
358
  _handleResizeBound: ResizeObserverCallback;
359
- _keepInnerValue: boolean;
360
359
  _shouldAutocomplete?: boolean;
361
360
  _enterKeyDown?: boolean;
362
361
  _isKeyNavigation?: boolean;
@@ -391,6 +390,7 @@ declare class Input extends UI5Element implements SuggestionComponent, IFormInpu
391
390
  _isGroupItem(item: IInputSuggestionItem): boolean;
392
391
  onBeforeRendering(): void;
393
392
  onAfterRendering(): void;
393
+ _adjustContainsSelectionRange(): void;
394
394
  _onkeydown(e: KeyboardEvent): void;
395
395
  _onkeyup(e: KeyboardEvent): void;
396
396
  get currentItemIndex(): number;
@@ -428,6 +428,9 @@ declare class Input extends UI5Element implements SuggestionComponent, IFormInpu
428
428
  _getFirstMatchingItem(current: string): IInputSuggestionItemSelectable | undefined;
429
429
  _handleSelectionChange(e: CustomEvent<ListSelectionChangeEventDetail>): void;
430
430
  _selectMatchingItem(item: IInputSuggestionItemSelectable): void;
431
+ _filterItems(value: string): void;
432
+ _filterGroups(filterType: `${InputSuggestionsFilter}`, groupItems: IInputSuggestionItem[]): IInputSuggestionItem[];
433
+ _resetItemVisibility(): void;
431
434
  _handleTypeAhead(item: IInputSuggestionItemSelectable): void;
432
435
  _handleResize(): void;
433
436
  _updateAssociatedLabelsTexts(): void;
package/dist/Input.js CHANGED
@@ -29,13 +29,14 @@ import getActiveElement from "@ui5/webcomponents-base/dist/util/getActiveElement
29
29
  import InputType from "./types/InputType.js";
30
30
  // Templates
31
31
  import InputTemplate from "./InputTemplate.js";
32
- import { StartsWith } from "./Filters.js";
32
+ import * as Filters from "./Filters.js";
33
33
  import { VALUE_STATE_SUCCESS, VALUE_STATE_INFORMATION, VALUE_STATE_ERROR, VALUE_STATE_WARNING, VALUE_STATE_TYPE_SUCCESS, VALUE_STATE_TYPE_INFORMATION, VALUE_STATE_TYPE_ERROR, VALUE_STATE_TYPE_WARNING, VALUE_STATE_LINK, VALUE_STATE_LINKS, VALUE_STATE_LINK_MAC, VALUE_STATE_LINKS_MAC, INPUT_SUGGESTIONS, INPUT_SUGGESTIONS_TITLE, INPUT_SUGGESTIONS_ONE_HIT, INPUT_SUGGESTIONS_MORE_HITS, INPUT_SUGGESTIONS_NO_HIT, INPUT_CLEAR_ICON_ACC_NAME, INPUT_AVALIABLE_VALUES, INPUT_SUGGESTIONS_OK_BUTTON, INPUT_SUGGESTIONS_CANCEL_BUTTON, } from "./generated/i18n/i18n-defaults.js";
34
34
  // Styles
35
35
  import inputStyles from "./generated/themes/Input.css.js";
36
36
  import ResponsivePopoverCommonCss from "./generated/themes/ResponsivePopoverCommon.css.js";
37
37
  import ValueStateMessageCss from "./generated/themes/ValueStateMessage.css.js";
38
38
  import SuggestionsCss from "./generated/themes/Suggestions.css.js";
39
+ import InputSuggestionsFilter from "./types/InputSuggestionsFilter.js";
39
40
  // all sementic events
40
41
  var INPUT_EVENTS;
41
42
  (function (INPUT_EVENTS) {
@@ -174,14 +175,6 @@ let Input = Input_1 = class Input extends UI5Element {
174
175
  * @public
175
176
  */
176
177
  this.value = "";
177
- /**
178
- * Defines the inner stored value of the component.
179
- *
180
- * **Note:** The property is updated upon typing. In some special cases the old value is kept (e.g. deleting the value after the dot in a float)
181
- * @default ""
182
- * @private
183
- */
184
- this._innerValue = "";
185
178
  /**
186
179
  * Defines the value state of the component.
187
180
  * @default "None"
@@ -211,6 +204,13 @@ let Input = Input_1 = class Input extends UI5Element {
211
204
  * @since 2.0.0
212
205
  */
213
206
  this.open = false;
207
+ /**
208
+ * Defines the filter type of the component.
209
+ * @default "None"
210
+ * @public
211
+ * @since 2.19.0
212
+ */
213
+ this.filter = InputSuggestionsFilter.None;
214
214
  /**
215
215
  * Defines whether the clear icon is visible.
216
216
  * @default false
@@ -269,7 +269,6 @@ let Input = Input_1 = class Input extends UI5Element {
269
269
  this._isChangeTriggeredBySuggestion = false;
270
270
  this._indexOfSelectedItem = -1;
271
271
  this._handleResizeBound = this._handleResize.bind(this);
272
- this._keepInnerValue = false;
273
272
  this._focusedAfterClear = false;
274
273
  this._valueStateLinks = [];
275
274
  }
@@ -291,9 +290,6 @@ let Input = Input_1 = class Input extends UI5Element {
291
290
  return item.hasAttribute("ui5-suggestion-item-group");
292
291
  }
293
292
  onBeforeRendering() {
294
- if (!this._keepInnerValue) {
295
- this._innerValue = this.value === null ? "" : this.value;
296
- }
297
293
  if (this.showSuggestions) {
298
294
  this.enableSuggestions();
299
295
  this._flattenItems.forEach(item => {
@@ -331,6 +327,9 @@ let Input = Input_1 = class Input extends UI5Element {
331
327
  if (!innerInput || !value) {
332
328
  return;
333
329
  }
330
+ if (this.filter !== InputSuggestionsFilter.None) {
331
+ this._filterItems(this.typedInValue);
332
+ }
334
333
  const autoCompletedChars = innerInput.selectionEnd - innerInput.selectionStart;
335
334
  // Typehead causes issues on Android devices, so we disable it for now
336
335
  // If there is already a selection the autocomplete has already been performed
@@ -354,11 +353,18 @@ let Input = Input_1 = class Input extends UI5Element {
354
353
  if (this._performTextSelection) {
355
354
  // this is required to syncronize lit-html input's value and user's input
356
355
  // lit-html does not sync its stored value for the value property when the user is typing
357
- if (innerInput.value !== this._innerValue) {
358
- innerInput.value = this._innerValue;
359
- }
356
+ // if (innerInput.value !== this._innerValue) {
357
+ // innerInput.value = this._innerValue;
358
+ // }
360
359
  if (this.typedInValue.length && this.value.length) {
361
- innerInput.setSelectionRange(this.typedInValue.length, this.value.length);
360
+ // "Contains" filtering requires custom selection range handling.
361
+ // Example: "e" → "Belgium" (item does not start with typed value, so select all).
362
+ if (this.filter === InputSuggestionsFilter.Contains) {
363
+ this._adjustContainsSelectionRange();
364
+ }
365
+ else {
366
+ innerInput.setSelectionRange(this.typedInValue.length, this.value.length);
367
+ }
362
368
  }
363
369
  this.fireDecoratorEvent("type-ahead");
364
370
  }
@@ -369,6 +375,21 @@ let Input = Input_1 = class Input extends UI5Element {
369
375
  this._valueStateLinks = this.linksInAriaValueStateHiddenText;
370
376
  }
371
377
  }
378
+ _adjustContainsSelectionRange() {
379
+ const innerInput = this.getInputDOMRefSync();
380
+ const visibleItems = this.Suggestions?._getItems().filter(item => !item.hidden);
381
+ const currentItem = visibleItems?.find(item => { return item.selected || item.focused; });
382
+ const groupItems = this._flattenItems.filter(item => this._isGroupItem(item));
383
+ if (currentItem && !groupItems.includes(currentItem)) {
384
+ const doesItemStartWithTypedValue = currentItem?.text?.toLowerCase().startsWith(this.typedInValue.toLowerCase());
385
+ if (doesItemStartWithTypedValue) {
386
+ innerInput.setSelectionRange(this.typedInValue.length, this.value.length);
387
+ }
388
+ else {
389
+ innerInput.setSelectionRange(0, this.value.length);
390
+ }
391
+ }
392
+ }
372
393
  _onkeydown(e) {
373
394
  this._isKeyNavigation = true;
374
395
  this._shouldAutocomplete = !this.noTypeahead && !(isBackSpace(e) || isDelete(e) || isEscape(e));
@@ -426,8 +447,9 @@ let Input = Input_1 = class Input extends UI5Element {
426
447
  }
427
448
  get currentItemIndex() {
428
449
  const allItems = this.Suggestions?._getItems();
429
- const currentItem = allItems.find(item => { return item.selected || item.focused; });
430
- const indexOfCurrentItem = currentItem ? allItems.indexOf(currentItem) : -1;
450
+ const visibleItems = allItems.filter(item => !item.hidden);
451
+ const currentItem = visibleItems.find(item => { return item.selected || item.focused; });
452
+ const indexOfCurrentItem = currentItem ? visibleItems.indexOf(currentItem) : -1;
431
453
  return indexOfCurrentItem;
432
454
  }
433
455
  _handleUp(e) {
@@ -597,7 +619,6 @@ let Input = Input_1 = class Input extends UI5Element {
597
619
  if (this.Suggestions?._getPicker()?.contains(toBeFocused) || this.contains(toBeFocused) || this.getSlottedNodes("valueStateMessage").some(el => el.contains(toBeFocused))) {
598
620
  return;
599
621
  }
600
- this._keepInnerValue = false;
601
622
  this.focused = false; // invalidating property
602
623
  this._isChangeTriggeredBySuggestion = false;
603
624
  if (this.showClearIcon && !this._effectiveShowClearIcon) {
@@ -693,8 +714,6 @@ let Input = Input_1 = class Input extends UI5Element {
693
714
  }
694
715
  _input(e, eventType) {
695
716
  const inputDomRef = this.getInputDOMRefSync();
696
- const emptyValueFiredOnNumberInput = this.value && this.isTypeNumber && !inputDomRef.value;
697
- this._keepInnerValue = false;
698
717
  const allowedEventTypes = [
699
718
  "deleteWordBackward",
700
719
  "deleteWordForward",
@@ -711,35 +730,6 @@ let Input = Input_1 = class Input extends UI5Element {
711
730
  "historyUndo",
712
731
  ];
713
732
  this._shouldAutocomplete = !allowedEventTypes.includes(eventType) && !this.noTypeahead;
714
- if (e instanceof InputEvent) {
715
- // ---- Special cases of numeric Input ----
716
- // ---------------- Start -----------------
717
- // When the last character after the delimiter is removed.
718
- // In such cases, we want to skip the re-rendering of the
719
- // component as this leads to cursor repositioning and causes user experience issues.
720
- // There are few scenarios:
721
- // Example: type "123.4" and press BACKSPACE - the native input is firing event with the whole part as value (123).
722
- // Pressing BACKSPACE again will remove the delimiter and the native input will fire event with the whole part as value again (123).
723
- // Example: type "123.456", select/mark "456" and press BACKSPACE - the native input is firing event with the whole part as value (123).
724
- // Example: type "123.456", select/mark "123.456" and press BACKSPACE - the native input is firing event with empty value.
725
- const delimiterCase = this.isTypeNumber
726
- && (e.inputType === "deleteContentForward" || e.inputType === "deleteContentBackward")
727
- && !e.target.value.includes(".")
728
- && this.value.includes(".");
729
- // Handle special numeric notation with "e", example "12.5e12"
730
- const eNotationCase = emptyValueFiredOnNumberInput && e.data === "e";
731
- // Handle special numeric notation with "-", example "-3"
732
- // When pressing BACKSPACE, the native input fires event with empty value
733
- const minusRemovalCase = emptyValueFiredOnNumberInput
734
- && this.value.startsWith("-")
735
- && this.value.length === 2
736
- && (e.inputType === "deleteContentForward" || e.inputType === "deleteContentBackward");
737
- if (delimiterCase || eNotationCase || minusRemovalCase) {
738
- this.value = e.target.value;
739
- this._keepInnerValue = true;
740
- }
741
- // ----------------- End ------------------
742
- }
743
733
  if (e.target === inputDomRef) {
744
734
  this.focused = true;
745
735
  // stop the native event, as the semantic "input" would be fired.
@@ -750,10 +740,13 @@ let Input = Input_1 = class Input extends UI5Element {
750
740
  if (this.Suggestions) {
751
741
  this.Suggestions.updateSelectedItemPosition(-1);
752
742
  }
743
+ if (this.filter && e.target.value === "") {
744
+ this.open = false;
745
+ }
753
746
  this.isTyping = true;
754
747
  }
755
748
  _startsWithMatchingItems(str) {
756
- return StartsWith(str, this._selectableItems, "text");
749
+ return Filters.StartsWith(str, this._selectableItems, "text");
757
750
  }
758
751
  _getFirstMatchingItem(current) {
759
752
  if (!this._flattenItems.length) {
@@ -770,9 +763,50 @@ let Input = Input_1 = class Input extends UI5Element {
770
763
  _selectMatchingItem(item) {
771
764
  item.selected = true;
772
765
  }
766
+ _filterItems(value) {
767
+ let matchingItems = [];
768
+ const groupItems = this._flattenItems.filter(item => this._isGroupItem(item));
769
+ this._resetItemVisibility();
770
+ if (groupItems.length) {
771
+ matchingItems = this._filterGroups(this.filter, groupItems);
772
+ }
773
+ else {
774
+ matchingItems = (Filters[this.filter])(value, this._selectableItems, "text");
775
+ }
776
+ this._selectableItems.forEach(item => {
777
+ item.hidden = !matchingItems.includes(item);
778
+ });
779
+ if (matchingItems.length === 0) {
780
+ this.open = false;
781
+ }
782
+ }
783
+ _filterGroups(filterType, groupItems) {
784
+ const filteredGroupItems = [];
785
+ groupItems.forEach(groupItem => {
786
+ const currentGroupItems = (Filters[filterType])(this.typedInValue, groupItem.items ?? [], "text");
787
+ filteredGroupItems.push(...currentGroupItems);
788
+ if (currentGroupItems.length === 0) {
789
+ groupItem.hidden = true;
790
+ }
791
+ else {
792
+ groupItem.hidden = false;
793
+ }
794
+ });
795
+ return filteredGroupItems;
796
+ }
797
+ _resetItemVisibility() {
798
+ this._flattenItems.forEach(item => {
799
+ if (this._isGroupItem(item)) {
800
+ item.items?.forEach(i => {
801
+ i.hidden = false;
802
+ });
803
+ return;
804
+ }
805
+ item.hidden = false;
806
+ });
807
+ }
773
808
  _handleTypeAhead(item) {
774
809
  const value = item.text ? item.text : "";
775
- this._innerValue = value;
776
810
  this.value = value;
777
811
  this._performTextSelection = true;
778
812
  this._shouldAutocomplete = false;
@@ -806,7 +840,6 @@ let Input = Input_1 = class Input extends UI5Element {
806
840
  this._handlePickerAfterOpen();
807
841
  }
808
842
  _afterClosePicker() {
809
- this.announceSelectedItem();
810
843
  // close device's keyboard and prevent further typing
811
844
  if (isPhone()) {
812
845
  this.blur();
@@ -825,6 +858,10 @@ let Input = Input_1 = class Input extends UI5Element {
825
858
  if (this.hasSuggestionItemSelected) {
826
859
  this.focus();
827
860
  }
861
+ const invisibleText = this.shadowRoot.querySelector(`#selectionText`);
862
+ if (invisibleText) {
863
+ invisibleText.textContent = "";
864
+ }
828
865
  this._handlePickerAfterClose();
829
866
  }
830
867
  _handlePickerAfterOpen() {
@@ -1358,9 +1395,6 @@ __decorate([
1358
1395
  __decorate([
1359
1396
  property()
1360
1397
  ], Input.prototype, "value", void 0);
1361
- __decorate([
1362
- property({ noAttribute: true })
1363
- ], Input.prototype, "_innerValue", void 0);
1364
1398
  __decorate([
1365
1399
  property()
1366
1400
  ], Input.prototype, "valueState", void 0);
@@ -1391,6 +1425,9 @@ __decorate([
1391
1425
  __decorate([
1392
1426
  property({ type: Boolean })
1393
1427
  ], Input.prototype, "open", void 0);
1428
+ __decorate([
1429
+ property()
1430
+ ], Input.prototype, "filter", void 0);
1394
1431
  __decorate([
1395
1432
  property({ type: Boolean })
1396
1433
  ], Input.prototype, "_effectiveShowClearIcon", void 0);