@ui5/webcomponents 0.0.0-32b659ddc → 0.0.0-35e2c9666

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 (1360) hide show
  1. package/CHANGELOG.md +1133 -1
  2. package/README.md +145 -41
  3. package/customI18n.js +50 -0
  4. package/dist/Assets-static.js +6 -0
  5. package/dist/Assets.js +3 -2
  6. package/dist/Avatar.js +223 -37
  7. package/dist/AvatarGroup.js +603 -0
  8. package/dist/Badge.js +44 -22
  9. package/dist/Breadcrumbs.js +632 -0
  10. package/dist/BreadcrumbsItem.js +103 -0
  11. package/dist/BusyIndicator.js +171 -17
  12. package/dist/Button.js +199 -43
  13. package/dist/Calendar.js +352 -551
  14. package/dist/CalendarDate.js +45 -0
  15. package/dist/CalendarHeader.js +134 -63
  16. package/dist/CalendarPart.js +111 -0
  17. package/dist/Card.js +43 -156
  18. package/dist/CardHeader.js +288 -0
  19. package/dist/Carousel.js +455 -77
  20. package/dist/CheckBox.js +187 -52
  21. package/dist/ColorPalette.js +494 -0
  22. package/dist/ColorPaletteItem.js +137 -0
  23. package/dist/ColorPalettePopover.js +244 -0
  24. package/dist/ColorPicker.js +562 -0
  25. package/dist/ComboBox.js +732 -104
  26. package/dist/ComboBoxFilters.js +8 -1
  27. package/dist/ComboBoxGroupItem.js +70 -0
  28. package/dist/ComboBoxItem.js +12 -24
  29. package/dist/CustomListItem.js +38 -9
  30. package/dist/DateComponentBase.js +168 -0
  31. package/dist/DatePicker.js +471 -381
  32. package/dist/DateRangePicker.js +356 -0
  33. package/dist/DateTimePicker.js +430 -0
  34. package/dist/DayPicker.js +513 -436
  35. package/dist/Dialog.js +514 -47
  36. package/dist/DurationPicker.js +312 -0
  37. package/dist/FileUploader.js +238 -32
  38. package/dist/GroupHeaderListItem.js +36 -8
  39. package/dist/Icon.js +224 -41
  40. package/dist/Input.js +955 -127
  41. package/dist/Interfaces.js +192 -0
  42. package/dist/Label.js +34 -13
  43. package/dist/Link.js +171 -32
  44. package/dist/List.js +575 -121
  45. package/dist/ListItem.js +139 -30
  46. package/dist/ListItemBase.js +55 -9
  47. package/dist/MessageStrip.js +87 -70
  48. package/dist/MonthPicker.js +181 -184
  49. package/dist/MultiComboBox.js +984 -198
  50. package/dist/MultiComboBoxItem.js +8 -5
  51. package/dist/MultiInput.js +348 -0
  52. package/dist/Option.js +59 -5
  53. package/dist/Panel.js +133 -42
  54. package/dist/Popover.js +413 -250
  55. package/dist/Popup.js +425 -278
  56. package/dist/ProgressIndicator.js +240 -0
  57. package/dist/RadioButton.js +163 -62
  58. package/dist/RadioButtonGroup.js +53 -29
  59. package/dist/RangeSlider.js +774 -0
  60. package/dist/RatingIndicator.js +321 -0
  61. package/dist/ResponsivePopover.js +90 -41
  62. package/dist/SegmentedButton.js +151 -52
  63. package/dist/SegmentedButtonItem.js +114 -0
  64. package/dist/Select.js +507 -109
  65. package/dist/Slider.js +325 -0
  66. package/dist/SliderBase.js +847 -0
  67. package/dist/SplitButton.js +431 -0
  68. package/dist/StandardListItem.js +46 -22
  69. package/dist/StepInput.js +684 -0
  70. package/dist/SuggestionGroupItem.js +64 -0
  71. package/dist/SuggestionItem.js +146 -0
  72. package/dist/SuggestionListItem.js +76 -0
  73. package/dist/Switch.js +84 -38
  74. package/dist/Tab.js +264 -19
  75. package/dist/TabContainer.js +923 -287
  76. package/dist/TabSeparator.js +44 -4
  77. package/dist/Table.js +735 -39
  78. package/dist/TableCell.js +13 -15
  79. package/dist/TableColumn.js +17 -13
  80. package/dist/TableGroupRow.js +164 -0
  81. package/dist/TableRow.js +327 -21
  82. package/dist/TextArea.js +327 -38
  83. package/dist/TimePicker.js +164 -0
  84. package/dist/TimePickerBase.js +463 -0
  85. package/dist/TimeSelection.js +493 -0
  86. package/dist/Title.js +18 -10
  87. package/dist/Toast.js +63 -37
  88. package/dist/ToggleButton.js +26 -13
  89. package/dist/Token.js +87 -46
  90. package/dist/Tokenizer.js +451 -62
  91. package/dist/Tree.js +447 -0
  92. package/dist/TreeItem.js +189 -0
  93. package/dist/TreeListItem.js +343 -0
  94. package/dist/WheelSlider.js +435 -0
  95. package/dist/YearPicker.js +201 -258
  96. package/dist/api.json +7259 -0
  97. package/dist/css/themes/Avatar.css +1 -0
  98. package/dist/css/themes/AvatarGroup.css +1 -0
  99. package/dist/css/themes/Badge.css +1 -0
  100. package/dist/css/themes/Breadcrumbs.css +1 -0
  101. package/dist/css/themes/BreadcrumbsPopover.css +1 -0
  102. package/dist/css/themes/BrowserScrollbar.css +1 -0
  103. package/dist/css/themes/BusyIndicator.css +1 -0
  104. package/dist/css/themes/Button.css +1 -0
  105. package/dist/css/themes/Button.ie11.css +1 -0
  106. package/dist/css/themes/Calendar.css +1 -0
  107. package/dist/css/themes/CalendarHeader.css +1 -0
  108. package/dist/css/themes/Card.css +1 -0
  109. package/dist/css/themes/CardHeader.css +1 -0
  110. package/dist/css/themes/Carousel.css +1 -0
  111. package/dist/css/themes/CheckBox.css +1 -0
  112. package/dist/css/themes/ColorPalette.css +1 -0
  113. package/dist/css/themes/ColorPaletteItem.css +1 -0
  114. package/dist/css/themes/ColorPalettePopover.css +1 -0
  115. package/dist/css/themes/ColorPaletteStaticArea.css +1 -0
  116. package/dist/css/themes/ColorPicker.css +1 -0
  117. package/dist/css/themes/ComboBox.css +1 -0
  118. package/dist/css/themes/ComboBoxPopover.css +1 -0
  119. package/dist/css/themes/CustomListItem.css +1 -0
  120. package/dist/css/themes/DatePicker.css +1 -0
  121. package/dist/css/themes/DatePickerPopover.css +1 -0
  122. package/dist/css/themes/DateRangePicker.css +1 -0
  123. package/dist/css/themes/DateTimePicker.css +1 -0
  124. package/dist/css/themes/DateTimePickerPopover.css +1 -0
  125. package/dist/css/themes/DayPicker.css +1 -0
  126. package/dist/css/themes/Dialog.css +1 -0
  127. package/dist/css/themes/FileUploader.css +1 -0
  128. package/dist/css/themes/GroupHeaderListItem.css +1 -0
  129. package/dist/css/themes/GrowingButton.css +1 -0
  130. package/dist/css/themes/Icon.css +1 -0
  131. package/dist/css/themes/Input.css +1 -0
  132. package/dist/css/themes/InputIcon.css +1 -0
  133. package/dist/css/themes/InvisibleTextStyles.css +1 -0
  134. package/dist/css/themes/Label.css +1 -0
  135. package/dist/css/themes/Link.css +1 -0
  136. package/dist/css/themes/List.css +1 -0
  137. package/dist/css/themes/ListItem.css +1 -0
  138. package/dist/css/themes/ListItemBase.css +1 -0
  139. package/dist/css/themes/MessageStrip.css +1 -0
  140. package/dist/css/themes/MonthPicker.css +1 -0
  141. package/dist/css/themes/MultiComboBox.css +1 -0
  142. package/dist/css/themes/MultiInput.css +1 -0
  143. package/dist/css/themes/Panel.css +1 -0
  144. package/dist/css/themes/Popover.css +1 -0
  145. package/dist/css/themes/Popup.css +1 -0
  146. package/dist/css/themes/PopupGlobal.css +1 -0
  147. package/dist/css/themes/PopupStaticAreaStyles.css +1 -0
  148. package/dist/css/themes/PopupsCommon.css +1 -0
  149. package/dist/css/themes/ProgressIndicator.css +1 -0
  150. package/dist/css/themes/RadioButton.css +1 -0
  151. package/dist/css/themes/RatingIndicator.css +1 -0
  152. package/dist/css/themes/ResponsivePopover.css +1 -0
  153. package/dist/css/themes/ResponsivePopoverCommon.css +1 -0
  154. package/dist/css/themes/SegmentedButton.css +1 -0
  155. package/dist/css/themes/Select.css +1 -0
  156. package/dist/css/themes/SelectPopover.css +1 -0
  157. package/dist/css/themes/SliderBase.css +1 -0
  158. package/dist/css/themes/SplitButton.css +1 -0
  159. package/dist/css/themes/StepInput.css +1 -0
  160. package/dist/css/themes/Suggestions.css +1 -0
  161. package/dist/css/themes/Switch.css +1 -0
  162. package/dist/css/themes/Tab.css +1 -0
  163. package/dist/css/themes/TabContainer.css +1 -0
  164. package/dist/css/themes/TabInOverflow.css +1 -0
  165. package/dist/css/themes/TabInStrip.css +1 -0
  166. package/dist/css/themes/TabSeparatorInOverflow.css +1 -0
  167. package/dist/css/themes/TabSeparatorInStrip.css +1 -0
  168. package/dist/css/themes/Table.css +1 -0
  169. package/dist/css/themes/TableCell.css +1 -0
  170. package/dist/css/themes/TableColumn.css +1 -0
  171. package/dist/css/themes/TableGroupRow.css +1 -0
  172. package/dist/css/themes/TableRow.css +1 -0
  173. package/dist/css/themes/TapHighlightColor.css +1 -0
  174. package/dist/css/themes/TextArea.css +1 -0
  175. package/dist/css/themes/TimePicker.css +1 -0
  176. package/dist/css/themes/TimePickerPopover.css +1 -0
  177. package/dist/css/themes/TimeSelection.css +1 -0
  178. package/dist/css/themes/Title.css +1 -0
  179. package/dist/css/themes/Toast.css +1 -0
  180. package/dist/css/themes/ToggleButton.css +1 -0
  181. package/dist/css/themes/ToggleButton.ie11.css +1 -0
  182. package/dist/css/themes/Token.css +1 -0
  183. package/dist/css/themes/Tokenizer.css +1 -0
  184. package/dist/css/themes/TokenizerPopover.css +1 -0
  185. package/dist/css/themes/Tree.css +1 -0
  186. package/dist/css/themes/TreeListItem.css +1 -0
  187. package/dist/css/themes/ValueStateMessage.css +1 -0
  188. package/dist/css/themes/WheelSlider.css +1 -0
  189. package/dist/css/themes/YearPicker.css +1 -0
  190. package/dist/css/themes/sap_belize/parameters-bundle.css +1 -0
  191. package/dist/css/themes/sap_belize_hcb/parameters-bundle.css +1 -0
  192. package/dist/css/themes/sap_belize_hcw/parameters-bundle.css +1 -0
  193. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -0
  194. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -0
  195. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -0
  196. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -0
  197. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -0
  198. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -0
  199. package/dist/css/themes/sap_horizon_exp/parameters-bundle.css +1 -0
  200. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -0
  201. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -0
  202. package/dist/features/ColorPaletteMoreColors.js +42 -0
  203. package/dist/features/InputElementsFormSupport.js +0 -1
  204. package/dist/features/InputSuggestions.js +364 -54
  205. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  206. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  207. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  208. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  209. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -0
  210. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  211. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  212. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  213. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  214. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -0
  215. package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -0
  216. package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -0
  217. package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -0
  218. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  219. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -0
  220. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  221. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  222. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  223. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -0
  224. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  225. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  226. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  227. package/dist/generated/assets/i18n/messagebundle_in.json +1 -0
  228. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  229. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  230. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  231. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  232. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  233. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  234. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  235. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  236. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  237. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  238. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  239. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  240. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -0
  241. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  242. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  243. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  244. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  245. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  246. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  247. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  248. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  249. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  250. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  251. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  252. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  253. package/dist/generated/assets/themes/sap_belize/parameters-bundle.css.json +1 -1
  254. package/dist/generated/assets/themes/sap_belize_hcb/parameters-bundle.css.json +1 -1
  255. package/dist/generated/assets/themes/sap_belize_hcw/parameters-bundle.css.json +1 -1
  256. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  257. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  258. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -0
  259. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -0
  260. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -0
  261. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -0
  262. package/dist/generated/assets/themes/sap_horizon_exp/parameters-bundle.css.json +1 -0
  263. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -0
  264. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -0
  265. package/dist/generated/i18n/i18n-defaults.js +2 -2
  266. package/dist/generated/json-imports/Themes-static.js +41 -0
  267. package/dist/generated/json-imports/Themes.js +26 -15
  268. package/dist/generated/json-imports/i18n-static.js +162 -0
  269. package/dist/generated/json-imports/i18n.js +113 -89
  270. package/dist/generated/templates/AvatarGroupTemplate.lit.js +9 -0
  271. package/dist/generated/templates/AvatarTemplate.lit.js +9 -9
  272. package/dist/generated/templates/BadgeTemplate.lit.js +5 -6
  273. package/dist/generated/templates/BreadcrumbsPopoverTemplate.lit.js +8 -0
  274. package/dist/generated/templates/BreadcrumbsTemplate.lit.js +9 -0
  275. package/dist/generated/templates/BusyIndicatorTemplate.lit.js +7 -5
  276. package/dist/generated/templates/ButtonTemplate.lit.js +6 -6
  277. package/dist/generated/templates/CalendarHeaderTemplate.lit.js +6 -4
  278. package/dist/generated/templates/CalendarTemplate.lit.js +4 -4
  279. package/dist/generated/templates/CardHeaderTemplate.lit.js +12 -0
  280. package/dist/generated/templates/CardTemplate.lit.js +5 -8
  281. package/dist/generated/templates/CarouselTemplate.lit.js +13 -14
  282. package/dist/generated/templates/CheckBoxTemplate.lit.js +7 -7
  283. package/dist/generated/templates/ColorPaletteDialogTemplate.lit.js +7 -0
  284. package/dist/generated/templates/ColorPaletteItemTemplate.lit.js +7 -0
  285. package/dist/generated/templates/ColorPalettePopoverTemplate.lit.js +8 -0
  286. package/dist/generated/templates/ColorPaletteTemplate.lit.js +12 -0
  287. package/dist/generated/templates/ColorPickerTemplate.lit.js +7 -0
  288. package/dist/generated/templates/ComboBoxPopoverTemplate.lit.js +20 -5
  289. package/dist/generated/templates/ComboBoxTemplate.lit.js +8 -5
  290. package/dist/generated/templates/CustomListItemTemplate.lit.js +13 -12
  291. package/dist/generated/templates/DatePickerPopoverTemplate.lit.js +7 -4
  292. package/dist/generated/templates/DatePickerTemplate.lit.js +6 -5
  293. package/dist/generated/templates/DateTimePickerPopoverTemplate.lit.js +12 -0
  294. package/dist/generated/templates/DayPickerTemplate.lit.js +13 -11
  295. package/dist/generated/templates/DialogTemplate.lit.js +9 -8
  296. package/dist/generated/templates/FileUploaderPopoverTemplate.lit.js +11 -0
  297. package/dist/generated/templates/FileUploaderTemplate.lit.js +7 -7
  298. package/dist/generated/templates/GroupHeaderListItemTemplate.lit.js +4 -4
  299. package/dist/generated/templates/IconTemplate.lit.js +6 -6
  300. package/dist/generated/templates/InputPopoverTemplate.lit.js +24 -6
  301. package/dist/generated/templates/InputTemplate.lit.js +10 -8
  302. package/dist/generated/templates/LabelTemplate.lit.js +4 -4
  303. package/dist/generated/templates/LinkTemplate.lit.js +5 -5
  304. package/dist/generated/templates/ListItemTemplate.lit.js +13 -12
  305. package/dist/generated/templates/ListTemplate.lit.js +12 -9
  306. package/dist/generated/templates/MessageStripTemplate.lit.js +6 -27
  307. package/dist/generated/templates/MonthPickerTemplate.lit.js +6 -6
  308. package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.js +23 -7
  309. package/dist/generated/templates/MultiComboBoxTemplate.lit.js +10 -8
  310. package/dist/generated/templates/MultiInputTemplate.lit.js +17 -0
  311. package/dist/generated/templates/PanelTemplate.lit.js +9 -6
  312. package/dist/generated/templates/PopoverTemplate.lit.js +9 -9
  313. package/dist/generated/templates/PopupBlockLayerTemplate.lit.js +7 -0
  314. package/dist/generated/templates/PopupTemplate.lit.js +4 -4
  315. package/dist/generated/templates/ProgressIndicatorTemplate.lit.js +17 -0
  316. package/dist/generated/templates/RadioButtonTemplate.lit.js +7 -7
  317. package/dist/generated/templates/RangeSliderTemplate.lit.js +13 -0
  318. package/dist/generated/templates/RatingIndicatorTemplate.lit.js +14 -0
  319. package/dist/generated/templates/ResponsivePopoverTemplate.lit.js +16 -11
  320. package/dist/generated/templates/SegmentedButtonItemTemplate.lit.js +8 -0
  321. package/dist/generated/templates/SegmentedButtonTemplate.lit.js +4 -9
  322. package/dist/generated/templates/SelectPopoverTemplate.lit.js +20 -6
  323. package/dist/generated/templates/SelectTemplate.lit.js +6 -4
  324. package/dist/generated/templates/SliderBaseTemplate.lit.js +11 -0
  325. package/dist/generated/templates/SliderTemplate.lit.js +12 -0
  326. package/dist/generated/templates/SplitButtonTemplate.lit.js +7 -0
  327. package/dist/generated/templates/StandardListItemTemplate.lit.js +21 -18
  328. package/dist/generated/templates/StepInputTemplate.lit.js +10 -0
  329. package/dist/generated/templates/SuggestionListItemTemplate.lit.js +27 -0
  330. package/dist/generated/templates/SwitchTemplate.lit.js +8 -6
  331. package/dist/generated/templates/TabContainerPopoverTemplate.lit.js +5 -8
  332. package/dist/generated/templates/TabContainerTemplate.lit.js +13 -18
  333. package/dist/generated/templates/TabInOverflowTemplate.lit.js +10 -0
  334. package/dist/generated/templates/TabInStripTemplate.lit.js +13 -0
  335. package/dist/generated/templates/TabSeparatorInOverflowTemplate.lit.js +7 -0
  336. package/dist/generated/templates/TabSeparatorInStripTemplate.lit.js +7 -0
  337. package/dist/generated/templates/TabTemplate.lit.js +5 -4
  338. package/dist/generated/templates/TableCellTemplate.lit.js +4 -4
  339. package/dist/generated/templates/TableColumnTemplate.lit.js +4 -4
  340. package/dist/generated/templates/TableGroupRowTemplate.lit.js +7 -0
  341. package/dist/generated/templates/TableRowTemplate.lit.js +12 -10
  342. package/dist/generated/templates/TableTemplate.lit.js +13 -8
  343. package/dist/generated/templates/TextAreaPopoverTemplate.lit.js +11 -0
  344. package/dist/generated/templates/TextAreaTemplate.lit.js +8 -8
  345. package/dist/generated/templates/TimePickerPopoverTemplate.lit.js +7 -0
  346. package/dist/generated/templates/TimePickerTemplate.lit.js +9 -0
  347. package/dist/generated/templates/TimeSelectionTemplate.lit.js +11 -0
  348. package/dist/generated/templates/TitleTemplate.lit.js +10 -10
  349. package/dist/generated/templates/ToastTemplate.lit.js +5 -4
  350. package/dist/generated/templates/ToggleButtonTemplate.lit.js +6 -6
  351. package/dist/generated/templates/TokenTemplate.lit.js +7 -5
  352. package/dist/generated/templates/TokenizerPopoverTemplate.lit.js +12 -0
  353. package/dist/generated/templates/TokenizerTemplate.lit.js +6 -6
  354. package/dist/generated/templates/TreeListItemTemplate.lit.js +21 -0
  355. package/dist/generated/templates/TreeTemplate.lit.js +8 -0
  356. package/dist/generated/templates/WheelSliderTemplate.lit.js +10 -0
  357. package/dist/generated/templates/YearPickerTemplate.lit.js +6 -6
  358. package/dist/generated/themes/Avatar.css.js +6 -7
  359. package/dist/generated/themes/AvatarGroup.css.js +8 -0
  360. package/dist/generated/themes/Badge.css.js +6 -7
  361. package/dist/generated/themes/Breadcrumbs.css.js +8 -0
  362. package/dist/generated/themes/BreadcrumbsPopover.css.js +8 -0
  363. package/dist/generated/themes/BrowserScrollbar.css.js +8 -0
  364. package/dist/generated/themes/BusyIndicator.css.js +6 -7
  365. package/dist/generated/themes/Button.css.js +6 -7
  366. package/dist/generated/themes/Button.ie11.css.js +8 -0
  367. package/dist/generated/themes/Calendar.css.js +6 -7
  368. package/dist/generated/themes/CalendarHeader.css.js +6 -7
  369. package/dist/generated/themes/Card.css.js +6 -7
  370. package/dist/generated/themes/CardHeader.css.js +8 -0
  371. package/dist/generated/themes/Carousel.css.js +6 -7
  372. package/dist/generated/themes/CheckBox.css.js +6 -7
  373. package/dist/generated/themes/ColorPalette.css.js +8 -0
  374. package/dist/generated/themes/ColorPaletteItem.css.js +8 -0
  375. package/dist/generated/themes/ColorPalettePopover.css.js +8 -0
  376. package/dist/generated/themes/ColorPaletteStaticArea.css.js +8 -0
  377. package/dist/generated/themes/ColorPicker.css.js +8 -0
  378. package/dist/generated/themes/ComboBox.css.js +6 -7
  379. package/dist/generated/themes/ComboBoxPopover.css.js +6 -7
  380. package/dist/generated/themes/CustomListItem.css.js +6 -7
  381. package/dist/generated/themes/DatePicker.css.js +6 -7
  382. package/dist/generated/themes/DatePickerPopover.css.js +6 -7
  383. package/dist/generated/themes/DateRangePicker.css.js +8 -0
  384. package/dist/generated/themes/DateTimePicker.css.js +8 -0
  385. package/dist/generated/themes/DateTimePickerPopover.css.js +8 -0
  386. package/dist/generated/themes/DayPicker.css.js +6 -7
  387. package/dist/generated/themes/Dialog.css.js +6 -7
  388. package/dist/generated/themes/FileUploader.css.js +6 -7
  389. package/dist/generated/themes/GroupHeaderListItem.css.js +6 -7
  390. package/dist/generated/themes/GrowingButton.css.js +8 -0
  391. package/dist/generated/themes/Icon.css.js +6 -7
  392. package/dist/generated/themes/Input.css.js +6 -7
  393. package/dist/generated/themes/InputIcon.css.js +6 -7
  394. package/dist/generated/themes/InvisibleTextStyles.css.js +6 -7
  395. package/dist/generated/themes/Label.css.js +6 -7
  396. package/dist/generated/themes/Link.css.js +6 -7
  397. package/dist/generated/themes/List.css.js +6 -7
  398. package/dist/generated/themes/ListItem.css.js +6 -7
  399. package/dist/generated/themes/ListItemBase.css.js +6 -7
  400. package/dist/generated/themes/MessageStrip.css.js +6 -7
  401. package/dist/generated/themes/MonthPicker.css.js +6 -7
  402. package/dist/generated/themes/MultiComboBox.css.js +6 -7
  403. package/dist/generated/themes/MultiInput.css.js +8 -0
  404. package/dist/generated/themes/Panel.css.js +6 -7
  405. package/dist/generated/themes/Popover.css.js +6 -7
  406. package/dist/generated/themes/Popup.css.js +6 -7
  407. package/dist/generated/themes/PopupGlobal.css.js +8 -0
  408. package/dist/generated/themes/PopupStaticAreaStyles.css.js +8 -0
  409. package/dist/generated/themes/PopupsCommon.css.js +8 -0
  410. package/dist/generated/themes/ProgressIndicator.css.js +8 -0
  411. package/dist/generated/themes/RadioButton.css.js +6 -7
  412. package/dist/generated/themes/RatingIndicator.css.js +8 -0
  413. package/dist/generated/themes/ResponsivePopover.css.js +6 -7
  414. package/dist/generated/themes/ResponsivePopoverCommon.css.js +6 -7
  415. package/dist/generated/themes/SegmentedButton.css.js +6 -7
  416. package/dist/generated/themes/Select.css.js +6 -7
  417. package/dist/generated/themes/SelectPopover.css.js +8 -0
  418. package/dist/generated/themes/SliderBase.css.js +8 -0
  419. package/dist/generated/themes/SplitButton.css.js +8 -0
  420. package/dist/generated/themes/StepInput.css.js +8 -0
  421. package/dist/generated/themes/Suggestions.css.js +8 -0
  422. package/dist/generated/themes/Switch.css.js +6 -7
  423. package/dist/generated/themes/Tab.css.js +6 -7
  424. package/dist/generated/themes/TabContainer.css.js +6 -7
  425. package/dist/generated/themes/TabInOverflow.css.js +8 -0
  426. package/dist/generated/themes/TabInStrip.css.js +8 -0
  427. package/dist/generated/themes/TabSeparatorInOverflow.css.js +8 -0
  428. package/dist/generated/themes/TabSeparatorInStrip.css.js +8 -0
  429. package/dist/generated/themes/Table.css.js +6 -7
  430. package/dist/generated/themes/TableCell.css.js +6 -7
  431. package/dist/generated/themes/TableColumn.css.js +6 -7
  432. package/dist/generated/themes/TableGroupRow.css.js +8 -0
  433. package/dist/generated/themes/TableRow.css.js +6 -7
  434. package/dist/generated/themes/TapHighlightColor.css.js +8 -0
  435. package/dist/generated/themes/TextArea.css.js +6 -7
  436. package/dist/generated/themes/TimePicker.css.js +8 -0
  437. package/dist/generated/themes/TimePickerPopover.css.js +8 -0
  438. package/dist/generated/themes/TimeSelection.css.js +8 -0
  439. package/dist/generated/themes/Title.css.js +6 -7
  440. package/dist/generated/themes/Toast.css.js +6 -7
  441. package/dist/generated/themes/ToggleButton.css.js +6 -7
  442. package/dist/generated/themes/ToggleButton.ie11.css.js +8 -0
  443. package/dist/generated/themes/Token.css.js +6 -7
  444. package/dist/generated/themes/Tokenizer.css.js +6 -7
  445. package/dist/generated/themes/TokenizerPopover.css.js +8 -0
  446. package/dist/generated/themes/Tree.css.js +8 -0
  447. package/dist/generated/themes/TreeListItem.css.js +8 -0
  448. package/dist/generated/themes/ValueStateMessage.css.js +8 -0
  449. package/dist/generated/themes/WheelSlider.css.js +8 -0
  450. package/dist/generated/themes/YearPicker.css.js +6 -7
  451. package/dist/generated/themes/sap_belize/parameters-bundle.css.js +1 -1
  452. package/dist/generated/themes/sap_belize_hcb/parameters-bundle.css.js +1 -1
  453. package/dist/generated/themes/sap_belize_hcw/parameters-bundle.css.js +1 -1
  454. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  455. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  456. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -0
  457. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -0
  458. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -0
  459. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -0
  460. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js +1 -0
  461. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -0
  462. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -0
  463. package/dist/i18n/messagebundle.properties +369 -0
  464. package/dist/i18n/messagebundle_ar.properties +243 -0
  465. package/dist/i18n/messagebundle_bg.properties +243 -0
  466. package/dist/i18n/messagebundle_ca.properties +243 -0
  467. package/dist/i18n/messagebundle_cs.properties +243 -0
  468. package/dist/i18n/messagebundle_cy.properties +243 -0
  469. package/dist/i18n/messagebundle_da.properties +243 -0
  470. package/dist/i18n/messagebundle_de.properties +243 -0
  471. package/dist/i18n/messagebundle_el.properties +243 -0
  472. package/dist/i18n/messagebundle_en.properties +243 -0
  473. package/dist/i18n/messagebundle_en_GB.properties +243 -0
  474. package/dist/i18n/messagebundle_en_US_sappsd.properties +243 -0
  475. package/dist/i18n/messagebundle_en_US_saprigi.properties +245 -0
  476. package/dist/i18n/messagebundle_en_US_saptrc.properties +243 -0
  477. package/dist/i18n/messagebundle_es.properties +243 -0
  478. package/dist/i18n/messagebundle_es_MX.properties +243 -0
  479. package/dist/i18n/messagebundle_et.properties +243 -0
  480. package/dist/i18n/messagebundle_fi.properties +243 -0
  481. package/dist/i18n/messagebundle_fr.properties +243 -0
  482. package/dist/i18n/messagebundle_fr_CA.properties +243 -0
  483. package/dist/i18n/messagebundle_hi.properties +243 -0
  484. package/dist/i18n/messagebundle_hr.properties +243 -0
  485. package/dist/i18n/messagebundle_hu.properties +243 -0
  486. package/dist/i18n/messagebundle_id.properties +243 -0
  487. package/dist/i18n/messagebundle_in.properties +172 -0
  488. package/dist/i18n/messagebundle_it.properties +243 -0
  489. package/dist/i18n/messagebundle_iw.properties +243 -0
  490. package/dist/i18n/messagebundle_ja.properties +243 -0
  491. package/dist/i18n/messagebundle_kk.properties +243 -0
  492. package/dist/i18n/messagebundle_ko.properties +243 -0
  493. package/dist/i18n/messagebundle_lt.properties +243 -0
  494. package/dist/i18n/messagebundle_lv.properties +243 -0
  495. package/dist/i18n/messagebundle_ms.properties +243 -0
  496. package/dist/i18n/messagebundle_nl.properties +243 -0
  497. package/dist/i18n/messagebundle_no.properties +243 -0
  498. package/dist/i18n/messagebundle_pl.properties +243 -0
  499. package/dist/i18n/messagebundle_pt.properties +243 -0
  500. package/dist/i18n/messagebundle_pt_PT.properties +243 -0
  501. package/dist/i18n/messagebundle_ro.properties +243 -0
  502. package/dist/i18n/messagebundle_ru.properties +243 -0
  503. package/dist/i18n/messagebundle_sh.properties +243 -0
  504. package/dist/i18n/messagebundle_sk.properties +243 -0
  505. package/dist/i18n/messagebundle_sl.properties +243 -0
  506. package/dist/i18n/messagebundle_sv.properties +243 -0
  507. package/dist/i18n/messagebundle_th.properties +243 -0
  508. package/dist/i18n/messagebundle_tr.properties +243 -0
  509. package/dist/i18n/messagebundle_uk.properties +243 -0
  510. package/dist/i18n/messagebundle_vi.properties +243 -0
  511. package/dist/i18n/messagebundle_zh_CN.properties +243 -0
  512. package/dist/i18n/messagebundle_zh_TW.properties +243 -0
  513. package/dist/popup-utils/OpenedPopupsRegistry.js +18 -13
  514. package/dist/popup-utils/PopoverRegistry.js +55 -21
  515. package/dist/timepicker-utils/TimeSlider.js +103 -0
  516. package/dist/types/{AvatarBackgroundColor.js → AvatarColorScheme.js} +9 -9
  517. package/dist/types/AvatarGroupType.js +43 -0
  518. package/dist/types/AvatarShape.js +1 -1
  519. package/dist/types/AvatarSize.js +1 -1
  520. package/dist/types/BreadcrumbsDesign.js +42 -0
  521. package/dist/types/BreadcrumbsSeparatorStyle.js +69 -0
  522. package/dist/types/BusyIndicatorSize.js +1 -1
  523. package/dist/types/ButtonDesign.js +8 -1
  524. package/dist/types/CalendarSelectionMode.js +47 -0
  525. package/dist/types/CarouselArrowsPlacement.js +3 -3
  526. package/dist/types/GrowingMode.js +48 -0
  527. package/dist/types/HasPopup.js +62 -0
  528. package/dist/types/InputType.js +7 -7
  529. package/dist/types/LinkDesign.js +1 -1
  530. package/dist/types/ListGrowingMode.js +48 -0
  531. package/dist/types/ListItemType.js +8 -1
  532. package/dist/types/ListMode.js +9 -1
  533. package/dist/types/ListSeparators.js +1 -1
  534. package/dist/types/{MessageStripType.js → MessageStripDesign.js} +7 -7
  535. package/dist/types/PanelAccessibleRole.js +1 -1
  536. package/dist/types/PopoverHorizontalAlign.js +1 -1
  537. package/dist/types/PopoverPlacementType.js +2 -2
  538. package/dist/types/PopoverVerticalAlign.js +1 -2
  539. package/dist/types/Priority.js +55 -0
  540. package/dist/types/SemanticColor.js +1 -1
  541. package/dist/types/SwitchDesign.js +40 -0
  542. package/dist/types/TabContainerTabsPlacement.js +40 -0
  543. package/dist/types/TabLayout.js +1 -1
  544. package/dist/types/TableGrowingMode.js +48 -0
  545. package/dist/types/TableMode.js +47 -0
  546. package/dist/types/TableRowType.js +40 -0
  547. package/dist/types/TabsOverflowMode.js +40 -0
  548. package/dist/types/TitleLevel.js +1 -1
  549. package/dist/types/ToastPlacement.js +1 -2
  550. package/dist/types/WrappingType.js +41 -0
  551. package/dist/webcomponentsjs/CHANGELOG.md +61 -0
  552. package/dist/webcomponentsjs/README.md +64 -47
  553. package/dist/webcomponentsjs/bundles/webcomponents-ce.js +38 -38
  554. package/dist/webcomponentsjs/bundles/webcomponents-ce.js.map +1 -1
  555. package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js +60 -0
  556. package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js.map +1 -0
  557. package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js +95 -0
  558. package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js.map +1 -0
  559. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js +292 -229
  560. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js.map +1 -1
  561. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js +190 -170
  562. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js.map +1 -1
  563. package/dist/webcomponentsjs/bundles/webcomponents-sd.js +151 -132
  564. package/dist/webcomponentsjs/bundles/webcomponents-sd.js.map +1 -1
  565. package/dist/webcomponentsjs/custom-elements-es5-adapter.js +2 -2
  566. package/dist/webcomponentsjs/webcomponents-bundle.js +302 -230
  567. package/dist/webcomponentsjs/webcomponents-bundle.js.map +1 -1
  568. package/dist/webcomponentsjs/webcomponents-loader.js +49 -28
  569. package/package-scripts.js +1 -0
  570. package/package.json +25 -6
  571. package/src/Assets-static.js +6 -0
  572. package/src/Assets.js +7 -0
  573. package/src/Avatar.hbs +20 -0
  574. package/src/Avatar.js +392 -0
  575. package/src/AvatarGroup.hbs +30 -0
  576. package/src/AvatarGroup.js +603 -0
  577. package/src/Badge.hbs +14 -0
  578. package/src/Badge.js +165 -0
  579. package/src/Breadcrumbs.hbs +45 -0
  580. package/src/Breadcrumbs.js +632 -0
  581. package/src/BreadcrumbsItem.js +103 -0
  582. package/src/BreadcrumbsPopover.hbs +28 -0
  583. package/src/BusyIndicator.hbs +32 -0
  584. package/src/BusyIndicator.js +268 -0
  585. package/src/Button.hbs +45 -0
  586. package/src/Button.js +504 -0
  587. package/src/Calendar.hbs +69 -0
  588. package/src/Calendar.js +496 -0
  589. package/src/CalendarDate.js +45 -0
  590. package/src/CalendarHeader.hbs +54 -0
  591. package/src/CalendarHeader.js +209 -0
  592. package/src/CalendarPart.js +111 -0
  593. package/src/Card.hbs +14 -0
  594. package/src/Card.js +160 -0
  595. package/src/CardHeader.hbs +42 -0
  596. package/src/CardHeader.js +288 -0
  597. package/src/Carousel.hbs +86 -0
  598. package/src/Carousel.js +690 -0
  599. package/src/CheckBox.hbs +45 -0
  600. package/src/CheckBox.js +457 -0
  601. package/src/ColorPalette.hbs +52 -0
  602. package/src/ColorPalette.js +494 -0
  603. package/src/ColorPaletteDialog.hbs +18 -0
  604. package/src/ColorPaletteItem.hbs +11 -0
  605. package/src/ColorPaletteItem.js +137 -0
  606. package/src/ColorPalettePopover.hbs +31 -0
  607. package/src/ColorPalettePopover.js +244 -0
  608. package/src/ColorPicker.hbs +99 -0
  609. package/src/ColorPicker.js +562 -0
  610. package/src/ComboBox.hbs +50 -0
  611. package/src/ComboBox.js +1115 -0
  612. package/src/ComboBoxFilters.js +40 -0
  613. package/src/ComboBoxGroupItem.js +70 -0
  614. package/src/ComboBoxItem.js +49 -0
  615. package/src/ComboBoxPopover.hbs +125 -0
  616. package/src/CustomListItem.hbs +5 -0
  617. package/src/CustomListItem.js +99 -0
  618. package/src/DateComponentBase.js +168 -0
  619. package/src/DatePicker.hbs +44 -0
  620. package/src/DatePicker.js +827 -0
  621. package/src/DatePickerPopover.hbs +61 -0
  622. package/src/DateRangePicker.js +356 -0
  623. package/src/DateTimePicker.js +430 -0
  624. package/src/DateTimePickerPopover.hbs +74 -0
  625. package/src/DayPicker.hbs +66 -0
  626. package/src/DayPicker.js +754 -0
  627. package/src/Dialog.hbs +36 -0
  628. package/src/Dialog.js +614 -0
  629. package/src/DurationPicker.js +312 -0
  630. package/src/FileUploader.hbs +40 -0
  631. package/src/FileUploader.js +531 -0
  632. package/src/FileUploaderPopover.hbs +26 -0
  633. package/src/GroupHeaderListItem.hbs +15 -0
  634. package/src/GroupHeaderListItem.js +94 -0
  635. package/src/Icon.hbs +25 -0
  636. package/src/Icon.js +376 -0
  637. package/src/Input.hbs +82 -0
  638. package/src/Input.js +1541 -0
  639. package/src/InputPopover.hbs +116 -0
  640. package/src/Interfaces.js +192 -0
  641. package/src/Label.hbs +13 -0
  642. package/src/Label.js +158 -0
  643. package/src/Link.hbs +21 -0
  644. package/src/Link.js +378 -0
  645. package/src/List.hbs +90 -0
  646. package/src/List.js +1105 -0
  647. package/src/ListItem.hbs +103 -0
  648. package/src/ListItem.js +371 -0
  649. package/src/ListItemBase.js +181 -0
  650. package/src/MessageStrip.hbs +34 -0
  651. package/src/MessageStrip.js +256 -0
  652. package/src/MonthPicker.hbs +29 -0
  653. package/src/MonthPicker.js +299 -0
  654. package/src/MultiComboBox.hbs +78 -0
  655. package/src/MultiComboBox.js +1455 -0
  656. package/src/MultiComboBoxItem.js +43 -0
  657. package/src/MultiComboBoxPopover.hbs +132 -0
  658. package/src/MultiInput.hbs +41 -0
  659. package/src/MultiInput.js +348 -0
  660. package/src/Option.js +126 -0
  661. package/src/Panel.hbs +64 -0
  662. package/src/Panel.js +470 -0
  663. package/src/Popover.hbs +25 -0
  664. package/src/Popover.js +872 -0
  665. package/src/Popup.hbs +34 -0
  666. package/src/Popup.js +616 -0
  667. package/src/PopupBlockLayer.hbs +7 -0
  668. package/src/ProgressIndicator.hbs +35 -0
  669. package/src/ProgressIndicator.js +240 -0
  670. package/src/RadioButton.hbs +33 -0
  671. package/src/RadioButton.js +506 -0
  672. package/src/RadioButtonGroup.js +205 -0
  673. package/src/RangeSlider.hbs +70 -0
  674. package/src/RangeSlider.js +774 -0
  675. package/src/RatingIndicator.hbs +35 -0
  676. package/src/RatingIndicator.js +321 -0
  677. package/src/ResponsivePopover.hbs +41 -0
  678. package/src/ResponsivePopover.js +211 -0
  679. package/src/SegmentedButton.hbs +18 -0
  680. package/src/SegmentedButton.js +303 -0
  681. package/src/SegmentedButtonItem.hbs +42 -0
  682. package/src/SegmentedButtonItem.js +114 -0
  683. package/src/Select.hbs +46 -0
  684. package/src/Select.js +844 -0
  685. package/src/SelectPopover.hbs +89 -0
  686. package/src/Slider.hbs +42 -0
  687. package/src/Slider.js +325 -0
  688. package/src/SliderBase.hbs +38 -0
  689. package/src/SliderBase.js +847 -0
  690. package/src/SplitButton.hbs +53 -0
  691. package/src/SplitButton.js +431 -0
  692. package/src/StandardListItem.hbs +44 -0
  693. package/src/StandardListItem.js +191 -0
  694. package/src/StepInput.hbs +81 -0
  695. package/src/StepInput.js +684 -0
  696. package/src/SuggestionGroupItem.js +64 -0
  697. package/src/SuggestionItem.js +146 -0
  698. package/src/SuggestionListItem.hbs +33 -0
  699. package/src/SuggestionListItem.js +76 -0
  700. package/src/Switch.hbs +51 -0
  701. package/src/Switch.js +292 -0
  702. package/src/Tab.hbs +7 -0
  703. package/src/Tab.js +410 -0
  704. package/src/TabContainer.hbs +81 -0
  705. package/src/TabContainer.js +1244 -0
  706. package/src/TabContainerPopover.hbs +21 -0
  707. package/src/TabInOverflow.hbs +28 -0
  708. package/src/TabInStrip.hbs +55 -0
  709. package/src/TabSeparator.js +83 -0
  710. package/src/TabSeparatorInOverflow.hbs +9 -0
  711. package/src/TabSeparatorInStrip.hbs +6 -0
  712. package/src/Table.hbs +109 -0
  713. package/src/Table.js +1010 -0
  714. package/src/TableCell.hbs +7 -0
  715. package/src/TableCell.js +88 -0
  716. package/src/TableColumn.hbs +8 -0
  717. package/src/TableColumn.js +129 -0
  718. package/src/TableGroupRow.hbs +13 -0
  719. package/src/TableGroupRow.js +164 -0
  720. package/src/TableRow.hbs +63 -0
  721. package/src/TableRow.js +467 -0
  722. package/src/TextArea.hbs +50 -0
  723. package/src/TextArea.js +702 -0
  724. package/src/TextAreaPopover.hbs +27 -0
  725. package/src/TimePicker.hbs +35 -0
  726. package/src/TimePicker.js +164 -0
  727. package/src/TimePickerBase.js +463 -0
  728. package/src/TimePickerPopover.hbs +33 -0
  729. package/src/TimeSelection.hbs +60 -0
  730. package/src/TimeSelection.js +493 -0
  731. package/src/Title.hbs +47 -0
  732. package/src/Title.js +132 -0
  733. package/src/Toast.hbs +13 -0
  734. package/src/Toast.js +243 -0
  735. package/src/ToggleButton.hbs +5 -0
  736. package/src/ToggleButton.js +89 -0
  737. package/src/Token.hbs +30 -0
  738. package/src/Token.js +220 -0
  739. package/src/Tokenizer.hbs +28 -0
  740. package/src/Tokenizer.js +617 -0
  741. package/src/TokenizerPopover.hbs +50 -0
  742. package/src/Tree.hbs +43 -0
  743. package/src/Tree.js +447 -0
  744. package/src/TreeItem.js +189 -0
  745. package/src/TreeListItem.hbs +48 -0
  746. package/src/TreeListItem.js +343 -0
  747. package/src/WheelSlider.hbs +48 -0
  748. package/src/WheelSlider.js +435 -0
  749. package/src/YearPicker.hbs +27 -0
  750. package/src/YearPicker.js +324 -0
  751. package/src/features/ColorPaletteMoreColors.js +42 -0
  752. package/src/features/InputElementsFormSupport.js +88 -0
  753. package/src/features/InputSuggestions.js +598 -0
  754. package/src/i18n/messagebundle.properties +369 -0
  755. package/src/i18n/messagebundle_ar.properties +243 -0
  756. package/src/i18n/messagebundle_bg.properties +243 -0
  757. package/src/i18n/messagebundle_ca.properties +243 -0
  758. package/src/i18n/messagebundle_cs.properties +243 -0
  759. package/src/i18n/messagebundle_cy.properties +243 -0
  760. package/src/i18n/messagebundle_da.properties +243 -0
  761. package/src/i18n/messagebundle_de.properties +243 -0
  762. package/src/i18n/messagebundle_el.properties +243 -0
  763. package/src/i18n/messagebundle_en.properties +243 -0
  764. package/src/i18n/messagebundle_en_GB.properties +243 -0
  765. package/src/i18n/messagebundle_en_US_sappsd.properties +243 -0
  766. package/src/i18n/messagebundle_en_US_saprigi.properties +245 -0
  767. package/src/i18n/messagebundle_en_US_saptrc.properties +243 -0
  768. package/src/i18n/messagebundle_es.properties +243 -0
  769. package/src/i18n/messagebundle_es_MX.properties +243 -0
  770. package/src/i18n/messagebundle_et.properties +243 -0
  771. package/src/i18n/messagebundle_fi.properties +243 -0
  772. package/src/i18n/messagebundle_fr.properties +243 -0
  773. package/src/i18n/messagebundle_fr_CA.properties +243 -0
  774. package/src/i18n/messagebundle_hi.properties +243 -0
  775. package/src/i18n/messagebundle_hr.properties +243 -0
  776. package/src/i18n/messagebundle_hu.properties +243 -0
  777. package/src/i18n/messagebundle_id.properties +243 -0
  778. package/src/i18n/messagebundle_in.properties +172 -0
  779. package/src/i18n/messagebundle_it.properties +243 -0
  780. package/src/i18n/messagebundle_iw.properties +243 -0
  781. package/src/i18n/messagebundle_ja.properties +243 -0
  782. package/src/i18n/messagebundle_kk.properties +243 -0
  783. package/src/i18n/messagebundle_ko.properties +243 -0
  784. package/src/i18n/messagebundle_lt.properties +243 -0
  785. package/src/i18n/messagebundle_lv.properties +243 -0
  786. package/src/i18n/messagebundle_ms.properties +243 -0
  787. package/src/i18n/messagebundle_nl.properties +243 -0
  788. package/src/i18n/messagebundle_no.properties +243 -0
  789. package/src/i18n/messagebundle_pl.properties +243 -0
  790. package/src/i18n/messagebundle_pt.properties +243 -0
  791. package/src/i18n/messagebundle_pt_PT.properties +243 -0
  792. package/src/i18n/messagebundle_ro.properties +243 -0
  793. package/src/i18n/messagebundle_ru.properties +243 -0
  794. package/src/i18n/messagebundle_sh.properties +243 -0
  795. package/src/i18n/messagebundle_sk.properties +243 -0
  796. package/src/i18n/messagebundle_sl.properties +243 -0
  797. package/src/i18n/messagebundle_sv.properties +243 -0
  798. package/src/i18n/messagebundle_th.properties +243 -0
  799. package/src/i18n/messagebundle_tr.properties +243 -0
  800. package/src/i18n/messagebundle_uk.properties +243 -0
  801. package/src/i18n/messagebundle_vi.properties +243 -0
  802. package/src/i18n/messagebundle_zh_CN.properties +243 -0
  803. package/src/i18n/messagebundle_zh_TW.properties +243 -0
  804. package/src/popup-utils/OpenedPopupsRegistry.js +50 -0
  805. package/src/popup-utils/PopoverRegistry.js +145 -0
  806. package/src/themes/Avatar.css +202 -0
  807. package/src/themes/AvatarGroup.css +82 -0
  808. package/src/themes/Badge.css +247 -0
  809. package/src/themes/Breadcrumbs.css +100 -0
  810. package/src/themes/BreadcrumbsPopover.css +10 -0
  811. package/src/themes/BrowserScrollbar.css +25 -0
  812. package/src/themes/BusyIndicator.css +143 -0
  813. package/src/themes/Button.css +306 -0
  814. package/src/themes/Button.ie11.css +48 -0
  815. package/src/themes/Calendar.css +23 -0
  816. package/src/themes/CalendarHeader.css +137 -0
  817. package/src/themes/Card.css +42 -0
  818. package/src/themes/CardHeader.css +133 -0
  819. package/src/themes/Carousel.css +140 -0
  820. package/src/themes/CheckBox.css +289 -0
  821. package/src/themes/ColorPalette.css +70 -0
  822. package/src/themes/ColorPaletteItem.css +70 -0
  823. package/src/themes/ColorPalettePopover.css +17 -0
  824. package/src/themes/ColorPaletteStaticArea.css +17 -0
  825. package/src/themes/ColorPicker.css +190 -0
  826. package/src/themes/ComboBox.css +9 -0
  827. package/src/themes/ComboBoxPopover.css +17 -0
  828. package/src/themes/CustomListItem.css +31 -0
  829. package/src/themes/DatePicker.css +46 -0
  830. package/src/themes/DatePickerPopover.css +9 -0
  831. package/src/themes/DateRangePicker.css +16 -0
  832. package/src/themes/DateTimePicker.css +11 -0
  833. package/src/themes/DateTimePickerPopover.css +78 -0
  834. package/src/themes/DayPicker.css +269 -0
  835. package/src/themes/Dialog.css +66 -0
  836. package/src/themes/FileUploader.css +40 -0
  837. package/src/themes/GroupHeaderListItem.css +24 -0
  838. package/src/themes/GrowingButton.css +67 -0
  839. package/src/themes/Icon.css +38 -0
  840. package/src/themes/Input.css +407 -0
  841. package/src/themes/InputIcon.css +53 -0
  842. package/src/themes/InvisibleTextStyles.css +9 -0
  843. package/src/themes/Label.css +85 -0
  844. package/src/themes/Link.css +77 -0
  845. package/src/themes/List.css +116 -0
  846. package/src/themes/ListItem.css +231 -0
  847. package/src/themes/ListItemBase.css +85 -0
  848. package/src/themes/MessageStrip.css +123 -0
  849. package/src/themes/MonthPicker.css +86 -0
  850. package/src/themes/MultiComboBox.css +36 -0
  851. package/src/themes/MultiInput.css +14 -0
  852. package/src/themes/Panel.css +100 -0
  853. package/src/themes/Popover.css +102 -0
  854. package/src/themes/Popup.css +5 -0
  855. package/src/themes/PopupGlobal.css +3 -0
  856. package/src/themes/PopupStaticAreaStyles.css +17 -0
  857. package/src/themes/PopupsCommon.css +127 -0
  858. package/src/themes/ProgressIndicator.css +158 -0
  859. package/src/themes/RadioButton.css +249 -0
  860. package/src/themes/RatingIndicator.css +52 -0
  861. package/src/themes/ResponsivePopover.css +29 -0
  862. package/src/themes/ResponsivePopoverCommon.css +208 -0
  863. package/src/themes/SegmentedButton.css +88 -0
  864. package/src/themes/Select.css +53 -0
  865. package/src/themes/SelectPopover.css +19 -0
  866. package/src/themes/SliderBase.css +253 -0
  867. package/src/themes/SplitButton.css +98 -0
  868. package/src/themes/StepInput.css +270 -0
  869. package/src/themes/Suggestions.css +28 -0
  870. package/src/themes/Switch.css +370 -0
  871. package/src/themes/Tab.css +9 -0
  872. package/src/themes/TabContainer.css +149 -0
  873. package/src/themes/TabInOverflow.css +74 -0
  874. package/src/themes/TabInStrip.css +385 -0
  875. package/src/themes/TabSeparatorInOverflow.css +9 -0
  876. package/src/themes/TabSeparatorInStrip.css +5 -0
  877. package/src/themes/Table.css +91 -0
  878. package/src/themes/TableCell.css +28 -0
  879. package/src/themes/TableColumn.css +29 -0
  880. package/src/themes/TableGroupRow.css +34 -0
  881. package/src/themes/TableRow.css +85 -0
  882. package/src/themes/TapHighlightColor.css +3 -0
  883. package/src/themes/TextArea.css +309 -0
  884. package/src/themes/TimePicker.css +50 -0
  885. package/src/themes/TimePickerPopover.css +15 -0
  886. package/src/themes/TimeSelection.css +27 -0
  887. package/src/themes/Title.css +65 -0
  888. package/src/themes/Toast.css +93 -0
  889. package/src/themes/ToggleButton.css +88 -0
  890. package/src/themes/ToggleButton.ie11.css +48 -0
  891. package/src/themes/Token.css +117 -0
  892. package/src/themes/Tokenizer.css +85 -0
  893. package/src/themes/TokenizerPopover.css +4 -0
  894. package/src/themes/Tree.css +11 -0
  895. package/src/themes/TreeListItem.css +107 -0
  896. package/src/themes/ValueStateMessage.css +86 -0
  897. package/src/themes/WheelSlider.css +203 -0
  898. package/src/themes/YearPicker.css +86 -0
  899. package/src/themes/base/Avatar-parameters.css +38 -0
  900. package/src/themes/base/AvatarGroup-parameter.css +6 -0
  901. package/src/themes/base/Badge-parameters.css +61 -0
  902. package/src/themes/base/BrowserScrollbar-parameters.css +4 -0
  903. package/src/themes/base/BusyIndicator-parameters.css +5 -0
  904. package/src/themes/base/Button-parameters.css +30 -0
  905. package/src/themes/base/CalendarHeader-parameters.css +20 -0
  906. package/src/themes/base/Card-parameters.css +17 -0
  907. package/src/themes/base/Carousel-parameters.css +9 -0
  908. package/src/themes/base/CheckBox-parameters.css +53 -0
  909. package/src/themes/base/ColorPalette-parameters.css +14 -0
  910. package/src/themes/base/ColorPicker-parameters.css +8 -0
  911. package/src/themes/base/DatePicker-parameters.css +6 -0
  912. package/src/themes/base/DayPicker-parameters.css +41 -0
  913. package/src/themes/base/Dialog-parameters.css +9 -0
  914. package/src/themes/base/GroupHeaderListItem-parameters.css +3 -0
  915. package/src/themes/base/GrowingButton-parameters.css +6 -0
  916. package/src/themes/base/Input-parameters.css +63 -0
  917. package/src/themes/base/InputIcon-parameters.css +11 -0
  918. package/src/themes/base/Link-parameters.css +8 -0
  919. package/src/themes/base/List-parameters.css +3 -0
  920. package/src/themes/base/ListItemBase-parameters.css +10 -0
  921. package/src/themes/base/MessageStrip-parameters.css +21 -0
  922. package/src/themes/base/MonthPicker-parameters.css +16 -0
  923. package/src/themes/base/MultiComboBox-parameters.css +3 -0
  924. package/src/themes/base/Panel-parameters.css +11 -0
  925. package/src/themes/base/PopupsCommon-parameters.css +13 -0
  926. package/src/themes/base/ProgressIndicator-parameters.css +21 -0
  927. package/src/themes/base/RadioButton-parameters.css +32 -0
  928. package/src/themes/base/RatingIndicator-parameters.css +3 -0
  929. package/src/themes/base/SegmentedButtton-parameters.css +8 -0
  930. package/src/themes/base/Select-parameters.css +11 -0
  931. package/src/themes/base/SelectPopover-parameters.css +4 -0
  932. package/src/themes/base/SliderBase-parameters.css +64 -0
  933. package/src/themes/base/StepInput-parameters.css +24 -0
  934. package/src/themes/base/Suggestions-parameters.css +3 -0
  935. package/src/themes/base/Switch-parameters.css +96 -0
  936. package/src/themes/base/TabContainer-parameters.css +84 -0
  937. package/src/themes/base/Table-parameters.css +6 -0
  938. package/src/themes/base/TableColumn-parameters.css +3 -0
  939. package/src/themes/base/TableRow-parameters.css +3 -0
  940. package/src/themes/base/TextArea-parameters.css +22 -0
  941. package/src/themes/base/TimePicker-parameters.css +4 -0
  942. package/src/themes/base/TimelineItem-parameters.css +10 -0
  943. package/src/themes/base/Toast-parameters.css +6 -0
  944. package/src/themes/base/ToggleButton-parameters.css +8 -0
  945. package/src/themes/base/Token-parameters.css +19 -0
  946. package/src/themes/base/Tokenizer-parameters.css +4 -0
  947. package/src/themes/base/ValueStateMessage-parameters.css +7 -0
  948. package/src/themes/base/WheelSlider-parameters.css +15 -0
  949. package/src/themes/base/YearPicker-parameters.css +16 -0
  950. package/src/themes/base/sizes-parameters.css +305 -0
  951. package/src/themes/sap_belize/BrowserScrollbar-parameters.css +4 -0
  952. package/src/themes/sap_belize/Carousel-parameters.css +9 -0
  953. package/src/themes/sap_belize/Dialog-parameters.css +5 -0
  954. package/src/themes/sap_belize/Input-parameters.css +6 -0
  955. package/src/themes/sap_belize/InputIcon-parameters.css +5 -0
  956. package/src/themes/sap_belize/ProgressIndicator-parameters.css +8 -0
  957. package/src/themes/sap_belize/SliderBase-parameters.css +22 -0
  958. package/src/themes/sap_belize/TabContainer-parameters.css +6 -0
  959. package/src/themes/sap_belize/Table-parameters.css +7 -0
  960. package/src/themes/sap_belize/TimePicker-parameters.css +5 -0
  961. package/src/themes/sap_belize/WheelSlider-parameters.css +17 -0
  962. package/src/themes/sap_belize/parameters-bundle.css +47 -0
  963. package/src/themes/sap_belize_hcb/Avatar-parameters.css +18 -0
  964. package/src/themes/sap_belize_hcb/Badge-parameters.css +43 -0
  965. package/src/themes/sap_belize_hcb/BrowserScrollbar-parameters.css +4 -0
  966. package/src/themes/sap_belize_hcb/Button-parameters.css +12 -0
  967. package/src/themes/sap_belize_hcb/CalendarHeader-parameters.css +11 -0
  968. package/src/themes/sap_belize_hcb/Card-parameters.css +6 -0
  969. package/src/themes/sap_belize_hcb/Carousel-parameters.css +9 -0
  970. package/src/themes/sap_belize_hcb/CheckBox-parameters.css +12 -0
  971. package/src/themes/sap_belize_hcb/DatePicker-parameters.css +6 -0
  972. package/src/themes/sap_belize_hcb/DayPicker-parameters.css +13 -0
  973. package/src/themes/sap_belize_hcb/Dialog-parameters.css +7 -0
  974. package/src/themes/sap_belize_hcb/GrowingButton-parameters.css +8 -0
  975. package/src/themes/sap_belize_hcb/Input-parameters.css +14 -0
  976. package/src/themes/sap_belize_hcb/InputIcon-parameters.css +5 -0
  977. package/src/themes/sap_belize_hcb/Link-parameters.css +7 -0
  978. package/src/themes/sap_belize_hcb/MessageStrip-parameters.css +10 -0
  979. package/src/themes/sap_belize_hcb/MonthPicker-parameters.css +10 -0
  980. package/src/themes/sap_belize_hcb/Panel-parameters.css +5 -0
  981. package/src/themes/sap_belize_hcb/ProgressIndicator-parameters.css +11 -0
  982. package/src/themes/sap_belize_hcb/RadioButton-parameters.css +10 -0
  983. package/src/themes/sap_belize_hcb/Select-parameters.css +12 -0
  984. package/src/themes/sap_belize_hcb/SliderBase-parameters.css +17 -0
  985. package/src/themes/sap_belize_hcb/Switch-parameters.css +44 -0
  986. package/src/themes/sap_belize_hcb/TabContainer-parameters.css +44 -0
  987. package/src/themes/sap_belize_hcb/Table-parameters.css +7 -0
  988. package/src/themes/sap_belize_hcb/TableRow-parameters.css +5 -0
  989. package/src/themes/sap_belize_hcb/TextArea-parameters.css +6 -0
  990. package/src/themes/sap_belize_hcb/ToggleButton-parameters.css +7 -0
  991. package/src/themes/sap_belize_hcb/Token-parameters.css +6 -0
  992. package/src/themes/sap_belize_hcb/ValueStateMessage-parameters.css +5 -0
  993. package/src/themes/sap_belize_hcb/WheelSlider-parameters.css +17 -0
  994. package/src/themes/sap_belize_hcb/YearPicker-parameters.css +10 -0
  995. package/src/themes/sap_belize_hcb/parameters-bundle.css +46 -0
  996. package/src/themes/sap_belize_hcw/Avatar-parameters.css +18 -0
  997. package/src/themes/sap_belize_hcw/Badge-parameters.css +43 -0
  998. package/src/themes/sap_belize_hcw/BrowserScrollbar-parameters.css +4 -0
  999. package/src/themes/sap_belize_hcw/Button-parameters.css +12 -0
  1000. package/src/themes/sap_belize_hcw/CalendarHeader-parameters.css +11 -0
  1001. package/src/themes/sap_belize_hcw/Card-parameters.css +6 -0
  1002. package/src/themes/sap_belize_hcw/Carousel-parameters.css +9 -0
  1003. package/src/themes/sap_belize_hcw/CheckBox-parameters.css +12 -0
  1004. package/src/themes/sap_belize_hcw/DatePicker-parameters.css +5 -0
  1005. package/src/themes/sap_belize_hcw/DayPicker-parameters.css +14 -0
  1006. package/src/themes/sap_belize_hcw/Dialog-parameters.css +7 -0
  1007. package/src/themes/sap_belize_hcw/GrowingButton-parameters.css +8 -0
  1008. package/src/themes/sap_belize_hcw/Input-parameters.css +14 -0
  1009. package/src/themes/sap_belize_hcw/InputIcon-parameters.css +5 -0
  1010. package/src/themes/sap_belize_hcw/Link-parameters.css +7 -0
  1011. package/src/themes/sap_belize_hcw/MessageStrip-parameters.css +10 -0
  1012. package/src/themes/sap_belize_hcw/MonthPicker-parameters.css +10 -0
  1013. package/src/themes/sap_belize_hcw/Panel-parameters.css +5 -0
  1014. package/src/themes/sap_belize_hcw/ProgressIndicator-parameters.css +11 -0
  1015. package/src/themes/sap_belize_hcw/RadioButton-parameters.css +10 -0
  1016. package/src/themes/sap_belize_hcw/Select-parameters.css +12 -0
  1017. package/src/themes/sap_belize_hcw/SliderBase-parameters.css +17 -0
  1018. package/src/themes/sap_belize_hcw/Switch-parameters.css +43 -0
  1019. package/src/themes/sap_belize_hcw/TabContainer-parameters.css +44 -0
  1020. package/src/themes/sap_belize_hcw/Table-parameters.css +7 -0
  1021. package/src/themes/sap_belize_hcw/TableRow-parameters.css +5 -0
  1022. package/src/themes/sap_belize_hcw/TextArea-parameters.css +6 -0
  1023. package/src/themes/sap_belize_hcw/ToggleButton-parameters.css +6 -0
  1024. package/src/themes/sap_belize_hcw/Token-parameters.css +6 -0
  1025. package/src/themes/sap_belize_hcw/ValueStateMessage-parameters.css +5 -0
  1026. package/src/themes/sap_belize_hcw/WheelSlider-parameters.css +17 -0
  1027. package/src/themes/sap_belize_hcw/YearPicker-parameters.css +10 -0
  1028. package/src/themes/sap_belize_hcw/parameters-bundle.css +46 -0
  1029. package/src/themes/sap_fiori_3/Avatar-parameters.css +9 -0
  1030. package/src/themes/sap_fiori_3/Button-parameters.css +14 -0
  1031. package/src/themes/sap_fiori_3/CalendarHeader-parameters.css +8 -0
  1032. package/src/themes/sap_fiori_3/CheckBox-parameters.css +13 -0
  1033. package/src/themes/sap_fiori_3/DayPicker-parameters.css +6 -0
  1034. package/src/themes/sap_fiori_3/Input-parameters.css +7 -0
  1035. package/src/themes/sap_fiori_3/Link-parameters.css +7 -0
  1036. package/src/themes/sap_fiori_3/List-parameters.css +5 -0
  1037. package/src/themes/sap_fiori_3/MonthPicker-parameters.css +5 -0
  1038. package/src/themes/sap_fiori_3/MultiComboBox-parameters.css +5 -0
  1039. package/src/themes/sap_fiori_3/Panel-parameters.css +6 -0
  1040. package/src/themes/sap_fiori_3/SliderBase-parameters.css +5 -0
  1041. package/src/themes/sap_fiori_3/TabContainer-parameters.css +12 -0
  1042. package/src/themes/sap_fiori_3/TimePicker-parameters.css +5 -0
  1043. package/src/themes/sap_fiori_3/Token-parameters.css +9 -0
  1044. package/src/themes/sap_fiori_3/WheelSlider-parameters.css +16 -0
  1045. package/src/themes/sap_fiori_3/YearPicker-parameters.css +5 -0
  1046. package/src/themes/sap_fiori_3/parameters-bundle.css +47 -0
  1047. package/src/themes/sap_fiori_3_dark/Avatar-parameters.css +9 -0
  1048. package/src/themes/sap_fiori_3_dark/Button-parameters.css +14 -0
  1049. package/src/themes/sap_fiori_3_dark/CalendarHeader-parameters.css +8 -0
  1050. package/src/themes/sap_fiori_3_dark/CheckBox-parameters.css +13 -0
  1051. package/src/themes/sap_fiori_3_dark/DayPicker-parameters.css +6 -0
  1052. package/src/themes/sap_fiori_3_dark/Input-parameters.css +7 -0
  1053. package/src/themes/sap_fiori_3_dark/Link-parameters.css +7 -0
  1054. package/src/themes/sap_fiori_3_dark/List-parameters.css +5 -0
  1055. package/src/themes/sap_fiori_3_dark/MonthPicker-parameters.css +5 -0
  1056. package/src/themes/sap_fiori_3_dark/MultiComboBox-parameters.css +5 -0
  1057. package/src/themes/sap_fiori_3_dark/Panel-parameters.css +6 -0
  1058. package/src/themes/sap_fiori_3_dark/SliderBase-parameters.css +5 -0
  1059. package/src/themes/sap_fiori_3_dark/TabContainer-parameters.css +12 -0
  1060. package/src/themes/sap_fiori_3_dark/Token-parameters.css +8 -0
  1061. package/src/themes/sap_fiori_3_dark/WheelSlider-parameters.css +15 -0
  1062. package/src/themes/sap_fiori_3_dark/YearPicker-parameters.css +5 -0
  1063. package/src/themes/sap_fiori_3_dark/parameters-bundle.css +46 -0
  1064. package/src/themes/sap_fiori_3_hcb/Avatar-parameters.css +24 -0
  1065. package/src/themes/sap_fiori_3_hcb/Badge-parameters.css +43 -0
  1066. package/src/themes/sap_fiori_3_hcb/Button-parameters.css +10 -0
  1067. package/src/themes/sap_fiori_3_hcb/CalendarHeader-parameters.css +11 -0
  1068. package/src/themes/sap_fiori_3_hcb/Card-parameters.css +6 -0
  1069. package/src/themes/sap_fiori_3_hcb/Carousel-parameters.css +9 -0
  1070. package/src/themes/sap_fiori_3_hcb/CheckBox-parameters.css +13 -0
  1071. package/src/themes/sap_fiori_3_hcb/DatePicker-parameters.css +5 -0
  1072. package/src/themes/sap_fiori_3_hcb/DayPicker-parameters.css +17 -0
  1073. package/src/themes/sap_fiori_3_hcb/Dialog-parameters.css +7 -0
  1074. package/src/themes/sap_fiori_3_hcb/GrowingButton-parameters.css +8 -0
  1075. package/src/themes/sap_fiori_3_hcb/Input-parameters.css +21 -0
  1076. package/src/themes/sap_fiori_3_hcb/InputIcon-parameters.css +5 -0
  1077. package/src/themes/sap_fiori_3_hcb/Link-parameters.css +7 -0
  1078. package/src/themes/sap_fiori_3_hcb/MessageStrip-parameters.css +10 -0
  1079. package/src/themes/sap_fiori_3_hcb/MonthPicker-parameters.css +11 -0
  1080. package/src/themes/sap_fiori_3_hcb/Panel-parameters.css +5 -0
  1081. package/src/themes/sap_fiori_3_hcb/ProgressIndicator-parameters.css +11 -0
  1082. package/src/themes/sap_fiori_3_hcb/RadioButton-parameters.css +10 -0
  1083. package/src/themes/sap_fiori_3_hcb/Select-parameters.css +12 -0
  1084. package/src/themes/sap_fiori_3_hcb/SliderBase-parameters.css +14 -0
  1085. package/src/themes/sap_fiori_3_hcb/Switch-parameters.css +43 -0
  1086. package/src/themes/sap_fiori_3_hcb/TabContainer-parameters.css +44 -0
  1087. package/src/themes/sap_fiori_3_hcb/Table-parameters.css +5 -0
  1088. package/src/themes/sap_fiori_3_hcb/TableRow-parameters.css +5 -0
  1089. package/src/themes/sap_fiori_3_hcb/TextArea-parameters.css +10 -0
  1090. package/src/themes/sap_fiori_3_hcb/TimePicker-parameters.css +5 -0
  1091. package/src/themes/sap_fiori_3_hcb/ToggleButton-parameters.css +6 -0
  1092. package/src/themes/sap_fiori_3_hcb/Token-parameters.css +7 -0
  1093. package/src/themes/sap_fiori_3_hcb/ValueStateMessage-parameters.css +5 -0
  1094. package/src/themes/sap_fiori_3_hcb/WheelSlider-parameters.css +17 -0
  1095. package/src/themes/sap_fiori_3_hcb/YearPicker-parameters.css +11 -0
  1096. package/src/themes/sap_fiori_3_hcb/parameters-bundle.css +47 -0
  1097. package/src/themes/sap_fiori_3_hcw/Avatar-parameters.css +24 -0
  1098. package/src/themes/sap_fiori_3_hcw/Badge-parameters.css +43 -0
  1099. package/src/themes/sap_fiori_3_hcw/Button-parameters.css +10 -0
  1100. package/src/themes/sap_fiori_3_hcw/CalendarHeader-parameters.css +11 -0
  1101. package/src/themes/sap_fiori_3_hcw/Card-parameters.css +6 -0
  1102. package/src/themes/sap_fiori_3_hcw/Carousel-parameters.css +9 -0
  1103. package/src/themes/sap_fiori_3_hcw/CheckBox-parameters.css +13 -0
  1104. package/src/themes/sap_fiori_3_hcw/DatePicker-parameters.css +5 -0
  1105. package/src/themes/sap_fiori_3_hcw/DayPicker-parameters.css +17 -0
  1106. package/src/themes/sap_fiori_3_hcw/Dialog-parameters.css +7 -0
  1107. package/src/themes/sap_fiori_3_hcw/GrowingButton-parameters.css +8 -0
  1108. package/src/themes/sap_fiori_3_hcw/Input-parameters.css +21 -0
  1109. package/src/themes/sap_fiori_3_hcw/InputIcon-parameters.css +5 -0
  1110. package/src/themes/sap_fiori_3_hcw/Link-parameters.css +7 -0
  1111. package/src/themes/sap_fiori_3_hcw/MessageStrip-parameters.css +10 -0
  1112. package/src/themes/sap_fiori_3_hcw/MonthPicker-parameters.css +11 -0
  1113. package/src/themes/sap_fiori_3_hcw/Panel-parameters.css +5 -0
  1114. package/src/themes/sap_fiori_3_hcw/ProgressIndicator-parameters.css +11 -0
  1115. package/src/themes/sap_fiori_3_hcw/RadioButton-parameters.css +10 -0
  1116. package/src/themes/sap_fiori_3_hcw/Select-parameters.css +12 -0
  1117. package/src/themes/sap_fiori_3_hcw/SliderBase-parameters.css +13 -0
  1118. package/src/themes/sap_fiori_3_hcw/Switch-parameters.css +43 -0
  1119. package/src/themes/sap_fiori_3_hcw/TabContainer-parameters.css +44 -0
  1120. package/src/themes/sap_fiori_3_hcw/Table-parameters.css +5 -0
  1121. package/src/themes/sap_fiori_3_hcw/TableRow-parameters.css +5 -0
  1122. package/src/themes/sap_fiori_3_hcw/TextArea-parameters.css +10 -0
  1123. package/src/themes/sap_fiori_3_hcw/TimePicker-parameters.css +5 -0
  1124. package/src/themes/sap_fiori_3_hcw/ToggleButton-parameters.css +6 -0
  1125. package/src/themes/sap_fiori_3_hcw/Token-parameters.css +7 -0
  1126. package/src/themes/sap_fiori_3_hcw/ValueStateMessage-parameters.css +5 -0
  1127. package/src/themes/sap_fiori_3_hcw/WheelSlider-parameters.css +17 -0
  1128. package/src/themes/sap_fiori_3_hcw/YearPicker-parameters.css +11 -0
  1129. package/src/themes/sap_fiori_3_hcw/parameters-bundle.css +47 -0
  1130. package/src/themes/sap_horizon/Avatar-parameters.css +33 -0
  1131. package/src/themes/sap_horizon/BusyIndicator-parameters.css +7 -0
  1132. package/src/themes/sap_horizon/Button-parameters.css +20 -0
  1133. package/src/themes/sap_horizon/CalendarHeader-parameters.css +19 -0
  1134. package/src/themes/sap_horizon/Card-parameters.css +10 -0
  1135. package/src/themes/sap_horizon/CheckBox-parameters.css +34 -0
  1136. package/src/themes/sap_horizon/ColorPalette-parameters.css +16 -0
  1137. package/src/themes/sap_horizon/ColorPicker-parameters.css +10 -0
  1138. package/src/themes/sap_horizon/DatePicker-parameters.css +6 -0
  1139. package/src/themes/sap_horizon/DayPicker-parameters.css +31 -0
  1140. package/src/themes/sap_horizon/Dialog-parameters.css +11 -0
  1141. package/src/themes/sap_horizon/GrowingButton-parameters.css +5 -0
  1142. package/src/themes/sap_horizon/Input-parameters.css +35 -0
  1143. package/src/themes/sap_horizon/InputIcon-parameters.css +17 -0
  1144. package/src/themes/sap_horizon/Link-parameters.css +10 -0
  1145. package/src/themes/sap_horizon/List-parameters.css +5 -0
  1146. package/src/themes/sap_horizon/ListItemBase-parameters.css +6 -0
  1147. package/src/themes/sap_horizon/MessageStrip-parameters.css +9 -0
  1148. package/src/themes/sap_horizon/MonthPicker-parameters.css +17 -0
  1149. package/src/themes/sap_horizon/MultiComboBox-parameters.css +5 -0
  1150. package/src/themes/sap_horizon/Panel-parameters.css +12 -0
  1151. package/src/themes/sap_horizon/PopupsCommon-parameters.css +9 -0
  1152. package/src/themes/sap_horizon/ProgressIndicator-parameters.css +23 -0
  1153. package/src/themes/sap_horizon/RadioButton-parameters.css +9 -0
  1154. package/src/themes/sap_horizon/RatingIndicator-parameters.css +3 -0
  1155. package/src/themes/sap_horizon/SegmentedButtton-parameters.css +10 -0
  1156. package/src/themes/sap_horizon/Select-parameters.css +5 -0
  1157. package/src/themes/sap_horizon/SelectPopover-parameters.css +4 -0
  1158. package/src/themes/sap_horizon/SliderBase-parameters.css +44 -0
  1159. package/src/themes/sap_horizon/StepInput-parameters.css +25 -0
  1160. package/src/themes/sap_horizon/Suggestions-parameters.css +5 -0
  1161. package/src/themes/sap_horizon/Switch-parameters.css +31 -0
  1162. package/src/themes/sap_horizon/TabContainer-parameters.css +25 -0
  1163. package/src/themes/sap_horizon/Table-parameters.css +8 -0
  1164. package/src/themes/sap_horizon/TableColumn-parameters.css +5 -0
  1165. package/src/themes/sap_horizon/TableRow-parameters.css +5 -0
  1166. package/src/themes/sap_horizon/TextArea-parameters.css +22 -0
  1167. package/src/themes/sap_horizon/TimePicker-parameters.css +6 -0
  1168. package/src/themes/sap_horizon/ToggleButton-parameters.css +11 -0
  1169. package/src/themes/sap_horizon/Token-parameters.css +28 -0
  1170. package/src/themes/sap_horizon/Tokenizer-parameters.css +6 -0
  1171. package/src/themes/sap_horizon/ValueStateMessage-parameters.css +8 -0
  1172. package/src/themes/sap_horizon/WheelSlider-parameters.css +19 -0
  1173. package/src/themes/sap_horizon/YearPicker-parameters.css +16 -0
  1174. package/src/themes/sap_horizon/parameters-bundle.css +56 -0
  1175. package/src/themes/sap_horizon/sizes-parameters.css +8 -0
  1176. package/src/themes/sap_horizon_dark/Avatar-parameters.css +33 -0
  1177. package/src/themes/sap_horizon_dark/BusyIndicator-parameters.css +7 -0
  1178. package/src/themes/sap_horizon_dark/Button-parameters.css +20 -0
  1179. package/src/themes/sap_horizon_dark/CalendarHeader-parameters.css +19 -0
  1180. package/src/themes/sap_horizon_dark/Card-parameters.css +10 -0
  1181. package/src/themes/sap_horizon_dark/CheckBox-parameters.css +34 -0
  1182. package/src/themes/sap_horizon_dark/ColorPalette-parameters.css +16 -0
  1183. package/src/themes/sap_horizon_dark/ColorPicker-parameters.css +10 -0
  1184. package/src/themes/sap_horizon_dark/DatePicker-parameters.css +6 -0
  1185. package/src/themes/sap_horizon_dark/DayPicker-parameters.css +31 -0
  1186. package/src/themes/sap_horizon_dark/Dialog-parameters.css +11 -0
  1187. package/src/themes/sap_horizon_dark/GrowingButton-parameters.css +5 -0
  1188. package/src/themes/sap_horizon_dark/Input-parameters.css +35 -0
  1189. package/src/themes/sap_horizon_dark/InputIcon-parameters.css +17 -0
  1190. package/src/themes/sap_horizon_dark/Link-parameters.css +10 -0
  1191. package/src/themes/sap_horizon_dark/List-parameters.css +5 -0
  1192. package/src/themes/sap_horizon_dark/ListItemBase-parameters.css +7 -0
  1193. package/src/themes/sap_horizon_dark/MessageStrip-parameters.css +9 -0
  1194. package/src/themes/sap_horizon_dark/MonthPicker-parameters.css +17 -0
  1195. package/src/themes/sap_horizon_dark/MultiComboBox-parameters.css +5 -0
  1196. package/src/themes/sap_horizon_dark/Panel-parameters.css +12 -0
  1197. package/src/themes/sap_horizon_dark/PopupsCommon-parameters.css +10 -0
  1198. package/src/themes/sap_horizon_dark/ProgressIndicator-parameters.css +23 -0
  1199. package/src/themes/sap_horizon_dark/RadioButton-parameters.css +9 -0
  1200. package/src/themes/sap_horizon_dark/RatingIndicator-parameters.css +3 -0
  1201. package/src/themes/sap_horizon_dark/SegmentedButtton-parameters.css +10 -0
  1202. package/src/themes/sap_horizon_dark/Select-parameters.css +5 -0
  1203. package/src/themes/sap_horizon_dark/SelectPopover-parameters.css +4 -0
  1204. package/src/themes/sap_horizon_dark/SliderBase-parameters.css +44 -0
  1205. package/src/themes/sap_horizon_dark/StepInput-parameters.css +25 -0
  1206. package/src/themes/sap_horizon_dark/Suggestions-parameters.css +5 -0
  1207. package/src/themes/sap_horizon_dark/Switch-parameters.css +31 -0
  1208. package/src/themes/sap_horizon_dark/TabContainer-parameters.css +25 -0
  1209. package/src/themes/sap_horizon_dark/Table-parameters.css +8 -0
  1210. package/src/themes/sap_horizon_dark/TableColumn-parameters.css +5 -0
  1211. package/src/themes/sap_horizon_dark/TableRow-parameters.css +5 -0
  1212. package/src/themes/sap_horizon_dark/TextArea-parameters.css +22 -0
  1213. package/src/themes/sap_horizon_dark/TimePicker-parameters.css +6 -0
  1214. package/src/themes/sap_horizon_dark/ToggleButton-parameters.css +11 -0
  1215. package/src/themes/sap_horizon_dark/Token-parameters.css +28 -0
  1216. package/src/themes/sap_horizon_dark/Tokenizer-parameters.css +6 -0
  1217. package/src/themes/sap_horizon_dark/ValueStateMessage-parameters.css +8 -0
  1218. package/src/themes/sap_horizon_dark/WheelSlider-parameters.css +19 -0
  1219. package/src/themes/sap_horizon_dark/YearPicker-parameters.css +16 -0
  1220. package/src/themes/sap_horizon_dark/parameters-bundle.css +56 -0
  1221. package/src/themes/sap_horizon_dark/sizes-parameters.css +8 -0
  1222. package/src/themes/sap_horizon_exp/Badge-parameters.css +91 -0
  1223. package/src/themes/sap_horizon_exp/Button-parameters.css +12 -0
  1224. package/src/themes/sap_horizon_exp/CalendarHeader-parameters.css +8 -0
  1225. package/src/themes/sap_horizon_exp/CheckBox-parameters.css +35 -0
  1226. package/src/themes/sap_horizon_exp/DatePicker-parameters.css +5 -0
  1227. package/src/themes/sap_horizon_exp/DayPicker-parameters.css +6 -0
  1228. package/src/themes/sap_horizon_exp/Input-parameters.css +46 -0
  1229. package/src/themes/sap_horizon_exp/InputIcon-parameters.css +9 -0
  1230. package/src/themes/sap_horizon_exp/Link-parameters.css +7 -0
  1231. package/src/themes/sap_horizon_exp/List-parameters.css +5 -0
  1232. package/src/themes/sap_horizon_exp/MonthPicker-parameters.css +5 -0
  1233. package/src/themes/sap_horizon_exp/MultiComboBox-parameters.css +7 -0
  1234. package/src/themes/sap_horizon_exp/Panel-parameters.css +6 -0
  1235. package/src/themes/sap_horizon_exp/Popover-parameters.css +5 -0
  1236. package/src/themes/sap_horizon_exp/RadioButton-parameters.css +30 -0
  1237. package/src/themes/sap_horizon_exp/Select-parameters.css +5 -0
  1238. package/src/themes/sap_horizon_exp/SliderBase-parameters.css +30 -0
  1239. package/src/themes/sap_horizon_exp/Switch-parameters.css +46 -0
  1240. package/src/themes/sap_horizon_exp/TabContainer-parameters.css +40 -0
  1241. package/src/themes/sap_horizon_exp/TimePicker-parameters.css +5 -0
  1242. package/src/themes/sap_horizon_exp/Token-parameters.css +9 -0
  1243. package/src/themes/sap_horizon_exp/WheelSlider-parameters.css +16 -0
  1244. package/src/themes/sap_horizon_exp/YearPicker-parameters.css +5 -0
  1245. package/src/themes/sap_horizon_exp/parameters-bundle.css +45 -0
  1246. package/src/themes/sap_horizon_hcb/Avatar-parameters.css +24 -0
  1247. package/src/themes/sap_horizon_hcb/Badge-parameters.css +43 -0
  1248. package/src/themes/sap_horizon_hcb/Button-parameters.css +10 -0
  1249. package/src/themes/sap_horizon_hcb/CalendarHeader-parameters.css +11 -0
  1250. package/src/themes/sap_horizon_hcb/Card-parameters.css +6 -0
  1251. package/src/themes/sap_horizon_hcb/Carousel-parameters.css +9 -0
  1252. package/src/themes/sap_horizon_hcb/CheckBox-parameters.css +13 -0
  1253. package/src/themes/sap_horizon_hcb/DatePicker-parameters.css +5 -0
  1254. package/src/themes/sap_horizon_hcb/DayPicker-parameters.css +17 -0
  1255. package/src/themes/sap_horizon_hcb/Dialog-parameters.css +7 -0
  1256. package/src/themes/sap_horizon_hcb/GrowingButton-parameters.css +8 -0
  1257. package/src/themes/sap_horizon_hcb/Input-parameters.css +21 -0
  1258. package/src/themes/sap_horizon_hcb/InputIcon-parameters.css +5 -0
  1259. package/src/themes/sap_horizon_hcb/Link-parameters.css +7 -0
  1260. package/src/themes/sap_horizon_hcb/MessageStrip-parameters.css +10 -0
  1261. package/src/themes/sap_horizon_hcb/MonthPicker-parameters.css +11 -0
  1262. package/src/themes/sap_horizon_hcb/Panel-parameters.css +5 -0
  1263. package/src/themes/sap_horizon_hcb/ProgressIndicator-parameters.css +11 -0
  1264. package/src/themes/sap_horizon_hcb/RadioButton-parameters.css +10 -0
  1265. package/src/themes/sap_horizon_hcb/Select-parameters.css +12 -0
  1266. package/src/themes/sap_horizon_hcb/SliderBase-parameters.css +14 -0
  1267. package/src/themes/sap_horizon_hcb/Switch-parameters.css +43 -0
  1268. package/src/themes/sap_horizon_hcb/TabContainer-parameters.css +44 -0
  1269. package/src/themes/sap_horizon_hcb/Table-parameters.css +5 -0
  1270. package/src/themes/sap_horizon_hcb/TableRow-parameters.css +5 -0
  1271. package/src/themes/sap_horizon_hcb/TextArea-parameters.css +10 -0
  1272. package/src/themes/sap_horizon_hcb/TimePicker-parameters.css +5 -0
  1273. package/src/themes/sap_horizon_hcb/ToggleButton-parameters.css +6 -0
  1274. package/src/themes/sap_horizon_hcb/Token-parameters.css +7 -0
  1275. package/src/themes/sap_horizon_hcb/ValueStateMessage-parameters.css +5 -0
  1276. package/src/themes/sap_horizon_hcb/WheelSlider-parameters.css +17 -0
  1277. package/src/themes/sap_horizon_hcb/YearPicker-parameters.css +11 -0
  1278. package/src/themes/sap_horizon_hcb/parameters-bundle.css +47 -0
  1279. package/src/themes/sap_horizon_hcw/Avatar-parameters.css +24 -0
  1280. package/src/themes/sap_horizon_hcw/Badge-parameters.css +43 -0
  1281. package/src/themes/sap_horizon_hcw/Button-parameters.css +10 -0
  1282. package/src/themes/sap_horizon_hcw/CalendarHeader-parameters.css +11 -0
  1283. package/src/themes/sap_horizon_hcw/Card-parameters.css +6 -0
  1284. package/src/themes/sap_horizon_hcw/Carousel-parameters.css +9 -0
  1285. package/src/themes/sap_horizon_hcw/CheckBox-parameters.css +13 -0
  1286. package/src/themes/sap_horizon_hcw/DatePicker-parameters.css +5 -0
  1287. package/src/themes/sap_horizon_hcw/DayPicker-parameters.css +17 -0
  1288. package/src/themes/sap_horizon_hcw/Dialog-parameters.css +7 -0
  1289. package/src/themes/sap_horizon_hcw/GrowingButton-parameters.css +8 -0
  1290. package/src/themes/sap_horizon_hcw/Input-parameters.css +21 -0
  1291. package/src/themes/sap_horizon_hcw/InputIcon-parameters.css +5 -0
  1292. package/src/themes/sap_horizon_hcw/Link-parameters.css +7 -0
  1293. package/src/themes/sap_horizon_hcw/MessageStrip-parameters.css +10 -0
  1294. package/src/themes/sap_horizon_hcw/MonthPicker-parameters.css +11 -0
  1295. package/src/themes/sap_horizon_hcw/Panel-parameters.css +5 -0
  1296. package/src/themes/sap_horizon_hcw/ProgressIndicator-parameters.css +11 -0
  1297. package/src/themes/sap_horizon_hcw/RadioButton-parameters.css +10 -0
  1298. package/src/themes/sap_horizon_hcw/Select-parameters.css +12 -0
  1299. package/src/themes/sap_horizon_hcw/SliderBase-parameters.css +13 -0
  1300. package/src/themes/sap_horizon_hcw/Switch-parameters.css +43 -0
  1301. package/src/themes/sap_horizon_hcw/TabContainer-parameters.css +44 -0
  1302. package/src/themes/sap_horizon_hcw/Table-parameters.css +5 -0
  1303. package/src/themes/sap_horizon_hcw/TableRow-parameters.css +5 -0
  1304. package/src/themes/sap_horizon_hcw/TextArea-parameters.css +10 -0
  1305. package/src/themes/sap_horizon_hcw/TimePicker-parameters.css +5 -0
  1306. package/src/themes/sap_horizon_hcw/ToggleButton-parameters.css +6 -0
  1307. package/src/themes/sap_horizon_hcw/Token-parameters.css +7 -0
  1308. package/src/themes/sap_horizon_hcw/ValueStateMessage-parameters.css +5 -0
  1309. package/src/themes/sap_horizon_hcw/WheelSlider-parameters.css +17 -0
  1310. package/src/themes/sap_horizon_hcw/YearPicker-parameters.css +11 -0
  1311. package/src/themes/sap_horizon_hcw/parameters-bundle.css +47 -0
  1312. package/src/timepicker-utils/TimeSlider.js +103 -0
  1313. package/src/types/AvatarColorScheme.js +104 -0
  1314. package/src/types/AvatarGroupType.js +43 -0
  1315. package/src/types/AvatarShape.js +41 -0
  1316. package/src/types/AvatarSize.js +67 -0
  1317. package/src/types/BreadcrumbsDesign.js +42 -0
  1318. package/src/types/BreadcrumbsSeparatorStyle.js +69 -0
  1319. package/src/types/BusyIndicatorSize.js +47 -0
  1320. package/src/types/ButtonDesign.js +68 -0
  1321. package/src/types/CalendarSelectionMode.js +47 -0
  1322. package/src/types/CarouselArrowsPlacement.js +40 -0
  1323. package/src/types/GrowingMode.js +48 -0
  1324. package/src/types/HasPopup.js +62 -0
  1325. package/src/types/InputType.js +68 -0
  1326. package/src/types/LinkDesign.js +47 -0
  1327. package/src/types/ListGrowingMode.js +48 -0
  1328. package/src/types/ListItemType.js +47 -0
  1329. package/src/types/ListMode.js +77 -0
  1330. package/src/types/ListSeparators.js +46 -0
  1331. package/src/types/MessageStripDesign.js +54 -0
  1332. package/src/types/PanelAccessibleRole.js +48 -0
  1333. package/src/types/PopoverHorizontalAlign.js +54 -0
  1334. package/src/types/PopoverPlacementType.js +54 -0
  1335. package/src/types/PopoverVerticalAlign.js +54 -0
  1336. package/src/types/Priority.js +55 -0
  1337. package/src/types/SemanticColor.js +61 -0
  1338. package/src/types/SwitchDesign.js +40 -0
  1339. package/src/types/TabContainerTabsPlacement.js +40 -0
  1340. package/src/types/TabLayout.js +40 -0
  1341. package/src/types/TableGrowingMode.js +48 -0
  1342. package/src/types/TableMode.js +47 -0
  1343. package/src/types/TableRowType.js +40 -0
  1344. package/src/types/TabsOverflowMode.js +40 -0
  1345. package/src/types/TitleLevel.js +68 -0
  1346. package/src/types/ToastPlacement.js +91 -0
  1347. package/src/types/WrappingType.js +41 -0
  1348. package/dist/Timeline.js +0 -82
  1349. package/dist/TimelineItem.js +0 -161
  1350. package/dist/generated/templates/ComboBoxItemTemplate.lit.js +0 -7
  1351. package/dist/generated/templates/TabSeparatorTemplate.lit.js +0 -7
  1352. package/dist/generated/templates/TimelineItemTemplate.lit.js +0 -12
  1353. package/dist/generated/templates/TimelineTemplate.lit.js +0 -8
  1354. package/dist/generated/themes/ComboBoxItem.css.js +0 -9
  1355. package/dist/generated/themes/TabContainerPopup.css.js +0 -9
  1356. package/dist/generated/themes/Timeline.css.js +0 -9
  1357. package/dist/generated/themes/TimelineItem.css.js +0 -9
  1358. package/dist/popup-utils/PopupUtils.js +0 -55
  1359. package/dist/types/AvatarFitType.js +0 -40
  1360. package/dist/webcomponentsjs/package.json +0 -46
