@ui5/webcomponents 0.0.0-c6d8872f3 → 0.0.0-cf069fb29

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 (1237) hide show
  1. package/CHANGELOG.md +1049 -1
  2. package/README.md +144 -41
  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 +223 -37
  7. package/dist/AvatarGroup.js +603 -0
  8. package/dist/Badge.js +44 -22
  9. package/dist/Breadcrumbs.js +575 -0
  10. package/dist/BreadcrumbsItem.js +103 -0
  11. package/dist/BusyIndicator.js +171 -17
  12. package/dist/Button.js +179 -37
  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 +45 -158
  18. package/dist/CardHeader.js +288 -0
  19. package/dist/Carousel.js +454 -76
  20. package/dist/CheckBox.js +186 -51
  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 +524 -0
  25. package/dist/ComboBox.js +726 -104
  26. package/dist/ComboBoxFilters.js +8 -1
  27. package/dist/ComboBoxGroupItem.js +70 -0
  28. package/dist/ComboBoxItem.js +12 -24
  29. package/dist/CustomListItem.js +38 -9
  30. package/dist/DateComponentBase.js +168 -0
  31. package/dist/DatePicker.js +471 -376
  32. package/dist/DateRangePicker.js +350 -0
  33. package/dist/DateTimePicker.js +430 -0
  34. package/dist/DayPicker.js +509 -431
  35. package/dist/Dialog.js +481 -51
  36. package/dist/DurationPicker.js +312 -0
  37. package/dist/FileUploader.js +237 -32
  38. package/dist/GroupHeaderListItem.js +36 -8
  39. package/dist/Icon.js +202 -36
  40. package/dist/Input.js +884 -124
  41. package/dist/Interfaces.js +192 -0
  42. package/dist/Label.js +27 -12
  43. package/dist/Link.js +160 -32
  44. package/dist/List.js +530 -115
  45. package/dist/ListItem.js +139 -30
  46. package/dist/ListItemBase.js +52 -8
  47. package/dist/MessageStrip.js +95 -70
  48. package/dist/MonthPicker.js +180 -182
  49. package/dist/MultiComboBox.js +621 -195
  50. package/dist/MultiComboBoxItem.js +8 -5
  51. package/dist/MultiInput.js +348 -0
  52. package/dist/Option.js +59 -5
  53. package/dist/Panel.js +129 -37
  54. package/dist/Popover.js +378 -252
  55. package/dist/Popup.js +394 -282
  56. package/dist/ProgressIndicator.js +235 -0
  57. package/dist/RadioButton.js +162 -61
  58. package/dist/RadioButtonGroup.js +53 -29
  59. package/dist/RangeSlider.js +769 -0
  60. package/dist/RatingIndicator.js +321 -0
  61. package/dist/ResponsivePopover.js +83 -40
  62. package/dist/SegmentedButton.js +151 -52
  63. package/dist/SegmentedButtonItem.js +109 -0
  64. package/dist/Select.js +496 -107
  65. package/dist/Slider.js +320 -0
  66. package/dist/SliderBase.js +846 -0
  67. package/dist/SplitButton.js +425 -0
  68. package/dist/StandardListItem.js +46 -22
  69. package/dist/StepInput.js +684 -0
  70. package/dist/SuggestionGroupItem.js +64 -0
  71. package/dist/SuggestionItem.js +146 -0
  72. package/dist/SuggestionListItem.js +76 -0
  73. package/dist/Switch.js +72 -38
  74. package/dist/Tab.js +190 -17
  75. package/dist/TabContainer.js +726 -283
  76. package/dist/TabSeparator.js +44 -4
  77. package/dist/Table.js +496 -39
  78. package/dist/TableCell.js +13 -15
  79. package/dist/TableColumn.js +18 -7
  80. package/dist/TableGroupRow.js +160 -0
  81. package/dist/TableRow.js +246 -19
  82. package/dist/TextArea.js +322 -38
  83. package/dist/TimePicker.js +166 -0
  84. package/dist/TimePickerBase.js +463 -0
  85. package/dist/TimeSelection.js +493 -0
  86. package/dist/Title.js +18 -10
  87. package/dist/Toast.js +43 -37
  88. package/dist/ToggleButton.js +26 -13
  89. package/dist/Token.js +85 -45
  90. package/dist/Tokenizer.js +376 -63
  91. package/dist/Tree.js +443 -0
  92. package/dist/TreeItem.js +189 -0
  93. package/dist/TreeListItem.js +340 -0
  94. package/dist/WheelSlider.js +435 -0
  95. package/dist/YearPicker.js +199 -255
  96. package/dist/api.json +7144 -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/Tree.css +1 -0
  185. package/dist/css/themes/TreeListItem.css +1 -0
  186. package/dist/css/themes/ValueStateMessage.css +1 -0
  187. package/dist/css/themes/WheelSlider.css +1 -0
  188. package/dist/css/themes/YearPicker.css +1 -0
  189. package/dist/css/themes/sap_belize/parameters-bundle.css +1 -0
  190. package/dist/css/themes/sap_belize_hcb/parameters-bundle.css +1 -0
  191. package/dist/css/themes/sap_belize_hcw/parameters-bundle.css +1 -0
  192. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -0
  193. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -0
  194. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -0
  195. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -0
  196. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -0
  197. package/dist/css/themes/sap_horizon_exp/parameters-bundle.css +1 -0
  198. package/dist/features/ColorPaletteMoreColors.js +42 -0
  199. package/dist/features/InputElementsFormSupport.js +0 -1
  200. package/dist/features/InputSuggestions.js +358 -56
  201. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  202. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  203. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  204. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  205. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -0
  206. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  207. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  208. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  209. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  210. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -0
  211. package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -0
  212. package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -0
  213. package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -0
  214. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  215. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -0
  216. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  217. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  218. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  219. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -0
  220. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  221. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  222. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  223. package/dist/generated/assets/i18n/messagebundle_in.json +1 -0
  224. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  225. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  226. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  227. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  228. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  229. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  230. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  231. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  232. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  233. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  234. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  235. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  236. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -0
  237. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  238. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  239. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  240. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  241. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  242. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  243. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  244. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  245. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  246. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  247. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  248. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  249. package/dist/generated/assets/themes/sap_belize/parameters-bundle.css.json +1 -1
  250. package/dist/generated/assets/themes/sap_belize_hcb/parameters-bundle.css.json +1 -1
  251. package/dist/generated/assets/themes/sap_belize_hcw/parameters-bundle.css.json +1 -1
  252. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  253. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  254. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -0
  255. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -0
  256. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -0
  257. package/dist/generated/assets/themes/sap_horizon_exp/parameters-bundle.css.json +1 -0
  258. package/dist/generated/i18n/i18n-defaults.js +2 -2
  259. package/dist/generated/json-imports/Themes-static.js +35 -0
  260. package/dist/generated/json-imports/Themes.js +23 -15
  261. package/dist/generated/json-imports/i18n-static.js +162 -0
  262. package/dist/generated/json-imports/i18n.js +113 -89
  263. package/dist/generated/templates/AvatarGroupTemplate.lit.js +9 -0
  264. package/dist/generated/templates/AvatarTemplate.lit.js +9 -9
  265. package/dist/generated/templates/BadgeTemplate.lit.js +5 -6
  266. package/dist/generated/templates/BreadcrumbsPopoverTemplate.lit.js +8 -0
  267. package/dist/generated/templates/BreadcrumbsTemplate.lit.js +9 -0
  268. package/dist/generated/templates/BusyIndicatorTemplate.lit.js +7 -5
  269. package/dist/generated/templates/ButtonTemplate.lit.js +6 -6
  270. package/dist/generated/templates/CalendarHeaderTemplate.lit.js +6 -4
  271. package/dist/generated/templates/CalendarTemplate.lit.js +4 -4
  272. package/dist/generated/templates/CardHeaderTemplate.lit.js +12 -0
  273. package/dist/generated/templates/CardTemplate.lit.js +5 -8
  274. package/dist/generated/templates/CarouselTemplate.lit.js +13 -14
  275. package/dist/generated/templates/CheckBoxTemplate.lit.js +7 -7
  276. package/dist/generated/templates/ColorPaletteDialogTemplate.lit.js +7 -0
  277. package/dist/generated/templates/ColorPaletteItemTemplate.lit.js +7 -0
  278. package/dist/generated/templates/ColorPalettePopoverTemplate.lit.js +8 -0
  279. package/dist/generated/templates/ColorPaletteTemplate.lit.js +12 -0
  280. package/dist/generated/templates/ColorPickerTemplate.lit.js +7 -0
  281. package/dist/generated/templates/ComboBoxPopoverTemplate.lit.js +20 -5
  282. package/dist/generated/templates/ComboBoxTemplate.lit.js +8 -5
  283. package/dist/generated/templates/CustomListItemTemplate.lit.js +13 -12
  284. package/dist/generated/templates/DatePickerPopoverTemplate.lit.js +7 -4
  285. package/dist/generated/templates/DatePickerTemplate.lit.js +6 -5
  286. package/dist/generated/templates/DateTimePickerPopoverTemplate.lit.js +12 -0
  287. package/dist/generated/templates/DayPickerTemplate.lit.js +13 -11
  288. package/dist/generated/templates/DialogTemplate.lit.js +9 -8
  289. package/dist/generated/templates/FileUploaderPopoverTemplate.lit.js +10 -0
  290. package/dist/generated/templates/FileUploaderTemplate.lit.js +7 -7
  291. package/dist/generated/templates/GroupHeaderListItemTemplate.lit.js +4 -4
  292. package/dist/generated/templates/IconTemplate.lit.js +6 -6
  293. package/dist/generated/templates/InputPopoverTemplate.lit.js +24 -6
  294. package/dist/generated/templates/InputTemplate.lit.js +9 -8
  295. package/dist/generated/templates/LabelTemplate.lit.js +4 -4
  296. package/dist/generated/templates/LinkTemplate.lit.js +5 -5
  297. package/dist/generated/templates/ListItemTemplate.lit.js +13 -12
  298. package/dist/generated/templates/ListTemplate.lit.js +12 -9
  299. package/dist/generated/templates/MessageStripTemplate.lit.js +6 -27
  300. package/dist/generated/templates/MonthPickerTemplate.lit.js +6 -6
  301. package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.js +23 -7
  302. package/dist/generated/templates/MultiComboBoxTemplate.lit.js +10 -8
  303. package/dist/generated/templates/MultiInputTemplate.lit.js +16 -0
  304. package/dist/generated/templates/PanelTemplate.lit.js +9 -6
  305. package/dist/generated/templates/PopoverTemplate.lit.js +9 -9
  306. package/dist/generated/templates/PopupBlockLayerTemplate.lit.js +7 -0
  307. package/dist/generated/templates/PopupTemplate.lit.js +4 -4
  308. package/dist/generated/templates/ProgressIndicatorTemplate.lit.js +17 -0
  309. package/dist/generated/templates/RadioButtonTemplate.lit.js +7 -7
  310. package/dist/generated/templates/RangeSliderTemplate.lit.js +13 -0
  311. package/dist/generated/templates/RatingIndicatorTemplate.lit.js +14 -0
  312. package/dist/generated/templates/ResponsivePopoverTemplate.lit.js +16 -11
  313. package/dist/generated/templates/SegmentedButtonItemTemplate.lit.js +8 -0
  314. package/dist/generated/templates/SegmentedButtonTemplate.lit.js +4 -9
  315. package/dist/generated/templates/SelectPopoverTemplate.lit.js +20 -6
  316. package/dist/generated/templates/SelectTemplate.lit.js +6 -4
  317. package/dist/generated/templates/SliderBaseTemplate.lit.js +11 -0
  318. package/dist/generated/templates/SliderTemplate.lit.js +12 -0
  319. package/dist/generated/templates/SplitButtonTemplate.lit.js +7 -0
  320. package/dist/generated/templates/StandardListItemTemplate.lit.js +21 -18
  321. package/dist/generated/templates/StepInputTemplate.lit.js +10 -0
  322. package/dist/generated/templates/SuggestionListItemTemplate.lit.js +27 -0
  323. package/dist/generated/templates/SwitchTemplate.lit.js +8 -6
  324. package/dist/generated/templates/TabContainerPopoverTemplate.lit.js +8 -8
  325. package/dist/generated/templates/TabContainerTemplate.lit.js +15 -18
  326. package/dist/generated/templates/TabInOverflowTemplate.lit.js +9 -0
  327. package/dist/generated/templates/TabInStripTemplate.lit.js +11 -0
  328. package/dist/generated/templates/TabSeparatorInOverflowTemplate.lit.js +7 -0
  329. package/dist/generated/templates/TabSeparatorInStripTemplate.lit.js +7 -0
  330. package/dist/generated/templates/TabTemplate.lit.js +4 -4
  331. package/dist/generated/templates/TableCellTemplate.lit.js +4 -4
  332. package/dist/generated/templates/TableColumnTemplate.lit.js +4 -4
  333. package/dist/generated/templates/TableGroupRowTemplate.lit.js +7 -0
  334. package/dist/generated/templates/TableRowTemplate.lit.js +12 -10
  335. package/dist/generated/templates/TableTemplate.lit.js +13 -8
  336. package/dist/generated/templates/TextAreaPopoverTemplate.lit.js +11 -0
  337. package/dist/generated/templates/TextAreaTemplate.lit.js +8 -8
  338. package/dist/generated/templates/TimePickerPopoverTemplate.lit.js +7 -0
  339. package/dist/generated/templates/TimePickerTemplate.lit.js +9 -0
  340. package/dist/generated/templates/TimeSelectionTemplate.lit.js +11 -0
  341. package/dist/generated/templates/TitleTemplate.lit.js +10 -10
  342. package/dist/generated/templates/ToastTemplate.lit.js +5 -4
  343. package/dist/generated/templates/ToggleButtonTemplate.lit.js +6 -6
  344. package/dist/generated/templates/TokenTemplate.lit.js +7 -5
  345. package/dist/generated/templates/TokenizerPopoverTemplate.lit.js +12 -0
  346. package/dist/generated/templates/TokenizerTemplate.lit.js +6 -6
  347. package/dist/generated/templates/TreeListItemTemplate.lit.js +21 -0
  348. package/dist/generated/templates/TreeTemplate.lit.js +8 -0
  349. package/dist/generated/templates/WheelSliderTemplate.lit.js +10 -0
  350. package/dist/generated/templates/YearPickerTemplate.lit.js +6 -6
  351. package/dist/generated/themes/Avatar.css.js +6 -7
  352. package/dist/generated/themes/AvatarGroup.css.js +8 -0
  353. package/dist/generated/themes/Badge.css.js +6 -7
  354. package/dist/generated/themes/Breadcrumbs.css.js +8 -0
  355. package/dist/generated/themes/BreadcrumbsPopover.css.js +8 -0
  356. package/dist/generated/themes/BrowserScrollbar.css.js +8 -0
  357. package/dist/generated/themes/BusyIndicator.css.js +6 -7
  358. package/dist/generated/themes/Button.css.js +6 -7
  359. package/dist/generated/themes/Button.ie11.css.js +8 -0
  360. package/dist/generated/themes/Calendar.css.js +6 -7
  361. package/dist/generated/themes/CalendarHeader.css.js +6 -7
  362. package/dist/generated/themes/Card.css.js +6 -7
  363. package/dist/generated/themes/CardHeader.css.js +8 -0
  364. package/dist/generated/themes/Carousel.css.js +6 -7
  365. package/dist/generated/themes/CheckBox.css.js +6 -7
  366. package/dist/generated/themes/ColorPalette.css.js +8 -0
  367. package/dist/generated/themes/ColorPaletteItem.css.js +8 -0
  368. package/dist/generated/themes/ColorPalettePopover.css.js +8 -0
  369. package/dist/generated/themes/ColorPaletteStaticArea.css.js +8 -0
  370. package/dist/generated/themes/ColorPicker.css.js +8 -0
  371. package/dist/generated/themes/ComboBox.css.js +6 -7
  372. package/dist/generated/themes/ComboBoxPopover.css.js +6 -7
  373. package/dist/generated/themes/CustomListItem.css.js +6 -7
  374. package/dist/generated/themes/DatePicker.css.js +6 -7
  375. package/dist/generated/themes/DatePickerPopover.css.js +6 -7
  376. package/dist/generated/themes/DateRangePicker.css.js +8 -0
  377. package/dist/generated/themes/DateTimePicker.css.js +8 -0
  378. package/dist/generated/themes/DateTimePickerPopover.css.js +8 -0
  379. package/dist/generated/themes/DayPicker.css.js +6 -7
  380. package/dist/generated/themes/Dialog.css.js +6 -7
  381. package/dist/generated/themes/FileUploader.css.js +6 -7
  382. package/dist/generated/themes/GroupHeaderListItem.css.js +6 -7
  383. package/dist/generated/themes/GrowingButton.css.js +8 -0
  384. package/dist/generated/themes/Icon.css.js +6 -7
  385. package/dist/generated/themes/Input.css.js +6 -7
  386. package/dist/generated/themes/InputIcon.css.js +6 -7
  387. package/dist/generated/themes/InvisibleTextStyles.css.js +6 -7
  388. package/dist/generated/themes/Label.css.js +6 -7
  389. package/dist/generated/themes/Link.css.js +6 -7
  390. package/dist/generated/themes/List.css.js +6 -7
  391. package/dist/generated/themes/ListItem.css.js +6 -7
  392. package/dist/generated/themes/ListItemBase.css.js +6 -7
  393. package/dist/generated/themes/MessageStrip.css.js +6 -7
  394. package/dist/generated/themes/MonthPicker.css.js +6 -7
  395. package/dist/generated/themes/MultiComboBox.css.js +6 -7
  396. package/dist/generated/themes/MultiInput.css.js +8 -0
  397. package/dist/generated/themes/Panel.css.js +6 -7
  398. package/dist/generated/themes/Popover.css.js +6 -7
  399. package/dist/generated/themes/Popup.css.js +6 -7
  400. package/dist/generated/themes/PopupGlobal.css.js +8 -0
  401. package/dist/generated/themes/PopupStaticAreaStyles.css.js +8 -0
  402. package/dist/generated/themes/PopupsCommon.css.js +8 -0
  403. package/dist/generated/themes/ProgressIndicator.css.js +8 -0
  404. package/dist/generated/themes/RadioButton.css.js +6 -7
  405. package/dist/generated/themes/RatingIndicator.css.js +8 -0
  406. package/dist/generated/themes/ResponsivePopover.css.js +6 -7
  407. package/dist/generated/themes/ResponsivePopoverCommon.css.js +6 -7
  408. package/dist/generated/themes/SegmentedButton.css.js +6 -7
  409. package/dist/generated/themes/Select.css.js +6 -7
  410. package/dist/generated/themes/SelectPopover.css.js +8 -0
  411. package/dist/generated/themes/SliderBase.css.js +8 -0
  412. package/dist/generated/themes/SplitButton.css.js +8 -0
  413. package/dist/generated/themes/StepInput.css.js +8 -0
  414. package/dist/generated/themes/Suggestions.css.js +8 -0
  415. package/dist/generated/themes/Switch.css.js +6 -7
  416. package/dist/generated/themes/Tab.css.js +6 -7
  417. package/dist/generated/themes/TabContainer.css.js +6 -7
  418. package/dist/generated/themes/TabInOverflow.css.js +8 -0
  419. package/dist/generated/themes/TabInStrip.css.js +8 -0
  420. package/dist/generated/themes/TabSeparatorInOverflow.css.js +8 -0
  421. package/dist/generated/themes/TabSeparatorInStrip.css.js +8 -0
  422. package/dist/generated/themes/Table.css.js +6 -7
  423. package/dist/generated/themes/TableCell.css.js +6 -7
  424. package/dist/generated/themes/TableColumn.css.js +6 -7
  425. package/dist/generated/themes/TableGroupRow.css.js +8 -0
  426. package/dist/generated/themes/TableRow.css.js +6 -7
  427. package/dist/generated/themes/TapHighlightColor.css.js +8 -0
  428. package/dist/generated/themes/TextArea.css.js +6 -7
  429. package/dist/generated/themes/TimePicker.css.js +8 -0
  430. package/dist/generated/themes/TimePickerPopover.css.js +8 -0
  431. package/dist/generated/themes/TimeSelection.css.js +8 -0
  432. package/dist/generated/themes/Title.css.js +6 -7
  433. package/dist/generated/themes/Toast.css.js +6 -7
  434. package/dist/generated/themes/ToggleButton.css.js +6 -7
  435. package/dist/generated/themes/ToggleButton.ie11.css.js +8 -0
  436. package/dist/generated/themes/Token.css.js +6 -7
  437. package/dist/generated/themes/Tokenizer.css.js +6 -7
  438. package/dist/generated/themes/Tree.css.js +8 -0
  439. package/dist/generated/themes/TreeListItem.css.js +8 -0
  440. package/dist/generated/themes/ValueStateMessage.css.js +8 -0
  441. package/dist/generated/themes/WheelSlider.css.js +8 -0
  442. package/dist/generated/themes/YearPicker.css.js +6 -7
  443. package/dist/generated/themes/sap_belize/parameters-bundle.css.js +1 -1
  444. package/dist/generated/themes/sap_belize_hcb/parameters-bundle.css.js +1 -1
  445. package/dist/generated/themes/sap_belize_hcw/parameters-bundle.css.js +1 -1
  446. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  447. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  448. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -0
  449. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -0
  450. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -0
  451. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js +1 -0
  452. package/dist/i18n/messagebundle.properties +360 -0
  453. package/dist/i18n/messagebundle_ar.properties +241 -0
  454. package/dist/i18n/messagebundle_bg.properties +241 -0
  455. package/dist/i18n/messagebundle_ca.properties +241 -0
  456. package/dist/i18n/messagebundle_cs.properties +241 -0
  457. package/dist/i18n/messagebundle_cy.properties +241 -0
  458. package/dist/i18n/messagebundle_da.properties +241 -0
  459. package/dist/i18n/messagebundle_de.properties +241 -0
  460. package/dist/i18n/messagebundle_el.properties +241 -0
  461. package/dist/i18n/messagebundle_en.properties +241 -0
  462. package/dist/i18n/messagebundle_en_GB.properties +241 -0
  463. package/dist/i18n/messagebundle_en_US_sappsd.properties +241 -0
  464. package/dist/i18n/messagebundle_en_US_saprigi.properties +241 -0
  465. package/dist/i18n/messagebundle_en_US_saptrc.properties +241 -0
  466. package/dist/i18n/messagebundle_es.properties +241 -0
  467. package/dist/i18n/messagebundle_es_MX.properties +241 -0
  468. package/dist/i18n/messagebundle_et.properties +241 -0
  469. package/dist/i18n/messagebundle_fi.properties +241 -0
  470. package/dist/i18n/messagebundle_fr.properties +241 -0
  471. package/dist/i18n/messagebundle_fr_CA.properties +241 -0
  472. package/dist/i18n/messagebundle_hi.properties +241 -0
  473. package/dist/i18n/messagebundle_hr.properties +241 -0
  474. package/dist/i18n/messagebundle_hu.properties +241 -0
  475. package/dist/i18n/messagebundle_id.properties +241 -0
  476. package/dist/i18n/messagebundle_in.properties +172 -0
  477. package/dist/i18n/messagebundle_it.properties +241 -0
  478. package/dist/i18n/messagebundle_iw.properties +241 -0
  479. package/dist/i18n/messagebundle_ja.properties +241 -0
  480. package/dist/i18n/messagebundle_kk.properties +241 -0
  481. package/dist/i18n/messagebundle_ko.properties +241 -0
  482. package/dist/i18n/messagebundle_lt.properties +241 -0
  483. package/dist/i18n/messagebundle_lv.properties +241 -0
  484. package/dist/i18n/messagebundle_ms.properties +241 -0
  485. package/dist/i18n/messagebundle_nl.properties +241 -0
  486. package/dist/i18n/messagebundle_no.properties +241 -0
  487. package/dist/i18n/messagebundle_pl.properties +241 -0
  488. package/dist/i18n/messagebundle_pt.properties +241 -0
  489. package/dist/i18n/messagebundle_pt_PT.properties +241 -0
  490. package/dist/i18n/messagebundle_ro.properties +241 -0
  491. package/dist/i18n/messagebundle_ru.properties +241 -0
  492. package/dist/i18n/messagebundle_sh.properties +241 -0
  493. package/dist/i18n/messagebundle_sk.properties +241 -0
  494. package/dist/i18n/messagebundle_sl.properties +241 -0
  495. package/dist/i18n/messagebundle_sv.properties +241 -0
  496. package/dist/i18n/messagebundle_th.properties +241 -0
  497. package/dist/i18n/messagebundle_tr.properties +241 -0
  498. package/dist/i18n/messagebundle_uk.properties +241 -0
  499. package/dist/i18n/messagebundle_vi.properties +241 -0
  500. package/dist/i18n/messagebundle_zh_CN.properties +241 -0
  501. package/dist/i18n/messagebundle_zh_TW.properties +241 -0
  502. package/dist/popup-utils/OpenedPopupsRegistry.js +18 -13
  503. package/dist/popup-utils/PopoverRegistry.js +55 -21
  504. package/dist/timepicker-utils/TimeSlider.js +103 -0
  505. package/dist/types/{AvatarBackgroundColor.js → AvatarColorScheme.js} +9 -9
  506. package/dist/types/AvatarGroupType.js +43 -0
  507. package/dist/types/AvatarShape.js +1 -1
  508. package/dist/types/AvatarSize.js +1 -1
  509. package/dist/types/BreadcrumbsDesign.js +42 -0
  510. package/dist/types/BreadcrumbsSeparatorStyle.js +69 -0
  511. package/dist/types/BusyIndicatorSize.js +1 -1
  512. package/dist/types/ButtonDesign.js +8 -1
  513. package/dist/types/CalendarSelectionMode.js +47 -0
  514. package/dist/types/CarouselArrowsPlacement.js +3 -3
  515. package/dist/types/GrowingMode.js +48 -0
  516. package/dist/types/HasPopup.js +62 -0
  517. package/dist/types/InputType.js +7 -7
  518. package/dist/types/LinkDesign.js +1 -1
  519. package/dist/types/ListGrowingMode.js +15 -0
  520. package/dist/types/ListItemType.js +8 -1
  521. package/dist/types/ListMode.js +9 -1
  522. package/dist/types/ListSeparators.js +1 -1
  523. package/dist/types/{MessageStripType.js → MessageStripDesign.js} +7 -7
  524. package/dist/types/PanelAccessibleRole.js +1 -1
  525. package/dist/types/PopoverHorizontalAlign.js +1 -1
  526. package/dist/types/PopoverPlacementType.js +2 -2
  527. package/dist/types/PopoverVerticalAlign.js +1 -2
  528. package/dist/types/Priority.js +55 -0
  529. package/dist/types/SemanticColor.js +1 -1
  530. package/dist/types/SwitchDesign.js +40 -0
  531. package/dist/types/TabContainerTabsPlacement.js +40 -0
  532. package/dist/types/TabLayout.js +1 -1
  533. package/dist/types/TableGrowingMode.js +15 -0
  534. package/dist/types/TableMode.js +47 -0
  535. package/dist/types/TableRowType.js +40 -0
  536. package/dist/types/TabsOverflowMode.js +40 -0
  537. package/dist/types/TitleLevel.js +1 -1
  538. package/dist/types/ToastPlacement.js +1 -2
  539. package/dist/types/WrappingType.js +41 -0
  540. package/dist/webcomponentsjs/CHANGELOG.md +61 -0
  541. package/dist/webcomponentsjs/README.md +64 -47
  542. package/dist/webcomponentsjs/bundles/webcomponents-ce.js +38 -38
  543. package/dist/webcomponentsjs/bundles/webcomponents-ce.js.map +1 -1
  544. package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js +60 -0
  545. package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js.map +1 -0
  546. package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js +95 -0
  547. package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js.map +1 -0
  548. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js +292 -229
  549. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js.map +1 -1
  550. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js +190 -170
  551. package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js.map +1 -1
  552. package/dist/webcomponentsjs/bundles/webcomponents-sd.js +151 -132
  553. package/dist/webcomponentsjs/bundles/webcomponents-sd.js.map +1 -1
  554. package/dist/webcomponentsjs/custom-elements-es5-adapter.js +2 -2
  555. package/dist/webcomponentsjs/webcomponents-bundle.js +302 -230
  556. package/dist/webcomponentsjs/webcomponents-bundle.js.map +1 -1
  557. package/dist/webcomponentsjs/webcomponents-loader.js +49 -28
  558. package/package-scripts.js +1 -0
  559. package/package.json +23 -6
  560. package/src/Assets-static.js +6 -0
  561. package/src/Assets.js +7 -0
  562. package/src/Avatar.hbs +20 -0
  563. package/src/Avatar.js +392 -0
  564. package/src/AvatarGroup.hbs +30 -0
  565. package/src/AvatarGroup.js +603 -0
  566. package/src/Badge.hbs +14 -0
  567. package/src/Badge.js +165 -0
  568. package/src/Breadcrumbs.hbs +43 -0
  569. package/src/Breadcrumbs.js +575 -0
  570. package/src/BreadcrumbsItem.js +103 -0
  571. package/src/BreadcrumbsPopover.hbs +28 -0
  572. package/src/BusyIndicator.hbs +32 -0
  573. package/src/BusyIndicator.js +268 -0
  574. package/src/Button.hbs +45 -0
  575. package/src/Button.js +490 -0
  576. package/src/Calendar.hbs +69 -0
  577. package/src/Calendar.js +496 -0
  578. package/src/CalendarDate.js +45 -0
  579. package/src/CalendarHeader.hbs +54 -0
  580. package/src/CalendarHeader.js +209 -0
  581. package/src/CalendarPart.js +111 -0
  582. package/src/Card.hbs +14 -0
  583. package/src/Card.js +160 -0
  584. package/src/CardHeader.hbs +42 -0
  585. package/src/CardHeader.js +288 -0
  586. package/src/Carousel.hbs +86 -0
  587. package/src/Carousel.js +690 -0
  588. package/src/CheckBox.hbs +45 -0
  589. package/src/CheckBox.js +457 -0
  590. package/src/ColorPalette.hbs +52 -0
  591. package/src/ColorPalette.js +494 -0
  592. package/src/ColorPaletteDialog.hbs +18 -0
  593. package/src/ColorPaletteItem.hbs +11 -0
  594. package/src/ColorPaletteItem.js +137 -0
  595. package/src/ColorPalettePopover.hbs +31 -0
  596. package/src/ColorPalettePopover.js +244 -0
  597. package/src/ColorPicker.hbs +98 -0
  598. package/src/ColorPicker.js +524 -0
  599. package/src/ComboBox.hbs +50 -0
  600. package/src/ComboBox.js +1109 -0
  601. package/src/ComboBoxFilters.js +40 -0
  602. package/src/ComboBoxGroupItem.js +70 -0
  603. package/src/ComboBoxItem.js +49 -0
  604. package/src/ComboBoxPopover.hbs +126 -0
  605. package/src/CustomListItem.hbs +5 -0
  606. package/src/CustomListItem.js +99 -0
  607. package/src/DateComponentBase.js +168 -0
  608. package/src/DatePicker.hbs +44 -0
  609. package/src/DatePicker.js +831 -0
  610. package/src/DatePickerPopover.hbs +63 -0
  611. package/src/DateRangePicker.js +350 -0
  612. package/src/DateTimePicker.js +430 -0
  613. package/src/DateTimePickerPopover.hbs +74 -0
  614. package/src/DayPicker.hbs +66 -0
  615. package/src/DayPicker.js +754 -0
  616. package/src/Dialog.hbs +35 -0
  617. package/src/Dialog.js +584 -0
  618. package/src/DurationPicker.js +312 -0
  619. package/src/FileUploader.hbs +40 -0
  620. package/src/FileUploader.js +530 -0
  621. package/src/FileUploaderPopover.hbs +25 -0
  622. package/src/GroupHeaderListItem.hbs +15 -0
  623. package/src/GroupHeaderListItem.js +94 -0
  624. package/src/Icon.hbs +25 -0
  625. package/src/Icon.js +376 -0
  626. package/src/Input.hbs +78 -0
  627. package/src/Input.js +1473 -0
  628. package/src/InputPopover.hbs +117 -0
  629. package/src/Interfaces.js +192 -0
  630. package/src/Label.hbs +13 -0
  631. package/src/Label.js +152 -0
  632. package/src/Link.hbs +21 -0
  633. package/src/Link.js +367 -0
  634. package/src/List.hbs +89 -0
  635. package/src/List.js +1066 -0
  636. package/src/ListItem.hbs +103 -0
  637. package/src/ListItem.js +371 -0
  638. package/src/ListItemBase.js +179 -0
  639. package/src/MessageStrip.hbs +34 -0
  640. package/src/MessageStrip.js +264 -0
  641. package/src/MonthPicker.hbs +29 -0
  642. package/src/MonthPicker.js +299 -0
  643. package/src/MultiComboBox.hbs +78 -0
  644. package/src/MultiComboBox.js +1095 -0
  645. package/src/MultiComboBoxItem.js +43 -0
  646. package/src/MultiComboBoxPopover.hbs +133 -0
  647. package/src/MultiInput.hbs +41 -0
  648. package/src/MultiInput.js +348 -0
  649. package/src/Option.js +126 -0
  650. package/src/Panel.hbs +63 -0
  651. package/src/Panel.js +471 -0
  652. package/src/Popover.hbs +25 -0
  653. package/src/Popover.js +835 -0
  654. package/src/Popup.hbs +34 -0
  655. package/src/Popup.js +581 -0
  656. package/src/PopupBlockLayer.hbs +7 -0
  657. package/src/ProgressIndicator.hbs +35 -0
  658. package/src/ProgressIndicator.js +235 -0
  659. package/src/RadioButton.hbs +33 -0
  660. package/src/RadioButton.js +506 -0
  661. package/src/RadioButtonGroup.js +205 -0
  662. package/src/RangeSlider.hbs +70 -0
  663. package/src/RangeSlider.js +769 -0
  664. package/src/RatingIndicator.hbs +33 -0
  665. package/src/RatingIndicator.js +321 -0
  666. package/src/ResponsivePopover.hbs +41 -0
  667. package/src/ResponsivePopover.js +207 -0
  668. package/src/SegmentedButton.hbs +18 -0
  669. package/src/SegmentedButton.js +303 -0
  670. package/src/SegmentedButtonItem.hbs +42 -0
  671. package/src/SegmentedButtonItem.js +109 -0
  672. package/src/Select.hbs +45 -0
  673. package/src/Select.js +835 -0
  674. package/src/SelectPopover.hbs +90 -0
  675. package/src/Slider.hbs +42 -0
  676. package/src/Slider.js +320 -0
  677. package/src/SliderBase.hbs +38 -0
  678. package/src/SliderBase.js +846 -0
  679. package/src/SplitButton.hbs +53 -0
  680. package/src/SplitButton.js +425 -0
  681. package/src/StandardListItem.hbs +44 -0
  682. package/src/StandardListItem.js +191 -0
  683. package/src/StepInput.hbs +80 -0
  684. package/src/StepInput.js +684 -0
  685. package/src/SuggestionGroupItem.js +64 -0
  686. package/src/SuggestionItem.js +146 -0
  687. package/src/SuggestionListItem.hbs +33 -0
  688. package/src/SuggestionListItem.js +76 -0
  689. package/src/Switch.hbs +51 -0
  690. package/src/Switch.js +280 -0
  691. package/src/Tab.hbs +3 -0
  692. package/src/Tab.js +338 -0
  693. package/src/TabContainer.hbs +83 -0
  694. package/src/TabContainer.js +1051 -0
  695. package/src/TabContainerPopover.hbs +27 -0
  696. package/src/TabInOverflow.hbs +21 -0
  697. package/src/TabInStrip.hbs +38 -0
  698. package/src/TabSeparator.js +83 -0
  699. package/src/TabSeparatorInOverflow.hbs +8 -0
  700. package/src/TabSeparatorInStrip.hbs +6 -0
  701. package/src/Table.hbs +99 -0
  702. package/src/Table.js +771 -0
  703. package/src/TableCell.hbs +7 -0
  704. package/src/TableCell.js +88 -0
  705. package/src/TableColumn.hbs +8 -0
  706. package/src/TableColumn.js +136 -0
  707. package/src/TableGroupRow.hbs +12 -0
  708. package/src/TableGroupRow.js +160 -0
  709. package/src/TableRow.hbs +61 -0
  710. package/src/TableRow.js +388 -0
  711. package/src/TextArea.hbs +50 -0
  712. package/src/TextArea.js +697 -0
  713. package/src/TextAreaPopover.hbs +28 -0
  714. package/src/TimePicker.hbs +35 -0
  715. package/src/TimePicker.js +166 -0
  716. package/src/TimePickerBase.js +463 -0
  717. package/src/TimePickerPopover.hbs +34 -0
  718. package/src/TimeSelection.hbs +60 -0
  719. package/src/TimeSelection.js +493 -0
  720. package/src/Title.hbs +47 -0
  721. package/src/Title.js +132 -0
  722. package/src/Toast.hbs +13 -0
  723. package/src/Toast.js +243 -0
  724. package/src/ToggleButton.hbs +5 -0
  725. package/src/ToggleButton.js +89 -0
  726. package/src/Token.hbs +30 -0
  727. package/src/Token.js +219 -0
  728. package/src/Tokenizer.hbs +27 -0
  729. package/src/Tokenizer.js +541 -0
  730. package/src/TokenizerPopover.hbs +50 -0
  731. package/src/Tree.hbs +43 -0
  732. package/src/Tree.js +443 -0
  733. package/src/TreeItem.js +189 -0
  734. package/src/TreeListItem.hbs +48 -0
  735. package/src/TreeListItem.js +340 -0
  736. package/src/WheelSlider.hbs +48 -0
  737. package/src/WheelSlider.js +435 -0
  738. package/src/YearPicker.hbs +27 -0
  739. package/src/YearPicker.js +324 -0
  740. package/src/features/ColorPaletteMoreColors.js +42 -0
  741. package/src/features/InputElementsFormSupport.js +88 -0
  742. package/src/features/InputSuggestions.js +594 -0
  743. package/src/i18n/messagebundle.properties +360 -0
  744. package/src/i18n/messagebundle_ar.properties +241 -0
  745. package/src/i18n/messagebundle_bg.properties +241 -0
  746. package/src/i18n/messagebundle_ca.properties +241 -0
  747. package/src/i18n/messagebundle_cs.properties +241 -0
  748. package/src/i18n/messagebundle_cy.properties +241 -0
  749. package/src/i18n/messagebundle_da.properties +241 -0
  750. package/src/i18n/messagebundle_de.properties +241 -0
  751. package/src/i18n/messagebundle_el.properties +241 -0
  752. package/src/i18n/messagebundle_en.properties +241 -0
  753. package/src/i18n/messagebundle_en_GB.properties +241 -0
  754. package/src/i18n/messagebundle_en_US_sappsd.properties +241 -0
  755. package/src/i18n/messagebundle_en_US_saprigi.properties +241 -0
  756. package/src/i18n/messagebundle_en_US_saptrc.properties +241 -0
  757. package/src/i18n/messagebundle_es.properties +241 -0
  758. package/src/i18n/messagebundle_es_MX.properties +241 -0
  759. package/src/i18n/messagebundle_et.properties +241 -0
  760. package/src/i18n/messagebundle_fi.properties +241 -0
  761. package/src/i18n/messagebundle_fr.properties +241 -0
  762. package/src/i18n/messagebundle_fr_CA.properties +241 -0
  763. package/src/i18n/messagebundle_hi.properties +241 -0
  764. package/src/i18n/messagebundle_hr.properties +241 -0
  765. package/src/i18n/messagebundle_hu.properties +241 -0
  766. package/src/i18n/messagebundle_id.properties +241 -0
  767. package/src/i18n/messagebundle_in.properties +172 -0
  768. package/src/i18n/messagebundle_it.properties +241 -0
  769. package/src/i18n/messagebundle_iw.properties +241 -0
  770. package/src/i18n/messagebundle_ja.properties +241 -0
  771. package/src/i18n/messagebundle_kk.properties +241 -0
  772. package/src/i18n/messagebundle_ko.properties +241 -0
  773. package/src/i18n/messagebundle_lt.properties +241 -0
  774. package/src/i18n/messagebundle_lv.properties +241 -0
  775. package/src/i18n/messagebundle_ms.properties +241 -0
  776. package/src/i18n/messagebundle_nl.properties +241 -0
  777. package/src/i18n/messagebundle_no.properties +241 -0
  778. package/src/i18n/messagebundle_pl.properties +241 -0
  779. package/src/i18n/messagebundle_pt.properties +241 -0
  780. package/src/i18n/messagebundle_pt_PT.properties +241 -0
  781. package/src/i18n/messagebundle_ro.properties +241 -0
  782. package/src/i18n/messagebundle_ru.properties +241 -0
  783. package/src/i18n/messagebundle_sh.properties +241 -0
  784. package/src/i18n/messagebundle_sk.properties +241 -0
  785. package/src/i18n/messagebundle_sl.properties +241 -0
  786. package/src/i18n/messagebundle_sv.properties +241 -0
  787. package/src/i18n/messagebundle_th.properties +241 -0
  788. package/src/i18n/messagebundle_tr.properties +241 -0
  789. package/src/i18n/messagebundle_uk.properties +241 -0
  790. package/src/i18n/messagebundle_vi.properties +241 -0
  791. package/src/i18n/messagebundle_zh_CN.properties +241 -0
  792. package/src/i18n/messagebundle_zh_TW.properties +241 -0
  793. package/src/popup-utils/OpenedPopupsRegistry.js +50 -0
  794. package/src/popup-utils/PopoverRegistry.js +145 -0
  795. package/src/themes/Avatar.css +227 -0
  796. package/src/themes/AvatarGroup.css +82 -0
  797. package/src/themes/Badge.css +247 -0
  798. package/src/themes/Breadcrumbs.css +100 -0
  799. package/src/themes/BreadcrumbsPopover.css +6 -0
  800. package/src/themes/BrowserScrollbar.css +25 -0
  801. package/src/themes/BusyIndicator.css +143 -0
  802. package/src/themes/Button.css +306 -0
  803. package/src/themes/Button.ie11.css +48 -0
  804. package/src/themes/Calendar.css +18 -0
  805. package/src/themes/CalendarHeader.css +137 -0
  806. package/src/themes/Card.css +42 -0
  807. package/src/themes/CardHeader.css +133 -0
  808. package/src/themes/Carousel.css +140 -0
  809. package/src/themes/CheckBox.css +289 -0
  810. package/src/themes/ColorPalette.css +70 -0
  811. package/src/themes/ColorPaletteItem.css +70 -0
  812. package/src/themes/ColorPalettePopover.css +16 -0
  813. package/src/themes/ColorPaletteStaticArea.css +17 -0
  814. package/src/themes/ColorPicker.css +190 -0
  815. package/src/themes/ComboBox.css +9 -0
  816. package/src/themes/ComboBoxPopover.css +17 -0
  817. package/src/themes/CustomListItem.css +31 -0
  818. package/src/themes/DatePicker.css +46 -0
  819. package/src/themes/DatePickerPopover.css +5 -0
  820. package/src/themes/DateRangePicker.css +16 -0
  821. package/src/themes/DateTimePicker.css +11 -0
  822. package/src/themes/DateTimePickerPopover.css +78 -0
  823. package/src/themes/DayPicker.css +269 -0
  824. package/src/themes/Dialog.css +70 -0
  825. package/src/themes/FileUploader.css +40 -0
  826. package/src/themes/GroupHeaderListItem.css +24 -0
  827. package/src/themes/GrowingButton.css +67 -0
  828. package/src/themes/Icon.css +38 -0
  829. package/src/themes/Input.css +406 -0
  830. package/src/themes/InputIcon.css +53 -0
  831. package/src/themes/InvisibleTextStyles.css +9 -0
  832. package/src/themes/Label.css +85 -0
  833. package/src/themes/Link.css +77 -0
  834. package/src/themes/List.css +116 -0
  835. package/src/themes/ListItem.css +231 -0
  836. package/src/themes/ListItemBase.css +79 -0
  837. package/src/themes/MessageStrip.css +123 -0
  838. package/src/themes/MonthPicker.css +86 -0
  839. package/src/themes/MultiComboBox.css +37 -0
  840. package/src/themes/MultiInput.css +14 -0
  841. package/src/themes/Panel.css +100 -0
  842. package/src/themes/Popover.css +102 -0
  843. package/src/themes/Popup.css +5 -0
  844. package/src/themes/PopupGlobal.css +6 -0
  845. package/src/themes/PopupStaticAreaStyles.css +17 -0
  846. package/src/themes/PopupsCommon.css +87 -0
  847. package/src/themes/ProgressIndicator.css +158 -0
  848. package/src/themes/RadioButton.css +249 -0
  849. package/src/themes/RatingIndicator.css +52 -0
  850. package/src/themes/ResponsivePopover.css +34 -0
  851. package/src/themes/ResponsivePopoverCommon.css +207 -0
  852. package/src/themes/SegmentedButton.css +88 -0
  853. package/src/themes/Select.css +53 -0
  854. package/src/themes/SelectPopover.css +10 -0
  855. package/src/themes/SliderBase.css +253 -0
  856. package/src/themes/SplitButton.css +98 -0
  857. package/src/themes/StepInput.css +269 -0
  858. package/src/themes/Suggestions.css +14 -0
  859. package/src/themes/Switch.css +370 -0
  860. package/src/themes/Tab.css +9 -0
  861. package/src/themes/TabContainer.css +128 -0
  862. package/src/themes/TabInOverflow.css +61 -0
  863. package/src/themes/TabInStrip.css +374 -0
  864. package/src/themes/TabSeparatorInOverflow.css +8 -0
  865. package/src/themes/TabSeparatorInStrip.css +5 -0
  866. package/src/themes/Table.css +91 -0
  867. package/src/themes/TableCell.css +28 -0
  868. package/src/themes/TableColumn.css +29 -0
  869. package/src/themes/TableGroupRow.css +34 -0
  870. package/src/themes/TableRow.css +84 -0
  871. package/src/themes/TapHighlightColor.css +3 -0
  872. package/src/themes/TextArea.css +309 -0
  873. package/src/themes/TimePicker.css +50 -0
  874. package/src/themes/TimePickerPopover.css +11 -0
  875. package/src/themes/TimeSelection.css +27 -0
  876. package/src/themes/Title.css +65 -0
  877. package/src/themes/Toast.css +93 -0
  878. package/src/themes/ToggleButton.css +88 -0
  879. package/src/themes/ToggleButton.ie11.css +48 -0
  880. package/src/themes/Token.css +117 -0
  881. package/src/themes/Tokenizer.css +84 -0
  882. package/src/themes/Tree.css +11 -0
  883. package/src/themes/TreeListItem.css +107 -0
  884. package/src/themes/ValueStateMessage.css +76 -0
  885. package/src/themes/WheelSlider.css +203 -0
  886. package/src/themes/YearPicker.css +86 -0
  887. package/src/themes/base/Avatar-parameters.css +38 -0
  888. package/src/themes/base/AvatarGroup-parameter.css +6 -0
  889. package/src/themes/base/Badge-parameters.css +61 -0
  890. package/src/themes/base/BrowserScrollbar-parameters.css +4 -0
  891. package/src/themes/base/BusyIndicator-parameters.css +5 -0
  892. package/src/themes/base/Button-parameters.css +30 -0
  893. package/src/themes/base/CalendarHeader-parameters.css +20 -0
  894. package/src/themes/base/Card-parameters.css +17 -0
  895. package/src/themes/base/Carousel-parameters.css +9 -0
  896. package/src/themes/base/CheckBox-parameters.css +53 -0
  897. package/src/themes/base/ColorPalette-parameters.css +14 -0
  898. package/src/themes/base/ColorPicker-parameters.css +8 -0
  899. package/src/themes/base/DatePicker-parameters.css +6 -0
  900. package/src/themes/base/DayPicker-parameters.css +41 -0
  901. package/src/themes/base/Dialog-parameters.css +9 -0
  902. package/src/themes/base/GroupHeaderListItem-parameters.css +3 -0
  903. package/src/themes/base/GrowingButton-parameters.css +6 -0
  904. package/src/themes/base/Input-parameters.css +63 -0
  905. package/src/themes/base/InputIcon-parameters.css +11 -0
  906. package/src/themes/base/Link-parameters.css +8 -0
  907. package/src/themes/base/List-parameters.css +3 -0
  908. package/src/themes/base/ListItemBase-parameters.css +9 -0
  909. package/src/themes/base/MessageStrip-parameters.css +21 -0
  910. package/src/themes/base/MonthPicker-parameters.css +16 -0
  911. package/src/themes/base/MultiComboBox-parameters.css +3 -0
  912. package/src/themes/base/Panel-parameters.css +11 -0
  913. package/src/themes/base/PopupsCommon-parameters.css +8 -0
  914. package/src/themes/base/ProgressIndicator-parameters.css +21 -0
  915. package/src/themes/base/RadioButton-parameters.css +32 -0
  916. package/src/themes/base/RatingIndicator-parameters.css +3 -0
  917. package/src/themes/base/SegmentedButtton-parameters.css +8 -0
  918. package/src/themes/base/Select-parameters.css +11 -0
  919. package/src/themes/base/SelectPopover-parameters.css +4 -0
  920. package/src/themes/base/SliderBase-parameters.css +57 -0
  921. package/src/themes/base/StepInput-parameters.css +23 -0
  922. package/src/themes/base/Suggestions-parameters.css +3 -0
  923. package/src/themes/base/Switch-parameters.css +107 -0
  924. package/src/themes/base/TabContainer-parameters.css +84 -0
  925. package/src/themes/base/Table-parameters.css +6 -0
  926. package/src/themes/base/TableColumn-parameters.css +3 -0
  927. package/src/themes/base/TableRow-parameters.css +3 -0
  928. package/src/themes/base/TextArea-parameters.css +22 -0
  929. package/src/themes/base/TimePicker-parameters.css +4 -0
  930. package/src/themes/base/TimelineItem-parameters.css +10 -0
  931. package/src/themes/base/Title-parameters.css +8 -0
  932. package/src/themes/base/Toast-parameters.css +6 -0
  933. package/src/themes/base/ToggleButton-parameters.css +8 -0
  934. package/src/themes/base/Token-parameters.css +19 -0
  935. package/src/themes/base/Tokenizer-parameters.css +4 -0
  936. package/src/themes/base/ValueStateMessage-parameters.css +7 -0
  937. package/src/themes/base/WheelSlider-parameters.css +15 -0
  938. package/src/themes/base/YearPicker-parameters.css +16 -0
  939. package/src/themes/base/sizes-parameters.css +302 -0
  940. package/src/themes/sap_belize/BrowserScrollbar-parameters.css +4 -0
  941. package/src/themes/sap_belize/Carousel-parameters.css +9 -0
  942. package/src/themes/sap_belize/Dialog-parameters.css +5 -0
  943. package/src/themes/sap_belize/Input-parameters.css +6 -0
  944. package/src/themes/sap_belize/InputIcon-parameters.css +5 -0
  945. package/src/themes/sap_belize/ProgressIndicator-parameters.css +8 -0
  946. package/src/themes/sap_belize/SliderBase-parameters.css +22 -0
  947. package/src/themes/sap_belize/TabContainer-parameters.css +6 -0
  948. package/src/themes/sap_belize/Table-parameters.css +7 -0
  949. package/src/themes/sap_belize/TimePicker-parameters.css +5 -0
  950. package/src/themes/sap_belize/WheelSlider-parameters.css +17 -0
  951. package/src/themes/sap_belize/parameters-bundle.css +48 -0
  952. package/src/themes/sap_belize_hcb/Avatar-parameters.css +18 -0
  953. package/src/themes/sap_belize_hcb/Badge-parameters.css +43 -0
  954. package/src/themes/sap_belize_hcb/BrowserScrollbar-parameters.css +4 -0
  955. package/src/themes/sap_belize_hcb/Button-parameters.css +12 -0
  956. package/src/themes/sap_belize_hcb/CalendarHeader-parameters.css +11 -0
  957. package/src/themes/sap_belize_hcb/Card-parameters.css +6 -0
  958. package/src/themes/sap_belize_hcb/Carousel-parameters.css +9 -0
  959. package/src/themes/sap_belize_hcb/CheckBox-parameters.css +12 -0
  960. package/src/themes/sap_belize_hcb/DatePicker-parameters.css +6 -0
  961. package/src/themes/sap_belize_hcb/DayPicker-parameters.css +13 -0
  962. package/src/themes/sap_belize_hcb/Dialog-parameters.css +7 -0
  963. package/src/themes/sap_belize_hcb/GrowingButton-parameters.css +8 -0
  964. package/src/themes/sap_belize_hcb/Input-parameters.css +14 -0
  965. package/src/themes/sap_belize_hcb/InputIcon-parameters.css +5 -0
  966. package/src/themes/sap_belize_hcb/Link-parameters.css +7 -0
  967. package/src/themes/sap_belize_hcb/MessageStrip-parameters.css +10 -0
  968. package/src/themes/sap_belize_hcb/MonthPicker-parameters.css +10 -0
  969. package/src/themes/sap_belize_hcb/Panel-parameters.css +5 -0
  970. package/src/themes/sap_belize_hcb/ProgressIndicator-parameters.css +11 -0
  971. package/src/themes/sap_belize_hcb/RadioButton-parameters.css +10 -0
  972. package/src/themes/sap_belize_hcb/Select-parameters.css +12 -0
  973. package/src/themes/sap_belize_hcb/SliderBase-parameters.css +17 -0
  974. package/src/themes/sap_belize_hcb/Switch-parameters.css +46 -0
  975. package/src/themes/sap_belize_hcb/TabContainer-parameters.css +44 -0
  976. package/src/themes/sap_belize_hcb/Table-parameters.css +7 -0
  977. package/src/themes/sap_belize_hcb/TableRow-parameters.css +5 -0
  978. package/src/themes/sap_belize_hcb/TextArea-parameters.css +6 -0
  979. package/src/themes/sap_belize_hcb/ToggleButton-parameters.css +7 -0
  980. package/src/themes/sap_belize_hcb/Token-parameters.css +6 -0
  981. package/src/themes/sap_belize_hcb/ValueStateMessage-parameters.css +5 -0
  982. package/src/themes/sap_belize_hcb/WheelSlider-parameters.css +17 -0
  983. package/src/themes/sap_belize_hcb/YearPicker-parameters.css +10 -0
  984. package/src/themes/sap_belize_hcb/parameters-bundle.css +47 -0
  985. package/src/themes/sap_belize_hcw/Avatar-parameters.css +18 -0
  986. package/src/themes/sap_belize_hcw/Badge-parameters.css +43 -0
  987. package/src/themes/sap_belize_hcw/BrowserScrollbar-parameters.css +4 -0
  988. package/src/themes/sap_belize_hcw/Button-parameters.css +12 -0
  989. package/src/themes/sap_belize_hcw/CalendarHeader-parameters.css +11 -0
  990. package/src/themes/sap_belize_hcw/Card-parameters.css +6 -0
  991. package/src/themes/sap_belize_hcw/Carousel-parameters.css +9 -0
  992. package/src/themes/sap_belize_hcw/CheckBox-parameters.css +12 -0
  993. package/src/themes/sap_belize_hcw/DatePicker-parameters.css +5 -0
  994. package/src/themes/sap_belize_hcw/DayPicker-parameters.css +14 -0
  995. package/src/themes/sap_belize_hcw/Dialog-parameters.css +7 -0
  996. package/src/themes/sap_belize_hcw/GrowingButton-parameters.css +8 -0
  997. package/src/themes/sap_belize_hcw/Input-parameters.css +14 -0
  998. package/src/themes/sap_belize_hcw/InputIcon-parameters.css +5 -0
  999. package/src/themes/sap_belize_hcw/Link-parameters.css +7 -0
  1000. package/src/themes/sap_belize_hcw/MessageStrip-parameters.css +10 -0
  1001. package/src/themes/sap_belize_hcw/MonthPicker-parameters.css +10 -0
  1002. package/src/themes/sap_belize_hcw/Panel-parameters.css +5 -0
  1003. package/src/themes/sap_belize_hcw/ProgressIndicator-parameters.css +11 -0
  1004. package/src/themes/sap_belize_hcw/RadioButton-parameters.css +10 -0
  1005. package/src/themes/sap_belize_hcw/Select-parameters.css +12 -0
  1006. package/src/themes/sap_belize_hcw/SliderBase-parameters.css +17 -0
  1007. package/src/themes/sap_belize_hcw/Switch-parameters.css +45 -0
  1008. package/src/themes/sap_belize_hcw/TabContainer-parameters.css +44 -0
  1009. package/src/themes/sap_belize_hcw/Table-parameters.css +7 -0
  1010. package/src/themes/sap_belize_hcw/TableRow-parameters.css +5 -0
  1011. package/src/themes/sap_belize_hcw/TextArea-parameters.css +6 -0
  1012. package/src/themes/sap_belize_hcw/ToggleButton-parameters.css +6 -0
  1013. package/src/themes/sap_belize_hcw/Token-parameters.css +6 -0
  1014. package/src/themes/sap_belize_hcw/ValueStateMessage-parameters.css +5 -0
  1015. package/src/themes/sap_belize_hcw/WheelSlider-parameters.css +17 -0
  1016. package/src/themes/sap_belize_hcw/YearPicker-parameters.css +10 -0
  1017. package/src/themes/sap_belize_hcw/parameters-bundle.css +47 -0
  1018. package/src/themes/sap_fiori_3/Avatar-parameters.css +9 -0
  1019. package/src/themes/sap_fiori_3/Button-parameters.css +14 -0
  1020. package/src/themes/sap_fiori_3/CalendarHeader-parameters.css +8 -0
  1021. package/src/themes/sap_fiori_3/CheckBox-parameters.css +13 -0
  1022. package/src/themes/sap_fiori_3/DayPicker-parameters.css +6 -0
  1023. package/src/themes/sap_fiori_3/Input-parameters.css +7 -0
  1024. package/src/themes/sap_fiori_3/Link-parameters.css +7 -0
  1025. package/src/themes/sap_fiori_3/List-parameters.css +5 -0
  1026. package/src/themes/sap_fiori_3/MonthPicker-parameters.css +5 -0
  1027. package/src/themes/sap_fiori_3/MultiComboBox-parameters.css +5 -0
  1028. package/src/themes/sap_fiori_3/Panel-parameters.css +6 -0
  1029. package/src/themes/sap_fiori_3/SliderBase-parameters.css +5 -0
  1030. package/src/themes/sap_fiori_3/TabContainer-parameters.css +12 -0
  1031. package/src/themes/sap_fiori_3/TimePicker-parameters.css +5 -0
  1032. package/src/themes/sap_fiori_3/Token-parameters.css +9 -0
  1033. package/src/themes/sap_fiori_3/WheelSlider-parameters.css +16 -0
  1034. package/src/themes/sap_fiori_3/YearPicker-parameters.css +5 -0
  1035. package/src/themes/sap_fiori_3/parameters-bundle.css +48 -0
  1036. package/src/themes/sap_fiori_3_dark/Avatar-parameters.css +9 -0
  1037. package/src/themes/sap_fiori_3_dark/Button-parameters.css +14 -0
  1038. package/src/themes/sap_fiori_3_dark/CalendarHeader-parameters.css +8 -0
  1039. package/src/themes/sap_fiori_3_dark/CheckBox-parameters.css +13 -0
  1040. package/src/themes/sap_fiori_3_dark/DayPicker-parameters.css +6 -0
  1041. package/src/themes/sap_fiori_3_dark/Input-parameters.css +7 -0
  1042. package/src/themes/sap_fiori_3_dark/Link-parameters.css +7 -0
  1043. package/src/themes/sap_fiori_3_dark/List-parameters.css +5 -0
  1044. package/src/themes/sap_fiori_3_dark/MonthPicker-parameters.css +5 -0
  1045. package/src/themes/sap_fiori_3_dark/MultiComboBox-parameters.css +5 -0
  1046. package/src/themes/sap_fiori_3_dark/Panel-parameters.css +6 -0
  1047. package/src/themes/sap_fiori_3_dark/SliderBase-parameters.css +5 -0
  1048. package/src/themes/sap_fiori_3_dark/TabContainer-parameters.css +12 -0
  1049. package/src/themes/sap_fiori_3_dark/Token-parameters.css +8 -0
  1050. package/src/themes/sap_fiori_3_dark/WheelSlider-parameters.css +15 -0
  1051. package/src/themes/sap_fiori_3_dark/YearPicker-parameters.css +5 -0
  1052. package/src/themes/sap_fiori_3_dark/parameters-bundle.css +47 -0
  1053. package/src/themes/sap_fiori_3_hcb/Avatar-parameters.css +24 -0
  1054. package/src/themes/sap_fiori_3_hcb/Badge-parameters.css +43 -0
  1055. package/src/themes/sap_fiori_3_hcb/Button-parameters.css +10 -0
  1056. package/src/themes/sap_fiori_3_hcb/CalendarHeader-parameters.css +11 -0
  1057. package/src/themes/sap_fiori_3_hcb/Card-parameters.css +6 -0
  1058. package/src/themes/sap_fiori_3_hcb/Carousel-parameters.css +9 -0
  1059. package/src/themes/sap_fiori_3_hcb/CheckBox-parameters.css +13 -0
  1060. package/src/themes/sap_fiori_3_hcb/DatePicker-parameters.css +5 -0
  1061. package/src/themes/sap_fiori_3_hcb/DayPicker-parameters.css +19 -0
  1062. package/src/themes/sap_fiori_3_hcb/Dialog-parameters.css +7 -0
  1063. package/src/themes/sap_fiori_3_hcb/GrowingButton-parameters.css +8 -0
  1064. package/src/themes/sap_fiori_3_hcb/Input-parameters.css +21 -0
  1065. package/src/themes/sap_fiori_3_hcb/InputIcon-parameters.css +5 -0
  1066. package/src/themes/sap_fiori_3_hcb/Link-parameters.css +7 -0
  1067. package/src/themes/sap_fiori_3_hcb/MessageStrip-parameters.css +10 -0
  1068. package/src/themes/sap_fiori_3_hcb/MonthPicker-parameters.css +11 -0
  1069. package/src/themes/sap_fiori_3_hcb/Panel-parameters.css +5 -0
  1070. package/src/themes/sap_fiori_3_hcb/ProgressIndicator-parameters.css +11 -0
  1071. package/src/themes/sap_fiori_3_hcb/RadioButton-parameters.css +10 -0
  1072. package/src/themes/sap_fiori_3_hcb/Select-parameters.css +12 -0
  1073. package/src/themes/sap_fiori_3_hcb/SliderBase-parameters.css +14 -0
  1074. package/src/themes/sap_fiori_3_hcb/Switch-parameters.css +45 -0
  1075. package/src/themes/sap_fiori_3_hcb/TabContainer-parameters.css +44 -0
  1076. package/src/themes/sap_fiori_3_hcb/Table-parameters.css +5 -0
  1077. package/src/themes/sap_fiori_3_hcb/TableRow-parameters.css +5 -0
  1078. package/src/themes/sap_fiori_3_hcb/TextArea-parameters.css +10 -0
  1079. package/src/themes/sap_fiori_3_hcb/TimePicker-parameters.css +5 -0
  1080. package/src/themes/sap_fiori_3_hcb/ToggleButton-parameters.css +6 -0
  1081. package/src/themes/sap_fiori_3_hcb/Token-parameters.css +7 -0
  1082. package/src/themes/sap_fiori_3_hcb/ValueStateMessage-parameters.css +5 -0
  1083. package/src/themes/sap_fiori_3_hcb/WheelSlider-parameters.css +17 -0
  1084. package/src/themes/sap_fiori_3_hcb/YearPicker-parameters.css +11 -0
  1085. package/src/themes/sap_fiori_3_hcb/parameters-bundle.css +48 -0
  1086. package/src/themes/sap_fiori_3_hcw/Avatar-parameters.css +24 -0
  1087. package/src/themes/sap_fiori_3_hcw/Badge-parameters.css +43 -0
  1088. package/src/themes/sap_fiori_3_hcw/Button-parameters.css +10 -0
  1089. package/src/themes/sap_fiori_3_hcw/CalendarHeader-parameters.css +11 -0
  1090. package/src/themes/sap_fiori_3_hcw/Card-parameters.css +6 -0
  1091. package/src/themes/sap_fiori_3_hcw/Carousel-parameters.css +9 -0
  1092. package/src/themes/sap_fiori_3_hcw/CheckBox-parameters.css +13 -0
  1093. package/src/themes/sap_fiori_3_hcw/DatePicker-parameters.css +5 -0
  1094. package/src/themes/sap_fiori_3_hcw/DayPicker-parameters.css +19 -0
  1095. package/src/themes/sap_fiori_3_hcw/Dialog-parameters.css +7 -0
  1096. package/src/themes/sap_fiori_3_hcw/GrowingButton-parameters.css +8 -0
  1097. package/src/themes/sap_fiori_3_hcw/Input-parameters.css +21 -0
  1098. package/src/themes/sap_fiori_3_hcw/InputIcon-parameters.css +5 -0
  1099. package/src/themes/sap_fiori_3_hcw/Link-parameters.css +7 -0
  1100. package/src/themes/sap_fiori_3_hcw/MessageStrip-parameters.css +10 -0
  1101. package/src/themes/sap_fiori_3_hcw/MonthPicker-parameters.css +11 -0
  1102. package/src/themes/sap_fiori_3_hcw/Panel-parameters.css +5 -0
  1103. package/src/themes/sap_fiori_3_hcw/ProgressIndicator-parameters.css +11 -0
  1104. package/src/themes/sap_fiori_3_hcw/RadioButton-parameters.css +10 -0
  1105. package/src/themes/sap_fiori_3_hcw/Select-parameters.css +12 -0
  1106. package/src/themes/sap_fiori_3_hcw/SliderBase-parameters.css +13 -0
  1107. package/src/themes/sap_fiori_3_hcw/Switch-parameters.css +45 -0
  1108. package/src/themes/sap_fiori_3_hcw/TabContainer-parameters.css +44 -0
  1109. package/src/themes/sap_fiori_3_hcw/Table-parameters.css +5 -0
  1110. package/src/themes/sap_fiori_3_hcw/TableRow-parameters.css +5 -0
  1111. package/src/themes/sap_fiori_3_hcw/TextArea-parameters.css +10 -0
  1112. package/src/themes/sap_fiori_3_hcw/TimePicker-parameters.css +5 -0
  1113. package/src/themes/sap_fiori_3_hcw/ToggleButton-parameters.css +6 -0
  1114. package/src/themes/sap_fiori_3_hcw/Token-parameters.css +7 -0
  1115. package/src/themes/sap_fiori_3_hcw/ValueStateMessage-parameters.css +5 -0
  1116. package/src/themes/sap_fiori_3_hcw/WheelSlider-parameters.css +17 -0
  1117. package/src/themes/sap_fiori_3_hcw/YearPicker-parameters.css +11 -0
  1118. package/src/themes/sap_fiori_3_hcw/parameters-bundle.css +48 -0
  1119. package/src/themes/sap_horizon/Avatar-parameters.css +33 -0
  1120. package/src/themes/sap_horizon/BusyIndicator-parameters.css +7 -0
  1121. package/src/themes/sap_horizon/Button-parameters.css +20 -0
  1122. package/src/themes/sap_horizon/CalendarHeader-parameters.css +19 -0
  1123. package/src/themes/sap_horizon/Card-parameters.css +10 -0
  1124. package/src/themes/sap_horizon/CheckBox-parameters.css +34 -0
  1125. package/src/themes/sap_horizon/ColorPalette-parameters.css +16 -0
  1126. package/src/themes/sap_horizon/ColorPicker-parameters.css +10 -0
  1127. package/src/themes/sap_horizon/DatePicker-parameters.css +6 -0
  1128. package/src/themes/sap_horizon/DayPicker-parameters.css +31 -0
  1129. package/src/themes/sap_horizon/Dialog-parameters.css +11 -0
  1130. package/src/themes/sap_horizon/GrowingButton-parameters.css +5 -0
  1131. package/src/themes/sap_horizon/Input-parameters.css +35 -0
  1132. package/src/themes/sap_horizon/InputIcon-parameters.css +17 -0
  1133. package/src/themes/sap_horizon/Link-parameters.css +10 -0
  1134. package/src/themes/sap_horizon/List-parameters.css +5 -0
  1135. package/src/themes/sap_horizon/ListItemBase-parameters.css +7 -0
  1136. package/src/themes/sap_horizon/MessageStrip-parameters.css +9 -0
  1137. package/src/themes/sap_horizon/MonthPicker-parameters.css +17 -0
  1138. package/src/themes/sap_horizon/MultiComboBox-parameters.css +5 -0
  1139. package/src/themes/sap_horizon/Panel-parameters.css +12 -0
  1140. package/src/themes/sap_horizon/PopupsCommon-parameters.css +10 -0
  1141. package/src/themes/sap_horizon/ProgressIndicator-parameters.css +23 -0
  1142. package/src/themes/sap_horizon/RadioButton-parameters.css +9 -0
  1143. package/src/themes/sap_horizon/RatingIndicator-parameters.css +3 -0
  1144. package/src/themes/sap_horizon/SegmentedButtton-parameters.css +10 -0
  1145. package/src/themes/sap_horizon/Select-parameters.css +5 -0
  1146. package/src/themes/sap_horizon/SelectPopover-parameters.css +4 -0
  1147. package/src/themes/sap_horizon/SliderBase-parameters.css +44 -0
  1148. package/src/themes/sap_horizon/StepInput-parameters.css +25 -0
  1149. package/src/themes/sap_horizon/Suggestions-parameters.css +5 -0
  1150. package/src/themes/sap_horizon/Switch-parameters.css +31 -0
  1151. package/src/themes/sap_horizon/TabContainer-parameters.css +25 -0
  1152. package/src/themes/sap_horizon/Table-parameters.css +8 -0
  1153. package/src/themes/sap_horizon/TableColumn-parameters.css +5 -0
  1154. package/src/themes/sap_horizon/TableRow-parameters.css +5 -0
  1155. package/src/themes/sap_horizon/TextArea-parameters.css +22 -0
  1156. package/src/themes/sap_horizon/TimePicker-parameters.css +6 -0
  1157. package/src/themes/sap_horizon/ToggleButton-parameters.css +11 -0
  1158. package/src/themes/sap_horizon/Token-parameters.css +28 -0
  1159. package/src/themes/sap_horizon/Tokenizer-parameters.css +6 -0
  1160. package/src/themes/sap_horizon/ValueStateMessage-parameters.css +8 -0
  1161. package/src/themes/sap_horizon/WheelSlider-parameters.css +19 -0
  1162. package/src/themes/sap_horizon/YearPicker-parameters.css +16 -0
  1163. package/src/themes/sap_horizon/parameters-bundle.css +57 -0
  1164. package/src/themes/sap_horizon/sizes-parameters.css +8 -0
  1165. package/src/themes/sap_horizon_exp/Badge-parameters.css +91 -0
  1166. package/src/themes/sap_horizon_exp/Button-parameters.css +12 -0
  1167. package/src/themes/sap_horizon_exp/CalendarHeader-parameters.css +8 -0
  1168. package/src/themes/sap_horizon_exp/CheckBox-parameters.css +35 -0
  1169. package/src/themes/sap_horizon_exp/DatePicker-parameters.css +5 -0
  1170. package/src/themes/sap_horizon_exp/DayPicker-parameters.css +6 -0
  1171. package/src/themes/sap_horizon_exp/Input-parameters.css +46 -0
  1172. package/src/themes/sap_horizon_exp/InputIcon-parameters.css +9 -0
  1173. package/src/themes/sap_horizon_exp/Link-parameters.css +7 -0
  1174. package/src/themes/sap_horizon_exp/List-parameters.css +5 -0
  1175. package/src/themes/sap_horizon_exp/MonthPicker-parameters.css +5 -0
  1176. package/src/themes/sap_horizon_exp/MultiComboBox-parameters.css +7 -0
  1177. package/src/themes/sap_horizon_exp/Panel-parameters.css +6 -0
  1178. package/src/themes/sap_horizon_exp/Popover-parameters.css +5 -0
  1179. package/src/themes/sap_horizon_exp/RadioButton-parameters.css +30 -0
  1180. package/src/themes/sap_horizon_exp/Select-parameters.css +5 -0
  1181. package/src/themes/sap_horizon_exp/SliderBase-parameters.css +30 -0
  1182. package/src/themes/sap_horizon_exp/Switch-parameters.css +46 -0
  1183. package/src/themes/sap_horizon_exp/TabContainer-parameters.css +40 -0
  1184. package/src/themes/sap_horizon_exp/TimePicker-parameters.css +5 -0
  1185. package/src/themes/sap_horizon_exp/Token-parameters.css +9 -0
  1186. package/src/themes/sap_horizon_exp/WheelSlider-parameters.css +16 -0
  1187. package/src/themes/sap_horizon_exp/YearPicker-parameters.css +5 -0
  1188. package/src/themes/sap_horizon_exp/parameters-bundle.css +46 -0
  1189. package/src/timepicker-utils/TimeSlider.js +103 -0
  1190. package/src/types/AvatarColorScheme.js +104 -0
  1191. package/src/types/AvatarGroupType.js +43 -0
  1192. package/src/types/AvatarShape.js +41 -0
  1193. package/src/types/AvatarSize.js +67 -0
  1194. package/src/types/BreadcrumbsDesign.js +42 -0
  1195. package/src/types/BreadcrumbsSeparatorStyle.js +69 -0
  1196. package/src/types/BusyIndicatorSize.js +47 -0
  1197. package/src/types/ButtonDesign.js +68 -0
  1198. package/src/types/CalendarSelectionMode.js +47 -0
  1199. package/src/types/CarouselArrowsPlacement.js +40 -0
  1200. package/src/types/GrowingMode.js +48 -0
  1201. package/src/types/HasPopup.js +62 -0
  1202. package/src/types/InputType.js +68 -0
  1203. package/src/types/LinkDesign.js +47 -0
  1204. package/src/types/ListGrowingMode.js +15 -0
  1205. package/src/types/ListItemType.js +47 -0
  1206. package/src/types/ListMode.js +77 -0
  1207. package/src/types/ListSeparators.js +46 -0
  1208. package/src/types/MessageStripDesign.js +54 -0
  1209. package/src/types/PanelAccessibleRole.js +48 -0
  1210. package/src/types/PopoverHorizontalAlign.js +54 -0
  1211. package/src/types/PopoverPlacementType.js +54 -0
  1212. package/src/types/PopoverVerticalAlign.js +54 -0
  1213. package/src/types/Priority.js +55 -0
  1214. package/src/types/SemanticColor.js +61 -0
  1215. package/src/types/SwitchDesign.js +40 -0
  1216. package/src/types/TabContainerTabsPlacement.js +40 -0
  1217. package/src/types/TabLayout.js +40 -0
  1218. package/src/types/TableGrowingMode.js +15 -0
  1219. package/src/types/TableMode.js +47 -0
  1220. package/src/types/TableRowType.js +40 -0
  1221. package/src/types/TabsOverflowMode.js +40 -0
  1222. package/src/types/TitleLevel.js +68 -0
  1223. package/src/types/ToastPlacement.js +91 -0
  1224. package/src/types/WrappingType.js +41 -0
  1225. package/dist/Timeline.js +0 -82
  1226. package/dist/TimelineItem.js +0 -161
  1227. package/dist/generated/templates/ComboBoxItemTemplate.lit.js +0 -7
  1228. package/dist/generated/templates/TabSeparatorTemplate.lit.js +0 -7
  1229. package/dist/generated/templates/TimelineItemTemplate.lit.js +0 -12
  1230. package/dist/generated/templates/TimelineTemplate.lit.js +0 -8
  1231. package/dist/generated/themes/ComboBoxItem.css.js +0 -9
  1232. package/dist/generated/themes/TabContainerPopup.css.js +0 -9
  1233. package/dist/generated/themes/Timeline.css.js +0 -9
  1234. package/dist/generated/themes/TimelineItem.css.js +0 -9
  1235. package/dist/popup-utils/PopupUtils.js +0 -55
  1236. package/dist/types/AvatarFitType.js +0 -40
  1237. package/dist/webcomponentsjs/package.json +0 -46
