@ui5/webcomponents 0.0.0-306572ffa → 0.0.0-3236d56be

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