@@ -1,28 +1,65 @@
1
1
  import UI5Element from "@ui5/webcomponents-base/dist/UI5Element.js";
2
2
  import litRender from "@ui5/webcomponents-base/dist/renderer/LitRenderer.js";
3
+ import ResizeHandler from "@ui5/webcomponents-base/dist/delegate/ResizeHandler.js";
3
4
  import ValueState from "@ui5/webcomponents-base/dist/types/ValueState.js";
4
5
  import {
5
- isShow, isDown, isBackSpace, isSpace,
6
- } from "@ui5/webcomponents-base/dist/events/PseudoEvents.js";
7
- import "@ui5/webcomponents-icons/dist/icons/slim-arrow-down.js";
8
- import { getRTL } from "@ui5/webcomponents-base/dist/config/RTL.js";
6
+ isShow,
7
+ isDown,
8
+ isUp,
9
+ isSpace,
10
+ isSpaceCtrl,
11
+ isSpaceShift,
12
+ isRight,
13
+ isHome,
14
+ isEnd,
15
+ isTabNext,
16
+ isTabPrevious,
17
+ isUpShift,
18
+ isDownShift,
19
+ isLeftCtrl,
20
+ isRightCtrl,
21
+ isUpCtrl,
22
+ isDownCtrl,
23
+ isHomeCtrl,
24
+ isEndCtrl,
25
+ isCtrlA,
26
+ isCtrlV,
27
+ isDeleteShift,
28
+ isInsertShift,
29
+ isInsertCtrl,
30
+ } from "@ui5/webcomponents-base/dist/Keys.js";
31
+ import Integer from "@ui5/webcomponents-base/dist/types/Integer.js";
32
+ import "@ui5/webcomponents-icons/dist/slim-arrow-down.js";
9
33
  import { isIE, isPhone } from "@ui5/webcomponents-base/dist/Device.js";