package/dist/List.js CHANGED
@@ -1,10 +1,19 @@
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 ItemNavigation from "@ui5/webcomponents-base/dist/delegate/ItemNavigation.js";
5
+ import { isIE } from "@ui5/webcomponents-base/dist/Device.js";
6
+ import { renderFinished } from "@ui5/webcomponents-base/dist/Render.js";
4
7
  import { getLastTabbableElement } from "@ui5/webcomponents-base/dist/util/TabbableElements.js";
5
- import { isTabNext } from "@ui5/webcomponents-base/dist/Keys.js";
8
+ import { isTabNext, isSpace, isEnter } from "@ui5/webcomponents-base/dist/Keys.js";
9
+ import Integer from "@ui5/webcomponents-base/dist/types/Integer.js";
6
10
  import NavigationMode from "@ui5/webcomponents-base/dist/types/NavigationMode.js";
11
+ import { getEffectiveAriaLabelText } from "@ui5/webcomponents-base/dist/util/AriaLabelHelper.js";
12
+ import { getI18nBundle } from "@ui5/webcomponents-base/dist/i18nBundle.js";
13
+ import debounce from "@ui5/webcomponents-base/dist/util/debounce.js";
14
+ import isElementInView from "@ui5/webcomponents-base/dist/util/isElementInView.js";
7
15
  import ListMode from "./types/ListMode.js";
