@ui5/webcomponents 0.0.0-934b4df24 → 0.0.0-a3eca7ade

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