10
- import { fetchI18nBundle, getI18nBundle } from "@ui5/webcomponents-base/dist/i18nBundle.js";
34
+ import { getI18nBundle } from "@ui5/webcomponents-base/dist/i18nBundle.js";
35
+ import "@ui5/webcomponents-icons/dist/decline.js";
36
+ import "@ui5/webcomponents-icons/dist/multiselect-all.js";
37
+ import "@ui5/webcomponents-icons/dist/not-editable.js";
38
+ import "@ui5/webcomponents-icons/dist/error.js";
39
+ import "@ui5/webcomponents-icons/dist/alert.js";
40
+ import "@ui5/webcomponents-icons/dist/sys-enter-2.js";
41
+ import "@ui5/webcomponents-icons/dist/information.js";
42
+ import MultiComboBoxItem from "./MultiComboBoxItem.js";
11
43
  import Tokenizer from "./Tokenizer.js";
12
44
  import Token from "./Token.js";
13
45
  import Icon from "./Icon.js";
46
+ import Popover from "./Popover.js";
14
47
  import ResponsivePopover from "./ResponsivePopover.js";
15
48
  import List from "./List.js";
16
49
  import StandardListItem from "./StandardListItem.js";
17
50
  import ToggleButton from "./ToggleButton.js";
51
+ import * as Filters from "./ComboBoxFilters.js";
52
+ import Button from "./Button.js";
53
+
18
54
  import {
19
55
  VALUE_STATE_SUCCESS,
20
56
  VALUE_STATE_ERROR,
21
57
  VALUE_STATE_WARNING,
22
- TOKENIZER_ARIA_CONTAIN_TOKEN,
23
- TOKENIZER_ARIA_CONTAIN_ONE_TOKEN,
24
- TOKENIZER_ARIA_CONTAIN_SEVERAL_TOKENS,
58
+ VALUE_STATE_INFORMATION,
25
59
  INPUT_SUGGESTIONS_TITLE,
60
+ SELECT_OPTIONS,
61
+ MULTICOMBOBOX_DIALOG_OK_BUTTON,
62
+ VALUE_STATE_ERROR_ALREADY_SELECTED,
26
63
  } from "./generated/i18n/i18n-defaults.js";