16
+ import ListGrowingMode from "./types/ListGrowingMode.js";
8
17
  import ListSeparators from "./types/ListSeparators.js";
9
18
  import BusyIndicator from "./BusyIndicator.js";
10
19
 
@@ -14,19 +23,29 @@ import ListTemplate from "./generated/templates/ListTemplate.lit.js";
14
23
  // Styles
15
24
  import listCss from "./generated/themes/List.css.js";
16
25
 
17
- const BUSYINDICATOR_HEIGHT = 48; // px
26
+ // Texts
27
+ import {
28
+ LOAD_MORE_TEXT, ARIA_LABEL_LIST_SELECTABLE,
29
+ ARIA_LABEL_LIST_MULTISELECTABLE,
30
+ ARIA_LABEL_LIST_DELETABLE,
31
+ } from "./generated/i18n/i18n-defaults.js";
32
+
18
33
  const INFINITE_SCROLL_DEBOUNCE_RATE = 250; // ms
19
34
 
35
+ const PAGE_UP_DOWN_SIZE = 10;
36
+
20
37
  /**
21
38
  * @public
22
39
  */
23
40
  const metadata = {
24
41
  tag: "ui5-list",
25
42
  managedSlots: true,
43
+ fastNavigation: true,
26
44
  slots: /** @lends sap.ui.webcomponents.main.List.prototype */ {
27
45
 
28
46
  /**
29
- * Defines the <code>ui5-li</code> header.
47
+ * Defines the component header.
48
+ * <br><br>
30
49
  * <b>Note:</b> When <code>header</code> is set, the
31
50
  * <code>headerText</code> property is ignored.
32
51
  *
@@ -39,11 +58,12 @@ const metadata = {
39
58
  },
40
59
 
41
60
  /**
42
- * Defines the items of the <code>ui5-list</code>.
43
- * <br><b>Note:</b> Use <code>ui5-li</code>, <code>ui5-li-custom</code>, and <code>ui5-li-groupheader</code> for the intended design.
61
+ * Defines the items of the component.
62
+ * <br><br>
63
+ * <b>Note:</b> Use <code>ui5-li</code>, <code>ui5-li-custom</code>, and <code>ui5-li-groupheader</code> for the intended design.
44
64
  *
45
- * @type {HTMLElement[]}
46
- * @slot
65
+ * @type {sap.ui.webcomponents.main.IListItem[]}
66
+ * @slot items
47
67
  * @public
48
68
  */
49
69
  "default": {
@@ -54,12 +74,12 @@ const metadata = {
54
74
  properties: /** @lends sap.ui.webcomponents.main.List.prototype */ {
55
75
 
56
76
  /**
57
- * Defines the <code>ui5-list</code> header text.
77
+ * Defines the component header text.
58
78
  * <br><br>
59
79
  * <b>Note:</b> If <code>header</code> is set this property is ignored.
60
80
  *
61
81
  * @type {string}
62
- * @defaultvalue: ""
82
+ * @defaultvalue ""
63
83
  * @public
64
84
  */
65
85
  headerText: {
@@ -70,7 +90,7 @@ const metadata = {
70
90
  * Defines the footer text.
71
91
  *
72
92
  * @type {string}
73
- * @defaultvalue: ""
93
+ * @defaultvalue ""
74
94
  * @public
75
95
  */
76
96
  footerText: {
@@ -78,23 +98,23 @@ const metadata = {
78
98
  },
79
99
 
80
100
  /**
81
- * Determines whether the list items are indented.
101
+ * Determines whether the component is indented.
82
102
  *
83
103
  * @type {boolean}
84
104
  * @defaultvalue false
85
105
  * @public
86
106
  */
87
- inset: {
107
+ indent: {
88
108
  type: Boolean,
89
109
  },
90
110
 
91
111
  /**
92
- * Defines the mode of the <code>ui5-list</code>.
112
+ * Defines the mode of the component.
93
113
  * <br><br>
94
- * <b>Note:</b> Avalaible options are <code>None</code>, <code>SingleSelect</code>,
95
- * <code>MultiSelect</code>, and <code>Delete</code>.
114
+ * <b>Note:</b> Available options are <code>None</code>, <code>SingleSelect</code>, <code>SingleSelectBegin</code>,
115
+ * <code>SingleSelectEnd</code>, <code>MultiSelect</code>, and <code>Delete</code>.
96
116
  *
97
- * @type {string}
117
+ * @type {ListMode}
98
118
  * @defaultvalue "None"
99
119
  * @public
100
120
  */
@@ -104,10 +124,10 @@ const metadata = {
104
124
  },
105
125
 
106
126
  /**
107
- * Defines the text that is displayed when the <code>ui5-list</code> contains no items.
127
+ * Defines the text that is displayed when the component contains no items.
108
128
  *
109
129
  * @type {string}
110
- * @defaultvalue: ""
130
+ * @defaultvalue ""
111
131
  * @public
112
132
  */
113
133
  noDataText: {
@@ -125,7 +145,7 @@ const metadata = {
125
145
  * item doesn't have a bottom separator.</li>
126
146
  * </ul>
127
147
  *
128
- * @type {string}
148
+ * @type {ListSeparators}
129
149
  * @defaultvalue "All"
130
150
  * @public
131
151
  */
@@ -135,22 +155,34 @@ const metadata = {
135
155
  },
136
156
 
137
157
  /**
138
- * Defines if the component would fire the <code>loadMore</code> event
139
- * when the user scrolls to the bottom of the list, and helps achieving an "infinite scroll" effect
140
- * by adding new items each time.
158
+ * Defines whether the component will have growing capability either by pressing a <code>More</code> button,
159
+ * or via user scroll. In both cases <code>load-more</code> event is fired.
160
+ * <br><br>
141
161
  *
142
- * @type {boolean}
143
- * @defaultvalue false
162
+ * Available options:
163
+ * <br><br>
164
+ * <code>Button</code> - Shows a <code>More</code> button at the bottom of the list,
165
+ * pressing of which triggers the <code>load-more</code> event.
166
+ * <br>
167
+ * <code>Scroll</code> - The <code>load-more</code> event is triggered when the user scrolls to the bottom of the list;
168
+ * <br>
169
+ * <code>None</code> (default) - The growing is off.
170
+ * <br><br>
171
+ *
172
+ * <b>Restrictions:</b> <code>growing="Scroll"</code> is not supported for Internet Explorer,
173
+ * on IE the component will fallback to <code>growing="Button"</code>.
174
+ * @type {ListGrowingMode}
175
+ * @defaultvalue "None"
176
+ * @since 1.0.0-rc.13
144
177
  * @public
145
- * @since 1.0.0-rc.6
146
178
  */
147
- infiniteScroll: {
148
- type: Boolean,
179
+ growing: {
180
+ type: ListGrowingMode,
181
+ defaultValue: ListGrowingMode.None,
149
182
  },
150
183
 
151
184
  /**
152
- * Defines if the component would display a loading indicator at the bottom of the list.
153
- * It's especially useful, when combined with <code>infiniteScroll</code>.
185
+ * Defines if the component would display a loading indicator over the list.
154
186
  *
155
187
  * @type {boolean}
156
188
  * @defaultvalue false
@@ -160,6 +192,72 @@ const metadata = {
160
192
  busy: {
161
193
  type: Boolean,
162
194
  },
195
+
196
+ /**
197
+ * Defines the delay in milliseconds, after which the busy indicator will show up for this component.
198
+ *
199
+ * @type {Integer}
200
+ * @defaultValue 1000
201
+ * @public
202
+ */
203
+ busyDelay: {
204
+ type: Integer,
205
+ defaultValue: 1000,
206
+ },
207
+
208
+ /**
209
+ * Defines the accessible name of the component.
210
+ *
211
+ * @type {String}
212
+ * @defaultvalue ""
213
+ * @public
214
+ * @since 1.0.0-rc.15
215
+ */
216
+ accessibleName: {
217
+ type: String,
218
+ },
219
+
220
+ /**
221
+ * Defines the IDs of the elements that label the input.
222
+ *
223
+ * @type {String}
224
+ * @defaultvalue ""
225
+ * @public
226
+ * @since 1.0.0-rc.15
227
+ */
228
+ accessibleNameRef: {
229
+ type: String,
230
+ defaultValue: "",
231
+ },
232
+
233
+ /**
234
+ * Defines the accessible role of the component.
235
+ * <br><br>
236
+ * @public
237
+ * @type {String}
238
+ * @defaultvalue "list"
239
+ * @since 1.0.0-rc.15
240
+ */
241
+ accessibleRole: {
242
+ type: String,
243
+ defaultValue: "list",
244
+ },
245
+
246
+ /**
247
+ * Defines if the entire list is in view port.
248
+ * @private
249
+ */
250
+ _inViewport: {
251
+ type: Boolean,
252
+ },
253
+
254
+ /**
255
+ * Defines the active state of the <code>More</code> button.
256
+ * @private
257
+ */
258
+ _loadMoreActive: {
259
+ type: Boolean,
260
+ },
163
261
  },
164
262
  events: /** @lends sap.ui.webcomponents.main.List.prototype */ {
165
263
 
@@ -167,11 +265,45 @@ const metadata = {
167
265
  * Fired when an item is activated, unless the item's <code>type</code> property
168
266
  * is set to <code>Inactive</code>.
169
267
  *
170
- * @event
171
- * @param {HTMLElement} item the clicked item.
268
+ * @event sap.ui.webcomponents.main.List#item-click
269
+ * @allowPreventDefault
270
+ * @param {HTMLElement} item The clicked item.
271
+ * @public
272
+ */
273
+ "item-click": {
274
+ detail: {
275
+ item: { type: HTMLElement },
276
+ },
277
+ },
278
+
279
+ /**
280
+ * Fired when the <code>Close</code> button of any item is clicked
281
+ * <br><br>
282
+ * <b>Note:</b> This event is applicable to <code>ui5-li-notification</code> items only,
283
+ * not to be confused with <code>item-delete</code>.
284
+ *
285
+ * @event sap.ui.webcomponents.main.List#item-close
286
+ * @param {HTMLElement} item the item about to be closed.
287
+ * @public
288
+ * @since 1.0.0-rc.8
289
+ */
290
+ "item-close": {
291
+ detail: {
292
+ item: { type: HTMLElement },
293
+ },
294
+ },
295
+
296
+ /**
297
+ * Fired when the <code>Toggle</code> button of any item is clicked.
298
+ * <br><br>
299
+ * <b>Note:</b> This event is applicable to <code>ui5-li-notification-group</code> items only.
300
+ *
301
+ * @event sap.ui.webcomponents.main.List#item-toggle
302
+ * @param {HTMLElement} item the toggled item.
172
303
  * @public
304
+ * @since 1.0.0-rc.8
173
305
  */
174
- itemClick: {
306
+ "item-toggle": {
175
307
  detail: {
176
308
  item: { type: HTMLElement },
177
309
  },
@@ -181,12 +313,13 @@ const metadata = {
181
313
  * Fired when the Delete button of any item is pressed.
182
314
  * <br><br>
183
315
  * <b>Note:</b> A Delete button is displayed on each item,
184
- * when the <code>ui5-list</code> <code>mode</code> property is set to <code>Delete</code>.
185
- * @event
316
+ * when the component <code>mode</code> property is set to <code>Delete</code>.
317
+ *
318
+ * @event sap.ui.webcomponents.main.List#item-delete
186
319
  * @param {HTMLElement} item the deleted item.
187
320
  * @public
188
321
  */
189
- itemDelete: {
322
+ "item-delete": {
190
323
  detail: {
191
324
  item: { type: HTMLElement },
192
325
  },
@@ -194,14 +327,14 @@ const metadata = {
194
327
 
195
328
  /**
196
329
  * Fired when selection is changed by user interaction
197
- * in <code>SingleSelect</code> and <code>MultiSelect</code> modes.
330
+ * in <code>SingleSelect</code>, <code>SingleSelectBegin</code>, <code>SingleSelectEnd</code> and <code>MultiSelect</code> modes.
198
331
  *
199
- * @event
332
+ * @event sap.ui.webcomponents.main.List#selection-change
200
333
  * @param {Array} selectedItems An array of the selected items.
201
334
  * @param {Array} previouslySelectedItems An array of the previously selected items.
202
335
  * @public
203
336
  */
204
- selectionChange: {
337
+ "selection-change": {
205
338
  detail: {
206
339
  selectedItems: { type: Array },
207
340
  previouslySelectedItems: { type: Array },
@@ -211,30 +344,30 @@ const metadata = {
211
344
 
212
345
  /**
213
346
  * Fired when the user scrolls to the bottom of the list.
214
- * <br>
215
- * <b>Note:</b> The event is fired when the <code>infiniteScroll</code> property is enabled.
347
+ * <br><br>
348
+ * <b>Note:</b> The event is fired when the <code>growing='Scroll'</code> property is enabled.
216
349
  *
217
- * @event
350
+ * @event sap.ui.webcomponents.main.List#load-more
218
351
  * @public
219
352
  * @since 1.0.0-rc.6
220
353
  */
221
- loadMore: {},
354
+ "load-more": {},
222
355
  },
223
356
  };
224
357
 
225
358
  /**
226
359
  * @class
227
360
  *
228
- * <h3 class="comment-api-title"> Overview </h3>
361
+ * <h3 class="comment-api-title">Overview</h3>
229
362
  *
230
363
  * The <code>ui5-list</code> component allows displaying a list of items, advanced keyboard
231
364
  * handling support for navigating between items, and predefined modes to improve the development efficiency.
232
365
  * <br><br>
233
- * The <code>ui5-list</code> is а container for the available list items:
366
+ * The <code>ui5-list</code> is a container for the available list items:
234
367
  * <ul>
235
368
  * <li><code>ui5-li</code></li>
236
369
  * <li><code>ui5-li-custom</code></li>
237
- * <li><code>ui5-li-group-header</code></li>
370
+ * <li><code>ui5-li-groupheader</code></li>
238
371
  * </ul>
239
372
  * <br><br>
240
373
  * To benefit from the built-in selection mechanism, you can use the available
@@ -243,6 +376,34 @@ const metadata = {
243
376
  * <br><br>
244
377
  * Additionally, the <code>ui5-list</code> provides header, footer, and customization for the list item separators.
245
378
  *
379
+ * <br><br>
380
+ * <h3>Keyboard Handling</h3>
381
+ *
382
+ * <h4>Basic Navigation</h4
383
+ * The <code>ui5-list</code> provides advanced keyboard handling.
384
+ * When a list is focused the user can use the following keyboard
385
+ * shortcuts in order to perform a navigation:
386
+ * <br>
387
+ *
388
+ * <ul>
389
+ * <li>[UP/DOWN] - Navigates up and down the items</li>
390
+ * <li>[HOME] - Navigates to first item</li>
391
+ * <li>[END] - Navigates to the last item</li>
392
+ * </ul>
393
+ *
394
+ * The user can use the following keyboard shortcuts to perform actions (such as select, delete),
395
+ * when the <code>mode</code> property is in use:
396
+ * <ul>
397
+ * <li>[SPACE] - Select an item (if <code>type</code> is 'Active') when <code>mode</code> is selection</li>
398
+ * <li>[DELETE] - Delete an item if <code>mode</code> property is <code>Delete</code></li>
399
+ * </ul>
400
+ *
401
+ * <h4>Fast Navigation</h4>
402
+ * This component provides a build in fast navigation group which can be used via <code>F6 / Shift + F6</code> or <code> Ctrl + Alt(Option) + Down / Ctrl + Alt(Option) + Up</code>.
403
+ * In order to use this functionality, you need to import the following module:
404
+ * <code>import "@ui5/webcomponents-base/dist/features/F6Navigation.js"</code>
405
+ * <br><br>
406
+ *
246
407
  * <h3>ES6 Module Import</h3>
247
408
  *
248
409
  * <code>import "@ui5/webcomponents/dist/List.js";</code>
@@ -251,7 +412,7 @@ const metadata = {
251
412
  * <br>
252
413
  * <code>import "@ui5/webcomponents/dist/CustomListItem.js";</code> (for <code>ui5-li-custom</code>)
253
414
  * <br>
254
- * <code>import "@ui5/webcomponents/dist/GroupHeaderListItem.js";</code> (for <code>ui5-li-group-header</code>)
415
+ * <code>import "@ui5/webcomponents/dist/GroupHeaderListItem.js";</code> (for <code>ui5-li-groupheader</code>)
255
416
  *
256
417
  * @constructor
257
418
  * @author SAP SE
@@ -278,6 +439,14 @@ class List extends UI5Element {
278
439
  return listCss;
279
440
  }
280
441
 
442
+ static async onDefine() {
443
+ List.i18nBundle = await getI18nBundle("@ui5/webcomponents");
444
+ }
445
+
446
+ static get dependencies() {
447
+ return [BusyIndicator];
448
+ }
449
+
281
450
  constructor() {
282
451
  super();
283
452
  this.initItemNavigation();
@@ -290,35 +459,177 @@ class List extends UI5Element {
290
459
 
291
460
  this._previouslySelectedItem = null;
292
461
 
462
+ // Indicates that the List has already subscribed for resize.
463
+ this.resizeListenerAttached = false;
464
+
465
+ // Indicates if the IntersectionObserver started observing the List
466
+ this.listEndObserved = false;
467
+
293
468
  this.addEventListener("ui5-_press", this.onItemPress.bind(this));
469
+ this.addEventListener("ui5-close", this.onItemClose.bind(this));
470
+ this.addEventListener("ui5-toggle", this.onItemToggle.bind(this));
294
471
  this.addEventListener("ui5-_focused", this.onItemFocused.bind(this));
295
- this.addEventListener("ui5-_forwardAfter", this.onForwardAfter.bind(this));
296
- this.addEventListener("ui5-_forwardBefore", this.onForwardBefore.bind(this));
297
- this.addEventListener("ui5-_selectionRequested", this.onSelectionRequested.bind(this));
472
+ this.addEventListener("ui5-_forward-after", this.onForwardAfter.bind(this));
473
+ this.addEventListener("ui5-_forward-before", this.onForwardBefore.bind(this));
474
+ this.addEventListener("ui5-_selection-requested", this.onSelectionRequested.bind(this));
475
+ this.addEventListener("ui5-_focus-requested", this.focusUploadCollectionItem.bind(this));
476
+
477
+ this._handleResize = this.checkListInViewport.bind(this);
478
+
479
+ // Indicates the List bottom most part has been detected by the IntersectionObserver
480
+ // for the first time.
481
+ this.initialIntersection = true;
482
+ }
483
+
484
+ onExitDOM() {
485
+ this.unobserveListEnd();
486
+ this.resizeListenerAttached = false;
487
+ ResizeHandler.deregister(this.getDomRef(), this._handleResize);
488
+ }
489
+
490
+ onBeforeRendering() {
491
+ this.prepareListItems();
492
+ }
493
+
494
+ onAfterRendering() {
495
+ if (this.growsOnScroll) {
496
+ this.observeListEnd();
497
+ } else if (this.listEndObserved) {
498
+ this.unobserveListEnd();
499
+ }
500
+
501
+ if (this.grows) {
502
+ this.checkListInViewport();
503
+ this.attachForResize();
504
+ }
505
+ }
506
+
507
+ attachForResize() {
508
+ if (!this.resizeListenerAttached) {
509
+ this.resizeListenerAttached = true;
510
+ ResizeHandler.register(this.getDomRef(), this._handleResize);
511
+ }
298
512
  }
299
513
 
300
514
  get shouldRenderH1() {
301
515
  return !this.header.length && this.headerText;
302
516
  }
303
517
 
518
+ get headerID() {
519
+ return `${this._id}-header`;
520
+ }
521
+
522
+ get modeLabelID() {
523
+ return `${this._id}-modeLabel`;
524
+ }
525
+
526
+ get listEndDOM() {
527
+ return this.shadowRoot.querySelector(".ui5-list-end-marker");
528
+ }
529
+
530
+ get hasData() {
531
+ return this.getSlottedNodes("items").length !== 0;
532
+ }
533
+
304
534
  get showNoDataText() {
305
- return this.items.length === 0 && this.noDataText;
535
+ return !this.hasData && this.noDataText;
306
536
  }
307
537
 
308
- get showBusy() {
309
- return this.busy || this.infiniteScroll;
538
+ get isDelete() {
539
+ return this.mode === ListMode.Delete;
310
540
  }
311
541
 
312
- onBeforeRendering() {
313
- this.prepareListItems();
542
+ get isSingleSelect() {
543
+ return [
544
+ ListMode.SingleSelect,
545
+ ListMode.SingleSelectBegin,
546
+ ListMode.SingleSelectEnd,
547
+ ListMode.SingleSelectAuto,
548
+ ].includes(this.mode);
549
+ }
550
+
551
+ get isMultiSelect() {
552
+ return this.mode === ListMode.MultiSelect;
553
+ }
554
+
555
+ get ariaLabelledBy() {
556
+ if (this.accessibleNameRef || this.accessibleName) {
557
+ return undefined;
558
+ }
559
+ const ids = [];
560
+
561
+ if (this.isMultiSelect || this.isSingleSelect || this.isDelete) {
562
+ ids.push(this.modeLabelID);
563
+ }
564
+
565
+ if (this.shouldRenderH1) {
566
+ ids.push(this.headerID);
567
+ }
568
+
569
+ return ids.length ? ids.join(" ") : undefined;
570
+ }
571
+
572
+ get ariaLabelTxt() {
573
+ return getEffectiveAriaLabelText(this);
574
+ }
575
+
576
+ get ariaLabelModeText() {
577
+ if (this.isMultiSelect) {
578
+ return List.i18nBundle.getText(ARIA_LABEL_LIST_MULTISELECTABLE);
579
+ }
580
+ if (this.isSingleSelect) {
581
+ return List.i18nBundle.getText(ARIA_LABEL_LIST_SELECTABLE);
582
+ }
583
+ if (this.isDelete) {
584
+ return List.i18nBundle.getText(ARIA_LABEL_LIST_DELETABLE);
585
+ }
586
+
587
+ return undefined;
588
+ }
589
+
590
+ get grows() {
591
+ return this.growing !== ListGrowingMode.None;
592
+ }
593
+
594
+ get growsOnScroll() {
595
+ return this.growing === ListGrowingMode.Scroll && !isIE();
596
+ }
597
+
598
+ get growsWithButton() {
599
+ if (isIE()) {
600
+ // On IE fallback to "More" button, even if growing of type "Scroll" is set.
601
+ return this.grows;
602
+ }
603
+
604
+ return this.growing === ListGrowingMode.Button;
605
+ }
606
+
607
+ get _growingButtonText() {
608
+ return List.i18nBundle.getText(LOAD_MORE_TEXT);
609
+ }
610
+
611
+ get busyIndPosition() {
612
+ if (isIE() || !this.grows) {
613
+ return "absolute";
614
+ }
615
+
616
+ return this._inViewport ? "absolute" : "sticky";
617
+ }
618
+
619
+ get styles() {
620
+ return {
621
+ busyInd: {
622
+ position: this.busyIndPosition,
623
+ },
624
+ };
314
625
  }
315
626
 
316
627
  initItemNavigation() {
317
628
  this._itemNavigation = new ItemNavigation(this, {
629
+ skipItemsSize: PAGE_UP_DOWN_SIZE, // PAGE_UP and PAGE_DOWN will skip trough 10 items
318
630
  navigationMode: NavigationMode.Vertical,
631
+ getItemsCallback: () => this.getEnabledItems(),
319
632
  });
320
-
321
- this._itemNavigation.getItemsCallback = () => this.getSlottedNodes("items");
322
633
  }
323
634
 
324
635
  prepareListItems() {
@@ -336,6 +647,34 @@ class List extends UI5Element {
336
647
  this._previouslySelectedItem = null;
337
648
  }
338
649
 
650
+ async observeListEnd() {
651
+ if (!this.listEndObserved) {
652
+ await renderFinished();
653
+ this.getIntersectionObserver().observe(this.listEndDOM);
654
+ this.listEndObserved = true;
655
+ }
656
+ }
657
+
658
+ unobserveListEnd() {
659
+ if (this.growingIntersectionObserver) {
660
+ this.growingIntersectionObserver.disconnect();
661
+ this.growingIntersectionObserver = null;
662
+ this.listEndObserved = false;
663
+ }
664
+ }
665
+
666
+ onInteresection(entries) {
667
+ if (this.initialIntersection) {
668
+ this.initialIntersection = false;
669
+ return;
670
+ }
671
+ entries.forEach(entry => {
672
+ if (entry.isIntersecting) {
673
+ debounce(this.loadMore.bind(this), INFINITE_SCROLL_DEBOUNCE_RATE);
674
+ }
675
+ });
676
+ }
677
+
339
678
  /*
340
679
  * ITEM SELECTION BASED ON THE CURRENT MODE
341
680
  */
@@ -349,7 +688,7 @@ class List extends UI5Element {
349
688
  }
350
689
 
351
690
  if (selectionChange) {
352
- this.fireEvent("selectionChange", {
691
+ this.fireEvent("selection-change", {
353
692
  selectedItems: this.getSelectedItems(),
354
693
  previouslySelectedItems,
355
694
  selectionComponentPressed: event.detail.selectionComponentPressed,
@@ -377,13 +716,17 @@ class List extends UI5Element {
377
716
  return this.handleSingleSelect(item);
378
717
  }
379
718
 
719
+ handleSingleSelectAuto(item) {
720
+ return this.handleSingleSelect(item);
721
+ }
722
+
380
723
  handleMultiSelect(item, selected) {
381
724
  item.selected = selected;
382
725
  return true;
383
726
  }
384
727
 
385
728
  handleDelete(item) {
386
- this.fireEvent("itemDelete", { item });
729
+ this.fireEvent("item-delete", { item });
387
730
  }
388
731
 
389
732
  deselectSelectedItems() {
@@ -394,18 +737,8 @@ class List extends UI5Element {
394
737
  return this.getSlottedNodes("items").filter(item => item.selected);
395
738
  }
396
739
 
397
- getFirstSelectedItem() {
398
- const slottedItems = this.getSlottedNodes("items");
399
- let firstSelectedItem = null;
400
-
401
- for (let i = 0; i < slottedItems.length; i++) {
402
- if (slottedItems[i].selected) {
403
- firstSelectedItem = slottedItems[i];
404
- break;
405
- }
406
- }
407
-
408
- return firstSelectedItem;
740
+ getEnabledItems() {
741
+ return this.getSlottedNodes("items").filter(item => !item.disabled);
409
742
  }
410
743
 
411
744
  _onkeydown(event) {
@@ -414,6 +747,50 @@ class List extends UI5Element {
414
747
  }
415
748
  }
416
749
 
750
+ _onLoadMoreKeydown(event) {
751
+ if (isSpace(event)) {
752
+ event.preventDefault();
753
+ this._loadMoreActive = true;
754
+ }
755
+
756
+ if (isEnter(event)) {
757
+ this._onLoadMoreClick();
758
+ this._loadMoreActive = true;
759
+ }
760
+
761
+ if (isTabNext(event)) {
762
+ this.setPreviouslyFocusedItem(event.target);
763
+ this.focusAfterElement();
764
+ }
765
+ }
766
+
767
+ _onLoadMoreKeyup(event) {
768
+ if (isSpace(event)) {
769
+ this._onLoadMoreClick();
770
+ }
771
+ this._loadMoreActive = false;
772
+ }
773
+
774
+ _onLoadMoreMousedown() {
775
+ this._loadMoreActive = true;
776
+ }
777
+
778
+ _onLoadMoreMouseup() {
779
+ this._loadMoreActive = false;
780
+ }
781
+
782
+ _onLoadMoreClick() {
783
+ this.loadMore();
784
+ }
785
+
786
+ checkListInViewport() {
787
+ this._inViewport = isElementInView(this.getDomRef());
788
+ }
789
+
790
+ loadMore() {
791
+ this.fireEvent("load-more");
792
+ }
793
+
417
794
  /*
418
795
  * KEYBOARD SUPPORT
419
796
  */
@@ -433,7 +810,7 @@ class List extends UI5Element {
433
810
  }
434
811
 
435
812
  if (lastTabbableEl === target) {
436
- if (this.getFirstSelectedItem()) {
813
+ if (this.getFirstItem(x => x.selected && !x.disabled)) {
437
814
  this.focusFirstSelectedItem();
438
815
  } else if (this.getPreviouslyFocusedItem()) {
439
816
  this.focusPreviouslyFocusedItem();
@@ -446,13 +823,6 @@ class List extends UI5Element {
446
823
  }
447
824
  }
448
825
 
449
- _onScroll(event) {
450
- if (!this.infiniteScroll) {
451
- return;
452
- }
453
- this.debounce(this.loadMore.bind(this, event.target), INFINITE_SCROLL_DEBOUNCE_RATE);
454
- }
455
-
456
826
  _onfocusin(event) {
457
827
  // If the focusin event does not origin from one of the 'triggers' - ignore it.
458
828
  if (!this.isForwardElement(this.getNormalizedTarget(event.target))) {
@@ -463,7 +833,7 @@ class List extends UI5Element {
463
833
  // The focus arrives in the List for the first time.
464
834
  // If there is selected item - focus it or focus the first item.
465
835
  if (!this.getPreviouslyFocusedItem()) {
466
- if (this.getFirstSelectedItem()) {
836
+ if (this.getFirstItem(x => x.selected && !x.disabled)) {
467
837
  this.focusFirstSelectedItem();
468
838
  } else {
469
839
  this.focusFirstItem();
@@ -476,11 +846,13 @@ class List extends UI5Element {
476
846
  // The focus returns to the List,
477
847
  // focus the first selected item or the previously focused element.
478
848
  if (!this.getForwardingFocus()) {
479
- if (this.getFirstSelectedItem()) {
849
+ if (this.getFirstItem(x => x.selected && !x.disabled)) {
480
850
  this.focusFirstSelectedItem();
481
851
  } else {
482
852
  this.focusPreviouslyFocusedItem();
483
853
  }
854
+
855
+ event.stopImmediatePropagation();
484
856
  }
485
857
 
486
858
  this.setForwardingFocus(false);
@@ -488,26 +860,40 @@ class List extends UI5Element {
488
860
 
489
861
  isForwardElement(node) {
490
862
  const nodeId = node.id;
863
+ const afterElement = this.getAfterElement();
864
+ const beforeElement = this.getBeforeElement();
491
865
 
492
- if (this._id === nodeId || this.getBeforeElement().id === nodeId) {
866
+ if (this._id === nodeId || (beforeElement && beforeElement.id === nodeId)) {
493
867
  return true;
494
868
  }
495
869
 
496
- return this.getAfterElement().id === nodeId;
870
+ return afterElement && afterElement.id === nodeId;
497
871
  }
498
872
 
499
873
  onItemFocused(event) {
500
874
  const target = event.target;
501
875
 
502
- this._itemNavigation.update(target);
503
- this.fireEvent("itemFocused", { item: target });
876
+ this._itemNavigation.setCurrentItem(target);
877
+ this.fireEvent("item-focused", { item: target });
878
+
879
+ if (this.mode === ListMode.SingleSelectAuto) {
880
+ this.onSelectionRequested({
881
+ detail: {
882
+ item: target,
883
+ selectionComponentPressed: false,
884
+ selected: true,
885
+ key: event.detail.key,
886
+ },
887
+ });
888
+ }
504
889
  }
505
890
 
506
891
  onItemPress(event) {
507
892
  const pressedItem = event.detail.item;
508
893
 
509
- this.fireEvent("itemPress", { item: pressedItem });
510
- this.fireEvent("itemClick", { item: pressedItem });
894
+ if (!this.fireEvent("item-click", { item: pressedItem }, true)) {
895
+ return;
896
+ }
511
897
 
512
898
  if (!this._selectionRequested && this.mode !== ListMode.Delete) {
513
899
  this._selectionRequested = true;
@@ -524,14 +910,27 @@ class List extends UI5Element {
524
910
  this._selectionRequested = false;
525
911
  }
526
912
 
913
+ // This is applicable to NoficationListItem
914
+ onItemClose(event) {
915
+ this.fireEvent("item-close", { item: event.detail.item });
916
+ }
917
+
918
+ onItemToggle(event) {
919
+ this.fireEvent("item-toggle", { item: event.detail.item });
920
+ }
921
+
527
922
  onForwardBefore(event) {
528
923
  this.setPreviouslyFocusedItem(event.target);
529
924
  this.focusBeforeElement();
925
+ event.stopImmediatePropagation();
530
926
  }
531
927
 
532
928
  onForwardAfter(event) {
533
929
  this.setPreviouslyFocusedItem(event.target);
534
- this.focusAfterElement();
930
+
931
+ if (!this.growsWithButton) {
932
+ this.focusAfterElement();
933
+ }
535
934
  }
536
935
 
537
936
  focusBeforeElement() {
@@ -545,7 +944,8 @@ class List extends UI5Element {
545
944
  }
546
945
 
547
946
  focusFirstItem() {
548
- const firstItem = this.getFirstItem();
947
+ // only enabled items are focusable
948
+ const firstItem = this.getFirstItem(x => !x.disabled);
549
949
 
550
950
  if (firstItem) {
551
951
  firstItem.focus();
@@ -561,13 +961,31 @@ class List extends UI5Element {
561
961
  }
562
962
 
563
963
  focusFirstSelectedItem() {
564
- const firstSelectedItem = this.getFirstSelectedItem();
964
+ // only enabled items are focusable
965
+ const firstSelectedItem = this.getFirstItem(x => x.selected && !x.disabled);
565
966
 
566
967
  if (firstSelectedItem) {
567
968
  firstSelectedItem.focus();
568
969
  }
569
970
  }
570
971
 
972
+ /**
973
+ * Focuses a list item and sets its tabindex to "0" via the ItemNavigation
974
+ * @protected
975
+ * @param item
976
+ */
977
+ focusItem(item) {
978
+ this._itemNavigation.setCurrentItem(item);
979
+ item.focus();
980
+ }
981
+
982
+ focusUploadCollectionItem(event) {
983
+ setTimeout(() => {
984
+ this.setPreviouslyFocusedItem(event.target);
985
+ this.focusPreviouslyFocusedItem();
986
+ }, 0);
987
+ }
988
+
571
989
  setForwardingFocus(forwardingFocus) {
572
990
  this._forwardingFocus = forwardingFocus;
573
991
  }
@@ -584,9 +1002,22 @@ class List extends UI5Element {
584
1002
  return this._previouslyFocusedItem;
585
1003
  }
586
1004
 
587
- getFirstItem() {
1005
+ getFirstItem(filter) {
588
1006
  const slottedItems = this.getSlottedNodes("items");
589
- return !!slottedItems.length && slottedItems[0];
1007
+ let firstItem = null;
1008
+
1009
+ if (!filter) {
1010
+ return !!slottedItems.length && slottedItems[0];
1011
+ }
1012
+
1013
+ for (let i = 0; i < slottedItems.length; i++) {
1014
+ if (filter(slottedItems[i])) {
1015
+ firstItem = slottedItems[i];
1016
+ break;
1017
+ }
1018
+ }
1019
+
1020
+ return firstItem;
590
1021
  }
591
1022
 
592
1023
  getAfterElement() {
@@ -617,32 +1048,16 @@ class List extends UI5Element {
617
1048
  return focused;
618
1049
  }
619
1050
 
620
- loadMore(el) {
621
- const scrollTop = el.scrollTop;
622
- const height = el.offsetHeight;
623
- const scrollHeight = el.scrollHeight;
624
-
625
- if (this.previousScrollPosition > scrollTop) { // skip scrolling upwards
626
- this.previousScrollPosition = scrollTop;
627
- return;
628
- }
629
- this.previousScrollPosition = scrollTop;
630
-
631
- if (scrollHeight - BUSYINDICATOR_HEIGHT <= height + scrollTop) {
632
- this.fireEvent("loadMore");
1051
+ getIntersectionObserver() {
1052
+ if (!this.growingIntersectionObserver) {
1053
+ this.growingIntersectionObserver = new IntersectionObserver(this.onInteresection.bind(this), {
1054
+ root: null,
1055
+ rootMargin: "0px",
1056
+ threshold: 1.0,
1057
+ });
633
1058
  }
634
- }
635
1059
 
636
- debounce(fn, delay) {
637
- clearTimeout(this.debounceInterval);
638
- this.debounceInterval = setTimeout(() => {
639
- this.debounceInterval = null;
640
- fn();
641
- }, delay);
642
- }
643
-
644
- static async onDefine() {
645
- await BusyIndicator.define();
1060
+ return this.growingIntersectionObserver;
646
1061
  }
647
1062
  }
648
1063