27
64
 
28
65
  // Templates
@@ -32,37 +69,62 @@ import MultiComboBoxPopoverTemplate from "./generated/templates/MultiComboBoxPop
32
69
  // Styles
33
70
  import styles from "./generated/themes/MultiComboBox.css.js";
34
71
  import ResponsivePopoverCommonCss from "./generated/themes/ResponsivePopoverCommon.css.js";
72
+ import ValueStateMessageCss from "./generated/themes/ValueStateMessage.css.js";
73
+ import SuggestionsCss from "./generated/themes/Suggestions.css.js";
35
74
 
36
75
  /**
37
76
  * @public
38
77
  */
39
78
  const metadata = {
40
79
  tag: "ui5-multi-combobox",
80
+ languageAware: true,
41
81
  managedSlots: true,
42
82
  slots: /** @lends sap.ui.webcomponents.main.MultiComboBox.prototype */ {
43
83
  /**
44
- * Defines the <code>ui5-multi-combobox</code> items.
84
+ * Defines the component items.
85
+ *
86
+ * @type {sap.ui.webcomponents.main.IMultiComboBoxItem[]}
87
+ * @slot items
88
+ * @public
89
+ */
90
+ "default": {
91
+ propertyName: "items",
92
+ type: HTMLElement,
93
+ invalidateOnChildChange: true,
94
+ },
95
+
96
+ /**
97
+ * Defines the icon to be displayed in the component.
98
+ *
99
+ * @type {sap.ui.webcomponents.main.IIcon}
100
+ * @slot
101
+ * @public
102
+ * @since 1.0.0-rc.9
103
+ */
104
+ icon: {
105
+ type: HTMLElement,
106
+ },
107
+
108
+ /**
109
+ * Defines the value state message that will be displayed as pop up under the component.
45
110
  * <br><br>
46
- * Example: <br>
47
- * &lt;ui5-multi-combobox><br>
48
- * &nbsp;&nbsp;&nbsp;&nbsp;&lt;ui5-li>Item #1&lt;/ui5-li><br>
49
- * &nbsp;&nbsp;&nbsp;&nbsp;&lt;ui5-li>Item #2&lt;/ui5-li><br>
50
- * &lt;/ui5-multi-combobox>
51
- * <br> <br>
52
111
  *
112
+ * <b>Note:</b> If not specified, a default text (in the respective language) will be displayed.
113
+ * <br>
114
+ * <b>Note:</b> The <code>valueStateMessage</code> would be displayed,
115
+ * when the component is in <code>Information</code>, <code>Warning</code> or <code>Error</code> value state.
53
116
  * @type {HTMLElement[]}
117
+ * @since 1.0.0-rc.9
54
118
  * @slot
55
119
  * @public
56
120
  */
57
- "default": {
58
- propertyName: "items",
121
+ valueStateMessage: {
59
122
  type: HTMLElement,
60
- listenFor: { include: ["*"] },
61
123
  },
62
124
  },
63
125
  properties: /** @lends sap.ui.webcomponents.main.MultiComboBox.prototype */ {
64
126
  /**
65
- * Defines the value of the <code>ui5-multi-combobox</code>.
127
+ * Defines the value of the component.
66
128
  * <br><br>
67
129
  * <b>Note:</b> The property is updated upon typing.
68
130
  *
@@ -77,7 +139,7 @@ const metadata = {
77
139
 
78
140
  /**
79
141
  * Defines a short hint intended to aid the user with data entry when the
80
- * <code>ui5-multi-combobox</code> has no value.
142
+ * component has no value.
81
143
  * @type {string}
82
144
  * @defaultvalue ""
83
145
  * @public
@@ -99,9 +161,9 @@ const metadata = {
99
161
  },
100
162
 
101
163
  /**
102
- * Defines whether <code>ui5-multi-combobox</code> is in disabled state.
164
+ * Defines whether the component is in disabled state.
103
165
  * <br><br>
104
- * <b>Note:</b> A disabled <code>ui5-multi-combobox</code> is completely noninteractive.
166
+ * <b>Note:</b> A disabled component is completely noninteractive.
105
167
  *
106
168
  * @type {boolean}
107
169
  * @defaultvalue false
@@ -112,10 +174,18 @@ const metadata = {
112
174
  },
113
175
 
114
176
  /**
115
- * Defines the value state of the <code>ui5-multi-combobox</code>.
116
- * Available options are: <code>None</code>, <code>Success</code>, <code>Warning</code>, and <code>Error</code>.
177
+ * Defines the value state of the component.
178
+ * <br><br>
179
+ * Available options are:
180
+ * <ul>
181
+ * <li><code>None</code></li>
182
+ * <li><code>Error</code></li>
183
+ * <li><code>Warning</code></li>
184
+ * <li><code>Success</code></li>
185
+ * <li><code>Information</code></li>
186
+ * </ul>
117
187
  *
118
- * @type {string}
188
+ * @type {ValueState}
119
189
  * @defaultvalue "None"
120
190
  * @public
121
191
  */
@@ -125,9 +195,9 @@ const metadata = {
125
195
  },
126
196
 
127
197
  /**
128
- * Defines whether the <code>ui5-multi-combobox</code> is read-only.
198
+ * Defines whether the component is read-only.
129
199
  * <br><br>
130
- * <b>Note:</b> A read-only <code>ui5-multi-combobox</code> is not editable,
200
+ * <b>Note:</b> A read-only component is not editable,
131
201
  * but still provides visual feedback upon user interaction.
132
202
  *
133
203
  * @type {boolean}
@@ -139,7 +209,7 @@ const metadata = {
139
209
  },
140
210
 
141
211
  /**
142
- * Defines whether the <code>ui5-multi-combobox</code> is required.
212
+ * Defines whether the component is required.
143
213
  *
144
214
  * @type {boolean}
145
215
  * @defaultvalue false
@@ -150,11 +220,25 @@ const metadata = {
150
220
  type: Boolean,
151
221
  },
152
222
 
223
+ /**
224
+ * Defines the filter type of the component.
225
+ * Available options are: <code>StartsWithPerTerm</code>, <code>StartsWith</code>, <code>Contains</code> and <code>None</code>.
226
+ *
227
+ * @type {string}
228
+ * @defaultvalue "StartsWithPerTerm"
229
+ * @public
230
+ */
231
+ filter: {
232
+ type: String,
233
+ defaultValue: "StartsWithPerTerm",
234
+ },
235
+
153
236
  /**
154
237
  * Indicates whether the dropdown is open. True if the dropdown is open, false otherwise.
155
238
  *
156
239
  * @type {boolean}
157
240
  * @defaultvalue false
241
+ * @readonly
158
242
  * @since 1.0.0-rc.5
159
243
  * @public
160
244
  */
@@ -162,16 +246,20 @@ const metadata = {
162
246
  type: Boolean,
163
247
  },
164
248
 
165
- /**
166
- * Indicates whether the input is focssed
167
- * @private
168
- */
249
+ _filteredItems: {
250
+ type: Object,
251
+ },
252
+
253
+ filterSelected: {
254
+ type: Boolean,
255
+ },
256
+
169
257
  focused: {
170
258
  type: Boolean,
171
259
  },
172
260
 
173
- _filteredItems: {
174
- type: Object,
261
+ _tokenizerFocused: {
262
+ type: Boolean,
175
263
  },
176
264
 
177
265
  _iconPressed: {
@@ -179,11 +267,18 @@ const metadata = {
179
267
  noAttribute: true,
180
268
  },
181
269
 
182
- /**
183
- * Indicates whether the tokenizer is expanded or collapsed(shows the n more label)
184
- * @private
185
- */
186
- expandedTokenizer: {
270
+ _inputWidth: {
271
+ type: Integer,
272
+ noAttribute: true,
273
+ },
274
+
275
+ _listWidth: {
276
+ type: Integer,
277
+ defaultValue: 0,
278
+ noAttribute: true,
279
+ },
280
+
281
+ _performingSelectionTwice: {
187
282
  type: Boolean,
188
283
  },
189
284
  },
@@ -197,7 +292,7 @@ const metadata = {
197
292
  change: {},
198
293
 
199
294
  /**
200
- * Fired when the value of the <code>ui5-multi-combobox</code> changes at each keystroke.
295
+ * Fired when the value of the component changes at each keystroke.
201
296
  *
202
297
  * @event
203
298
  * @public
@@ -207,21 +302,21 @@ const metadata = {
207
302
  /**
208
303
  * Fired when the dropdown is opened or closed.
209
304
  *
210
- * @event
305
+ * @event sap.ui.webcomponents.main.MultiComboBox#open-change
211
306
  * @since 1.0.0-rc.5
212
307
  * @public
213
308
  */
214
- openChange: {},
309
+ "open-change": {},
215
310
 
216
311
  /**
217
312
  * Fired when selection is changed by user interaction
218
313
  * in <code>SingleSelect</code> and <code>MultiSelect</code> modes.
219
314
  *
220
- * @event
315
+ * @event sap.ui.webcomponents.main.MultiComboBox#selection-change
221
316
  * @param {Array} items an array of the selected items.
222
317
  * @public
223
318
  */
224
- selectionChange: {
319
+ "selection-change": {
225
320
  detail: {
226
321
  items: { type: Array },
227
322
  },
@@ -234,10 +329,10 @@ const metadata = {
234
329
  *
235
330
  * <h3 class="comment-api-title">Overview</h3>
236
331
  *
237
- * The <code>ui5-multi-combobox</code> component provides a list box with items and a text field allowing the user to either type a value directly into the control, or choose from the list of existing items.
332
+ * The <code>ui5-multi-combobox</code> component consists of a list box with items and a text field allowing the user to either type a value directly into the text field, or choose from the list of existing items.
238
333
  *
239
- * It is a drop-down list for selecting and filtering values, commonly used to enable users to select one or more options from a predefined list. The control provides an editable input field to filter the list, and a dropdown arrow of available options.
240
- * The select options in the list have checkboxes that permit multi-selection. Entered values are displayed as tokens.
334
+ * The drop-down list is used for selecting and filtering values, it enables users to select one or more options from a predefined list. The control provides an editable input field to filter the list, and a dropdown arrow to expand/collapse the list of available options.
335
+ * The options in the list have checkboxes that permit multi-selection. Entered values are displayed as tokens.
241
336
  * <h3>Structure</h3>
242
337
  * The <code>ui5-multi-combobox</code> consists of the following elements:
243
338
  * <ul>
@@ -264,6 +359,15 @@ const metadata = {
264
359
  * <li> Backspace - deletes the token and focus the next token. </li>
265
360
  * </ul>
266
361
  *
362
+ * <h3>CSS Shadow Parts</h3>
363
+ *
364
+ * <ui5-link target="_blank" href="https://developer.mozilla.org/en-US/docs/Web/CSS/::part">CSS Shadow Parts</ui5-link> allow developers to style elements inside the Shadow DOM.
365
+ * <br>
366
+ * The <code>ui5-multi-combobox</code> exposes the following CSS Shadow Parts:
367
+ * <ul>
368
+ * <li>token-{index} - Used to style each token(where <code>token-0</code> corresponds to the first item)</li>
369
+ * </ul>
370
+ *
267
371
  * <h3>ES6 Module Import</h3>
268
372
  *
269
373
  * <code>import "@ui5/webcomponents/dist/MultiComboBox";</code>
@@ -300,47 +404,76 @@ class MultiComboBox extends UI5Element {
300
404
  }
301
405
 
302
406
  static get staticAreaStyles() {
303
- return ResponsivePopoverCommonCss;
407
+ return [ResponsivePopoverCommonCss, ValueStateMessageCss, SuggestionsCss];
408
+ }
409
+
410
+ static get dependencies() {
411
+ return [
412
+ MultiComboBoxItem,
413
+ Tokenizer,
414
+ Token,
415
+ Icon,
416
+ ResponsivePopover,
417
+ Popover,
418
+ List,
419
+ StandardListItem,
420
+ ToggleButton,
421
+ Button,
422
+ ];
304
423
  }
305
424
 
306
425
  constructor() {
307
426
  super();
308
427
 
309
428
  this._filteredItems = [];
429
+ this.selectedValues = [];
310
430
  this._inputLastValue = "";
431
+ this._valueBeforeOpen = "";
311
432
  this._deleting = false;
312
433
  this._validationTimeout = null;
313
- this._selectedItemsPopoverOpened = false;
314
- this.i18nBundle = getI18nBundle("@ui5/webcomponents");
434
+ this._handleResizeBound = this._handleResize.bind(this);
435
+ this.currentItemIdx = -1;
436
+ }
437
+
438
+ onEnterDOM() {
439
+ ResizeHandler.register(this, this._handleResizeBound);
440
+ }
441
+
442
+ onExitDOM() {
443
+ ResizeHandler.deregister(this, this._handleResizeBound);
444
+ }
445
+
446
+ _handleResize() {
447
+ this._inputWidth = this.offsetWidth;
315
448
  }
316
449
 
317
450
  _inputChange() {
318
451
  this.fireEvent("change");
319
452
  }
320
453
 
321
- _showMorePopover() {
322
- if (this.readonly) {
323
- return;
324
- }
454
+ togglePopover() {
455
+ this.allItemsPopover.toggle(this);
456
+ }
325
457
 
326
- this._showMorePressed = true;
327
- this._selectedItemsPopoverOpened = true;
328
- this._toggleRespPopover(true);
458
+ togglePopoverByDropdownIcon() {
459
+ this._shouldFilterItems = false;
460
+ this.allItemsPopover.toggle(this);
329
461
  }
330
462
 
331
- _showAllItemsPopover() {
332
- this._selectedItemsPopoverOpened = false;
333
- this._toggleRespPopover(false);
463
+ _showFilteredItems() {
464
+ this.filterSelected = true;
465
+ this._showMorePressed = true;
334
466
 
335
- this._inputDom.focus();
467
+ this.togglePopover();
336
468
  }
337
469
 
338
- _closeMorePopover() {
339
- this._getRespPopover(true).close();
470
+ filterSelectedItems(event) {
471
+ this.filterSelected = event.target.pressed;
472
+ this.selectedItems = this._filteredItems.filter(item => item.selected);
340
473
  }
341
474
 
342
- _closeAllItemsPopover() {
343
- this._getRespPopover().close();
475
+ get _showAllItemsButtonPressed() {
476
+ return this.filterSelected;
344
477
  }
345
478
 
346
479
  get _inputDom() {
@@ -353,11 +486,17 @@ class MultiComboBox extends UI5Element {
353
486
  const filteredItems = this._filterItems(value);
354
487
  const oldValueState = this.valueState;
355
488
 
489
+ this._shouldFilterItems = true;
490
+
491
+ if (this.filterSelected) {
492
+ this.filterSelected = false;
493
+ }
494
+
356
495
  /* skip calling change event when an input with a placeholder is focused on IE
357
496
  - value of the host and the internal input should be differnt in case of actual input
358
497
  - input is called when a key is pressed => keyup should not be called yet
359
498
  */
360
- const skipFiring = (this._inputDom.value === this.value) && isIE && !this._keyDown && !!this.placeholder;
499
+ const skipFiring = (this._inputDom.value === this.value) && isIE() && !this._keyDown && !!this.placeholder;
361
500
 
362
501
  if (skipFiring) {
363
502
  event.preventDefault();
@@ -374,25 +513,20 @@ class MultiComboBox extends UI5Element {
374
513
  input.value = this._inputLastValue;
375
514
  this.valueState = "Error";
376
515
 
377
- this._validationTimeout = setTimeout(() => {
378
- this.valueState = oldValueState;
379
- this._validationTimeout = null;
380
- }, 2000);
516
+ this._resetValueState(oldValueState);
381
517
 
382
518
  return;
383
519
  }
384
520
 
385
-
386
521
  this._inputLastValue = input.value;
387
522
  this.value = input.value;
388
523
  this._filteredItems = filteredItems;
389
524
 
390
525
  if (!isPhone()) {
391
526
  if (filteredItems.length === 0) {
392
- this._getRespPopover().close();
527
+ this.allItemsPopover.close();
393
528
  } else {
394
- this.updateStaticAreaItemContentDensity();
395
- this._getRespPopover().open(this);
529
+ this.allItemsPopover.showAt(this);
396
530
  }
397
531
  }
398
532
 
@@ -406,261 +540,913 @@ class MultiComboBox extends UI5Element {
406
540
  deletingItem.selected = false;
407
541
  this._deleting = true;
408
542
 
409
- this.fireEvent("selectionChange", { items: this._getSelectedItems() });
543
+ this.fireSelectionChange();
544
+ }
545
+
546
+ get _getPlaceholder() {
547
+ if (this._tokenizer && this._tokenizer.tokens.length) {
548
+ return "";
549
+ }
550
+
551
+ return this.placeholder;
552
+ }
553
+
554
+ _handleArrowLeft() {
555
+ const cursorPosition = this.getDomRef().querySelector(`input`).selectionStart;
556
+ const isTextSelected = this.getDomRef().querySelector(`input`).selectionEnd - cursorPosition > 0;
557
+
558
+ if (cursorPosition === 0 && !isTextSelected) {
559
+ this._tokenizer._focusLastToken();
560
+ }
410
561
  }
411
562
 
412
- _tokenizerFocusOut() {
413
- const tokenizer = this.shadowRoot.querySelector("ui5-tokenizer");
414
- const tokensCount = tokenizer.tokens.length - 1;
563
+ _tokenizerFocusOut(event) {
564
+ this._tokenizerFocused = false;
415
565
 
416
- tokenizer.tokens.forEach(token => { token.selected = false; });
566
+ const tokensCount = this._tokenizer.tokens.length;
567
+ const selectedTokens = this._selectedTokensCount;
568
+ const lastTokenBeingDeleted = tokensCount - 1 === 0 && this._deleting;
569
+ const allTokensAreBeingDeleted = selectedTokens === tokensCount && this._deleting;
417
570
 
418
- if (tokensCount === 0 && this._deleting) {
571
+ if (!event.relatedTarget || !event.relatedTarget.hasAttribute("ui5-token")) {
572
+ this._tokenizer.tokens.forEach(token => { token.selected = false; });
573
+ this._tokenizer.scrollToStart();
574
+ }
575
+
576
+ if (allTokensAreBeingDeleted || lastTokenBeingDeleted) {
419
577
  setTimeout(() => {
420
- this.shadowRoot.querySelector("input").focus();
578
+ if (!isPhone()) {
579
+ this.shadowRoot.querySelector("input").focus();
580
+ }
581
+
421
582
  this._deleting = false;
422
583
  }, 0);
423
584
  }
424
585
  }
425
586
 
587
+ _tokenizerFocusIn() {
588
+ this._tokenizerFocused = true;
589
+ this.focused = false;
590
+ }
591
+
426
592
  _onkeyup() {
427
593
  this._keyDown = false;
428
594
  }
429
595
 
430
- _onkeydown(event) {
431
- if (isShow(event) && !this.readonly && !this.disabled) {
596
+ async _onkeydown(event) {
597
+ const isArrowDownCtrl = isDownCtrl(event);
598
+
599
+ if (isShow(event) && !this.disabled) {
600
+ this._handleShow(event);
601
+ return;
602
+ }
603
+
604
+ if (isDownShift(event) || isUpShift(event)) {
432
605
  event.preventDefault();
433
- this._toggleRespPopover();
606
+ return;
434
607
  }
435
608
 
436
- if (isDown(event) && this._getRespPopover().opened && this.items.length) {
609
+ if (isUp(event) || isDown(event) || isUpCtrl(event) || isArrowDownCtrl) {
610
+ this._handleArrowNavigation(event, isArrowDownCtrl);
611
+ return;
612
+ }
613
+
614
+ // CTRL + Arrow Down navigation is performed by the ItemNavigation module of the List,
615
+ // here we only implement the text selection of the selected item
616
+ if (isArrowDownCtrl && !this.allItemsPopover.opened) {
617
+ setTimeout(() => this._inputDom.setSelectionRange(0, this._inputDom.value.length), 0);
618
+ }
619
+
620
+ if (isLeftCtrl(event) || isRightCtrl(event)) {
621
+ this._handleArrowCtrl(event);
622
+ return;
623
+ }
624
+
625
+ if (isCtrlV(event) || isInsertShift(event)) {
626
+ this._handlePaste(event);
627
+ return;
628
+ }
629
+
630
+ if (isSpaceShift(event)) {
437
631
  event.preventDefault();
438
- const list = this.getStaticAreaItemDomRef().querySelector(".ui5-multi-combobox-all-items-list");
439
- list._itemNavigation.current = 0;
440
- list.items[0].focus();
441
632
  }
442
633
 
443
- if (isBackSpace(event) && event.target.value === "") {
634
+ this._keyDown = true;
635
+ this[`_handle${event.key}`] && this[`_handle${event.key}`](event);
636
+ }
637
+
638
+ async _handlePaste(event) {
639
+ const pastedText = await navigator.clipboard.readText();
640
+
641
+ if (!pastedText) {
642
+ return;
643
+ }
644
+
645
+ const separatedText = pastedText.split(/\r\n|\r|\n/g);
646
+ const matchingItems = this.items.filter(item => separatedText.indexOf(item.text) > -1 && !item.selected);
647
+
648
+ if (matchingItems.length) {
649
+ matchingItems.forEach(item => {
650
+ item.selected = true;
651
+ this.value = "";
652
+ this.fireSelectionChange();
653
+ });
654
+ } else {
655
+ this.value = pastedText;
656
+ this.fireEvent("input");
657
+ }
658
+ }
659
+
660
+ _handleShow(event) {
661
+ const items = this.items;
662
+ const selectedItem = this._getSelectedItems()[0];
663
+ const focusedToken = this._tokenizer.tokens.find(token => token.focused);
664
+ const value = this.value;
665
+ const matchingItem = this.items.find(item => item.text.localeCompare(value, undefined, { sensitivity: "base" }) === 0);
666
+
667
+ event.preventDefault();
668
+
669
+ if (this.readonly) {
670
+ return;
671
+ }
672
+
673
+ this._isOpenedByKeyboard = true;
674
+ this._shouldFilterItems = false;
675
+ this._filteredItems = this.items;
676
+
677
+ this.togglePopover();
678
+
679
+ if (!focusedToken && matchingItem) {
680
+ this._itemToFocus = matchingItem;
681
+ return;
682
+ }
683
+
684
+ if (selectedItem && !focusedToken) {
685
+ this._itemToFocus = selectedItem;
686
+ } else if (focusedToken && event.target === focusedToken) {
687
+ this._itemToFocus = items.find(item => item.text === focusedToken.text);
688
+ } else {
689
+ this._itemToFocus = items[0];
690
+ }
691
+ }
692
+
693
+ _handlePageUp(event) {
694
+ event.preventDefault();
695
+ }
696
+
697
+ _handlePageDown(event) {
698
+ event.preventDefault();
699
+ }
700
+
701
+ _handleBackspace(event) {
702
+ if (event.target.value === "") {
444
703
  event.preventDefault();
704
+ this._tokenizer._focusLastToken();
705
+ }
706
+ }
445
707
 
446
- const lastTokenIndex = this._tokenizer.tokens.length - 1;
708
+ _handleEscape(event) {
709
+ if (!this.allowCustomValues || (!this.open && this.allowCustomValues)) {
710
+ this.value = this._lastValue;
711
+ }
712
+ }
447
713
 
448
- if (lastTokenIndex < 0) {
449
- return;
450
- }
714
+ _handleHome(event) {
715
+ const shouldFocusToken = this._isFocusInside && event.target.selectionStart === 0 && this._tokenizer.tokens.length > 0;
451
716
 
452
- this._tokenizer.tokens[lastTokenIndex].focus();
453
- this._tokenizer._itemNav.currentIndex = lastTokenIndex;
717
+ if (shouldFocusToken) {
718
+ event.preventDefault();
719
+ this._tokenizer.tokens[0].focus();
454
720
  }
721
+ }
455
722
 
456
- this._keyDown = true;
723
+ _handleEnd(event) {
724
+ const tokens = this._tokenizer.tokens;
725
+ const lastTokenIdx = tokens.length - 1;
726
+ const shouldFocusInput = event.target === tokens[lastTokenIdx] && tokens[lastTokenIdx] === this.shadowRoot.activeElement;
727
+
728
+ if (shouldFocusInput) {
729
+ event.preventDefault();
730
+ this._inputDom.focus();
731
+ }
457
732
  }
458
733
 
459
- _filterItems(value) {
460
- return this.items.filter(item => {
461
- return item.text && item.text.toLowerCase().startsWith(value.toLowerCase());
734
+ _handleTab(event) {
735
+ this.allItemsPopover.close();
736
+ }
737
+
738
+ _handleSelectAll(event) {
739
+ const filteredItems = this._filteredItems;
740
+ const allItemsSelected = filteredItems.every(item => item.selected);
741
+
742
+ filteredItems.forEach(item => {
743
+ item.selected = !allItemsSelected;
462
744
  });
745
+
746
+ this.fireSelectionChange();
463
747
  }
464
748
 
465
- _toggleIcon() {
466
- this._iconPressed = !this._iconPressed;
467
- this.open = this._iconPressed;
749
+ _onValueStateKeydown(event) {
750
+ const isArrowDown = isDown(event);
751
+ const isArrowUp = isUp(event);
752
+
753
+ if (isTabNext(event) || isTabPrevious(event)) {
754
+ this._onItemTab(event);
755
+ return;
756
+ }
468
757
 
469
- this.fireEvent("openChange");
758
+ event.preventDefault();
470
759
 
471
- if (!this._iconPressed) {
472
- this._afterClosePopover();
760
+ if (isArrowDown || isDownCtrl(event)) {
761
+ this._handleArrowDown(event);
762
+ }
763
+
764
+ if (isArrowUp || isUpCtrl(event)) {
765
+ this._inputDom.focus();
473
766
  }
474
767
  }
475
768
 
476
- _getSelectedItems() {
477
- return this.items.filter(item => item.selected);
769
+ async _onItemKeydown(event) {
770
+ const isFirstItem = this.list.items[0] === event.target;
771
+ const isArrowUp = isUp(event) || isUpCtrl(event);
772
+
773
+ if (this.hasValueStateMessage && !this.valueStateHeader) {
774
+ await this._setValueStateHeader();
775
+ }
776
+
777
+ if (isTabNext(event) || isTabPrevious(event)) {
778
+ this._onItemTab(event);
779
+ return;
780
+ }
781
+
782
+ if (isHomeCtrl(event)) {
783
+ this.list._itemNavigation._handleHome(event);
784
+ this.list.items[this.list._itemNavigation._currentIndex].focus();
785
+ }
786
+
787
+ if (isEndCtrl(event)) {
788
+ this.list._itemNavigation._handleEnd(event);
789
+ this.list.items[this.list._itemNavigation._currentIndex].focus();
790
+ }
791
+
792
+ event.preventDefault();
793
+
794
+ if (isDownShift(event) || isUpShift(event)) {
795
+ this._handleItemRangeSelection(event);
796
+ return;
797
+ }
798
+
799
+ if ((isUpCtrl(event)) && !isFirstItem) {
800
+ this.list._itemNavigation._handleUp(event);
801
+ this.list.items[this.list._itemNavigation._currentIndex].focus();
802
+ }
803
+
804
+ if (isDownCtrl(event)) {
805
+ this.list._itemNavigation._handleDown(event);
806
+ this.list.items[this.list._itemNavigation._currentIndex].focus();
807
+ }
808
+
809
+ if (isShow(event)) {
810
+ this.togglePopover();
811
+ }
812
+
813
+ if (isCtrlA(event)) {
814
+ this._handleSelectAll(event);
815
+ return;
816
+ }
817
+
818
+ if (((isArrowUp && isFirstItem) || isHome(event)) && this.valueStateHeader) {
819
+ this.valueStateHeader.focus();
820
+ }
821
+
822
+ if (!this.valueStateHeader && isFirstItem && isArrowUp) {
823
+ this._inputDom.focus();
824
+ }
478
825
  }
479
826
 
480
- _listSelectionChange(event) {
481
- event.target.items.forEach(item => {
482
- this.items.forEach(mcbItem => {
483
- if (mcbItem._id === item.getAttribute("data-ui5-token-id")) {
484
- mcbItem.selected = item.selected;
827
+ _handleArrowCtrl(event) {
828
+ const input = this._inputDom;
829
+ const isArrowLeft = isLeftCtrl(event);
830
+
831
+ if (isArrowLeft && input.selectionStart === 0 && input.selectionEnd === 0) {
832
+ event.preventDefault();
833
+ }
834
+
835
+ if (isArrowLeft && ((input.selectionEnd - input.selectionStart) > 0)) {
836
+ input.setSelectionRange(0, 0);
837
+ }
838
+ }
839
+
840
+ _onItemTab(event) {
841
+ this._inputDom.focus();
842
+ this.allItemsPopover.close();
843
+ }
844
+
845
+ async _handleArrowNavigation(event, isDownControl) {
846
+ const isArrowDown = isDownControl || isDown(event);
847
+ const hasSuggestions = this.items.length;
848
+ const isOpen = this.allItemsPopover.opened;
849
+
850
+ event.preventDefault();
851
+
852
+ if (this.hasValueStateMessage && !this.valueStateHeader) {
853
+ await this._setValueStateHeader();
854
+ }
855
+
856
+ if (isArrowDown && isOpen && this.valueStateHeader) {
857
+ this.valueStateHeader.focus();
858
+ return;
859
+ }
860
+
861
+ if (isArrowDown && hasSuggestions) {
862
+ this._handleArrowDown(event);
863
+ }
864
+
865
+ if (!isArrowDown && !isOpen && !this.readonly) {
866
+ this._navigateToPrevItem();
867
+ }
868
+ }
869
+
870
+ _handleArrowDown(event) {
871
+ const isOpen = this.allItemsPopover.opened;
872
+ const firstListItem = this.list.items[0];
873
+
874
+ if (isOpen) {
875
+ this.list._itemNavigation.setCurrentItem(firstListItem);
876
+ firstListItem.focus();
877
+ } else if (!this.readonly) {
878
+ this._navigateToNextItem();
879
+ }
880
+ }
881
+
882
+ _handleItemRangeSelection(event) {
883
+ const items = this.items;
884
+ const listItems = this.list.items;
885
+ const currentItemIdx = listItems.indexOf(event.target);
886
+ const nextItemIdx = currentItemIdx + 1;
887
+ const prevItemIdx = currentItemIdx - 1;
888
+
889
+ if (isDownShift(event) && items[nextItemIdx]) {
890
+ items[nextItemIdx].selected = items[currentItemIdx].selected;
891
+ items[nextItemIdx].focus();
892
+ }
893
+
894
+ if (isUpShift(event) && items[prevItemIdx]) {
895
+ items[prevItemIdx].selected = items[currentItemIdx].selected;
896
+ items[prevItemIdx].focus();
897
+ }
898
+
899
+ this.fireSelectionChange();
900
+ }
901
+
902
+ _navigateToNextItem() {
903
+ const items = this.items;
904
+ const itemsCount = items.length;
905
+ const previousItemIdx = this.currentItemIdx;
906
+
907
+ if (previousItemIdx > -1 && items[previousItemIdx].text !== this.value) {
908
+ this.currentItemIdx = -1;
909
+ }
910
+
911
+ if (previousItemIdx >= itemsCount - 1) {
912
+ return;
913
+ }
914
+
915
+ let currentItem = this.items[++this.currentItemIdx];
916
+
917
+ while (this.currentItemIdx < itemsCount - 1 && currentItem.selected) {
918
+ currentItem = this.items[++this.currentItemIdx];
919
+ }
920
+
921
+ if (currentItem.selected === true) {
922
+ this.currentItemIdx = previousItemIdx;
923
+ return;
924
+ }
925
+
926
+ this.value = currentItem.text;
927
+ this._innerInput.value = currentItem.text;
928
+ this._innerInput.setSelectionRange(0, currentItem.text.length);
929
+ }
930
+
931
+ _navigateToPrevItem() {
932
+ const items = this.items;
933
+ let previousItemIdx = this.currentItemIdx;
934
+
935
+ if ((!this.value && previousItemIdx !== -1) || (previousItemIdx !== -1 && this.value && this.value !== items[previousItemIdx].text)) {
936
+ previousItemIdx = -1;
937
+ }
938
+
939
+ if (previousItemIdx === -1) {
940
+ this.currentItemIdx = items.length;
941
+ }
942
+
943
+ if (previousItemIdx === 0) {
944
+ this.currentItemIdx = 0;
945
+ return;
946
+ }
947
+
948
+ let currentItem = this.items[--this.currentItemIdx];
949
+
950
+ while (currentItem && currentItem.selected && this.currentItemIdx > 0) {
951
+ currentItem = this.items[--this.currentItemIdx];
952
+ }
953
+
954
+ if (!currentItem) {
955
+ return;
956
+ }
957
+
958
+ if (currentItem.selected) {
959
+ this.currentItemIdx = previousItemIdx;
960
+ return;
961
+ }
962
+
963
+ this.value = currentItem.text;
964
+ this._innerInput.value = currentItem.text;
965
+ this._innerInput.setSelectionRange(0, currentItem.text.length);
966
+ }
967
+
968
+ _handleEnter() {
969
+ const lowerCaseValue = this.value.toLowerCase();
970
+ const matchingItem = this.items.find(item => item.text.toLowerCase() === lowerCaseValue);
971
+ const oldValueState = this.valueState;
972
+
973
+ if (matchingItem) {
974
+ if (matchingItem.selected) {
975
+ if (this._validationTimeout) {
976
+ return;
485
977
  }
486
- });
487
- });
488
978
 
489
- this.fireEvent("selectionChange", { items: this._getSelectedItems() });
979
+ this.valueState = "Error";
980
+ this._performingSelectionTwice = true;
981
+ this._resetValueState(oldValueState, () => {
982
+ this._performingSelectionTwice = false;
983
+ });
984
+ } else {
985
+ matchingItem.selected = true;
986
+ this.value = "";
987
+ this.fireSelectionChange();
988
+ }
490
989
 
491
- if (!event.detail.selectionComponentPressed && !isSpace(event.detail)) {
492
- this._getRespPopover().close();
493
- this.value = "";
494
- this.fireEvent("input");
990
+ this.allItemsPopover.close();
495
991
  }
496
992
  }
497
993
 
498
- _getRespPopover(isMorePopover) {
499
- return this.getStaticAreaItemDomRef().querySelector(`.ui5-multi-combobox-${isMorePopover ? "selected" : "all"}-items-responsive-popover`);
994
+ _resetValueState(valueState, callback) {
995
+ this._validationTimeout = setTimeout(() => {
996
+ this.valueState = valueState;
997
+ this._validationTimeout = null;
998
+
999
+ callback && callback();
1000
+ }, 2000);
500
1001
  }
501
1002
 
502
- _toggleRespPopover(isMorePopover) {
503
- const popover = this._getRespPopover(isMorePopover);
504
- const otherPopover = this._getRespPopover(!isMorePopover);
1003
+ _onTokenizerKeydown(event) {
1004
+ const isCtrl = !!(event.metaKey || event.ctrlKey);
505
1005
 
506
- this.updateStaticAreaItemContentDensity();
1006
+ if (isRight(event)) {
1007
+ const lastTokenIndex = this._tokenizer.tokens.length - 1;
507
1008
 
508
- if (popover && popover.opened) {
509
- return popover.close();
1009
+ if (event.target === this._tokenizer.tokens[lastTokenIndex]) {
1010
+ setTimeout(() => {
1011
+ this.shadowRoot.querySelector("input").focus();
1012
+ }, 0);
1013
+ }
510
1014
  }
511
1015
 
512
- otherPopover && otherPopover.close();
1016
+ if ((isCtrl && ["c", "x"].includes(event.key.toLowerCase())) || isDeleteShift(event) || isInsertCtrl(event)) {
1017
+ event.preventDefault();
1018
+
1019
+ const isCut = event.key.toLowerCase() === "x" || isDeleteShift(event);
1020
+ const selectedTokens = this._tokenizer.tokens.filter(token => token.selected);
513
1021
 
514
- popover && popover.open(this);
1022
+ if (isCut) {
1023
+ const cutResult = this._tokenizer._fillClipboard("cut", selectedTokens);
1024
+ selectedTokens.forEach(token => {
1025
+ this._tokenizer._tokenDelete(event, token);
1026
+ });
1027
+
1028
+ this.focus();
1029
+ return cutResult;
1030
+ }
1031
+ return this._tokenizer._fillClipboard("copy", selectedTokens);
1032
+ }
1033
+
1034
+ if (isCtrlV(event) || isInsertShift(event)) {
1035
+ this._handlePaste(event);
1036
+ }
1037
+
1038
+ if (isHome(event)) {
1039
+ this._handleHome(event);
1040
+ }
1041
+
1042
+ if (isEnd(event)) {
1043
+ this._handleEnd(event);
1044
+ }
1045
+
1046
+ if (isShow(event) && !this.readonly && !this.disabled) {
1047
+ this._handleShow(event);
1048
+ }
515
1049
  }
516
1050
 
517
- _focusin() {
518
- this.focused = true;
1051
+ _filterItems(str) {
1052
+ return (Filters[this.filter] || Filters.StartsWithPerTerm)(str, this.items);
519
1053
  }
520
1054
 
521
- _focusout() {
522
- this.focused = false;
1055
+ _afterOpenPicker() {
1056
+ this._toggle();
1057
+
1058
+ if (!isPhone() && !this._isOpenedByKeyboard) {
1059
+ this._innerInput.focus();
1060
+ } else if (this._isOpenedByKeyboard) {
1061
+ this._itemToFocus.focus();
1062
+ } else {
1063
+ this.allItemsPopover.focus();
1064
+ }
1065
+
1066
+ this._isOpenedByKeyboard = false;
1067
+ }
1068
+
1069
+ _toggle() {
1070
+ this.open = !this.open;
1071
+ this.fireEvent("open-change");
1072
+ }
1073
+
1074
+ _getSelectedItems() {
1075
+ // Angular 2 way data binding
1076
+ this.selectedValues = this.items.filter(item => item.selected);
1077
+ return this.selectedValues;
1078
+ }
1079
+
1080
+ _listSelectionChange(event) {
1081
+ // sync list items and cb items
1082
+ this.syncItems(event.target.items);
1083
+
1084
+ // don't call selection change right after selection as user can cancel it on phone
1085
+ if (!isPhone()) {
1086
+ this.fireSelectionChange();
1087
+ }
1088
+
1089
+ if (!event.detail.selectionComponentPressed && !isSpace(event.detail) && !isSpaceCtrl(event.detail)) {
1090
+ this.allItemsPopover.close();
1091
+ this.value = "";
1092
+
1093
+ // if the item (not checkbox) is clicked, call the selection change
1094
+ if (isPhone()) {
1095
+ this.fireSelectionChange();
1096
+ }
1097
+
1098
+ this.fireEvent("input");
1099
+ }
1100
+ }
1101
+
1102
+ syncItems(listItems) {
1103
+ listItems.forEach(item => {
1104
+ this.items.forEach(mcbItem => {
1105
+ if (mcbItem._id === item.getAttribute("data-ui5-token-id")) {
1106
+ mcbItem.selected = item.selected;
1107
+ }
1108
+ });
1109
+ });
1110
+ }
1111
+
1112
+ fireSelectionChange() {
1113
+ this.fireEvent("selection-change", { items: this._getSelectedItems() });
1114
+ // Angular 2 way data binding
1115
+ this.fireEvent("value-changed");
1116
+ }
1117
+
1118
+ async _getRespPopover() {
1119
+ const staticAreaItem = await this.getStaticAreaItemDomRef();
1120
+ this.allItemsPopover = staticAreaItem.querySelector(`.ui5-multi-combobox-all-items-responsive-popover`);
1121
+ }
1122
+
1123
+ async _getList() {
1124
+ const staticAreaItem = await this.getStaticAreaItemDomRef();
1125
+ this.list = staticAreaItem.querySelector(".ui5-multi-combobox-all-items-list");
523
1126
  }
524
1127
 
525
1128
  _click(event) {
526
- if (isPhone() && !this.readonly && !this._showMorePressed) {
527
- this.updateStaticAreaItemContentDensity();
528
- this._getRespPopover().open(this);
1129
+ if (isPhone() && !this.readonly && !this._showMorePressed && !this._deleting) {
1130
+ this.allItemsPopover.showAt(this);
529
1131
  }
530
1132
 
531
1133
  this._showMorePressed = false;
532
1134
  }
533
1135
 
534
- _afterClosePopover() {
1136
+ _afterClosePicker() {
535
1137
  // close device's keyboard and prevent further typing
536
1138
  if (isPhone()) {
537
1139
  this.blur();
538
1140
  }
1141
+
1142
+ this._toggle();
1143
+
1144
+ this._iconPressed = false;
1145
+ this.filterSelected = false;
539
1146
  }
540
1147
 
541
- _toggleButtonPress(event) {
542
- if (this._selectedItemsPopoverOpened) {
543
- event.target.pressed = true;
544
- this._showAllItemsPopover();
545
- } else {
546
- event.target.pressed = false;
547
- this._showMorePopover();
1148
+ _beforeOpen() {
1149
+ this._itemsBeforeOpen = this.items.map(item => {
1150
+ return {
1151
+ ref: item,
1152
+ selected: item.selected,
1153
+ };
1154
+ });
1155
+
1156
+ this._valueBeforeOpen = this.value;
1157
+
1158
+ if (this.filterSelected) {
1159
+ this.selectedItems = this._filteredItems.filter(item => item.selected);
548
1160
  }
549
1161
  }
550
1162
 
551
1163
  onBeforeRendering() {
1164
+ const input = this.shadowRoot.querySelector("input");
552
1165
  this._inputLastValue = this.value;
553
1166
 
554
- const hasSelectedItem = this.items.some(item => item.selected);
555
-
556
- if (this.getDomRef() && !hasSelectedItem) {
557
- const morePopover = this._getRespPopover(true);
558
-
559
- morePopover && morePopover.close();
1167
+ if (input && !input.value) {
1168
+ this._filteredItems = this.items;
560
1169
  }
561
1170
 
562
- const input = this.shadowRoot.querySelector("input");
1171
+ this.items.forEach(item => {
1172
+ item._getRealDomRef = () => this.allItemsPopover.querySelector(`*[data-ui5-stable=${item.stableDomRef}]`);
1173
+ });
563
1174
 
564
- if (input && !input.value) {
1175
+ if (this._shouldFilterItems) {
1176
+ this._filteredItems = this._filterItems(this.value);
1177
+ } else {
565
1178
  this._filteredItems = this.items;
566
1179
  }
1180
+ }
567
1181
 
568
- const filteredItems = this._filterItems(this.value);
569
- this._filteredItems = filteredItems;
1182
+ async onAfterRendering() {
1183
+ await this._getRespPopover();
1184
+ await this._getList();
1185
+
1186
+ this.toggle(this.shouldDisplayOnlyValueStateMessage);
1187
+ this.storeResponsivePopoverWidth();
1188
+
1189
+ this._deleting = false;
570
1190
  }
571
1191
 
572
- onAfterRendering() {
573
- if (this.open && !this._getRespPopover().opened) {
574
- this.updateStaticAreaItemContentDensity();
575
- this._getRespPopover().open(this);
576
- // Set initial focus to the native input
577
- this._innerInput.focus();
578
- }
1192
+ get _isPhone() {
1193
+ return isPhone();
579
1194
  }
580
1195
 
581
- get valueStateTextMappings() {
582
- return {
583
- "Success": this.i18nBundle.getText(VALUE_STATE_SUCCESS),
584
- "Error": this.i18nBundle.getText(VALUE_STATE_ERROR),
585
- "Warning": this.i18nBundle.getText(VALUE_STATE_WARNING),
586
- };
1196
+ _onIconMousedown() {
1197
+ this._iconPressed = true;
587
1198
  }
588
1199
 
589
- get _tokenizer() {
590
- return this.shadowRoot.querySelector("ui5-tokenizer");
1200
+ storeResponsivePopoverWidth() {
1201
+ if (this.open && !this._listWidth) {
1202
+ this._listWidth = this.list.offsetWidth;
1203
+ }
1204
+ }
1205
+
1206
+ toggle(isToggled) {
1207
+ if (isToggled && !this.open) {
1208
+ this.openPopover();
1209
+ } else {
1210
+ this.closePopover();
1211
+ }
591
1212
  }
592
1213
 
593
- get nMoreCountText() {
594
- const iTokenCount = this._getSelectedItems().length;
1214
+ handleCancel() {
1215
+ this._itemsBeforeOpen.forEach(item => {
1216
+ item.ref.selected = item.selected;
1217
+ });
1218
+
1219
+ this.togglePopover();
1220
+
1221
+ this.value = this._valueBeforeOpen;
1222
+ }
595
1223
 
596
- if (iTokenCount === 0) {
597
- return this.i18nBundle.getText(TOKENIZER_ARIA_CONTAIN_TOKEN);
1224
+ handleOK() {
1225
+ if (isPhone()) {
1226
+ this.fireSelectionChange();
598
1227
  }
599
1228
 
600
- if (iTokenCount === 1) {
601
- return this.i18nBundle.getText(TOKENIZER_ARIA_CONTAIN_ONE_TOKEN);
1229
+ this.togglePopover();
1230
+ }
1231
+
1232
+ async openPopover() {
1233
+ const popover = await this._getPopover();
1234
+
1235
+ if (popover) {
1236
+ popover.showAt(this);
602
1237
  }
1238
+ }
1239
+
1240
+ _forwardFocusToInner() {
1241
+ this._innerInput.focus();
1242
+ }
603
1243
 
604
- return this.i18nBundle.getText(TOKENIZER_ARIA_CONTAIN_SEVERAL_TOKENS, iTokenCount);
1244
+ async closePopover() {
1245
+ const popover = await this._getPopover();
1246
+
1247
+ popover && popover.close();
1248
+ }
1249
+
1250
+ async _getPopover() {
1251
+ const staticAreaItem = await this.getStaticAreaItemDomRef();
1252
+ return staticAreaItem.querySelector("[ui5-popover]");
605
1253
  }
606
1254
 
607
- rootFocusIn() {
608
- this.expandedTokenizer = true;
1255
+ async _getResponsivePopover() {
1256
+ const staticAreaItem = await this.getStaticAreaItemDomRef();
1257
+ return staticAreaItem.querySelector("[ui5-responsive-popover]");
609
1258
  }
610
1259
 
611
- rootFocusOut(event) {
1260
+ async _setValueStateHeader() {
1261
+ const responsivePopover = await this._getResponsivePopover();
1262
+ this.valueStateHeader = responsivePopover.querySelector("div.ui5-responsive-popover-header.ui5-valuestatemessage-root");
1263
+ }
1264
+
1265
+ get _tokenizer() {
1266
+ return this.shadowRoot.querySelector("[ui5-tokenizer]");
1267
+ }
1268
+
1269
+ inputFocusIn() {
1270
+ if (!isPhone() || this.readonly) {
1271
+ this.focused = true;
1272
+ } else {
1273
+ this._innerInput.blur();
1274
+ }
1275
+
1276
+ !isPhone() && this._innerInput.setSelectionRange(0, this.value.length);
1277
+ this._lastValue = this.value;
1278
+ }
1279
+
1280
+ inputFocusOut(event) {
612
1281
  if (!this.shadowRoot.contains(event.relatedTarget) && !this._deleting) {
613
- this.expandedTokenizer = false;
1282
+ this.focused = false;
1283
+
1284
+ // remove the value if user focus out the input and focus is not going in the popover
1285
+ if (!isPhone() && !this.allowCustomValues && (this.staticAreaItem !== event.relatedTarget)) {
1286
+ this.value = "";
1287
+ }
614
1288
  }
615
1289
  }
616
1290
 
1291
+ _readonlyIconClick() {
1292
+ this._inputDom.focus();
1293
+ }
1294
+
617
1295
  get editable() {
618
1296
  return !this.readonly;
619
1297
  }
620
1298
 
621
- get dir() {
622
- return getRTL() ? "rtl" : "ltr";
1299
+ get _isFocusInside() {
1300
+ return !isPhone() && (this.focused || this._tokenizerFocused);
623
1301
  }
624
1302
 
625
1303
  get selectedItemsListMode() {
626
1304
  return this.readonly ? "None" : "MultiSelect";
627
1305
  }
628
1306
 
1307
+ get _listItemsType() {
1308
+ return this.readonly ? "Inactive" : "Active";
1309
+ }
1310
+
629
1311
  get hasValueState() {
630
1312
  return this.valueState !== ValueState.None;
631
1313
  }
632
1314
 
1315
+ get hasValueStateMessage() {
1316
+ return this.hasValueState && this.valueState !== ValueState.Success;
1317
+ }
1318
+
633
1319
  get valueStateText() {
634
- return this.valueStateTextMappings[this.valueState];
1320
+ let key = this.valueState;
1321
+
1322
+ if (this._performingSelectionTwice) {
1323
+ key = "Error_Selection";
1324
+ }
1325
+
1326
+ return this.valueStateTextMappings[key];
1327
+ }
1328
+
1329
+ get valueStateTextId() {
1330
+ return this.hasValueState ? `${this._id}-valueStateDesc` : undefined;
1331
+ }
1332
+
1333
+ get valueStateMessageText() {
1334
+ return this.getSlottedNodes("valueStateMessage").map(el => el.cloneNode(true));
1335
+ }
1336
+
1337
+ /**
1338
+ * This method is relevant for sap_horizon theme only
1339
+ */
1340
+ get _valueStateMessageIcon() {
1341
+ const iconPerValueState = {
1342
+ Error: "error",
1343
+ Warning: "alert",
1344
+ Success: "sys-enter-2",
1345
+ Information: "information",
1346
+ };
1347
+
1348
+ return this.valueState !== ValueState.None ? iconPerValueState[this.valueState] : "";
1349
+ }
1350
+
1351
+ get _tokensCountText() {
1352
+ if (!this._tokenizer) {
1353
+ return;
1354
+ }
1355
+ return this._tokenizer._tokensCountText();
1356
+ }
1357
+
1358
+ get _tokensCountTextId() {
1359
+ return `${this._id}-hiddenText-nMore`;
1360
+ }
1361
+
1362
+ get _selectedTokensCount() {
1363
+ return this._tokenizer.tokens.filter(token => token.selected).length;
1364
+ }
1365
+
1366
+ get ariaDescribedByText() {
1367
+ return this.valueStateTextId ? `${this._tokensCountTextId} ${this.valueStateTextId}` : `${this._tokensCountTextId}`;
1368
+ }
1369
+
1370
+ get shouldDisplayDefaultValueStateMessage() {
1371
+ return !this.valueStateMessage.length && this.hasValueStateMessage;
1372
+ }
1373
+
1374
+ get shouldDisplayOnlyValueStateMessage() {
1375
+ return this.focused && !this.readonly && this.hasValueStateMessage && !this._iconPressed;
1376
+ }
1377
+
1378
+ get valueStateTextMappings() {
1379
+ return {
1380
+ "Success": MultiComboBox.i18nBundle.getText(VALUE_STATE_SUCCESS),
1381
+ "Error": MultiComboBox.i18nBundle.getText(VALUE_STATE_ERROR),
1382
+ "Error_Selection": MultiComboBox.i18nBundle.getText(VALUE_STATE_ERROR_ALREADY_SELECTED),
1383
+ "Warning": MultiComboBox.i18nBundle.getText(VALUE_STATE_WARNING),
1384
+ "Information": MultiComboBox.i18nBundle.getText(VALUE_STATE_INFORMATION),
1385
+ };
635
1386
  }
636
1387
 
637
1388
  get _innerInput() {
638
1389
  if (isPhone()) {
639
- if (this._getRespPopover().opened) {
640
- return this._getRespPopover().querySelector("input");
1390
+ if (this.allItemsPopover.opened) {
1391
+ return this.allItemsPopover.querySelector("input");
641
1392
  }
642
-
643
- return this._getRespPopover(true).querySelector("input");
644
1393
  }
645
1394
 
646
1395
  return this.getDomRef().querySelector("#ui5-multi-combobox-input");
647
1396
  }
648
1397
 
649
1398
  get _headerTitleText() {
650
- return this.i18nBundle.getText(INPUT_SUGGESTIONS_TITLE);
1399
+ return MultiComboBox.i18nBundle.getText(INPUT_SUGGESTIONS_TITLE);
1400
+ }
1401
+
1402
+ get _iconAccessibleNameText() {
1403
+ return MultiComboBox.i18nBundle.getText(SELECT_OPTIONS);
1404
+ }
1405
+
1406
+ get _dialogOkButton() {
1407
+ return MultiComboBox.i18nBundle.getText(MULTICOMBOBOX_DIALOG_OK_BUTTON);
1408
+ }
1409
+
1410
+ get _tokenizerExpanded() {
1411
+ return (this._isFocusInside || this.open) && !this.readonly;
1412
+ }
1413
+
1414
+ get _valueStatePopoverHorizontalAlign() {
1415
+ return this.effectiveDir !== "rtl" ? "Left" : "Right";
1416
+ }
1417
+
1418
+ get classes() {
1419
+ return {
1420
+ popover: {
1421
+ "ui5-multi-combobox-all-items-responsive-popover": true,
1422
+ "ui5-suggestions-popover": !this.isPhone,
1423
+ "ui5-suggestions-popover-with-value-state-header": !this.isPhone && this.hasValueStateMessage,
1424
+ },
1425
+ popoverValueState: {
1426
+ "ui5-valuestatemessage-root": true,
1427
+ "ui5-valuestatemessage-header": true,
1428
+ "ui5-valuestatemessage--success": this.valueState === ValueState.Success,
1429
+ "ui5-valuestatemessage--error": this.valueState === ValueState.Error,
1430
+ "ui5-valuestatemessage--warning": this.valueState === ValueState.Warning,
1431
+ "ui5-valuestatemessage--information": this.valueState === ValueState.Information,
1432
+ },
1433
+ };
1434
+ }
1435
+
1436
+ get styles() {
1437
+ return {
1438
+ popoverValueStateMessage: {
1439
+ "width": `${this._listWidth}px`,
1440
+ "display": this._listWidth === 0 ? "none" : "inline-block",
1441
+ },
1442
+ popoverHeader: {
1443
+ "max-width": isPhone() ? "100%" : `${this._inputWidth}px`,
1444
+ },
1445
+ };
651
1446
  }
652
1447
 
653
1448
  static async onDefine() {
654
- await Promise.all([
655
- Tokenizer.define(),
656
- Token.define(),
657
- Icon.define(),
658
- ResponsivePopover.define(),
659
- List.define(),
660
- StandardListItem.define(),
661
- ToggleButton,
662
- fetchI18nBundle("@ui5/webcomponents"),
663
- ]);
1449
+ MultiComboBox.i18nBundle = await getI18nBundle("@ui5/webcomponents");
664
1450
  }
665
1451
  }
666
1452