@ui5/webcomponents 1.19.0 → 1.20.0-rc.1

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 (524) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/List.d.ts +1 -0
  3. package/dist/List.js +4 -0
  4. package/dist/List.js.map +1 -1
  5. package/dist/ListItemBase.js +2 -0
  6. package/dist/ListItemBase.js.map +1 -1
  7. package/dist/SegmentedButton.js +3 -0
  8. package/dist/SegmentedButton.js.map +1 -1
  9. package/dist/TimePicker.js +3 -1
  10. package/dist/TimePicker.js.map +1 -1
  11. package/dist/Tree.d.ts +1 -15
  12. package/dist/Tree.js +1 -9
  13. package/dist/Tree.js.map +1 -1
  14. package/dist/TreeItem.d.ts +1 -1
  15. package/dist/TreeItem.js +1 -1
  16. package/dist/TreeItem.js.map +1 -1
  17. package/dist/TreeItemBase.d.ts +2 -19
  18. package/dist/TreeItemBase.js +4 -23
  19. package/dist/TreeItemBase.js.map +1 -1
  20. package/dist/assets/messagebundle_en-5cd4cf2a.js +1 -0
  21. package/dist/assets/parameters-bundle.css-062ff31b.js +1 -0
  22. package/dist/assets/parameters-bundle.css-071f5d23.js +1 -0
  23. package/dist/assets/parameters-bundle.css-2e9b128f.js +1 -0
  24. package/dist/assets/parameters-bundle.css-4ff20877.js +1 -0
  25. package/dist/assets/parameters-bundle.css-5c0f33e5.js +1 -0
  26. package/dist/assets/parameters-bundle.css-607a8736.js +1 -0
  27. package/dist/assets/parameters-bundle.css-68df1060.js +1 -0
  28. package/dist/assets/parameters-bundle.css-6bc0f6b8.js +1 -0
  29. package/dist/assets/parameters-bundle.css-82297705.js +1 -0
  30. package/dist/assets/parameters-bundle.css-8bf039b3.js +1 -0
  31. package/dist/assets/parameters-bundle.css-c518d318.js +1 -0
  32. package/dist/assets/parameters-bundle.css-e45e8f20.js +1 -0
  33. package/dist/assets/parameters-bundle.css-e96e9d99.js +1 -0
  34. package/dist/assets/parameters-bundle.css-f0d804c1.js +1 -0
  35. package/dist/assets/parameters-bundle.css-f829b27d.js +1 -0
  36. package/dist/assets/test/pages/{ComboBox.html-c1a9c233.js → ComboBox.html-3a8094e4.js} +1 -1
  37. package/dist/assets/test/pages/{Icon.html-84d47be2.js → Icon.html-12111283.js} +1 -1
  38. package/dist/assets/test/pages/{Label.html-c300f56e.js → Label.html-4f9b5452.js} +1 -1
  39. package/dist/assets/test/pages/{Popups.html-c7cbd384.js → Popups.html-c2111467.js} +1 -1
  40. package/dist/css/themes/Avatar.css +1 -1
  41. package/dist/css/themes/AvatarGroup.css +1 -1
  42. package/dist/css/themes/Badge.css +1 -1
  43. package/dist/css/themes/Breadcrumbs.css +1 -1
  44. package/dist/css/themes/BusyIndicator.css +1 -1
  45. package/dist/css/themes/Button.css +1 -1
  46. package/dist/css/themes/Calendar.css +1 -1
  47. package/dist/css/themes/CalendarHeader.css +1 -1
  48. package/dist/css/themes/Card.css +1 -1
  49. package/dist/css/themes/CardHeader.css +1 -1
  50. package/dist/css/themes/Carousel.css +1 -1
  51. package/dist/css/themes/CheckBox.css +1 -1
  52. package/dist/css/themes/ColorPalette.css +1 -1
  53. package/dist/css/themes/ColorPaletteItem.css +1 -1
  54. package/dist/css/themes/ColorPalettePopover.css +1 -1
  55. package/dist/css/themes/ColorPicker.css +1 -1
  56. package/dist/css/themes/ComboBox.css +1 -1
  57. package/dist/css/themes/CustomListItem.css +1 -1
  58. package/dist/css/themes/DatePicker.css +1 -1
  59. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  60. package/dist/css/themes/DayPicker.css +1 -1
  61. package/dist/css/themes/Dialog.css +1 -1
  62. package/dist/css/themes/FileUploader.css +1 -1
  63. package/dist/css/themes/GroupHeaderListItem.css +1 -1
  64. package/dist/css/themes/GrowingButton.css +1 -1
  65. package/dist/css/themes/Icon.css +1 -1
  66. package/dist/css/themes/Input.css +1 -1
  67. package/dist/css/themes/InputIcon.css +1 -1
  68. package/dist/css/themes/InputSharedStyles.css +1 -1
  69. package/dist/css/themes/Link.css +1 -1
  70. package/dist/css/themes/List.css +1 -1
  71. package/dist/css/themes/ListItem.css +1 -1
  72. package/dist/css/themes/ListItemBase.css +1 -1
  73. package/dist/css/themes/Menu.css +1 -1
  74. package/dist/css/themes/MessageStrip.css +1 -1
  75. package/dist/css/themes/MonthPicker.css +1 -1
  76. package/dist/css/themes/MultiComboBox.css +1 -1
  77. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  78. package/dist/css/themes/MultiInput.css +1 -1
  79. package/dist/css/themes/Panel.css +1 -1
  80. package/dist/css/themes/Popover.css +1 -1
  81. package/dist/css/themes/PopupsCommon.css +1 -1
  82. package/dist/css/themes/ProgressIndicator.css +1 -1
  83. package/dist/css/themes/RadioButton.css +1 -1
  84. package/dist/css/themes/RangeSlider.css +1 -1
  85. package/dist/css/themes/RatingIndicator.css +1 -1
  86. package/dist/css/themes/ResponsivePopover.css +1 -1
  87. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  88. package/dist/css/themes/SegmentedButton.css +1 -1
  89. package/dist/css/themes/Select.css +1 -1
  90. package/dist/css/themes/SelectMenu.css +1 -1
  91. package/dist/css/themes/SelectPopover.css +1 -1
  92. package/dist/css/themes/SliderBase.css +1 -1
  93. package/dist/css/themes/SplitButton.css +1 -1
  94. package/dist/css/themes/StepInput.css +1 -1
  95. package/dist/css/themes/Switch.css +1 -1
  96. package/dist/css/themes/TabContainer.css +1 -1
  97. package/dist/css/themes/TabInOverflow.css +1 -1
  98. package/dist/css/themes/TabInStrip.css +1 -1
  99. package/dist/css/themes/TabSemanticIcon.css +1 -1
  100. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  101. package/dist/css/themes/Table.css +1 -1
  102. package/dist/css/themes/TableCell.css +1 -1
  103. package/dist/css/themes/TableColumn.css +1 -1
  104. package/dist/css/themes/TableGroupRow.css +1 -1
  105. package/dist/css/themes/TableRow.css +1 -1
  106. package/dist/css/themes/TextArea.css +2 -2
  107. package/dist/css/themes/TimePicker.css +1 -1
  108. package/dist/css/themes/Toast.css +1 -1
  109. package/dist/css/themes/ToggleButton.css +1 -1
  110. package/dist/css/themes/Token.css +1 -1
  111. package/dist/css/themes/Tokenizer.css +1 -1
  112. package/dist/css/themes/TokenizerPopover.css +1 -1
  113. package/dist/css/themes/Toolbar.css +1 -1
  114. package/dist/css/themes/ToolbarPopover.css +1 -1
  115. package/dist/css/themes/TreeItem.css +1 -1
  116. package/dist/css/themes/ValueStateMessage.css +1 -1
  117. package/dist/css/themes/WheelSlider.css +1 -1
  118. package/dist/css/themes/YearPicker.css +1 -1
  119. package/dist/css/themes/sap_belize/parameters-bundle.css +1 -1
  120. package/dist/css/themes/sap_belize_hcb/parameters-bundle.css +1 -1
  121. package/dist/css/themes/sap_belize_hcw/parameters-bundle.css +1 -1
  122. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  123. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  124. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  125. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  126. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  127. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  128. package/dist/css/themes/sap_horizon_dark_exp/parameters-bundle.css +1 -1
  129. package/dist/css/themes/sap_horizon_exp/parameters-bundle.css +1 -1
  130. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  131. package/dist/css/themes/sap_horizon_hcb_exp/parameters-bundle.css +1 -1
  132. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  133. package/dist/css/themes/sap_horizon_hcw_exp/parameters-bundle.css +1 -1
  134. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  135. package/dist/generated/assets/themes/sap_belize/parameters-bundle.css.json +1 -1
  136. package/dist/generated/assets/themes/sap_belize_hcb/parameters-bundle.css.json +1 -1
  137. package/dist/generated/assets/themes/sap_belize_hcw/parameters-bundle.css.json +1 -1
  138. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  139. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  140. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  141. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  142. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  143. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  144. package/dist/generated/assets/themes/sap_horizon_dark_exp/parameters-bundle.css.json +1 -1
  145. package/dist/generated/assets/themes/sap_horizon_exp/parameters-bundle.css.json +1 -1
  146. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  147. package/dist/generated/assets/themes/sap_horizon_hcb_exp/parameters-bundle.css.json +1 -1
  148. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  149. package/dist/generated/assets/themes/sap_horizon_hcw_exp/parameters-bundle.css.json +1 -1
  150. package/dist/generated/json-imports/Themes.js +15 -15
  151. package/dist/generated/json-imports/i18n.js +48 -48
  152. package/dist/generated/templates/ListTemplate.lit.js +1 -1
  153. package/dist/generated/templates/ListTemplate.lit.js.map +1 -1
  154. package/dist/generated/templates/TreeItemBaseTemplate.lit.js +11 -12
  155. package/dist/generated/templates/TreeItemBaseTemplate.lit.js.map +1 -1
  156. package/dist/generated/templates/TreeItemCustomTemplate.lit.js +11 -12
  157. package/dist/generated/templates/TreeItemCustomTemplate.lit.js.map +1 -1
  158. package/dist/generated/templates/TreeItemTemplate.lit.js +11 -12
  159. package/dist/generated/templates/TreeItemTemplate.lit.js.map +1 -1
  160. package/dist/generated/themes/Avatar.css.js +1 -1
  161. package/dist/generated/themes/Avatar.css.js.map +1 -1
  162. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  163. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  164. package/dist/generated/themes/Badge.css.js +1 -1
  165. package/dist/generated/themes/Badge.css.js.map +1 -1
  166. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  167. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  168. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  169. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  170. package/dist/generated/themes/Button.css.js +1 -1
  171. package/dist/generated/themes/Button.css.js.map +1 -1
  172. package/dist/generated/themes/Calendar.css.js +1 -1
  173. package/dist/generated/themes/Calendar.css.js.map +1 -1
  174. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  175. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  176. package/dist/generated/themes/Card.css.js +1 -1
  177. package/dist/generated/themes/Card.css.js.map +1 -1
  178. package/dist/generated/themes/CardHeader.css.js +1 -1
  179. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  180. package/dist/generated/themes/Carousel.css.js +1 -1
  181. package/dist/generated/themes/Carousel.css.js.map +1 -1
  182. package/dist/generated/themes/CheckBox.css.js +1 -1
  183. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  184. package/dist/generated/themes/ColorPalette.css.js +1 -1
  185. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  186. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  187. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  188. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  189. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  190. package/dist/generated/themes/ColorPicker.css.js +1 -1
  191. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  192. package/dist/generated/themes/ComboBox.css.js +1 -1
  193. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  194. package/dist/generated/themes/CustomListItem.css.js +1 -1
  195. package/dist/generated/themes/CustomListItem.css.js.map +1 -1
  196. package/dist/generated/themes/DatePicker.css.js +1 -1
  197. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  198. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  199. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  200. package/dist/generated/themes/DayPicker.css.js +1 -1
  201. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  202. package/dist/generated/themes/Dialog.css.js +1 -1
  203. package/dist/generated/themes/Dialog.css.js.map +1 -1
  204. package/dist/generated/themes/FileUploader.css.js +1 -1
  205. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  206. package/dist/generated/themes/GroupHeaderListItem.css.js +1 -1
  207. package/dist/generated/themes/GroupHeaderListItem.css.js.map +1 -1
  208. package/dist/generated/themes/GrowingButton.css.js +1 -1
  209. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  210. package/dist/generated/themes/Icon.css.js +1 -1
  211. package/dist/generated/themes/Icon.css.js.map +1 -1
  212. package/dist/generated/themes/Input.css.js +1 -1
  213. package/dist/generated/themes/Input.css.js.map +1 -1
  214. package/dist/generated/themes/InputIcon.css.js +1 -1
  215. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  216. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  217. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  218. package/dist/generated/themes/Link.css.js +1 -1
  219. package/dist/generated/themes/Link.css.js.map +1 -1
  220. package/dist/generated/themes/List.css.js +1 -1
  221. package/dist/generated/themes/List.css.js.map +1 -1
  222. package/dist/generated/themes/ListItem.css.js +1 -1
  223. package/dist/generated/themes/ListItem.css.js.map +1 -1
  224. package/dist/generated/themes/ListItemBase.css.js +1 -1
  225. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  226. package/dist/generated/themes/Menu.css.js +1 -1
  227. package/dist/generated/themes/Menu.css.js.map +1 -1
  228. package/dist/generated/themes/MessageStrip.css.js +1 -1
  229. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  230. package/dist/generated/themes/MonthPicker.css.js +1 -1
  231. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  232. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  233. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  234. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  235. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  236. package/dist/generated/themes/MultiInput.css.js +1 -1
  237. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  238. package/dist/generated/themes/Panel.css.js +1 -1
  239. package/dist/generated/themes/Panel.css.js.map +1 -1
  240. package/dist/generated/themes/Popover.css.js +1 -1
  241. package/dist/generated/themes/Popover.css.js.map +1 -1
  242. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  243. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  244. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  245. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  246. package/dist/generated/themes/RadioButton.css.js +1 -1
  247. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  248. package/dist/generated/themes/RangeSlider.css.js +1 -1
  249. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  250. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  251. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  252. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  253. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  254. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  255. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  256. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  257. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  258. package/dist/generated/themes/Select.css.js +1 -1
  259. package/dist/generated/themes/Select.css.js.map +1 -1
  260. package/dist/generated/themes/SelectMenu.css.js +1 -1
  261. package/dist/generated/themes/SelectMenu.css.js.map +1 -1
  262. package/dist/generated/themes/SelectPopover.css.js +1 -1
  263. package/dist/generated/themes/SelectPopover.css.js.map +1 -1
  264. package/dist/generated/themes/SliderBase.css.js +1 -1
  265. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  266. package/dist/generated/themes/SplitButton.css.js +1 -1
  267. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  268. package/dist/generated/themes/StepInput.css.js +1 -1
  269. package/dist/generated/themes/StepInput.css.js.map +1 -1
  270. package/dist/generated/themes/Switch.css.js +1 -1
  271. package/dist/generated/themes/Switch.css.js.map +1 -1
  272. package/dist/generated/themes/TabContainer.css.js +1 -1
  273. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  274. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  275. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  276. package/dist/generated/themes/TabInStrip.css.js +1 -1
  277. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  278. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  279. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  280. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  281. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  282. package/dist/generated/themes/Table.css.js +1 -1
  283. package/dist/generated/themes/Table.css.js.map +1 -1
  284. package/dist/generated/themes/TableCell.css.js +1 -1
  285. package/dist/generated/themes/TableCell.css.js.map +1 -1
  286. package/dist/generated/themes/TableColumn.css.js +1 -1
  287. package/dist/generated/themes/TableColumn.css.js.map +1 -1
  288. package/dist/generated/themes/TableGroupRow.css.js +1 -1
  289. package/dist/generated/themes/TableGroupRow.css.js.map +1 -1
  290. package/dist/generated/themes/TableRow.css.js +1 -1
  291. package/dist/generated/themes/TableRow.css.js.map +1 -1
  292. package/dist/generated/themes/TextArea.css.js +1 -1
  293. package/dist/generated/themes/TextArea.css.js.map +1 -1
  294. package/dist/generated/themes/TimePicker.css.js +1 -1
  295. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  296. package/dist/generated/themes/Toast.css.js +1 -1
  297. package/dist/generated/themes/Toast.css.js.map +1 -1
  298. package/dist/generated/themes/ToggleButton.css.js +1 -1
  299. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  300. package/dist/generated/themes/Token.css.js +1 -1
  301. package/dist/generated/themes/Token.css.js.map +1 -1
  302. package/dist/generated/themes/Tokenizer.css.js +1 -1
  303. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  304. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  305. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  306. package/dist/generated/themes/Toolbar.css.js +1 -1
  307. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  308. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  309. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  310. package/dist/generated/themes/TreeItem.css.js +1 -1
  311. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  312. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  313. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  314. package/dist/generated/themes/WheelSlider.css.js +1 -1
  315. package/dist/generated/themes/WheelSlider.css.js.map +1 -1
  316. package/dist/generated/themes/YearPicker.css.js +1 -1
  317. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  318. package/dist/generated/themes/sap_belize/parameters-bundle.css.js +1 -1
  319. package/dist/generated/themes/sap_belize/parameters-bundle.css.js.map +1 -1
  320. package/dist/generated/themes/sap_belize_hcb/parameters-bundle.css.js +1 -1
  321. package/dist/generated/themes/sap_belize_hcb/parameters-bundle.css.js.map +1 -1
  322. package/dist/generated/themes/sap_belize_hcw/parameters-bundle.css.js +1 -1
  323. package/dist/generated/themes/sap_belize_hcw/parameters-bundle.css.js.map +1 -1
  324. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  325. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  326. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  327. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  328. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  329. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  330. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  331. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  332. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  333. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  334. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  335. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  336. package/dist/generated/themes/sap_horizon_dark_exp/parameters-bundle.css.js +1 -1
  337. package/dist/generated/themes/sap_horizon_dark_exp/parameters-bundle.css.js.map +1 -1
  338. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js +1 -1
  339. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js.map +1 -1
  340. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  341. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  342. package/dist/generated/themes/sap_horizon_hcb_exp/parameters-bundle.css.js +1 -1
  343. package/dist/generated/themes/sap_horizon_hcb_exp/parameters-bundle.css.js.map +1 -1
  344. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  345. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  346. package/dist/generated/themes/sap_horizon_hcw_exp/parameters-bundle.css.js +1 -1
  347. package/dist/generated/themes/sap_horizon_hcw_exp/parameters-bundle.css.js.map +1 -1
  348. package/dist/i18n/messagebundle_en.properties +2 -0
  349. package/dist/test/pages/72override.html +1 -1
  350. package/dist/test/pages/AnimanitionOff.html +1 -1
  351. package/dist/test/pages/Avatar.html +1 -1
  352. package/dist/test/pages/AvatarGroup.html +1 -1
  353. package/dist/test/pages/Badge.html +1 -1
  354. package/dist/test/pages/Breadcrumbs.html +1 -1
  355. package/dist/test/pages/BusyIndicator.html +1 -1
  356. package/dist/test/pages/Button.html +1 -1
  357. package/dist/test/pages/ButtonDesign.html +1 -1
  358. package/dist/test/pages/Calendar.html +1 -1
  359. package/dist/test/pages/CalendarConfig.html +1 -1
  360. package/dist/test/pages/Card.html +1 -1
  361. package/dist/test/pages/Carousel.html +1 -1
  362. package/dist/test/pages/CheckBox.html +1 -1
  363. package/dist/test/pages/ColorPalette.html +1 -1
  364. package/dist/test/pages/ColorPalettePopover.html +1 -1
  365. package/dist/test/pages/ColorPicker.html +1 -1
  366. package/dist/test/pages/ComboBox.html +2 -2
  367. package/dist/test/pages/Components.html +1 -1
  368. package/dist/test/pages/CoreControls.html +1 -1
  369. package/dist/test/pages/CoreControls_exp.html +1 -1
  370. package/dist/test/pages/CustomCSS.html +1 -1
  371. package/dist/test/pages/DatePicker.html +1 -1
  372. package/dist/test/pages/DatePicker_test_page.html +1 -1
  373. package/dist/test/pages/DateRangePicker.html +1 -1
  374. package/dist/test/pages/DateTimePicker.html +1 -1
  375. package/dist/test/pages/DateTimePicker_Timezone.html +1 -1
  376. package/dist/test/pages/DayPicker.html +1 -1
  377. package/dist/test/pages/Dialog.html +1 -1
  378. package/dist/test/pages/DialogLifecycle.html +1 -1
  379. package/dist/test/pages/DialogSemantic.html +1 -1
  380. package/dist/test/pages/Eventing.html +1 -1
  381. package/dist/test/pages/F6Test1.html +1 -1
  382. package/dist/test/pages/F6Test2.html +1 -1
  383. package/dist/test/pages/F6Test3.html +1 -1
  384. package/dist/test/pages/F6Test4.html +1 -1
  385. package/dist/test/pages/F6Test5.html +1 -1
  386. package/dist/test/pages/F6Test6.html +1 -1
  387. package/dist/test/pages/F6Test7.html +1 -1
  388. package/dist/test/pages/FileUploader.html +1 -1
  389. package/dist/test/pages/FontFace.html +1 -1
  390. package/dist/test/pages/FormComponents.html +1 -1
  391. package/dist/test/pages/FormSupport.html +1 -1
  392. package/dist/test/pages/HCB.html +1 -1
  393. package/dist/test/pages/Icon.html +2 -2
  394. package/dist/test/pages/Icon_and_theming.html +1 -1
  395. package/dist/test/pages/Icon_custom.html +1 -1
  396. package/dist/test/pages/Input.html +1 -1
  397. package/dist/test/pages/InputFieldLabels.html +1 -1
  398. package/dist/test/pages/InputFieldMinWidth.html +1 -1
  399. package/dist/test/pages/InputIcons.html +1 -1
  400. package/dist/test/pages/Input_quickview.html +1 -1
  401. package/dist/test/pages/Input_variations.html +1 -1
  402. package/dist/test/pages/InputsAlignment.html +1 -1
  403. package/dist/test/pages/InputsLazyLoading.html +1 -1
  404. package/dist/test/pages/ItemNavigation.html +1 -1
  405. package/dist/test/pages/Kitchen.html +1 -1
  406. package/dist/test/pages/Kitchen.openui5.html +1 -1
  407. package/dist/test/pages/Label.html +2 -2
  408. package/dist/test/pages/Link.html +1 -1
  409. package/dist/test/pages/List.html +1 -1
  410. package/dist/test/pages/ListGrowing_Button.html +1 -1
  411. package/dist/test/pages/ListGrowing_Scroll.html +1 -1
  412. package/dist/test/pages/List_keyboard_support.html +1 -1
  413. package/dist/test/pages/List_test_page.html +12 -1
  414. package/dist/test/pages/LitKeyFunction.html +1 -1
  415. package/dist/test/pages/MemoryLeak.html +1 -1
  416. package/dist/test/pages/Menu.html +1 -1
  417. package/dist/test/pages/MessagePage.html +1 -1
  418. package/dist/test/pages/MessageStrip.html +1 -1
  419. package/dist/test/pages/MultiComboBox.html +1 -1
  420. package/dist/test/pages/MultiInput.html +1 -1
  421. package/dist/test/pages/MultiInput_Suggestions.html +1 -1
  422. package/dist/test/pages/OpenUI5-second.html +1 -1
  423. package/dist/test/pages/OpenUI5.html +1 -1
  424. package/dist/test/pages/OpenUI5Nightly.html +1 -1
  425. package/dist/test/pages/Panel.html +1 -1
  426. package/dist/test/pages/Popover.html +1 -1
  427. package/dist/test/pages/PopoverArrowBounds.html +1 -1
  428. package/dist/test/pages/Popups.html +2 -2
  429. package/dist/test/pages/ProgressIndicator.html +1 -1
  430. package/dist/test/pages/RTL.html +1 -1
  431. package/dist/test/pages/RadioButton.html +1 -1
  432. package/dist/test/pages/RangeSlider.html +1 -1
  433. package/dist/test/pages/RatingIndicator.html +1 -1
  434. package/dist/test/pages/ResizeHandler.html +1 -1
  435. package/dist/test/pages/ResponsivePopover.html +1 -1
  436. package/dist/test/pages/SegmentedButton.html +1 -1
  437. package/dist/test/pages/Select.html +1 -1
  438. package/dist/test/pages/SelectMenu.html +1 -1
  439. package/dist/test/pages/SelectMenuLifecycle.html +1 -1
  440. package/dist/test/pages/Simple.html +1 -1
  441. package/dist/test/pages/Slider.html +1 -1
  442. package/dist/test/pages/SplitButton.html +1 -1
  443. package/dist/test/pages/StepInput.html +1 -1
  444. package/dist/test/pages/Switch.html +1 -1
  445. package/dist/test/pages/TabContainer.html +1 -1
  446. package/dist/test/pages/Table-perf-pure.html +1 -1
  447. package/dist/test/pages/Table-perf.html +1 -1
  448. package/dist/test/pages/Table.html +1 -1
  449. package/dist/test/pages/Table2.html +1 -1
  450. package/dist/test/pages/TableAllPopin.html +1 -1
  451. package/dist/test/pages/TableCustomStyling.html +1 -1
  452. package/dist/test/pages/TableGrouping.html +1 -1
  453. package/dist/test/pages/TableGrowingWithButton.html +1 -1
  454. package/dist/test/pages/TableGrowingWithScroll.html +1 -1
  455. package/dist/test/pages/TableSelection.html +1 -1
  456. package/dist/test/pages/TextArea.html +1 -1
  457. package/dist/test/pages/TimePicker.html +1 -1
  458. package/dist/test/pages/TimePickerClock.html +1 -1
  459. package/dist/test/pages/TimeSelection.html +1 -1
  460. package/dist/test/pages/TimeSelectionClocks.html +1 -1
  461. package/dist/test/pages/TimeSelectionInputs.html +1 -1
  462. package/dist/test/pages/Title.html +1 -1
  463. package/dist/test/pages/Toast.html +1 -1
  464. package/dist/test/pages/ToggleButton.html +1 -1
  465. package/dist/test/pages/Tokenizer.html +1 -1
  466. package/dist/test/pages/Toolbar.html +1 -1
  467. package/dist/test/pages/ToolbarButton.html +1 -1
  468. package/dist/test/pages/ToolbarSelect.html +1 -1
  469. package/dist/test/pages/Tree.html +1 -1
  470. package/dist/test/pages/TreeDynamic.html +1 -1
  471. package/dist/test/pages/WheelSlider_Test_Page.html +1 -1
  472. package/dist/test/pages/base/AriaLabelHelper.html +1 -1
  473. package/dist/test/pages/base/DOMObserver.html +1 -1
  474. package/dist/test/pages/base/IconCollection.html +1 -1
  475. package/dist/test/pages/base/IconCollectionInCustomTheme.html +1 -1
  476. package/dist/test/pages/base/IgnoreCustomElements.html +1 -1
  477. package/dist/test/pages/base/InvisibleMessage.html +1 -1
  478. package/dist/test/pages/form.html +1 -1
  479. package/dist/test/pages/i18n-defaultLang.html +1 -1
  480. package/dist/test/pages/i18n-demo.html +1 -1
  481. package/package.json +7 -7
  482. package/src/List.hbs +1 -0
  483. package/src/TreeItemBase.hbs +1 -12
  484. package/src/i18n/messagebundle_en.properties +2 -0
  485. package/src/themes/ListItemBase.css +3 -6
  486. package/src/themes/TreeItem.css +0 -37
  487. package/src/themes/base/ListItemBase-parameters.css +0 -3
  488. package/src/themes/sap_fiori_3/parameters-bundle.css +0 -1
  489. package/src/themes/sap_fiori_3_dark/parameters-bundle.css +0 -1
  490. package/src/themes/sap_fiori_3_hcb/parameters-bundle.css +0 -1
  491. package/src/themes/sap_fiori_3_hcw/parameters-bundle.css +0 -1
  492. package/src/themes/sap_horizon/parameters-bundle.css +0 -1
  493. package/src/themes/sap_horizon_dark/parameters-bundle.css +0 -1
  494. package/src/themes/sap_horizon_dark_exp/parameters-bundle.css +0 -1
  495. package/src/themes/sap_horizon_exp/parameters-bundle.css +0 -1
  496. package/src/themes/sap_horizon_hcb/parameters-bundle.css +0 -1
  497. package/src/themes/sap_horizon_hcb_exp/parameters-bundle.css +0 -1
  498. package/src/themes/sap_horizon_hcw/parameters-bundle.css +0 -1
  499. package/src/themes/sap_horizon_hcw_exp/parameters-bundle.css +0 -1
  500. package/dist/assets/messagebundle_en-47d404a7.js +0 -1
  501. package/dist/assets/parameters-bundle.css-046c78b9.js +0 -1
  502. package/dist/assets/parameters-bundle.css-096fcf9e.js +0 -1
  503. package/dist/assets/parameters-bundle.css-0f11cedd.js +0 -1
  504. package/dist/assets/parameters-bundle.css-1663bebb.js +0 -1
  505. package/dist/assets/parameters-bundle.css-17c0e61d.js +0 -1
  506. package/dist/assets/parameters-bundle.css-20f2adfd.js +0 -1
  507. package/dist/assets/parameters-bundle.css-2d7b9655.js +0 -1
  508. package/dist/assets/parameters-bundle.css-58725f0e.js +0 -1
  509. package/dist/assets/parameters-bundle.css-87a8a0f9.js +0 -1
  510. package/dist/assets/parameters-bundle.css-925376c2.js +0 -1
  511. package/dist/assets/parameters-bundle.css-9656756a.js +0 -1
  512. package/dist/assets/parameters-bundle.css-96f5889c.js +0 -1
  513. package/dist/assets/parameters-bundle.css-a8404051.js +0 -1
  514. package/dist/assets/parameters-bundle.css-de730ed5.js +0 -1
  515. package/dist/assets/parameters-bundle.css-f0af878c.js +0 -1
  516. package/src/themes/base/TreeItem-parameters.css +0 -4
  517. package/src/themes/sap_horizon/TreeItem-parameters.css +0 -6
  518. package/src/themes/sap_horizon_dark/TreeItem-parameters.css +0 -6
  519. package/src/themes/sap_horizon_dark_exp/TreeItem-parameters.css +0 -6
  520. package/src/themes/sap_horizon_exp/TreeItem-parameters.css +0 -6
  521. package/src/themes/sap_horizon_hcb/TreeItem-parameters.css +0 -6
  522. package/src/themes/sap_horizon_hcb_exp/TreeItem-parameters.css +0 -6
  523. package/src/themes/sap_horizon_hcw/TreeItem-parameters.css +0 -6
  524. package/src/themes/sap_horizon_hcw_exp/TreeItem-parameters.css +0 -6
package/CHANGELOG.md CHANGED
@@ -3,6 +3,29 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [1.20.0-rc.1](https://github.com/SAP/ui5-webcomponents/compare/v1.20.0-rc.0...v1.20.0-rc.1) (2023-11-16)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * **ui5-list:** shift+tab navigation in List ([#7728](https://github.com/SAP/ui5-webcomponents/issues/7728)) ([399b941](https://github.com/SAP/ui5-webcomponents/commit/399b941ebeae7b44f6dba9cd4e8ec7ebb6f283c6))
12
+
13
+
14
+
15
+
16
+
17
+ # [1.20.0-rc.0](https://github.com/SAP/ui5-webcomponents/compare/v1.19.0...v1.20.0-rc.0) (2023-11-09)
18
+
19
+
20
+ ### Bug Fixes
21
+
22
+ * **ui5-segmented-button:** check for items before applying settings ([#7792](https://github.com/SAP/ui5-webcomponents/issues/7792)) ([7f11274](https://github.com/SAP/ui5-webcomponents/commit/7f112746d50381474ec86da5e428df79c17c6499)), closes [#7788](https://github.com/SAP/ui5-webcomponents/issues/7788)
23
+ * **ui5-time-picker:** check value before formatting ([#7793](https://github.com/SAP/ui5-webcomponents/issues/7793)) ([70deda8](https://github.com/SAP/ui5-webcomponents/commit/70deda85293d5e62e99530c9dc0747071d9ee59c)), closes [#7790](https://github.com/SAP/ui5-webcomponents/issues/7790)
24
+
25
+
26
+
27
+
28
+
6
29
  # [1.19.0](https://github.com/SAP/ui5-webcomponents/compare/v1.19.0-rc.3...v1.19.0) (2023-11-02)
7
30
 
8
31
  **Note:** Version bump only for package @ui5/webcomponents
package/dist/List.d.ts CHANGED
@@ -328,6 +328,7 @@ declare class List extends UI5Element {
328
328
  _onfocusin(e: FocusEvent): void;
329
329
  isForwardElement(element: HTMLElement): boolean;
330
330
  isForwardAfterElement(element: HTMLElement): boolean;
331
+ onItemTabIndexChange(e: CustomEvent): void;
331
332
  onItemFocused(e: CustomEvent): void;
332
333
  onItemPress(e: CustomEvent<PressEventDetail>): void;
333
334
  onItemClose(e: CustomEvent<ListItemCloseEventDetail>): void;
package/dist/List.js CHANGED
@@ -478,6 +478,10 @@ let List = List_1 = class List extends UI5Element {
478
478
  const afterElement = this.getAfterElement();
479
479
  return afterElement && afterElement.id === elementId;
480
480
  }
481
+ onItemTabIndexChange(e) {
482
+ const target = e.target;
483
+ this._itemNavigation.setCurrentItem(target);
484
+ }
481
485
  onItemFocused(e) {
482
486
  const target = e.target;
483
487
  e.stopPropagation();
package/dist/List.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"List.js","sourceRoot":"","sources":["../src/List.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport ResizeHandler from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport type { ResizeObserverCallback } from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport ItemNavigation from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport type { ClassMap } from \"@ui5/webcomponents-base/dist/types.js\";\nimport { renderFinished } from \"@ui5/webcomponents-base/dist/Render.js\";\nimport {\n\tisTabNext,\n\tisSpace,\n\tisEnter,\n\tisTabPrevious,\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport Integer from \"@ui5/webcomponents-base/dist/types/Integer.js\";\nimport NavigationMode from \"@ui5/webcomponents-base/dist/types/NavigationMode.js\";\nimport { getEffectiveAriaLabelText } from \"@ui5/webcomponents-base/dist/util/AriaLabelHelper.js\";\nimport getNormalizedTarget from \"@ui5/webcomponents-base/dist/util/getNormalizedTarget.js\";\nimport getEffectiveScrollbarStyle from \"@ui5/webcomponents-base/dist/util/getEffectiveScrollbarStyle.js\";\nimport { getI18nBundle } from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport type I18nBundle from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport debounce from \"@ui5/webcomponents-base/dist/util/debounce.js\";\nimport isElementInView from \"@ui5/webcomponents-base/dist/util/isElementInView.js\";\nimport ListMode from \"./types/ListMode.js\";\nimport ListGrowingMode from \"./types/ListGrowingMode.js\";\nimport ListItemBase from \"./ListItemBase.js\";\nimport type ListItem from \"./ListItem.js\";\nimport type {\n\tSelectionRequestEventDetail,\n\tPressEventDetail,\n} from \"./ListItem.js\";\nimport ListSeparators from \"./types/ListSeparators.js\";\nimport BusyIndicator from \"./BusyIndicator.js\";\n\n// Template\nimport ListTemplate from \"./generated/templates/ListTemplate.lit.js\";\n\n// Styles\nimport listCss from \"./generated/themes/List.css.js\";\nimport browserScrollbarCSS from \"./generated/themes/BrowserScrollbar.css.js\";\n\n// Texts\nimport {\n\tLOAD_MORE_TEXT, ARIA_LABEL_LIST_SELECTABLE,\n\tARIA_LABEL_LIST_MULTISELECTABLE,\n\tARIA_LABEL_LIST_DELETABLE,\n} from \"./generated/i18n/i18n-defaults.js\";\nimport CheckBox from \"./CheckBox.js\";\nimport RadioButton from \"./RadioButton.js\";\n\nconst INFINITE_SCROLL_DEBOUNCE_RATE = 250; // ms\n\nconst PAGE_UP_DOWN_SIZE = 10;\n\n// ListItemBase-based events\ntype ListItemFocusEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListSelectionChangeEventDetail = {\n\tselectedItems: Array<ListItemBase>;\n\tpreviouslySelectedItems: Array<ListItemBase>;\n\tselectionComponentPressed: boolean;\n\ttargetItem: ListItemBase;\n\tkey?: string;\n}\n\ntype ListItemDeleteEventDetail = {\n\titem: ListItemBase,\n}\n\n// ListItem-based events\ntype ListItemCloseEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListItemToggleEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListItemClickEventDetail = {\n\titem: ListItemBase,\n}\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n *\n * The <code>ui5-list</code> component allows displaying a list of items, advanced keyboard\n * handling support for navigating between items, and predefined modes to improve the development efficiency.\n * <br><br>\n * The <code>ui5-list</code> is a container for the available list items:\n * <ul>\n * <li><code>ui5-li</code></li>\n * <li><code>ui5-li-custom</code></li>\n * <li><code>ui5-li-groupheader</code></li>\n * </ul>\n * <br><br>\n * To benefit from the built-in selection mechanism, you can use the available\n * selection modes, such as\n * <code>SingleSelect</code>, <code>MultiSelect</code> and <code>Delete</code>.\n * <br><br>\n * Additionally, the <code>ui5-list</code> provides header, footer, and customization for the list item separators.\n *\n * <br><br>\n * <h3>Keyboard Handling</h3>\n *\n * <h4>Basic Navigation</h4>\n * The <code>ui5-list</code> provides advanced keyboard handling.\n * When a list is focused the user can use the following keyboard\n * shortcuts in order to perform a navigation:\n * <br>\n *\n * <ul>\n * <li>[UP/DOWN] - Navigates up and down the items</li>\n * <li>[HOME] - Navigates to first item</li>\n * <li>[END] - Navigates to the last item</li>\n * </ul>\n *\n * The user can use the following keyboard shortcuts to perform actions (such as select, delete),\n * when the <code>mode</code> property is in use:\n * <ul>\n * <li>[SPACE] - Select an item (if <code>type</code> is 'Active') when <code>mode</code> is selection</li>\n * <li>[DELETE] - Delete an item if <code>mode</code> property is <code>Delete</code></li>\n * </ul>\n *\n * <h4>Fast Navigation</h4>\n * 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>.\n * In order to use this functionality, you need to import the following module:\n * <code>import \"@ui5/webcomponents-base/dist/features/F6Navigation.js\"</code>\n * <br><br>\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/List.js\";</code>\n * <br>\n * <code>import \"@ui5/webcomponents/dist/StandardListItem.js\";</code> (for <code>ui5-li</code>)\n * <br>\n * <code>import \"@ui5/webcomponents/dist/CustomListItem.js\";</code> (for <code>ui5-li-custom</code>)\n * <br>\n * <code>import \"@ui5/webcomponents/dist/GroupHeaderListItem.js\";</code> (for <code>ui5-li-groupheader</code>)\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.List\n * @extends sap.ui.webc.base.UI5Element\n * @tagname ui5-list\n * @appenddocs sap.ui.webc.main.StandardListItem sap.ui.webc.main.CustomListItem sap.ui.webc.main.GroupHeaderListItem\n * @public\n */\n@customElement({\n\ttag: \"ui5-list\",\n\tfastNavigation: true,\n\trenderer: litRender,\n\ttemplate: ListTemplate,\n\tstyles: [browserScrollbarCSS, listCss],\n\tdependencies: [BusyIndicator],\n})\n/**\n * Fired when an item is activated, unless the item's <code>type</code> property\n * is set to <code>Inactive</code>.\n *\n * @event sap.ui.webc.main.List#item-click\n * @allowPreventDefault\n * @param {HTMLElement} item The clicked item.\n * @public\n */\n@event(\"item-click\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the <code>Close</code> button of any item is clicked\n * <br><br>\n * <b>Note:</b> This event is only applicable to list items that can be closed (such as notification list items),\n * not to be confused with <code>item-delete</code>.\n *\n * @event sap.ui.webc.main.List#item-close\n * @param {HTMLElement} item the item about to be closed.\n * @public\n * @since 1.0.0-rc.8\n */\n@event(\"item-close\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the <code>Toggle</code> button of any item is clicked.\n * <br><br>\n * <b>Note:</b> This event is only applicable to list items that can be toggled (such as notification group list items).\n *\n * @event sap.ui.webc.main.List#item-toggle\n * @param {HTMLElement} item the toggled item.\n * @public\n * @since 1.0.0-rc.8\n */\n@event(\"item-toggle\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the Delete button of any item is pressed.\n * <br><br>\n * <b>Note:</b> A Delete button is displayed on each item,\n * when the component <code>mode</code> property is set to <code>Delete</code>.\n *\n * @event sap.ui.webc.main.List#item-delete\n * @param {HTMLElement} item the deleted item.\n * @public\n */\n@event(\"item-delete\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when selection is changed by user interaction\n * in <code>SingleSelect</code>, <code>SingleSelectBegin</code>, <code>SingleSelectEnd</code> and <code>MultiSelect</code> modes.\n *\n * @event sap.ui.webc.main.List#selection-change\n * @allowPreventDefault\n * @param {Array} selectedItems An array of the selected items.\n * @param {Array} previouslySelectedItems An array of the previously selected items.\n * @public\n */\n@event(\"selection-change\", {\n\tdetail: {\n\t\tselectedItems: { type: Array },\n\t\tpreviouslySelectedItems: { type: Array },\n\t\ttargetItem: { type: HTMLElement }, // protected, holds the event target item\n\t\tselectionComponentPressed: { type: Boolean }, // protected, indicates if the user used the selection components to change the selection\n\t},\n})\n\n/**\n * Fired when the user scrolls to the bottom of the list.\n * <br><br>\n * <b>Note:</b> The event is fired when the <code>growing='Scroll'</code> property is enabled.\n *\n * @event sap.ui.webc.main.List#load-more\n * @public\n * @since 1.0.0-rc.6\n */\n@event(\"load-more\")\n\n/**\n * @private\n */\n@event(\"item-focused\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\nclass List extends UI5Element {\n\t/**\n\t * Defines the component header text.\n\t * <br><br>\n\t * <b>Note:</b> If <code>header</code> is set this property is ignored.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.headerText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\theaderText!: string;\n\n\t/**\n\t * Defines the footer text.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.footerText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tfooterText!: string;\n\n\t/**\n\t * Determines whether the component is indented.\n\t *\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.List.prototype.indent\n\t * @defaultvalue false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tindent!: boolean;\n\n\t/**\n\t * Defines the mode of the component.\n\t *\n\t * @type {sap.ui.webc.main.types.ListMode}\n\t * @name sap.ui.webc.main.List.prototype.mode\n\t * @defaultvalue \"None\"\n\t * @public\n\t */\n\t@property({ type: ListMode, defaultValue: ListMode.None })\n\tmode!: `${ListMode}`;\n\n\t/**\n\t * Defines the text that is displayed when the component contains no items.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.noDataText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tnoDataText!: string;\n\n\t/**\n\t * Defines the item separator style that is used.\n\t *\n\t * @type {sap.ui.webc.main.types.ListSeparators}\n\t * @name sap.ui.webc.main.List.prototype.separators\n\t * @defaultvalue \"All\"\n\t * @public\n\t */\n\t@property({ type: ListSeparators, defaultValue: ListSeparators.All })\n\tseparators!: `${ListSeparators}`;\n\n\t/**\n\t * Defines whether the component will have growing capability either by pressing a <code>More</code> button,\n\t * or via user scroll. In both cases <code>load-more</code> event is fired.\n\t * <br><br>\n\t * <b>Restrictions:</b> <code>growing=\"Scroll\"</code> is not supported for Internet Explorer,\n\t * on IE the component will fallback to <code>growing=\"Button\"</code>.\n\t * @type {sap.ui.webc.main.types.ListGrowingMode}\n\t * @name sap.ui.webc.main.List.prototype.growing\n\t * @defaultvalue \"None\"\n\t * @since 1.0.0-rc.13\n\t * @public\n\t */\n\t@property({ type: ListGrowingMode, defaultValue: ListGrowingMode.None })\n\tgrowing!: `${ListGrowingMode}`;\n\n\t/**\n\t * Defines if the component would display a loading indicator over the list.\n\t *\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.List.prototype.busy\n\t * @defaultvalue false\n\t * @public\n\t * @since 1.0.0-rc.6\n\t */\n\t@property({ type: Boolean })\n\tbusy!: boolean;\n\n\t/**\n\t * Defines the delay in milliseconds, after which the busy indicator will show up for this component.\n\t *\n\t * @type {sap.ui.webc.base.types.Integer}\n\t * @name sap.ui.webc.main.List.prototype.busyDelay\n\t * @defaultValue 1000\n\t * @public\n\t */\n\t@property({ validator: Integer, defaultValue: 1000 })\n\tbusyDelay!: number;\n\n\t/**\n\t * Defines the accessible name of the component.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleName\n\t * @defaultvalue \"\"\n\t * @public\n\t * @since 1.0.0-rc.15\n\t */\n\t@property()\n\taccessibleName!: string;\n\n\t/**\n\t * Defines the IDs of the elements that label the input.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleNameRef\n\t * @defaultvalue \"\"\n\t * @public\n\t * @since 1.0.0-rc.15\n\t */\n\t@property({ defaultValue: \"\" })\n\taccessibleNameRef!: string;\n\n\t/**\n\t * Defines the accessible role of the component.\n\t * <br><br>\n\t * @public\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleRole\n\t * @defaultvalue \"list\"\n\t * @since 1.0.0-rc.15\n\t */\n\t@property({ defaultValue: \"list\" })\n\taccessibleRole!: string;\n\n\t/**\n\t * Defines the description for the accessible role of the component.\n\t * @protected\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleRoleDescription\n\t * @defaultvalue undefined\n\t * @since 1.10.0\n\t */\n\t@property({ defaultValue: undefined, noAttribute: true })\n\taccessibleRoleDescription?: string;\n\n\t/**\n\t * Defines if the entire list is in view port.\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_inViewport!: boolean;\n\n\t/**\n\t * Defines the active state of the <code>More</code> button.\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_loadMoreActive!: boolean;\n\n\t/**\n\t * Defines the items of the component.\n\t * <br><br>\n\t * <b>Note:</b> Use <code>ui5-li</code>, <code>ui5-li-custom</code>, and <code>ui5-li-groupheader</code> for the intended design.\n\t *\n\t * @type {sap.ui.webc.main.IListItem[]}\n\t * @name sap.ui.webc.main.List.prototype.default\n\t * @slot items\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, \"default\": true })\n\titems!: Array<ListItemBase>;\n\n\t/**\n\t * Defines the component header.\n\t * <br><br>\n\t * <b>Note:</b> When <code>header</code> is set, the\n\t * <code>headerText</code> property is ignored.\n\t *\n\t * @type {HTMLElement[]}\n\t * @name sap.ui.webc.main.List.prototype.header\n\t * @slot\n\t * @public\n\t */\n\t@slot()\n\theader!: Array<HTMLElement>;\n\n\tstatic i18nBundle: I18nBundle;\n\t_previouslyFocusedItem: ListItemBase | null;\n\t_forwardingFocus: boolean;\n\tresizeListenerAttached: boolean;\n\tlistEndObserved: boolean;\n\t_handleResize: ResizeObserverCallback;\n\tinitialIntersection: boolean;\n\t_selectionRequested?: boolean;\n\tgrowingIntersectionObserver?: IntersectionObserver | null;\n\t_itemNavigation: ItemNavigation;\n\t_beforeElement?: HTMLElement | null;\n\t_afterElement?: HTMLElement | null;\n\n\tstatic async onDefine() {\n\t\tList.i18nBundle = await getI18nBundle(\"@ui5/webcomponents\");\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\tthis._previouslyFocusedItem = null;\n\n\t\t// Indicates that the List is forwarding the focus before or after the internal ul.\n\t\tthis._forwardingFocus = false;\n\n\t\t// Indicates that the List has already subscribed for resize.\n\t\tthis.resizeListenerAttached = false;\n\n\t\t// Indicates if the IntersectionObserver started observing the List\n\t\tthis.listEndObserved = false;\n\n\t\tthis._itemNavigation = new ItemNavigation(this, {\n\t\t\tskipItemsSize: PAGE_UP_DOWN_SIZE, // PAGE_UP and PAGE_DOWN will skip trough 10 items\n\t\t\tnavigationMode: NavigationMode.Vertical,\n\t\t\tgetItemsCallback: () => this.getEnabledItems(),\n\t\t});\n\n\t\tthis._handleResize = this.checkListInViewport.bind(this);\n\n\t\tthis._handleResize = this.checkListInViewport.bind(this);\n\n\t\t// Indicates the List bottom most part has been detected by the IntersectionObserver\n\t\t// for the first time.\n\t\tthis.initialIntersection = true;\n\t}\n\n\tonExitDOM() {\n\t\tthis.unobserveListEnd();\n\t\tthis.resizeListenerAttached = false;\n\t\tResizeHandler.deregister(this.getDomRef()!, this._handleResize);\n\t}\n\n\tonBeforeRendering() {\n\t\tthis.prepareListItems();\n\t}\n\n\tonAfterRendering() {\n\t\tif (this.growsOnScroll) {\n\t\t\tthis.observeListEnd();\n\t\t} else if (this.listEndObserved) {\n\t\t\tthis.unobserveListEnd();\n\t\t}\n\n\t\tif (this.grows) {\n\t\t\tthis.checkListInViewport();\n\t\t\tthis.attachForResize();\n\t\t}\n\t}\n\n\tattachForResize() {\n\t\tif (!this.resizeListenerAttached) {\n\t\t\tthis.resizeListenerAttached = true;\n\t\t\tResizeHandler.register(this.getDomRef()!, this._handleResize);\n\t\t}\n\t}\n\n\tget shouldRenderH1() {\n\t\treturn !this.header.length && this.headerText;\n\t}\n\n\tget headerID() {\n\t\treturn `${this._id}-header`;\n\t}\n\n\tget modeLabelID() {\n\t\treturn `${this._id}-modeLabel`;\n\t}\n\n\tget listEndDOM() {\n\t\treturn this.shadowRoot!.querySelector(\".ui5-list-end-marker\");\n\t}\n\n\tget hasData() {\n\t\treturn this.getItems().length !== 0;\n\t}\n\n\tget showNoDataText() {\n\t\treturn !this.hasData && this.noDataText;\n\t}\n\n\tget isDelete() {\n\t\treturn this.mode === ListMode.Delete;\n\t}\n\n\tget isSingleSelect() {\n\t\treturn [\n\t\t\tListMode.SingleSelect,\n\t\t\tListMode.SingleSelectBegin,\n\t\t\tListMode.SingleSelectEnd,\n\t\t\tListMode.SingleSelectAuto,\n\t\t].includes(this.mode as ListMode);\n\t}\n\n\tget isMultiSelect() {\n\t\treturn this.mode === ListMode.MultiSelect;\n\t}\n\n\tget ariaLabelledBy() {\n\t\tif (this.accessibleNameRef || this.accessibleName) {\n\t\t\treturn undefined;\n\t\t}\n\t\tconst ids = [];\n\n\t\tif (this.isMultiSelect || this.isSingleSelect || this.isDelete) {\n\t\t\tids.push(this.modeLabelID);\n\t\t}\n\n\t\tif (this.shouldRenderH1) {\n\t\t\tids.push(this.headerID);\n\t\t}\n\n\t\treturn ids.length ? ids.join(\" \") : undefined;\n\t}\n\n\tget ariaLabelTxt() {\n\t\treturn getEffectiveAriaLabelText(this);\n\t}\n\n\tget ariaLabelModeText(): string {\n\t\tif (this.hasData) {\n\t\t\tif (this.isMultiSelect) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_MULTISELECTABLE);\n\t\t\t}\n\t\t\tif (this.isSingleSelect) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_SELECTABLE);\n\t\t\t}\n\t\t\tif (this.isDelete) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_DELETABLE);\n\t\t\t}\n\t\t}\n\n\t\treturn \"\";\n\t}\n\n\tget grows() {\n\t\treturn this.growing !== ListGrowingMode.None;\n\t}\n\n\tget growsOnScroll() {\n\t\treturn this.growing === ListGrowingMode.Scroll;\n\t}\n\n\tget growsWithButton() {\n\t\treturn this.growing === ListGrowingMode.Button;\n\t}\n\n\tget _growingButtonText(): string {\n\t\treturn List.i18nBundle.getText(LOAD_MORE_TEXT);\n\t}\n\n\tget busyIndPosition() {\n\t\tif (!this.grows) {\n\t\t\treturn \"absolute\";\n\t\t}\n\n\t\treturn this._inViewport ? \"absolute\" : \"sticky\";\n\t}\n\n\tget styles() {\n\t\treturn {\n\t\t\tbusyInd: {\n\t\t\t\tposition: this.busyIndPosition,\n\t\t\t},\n\t\t};\n\t}\n\n\tget classes(): ClassMap {\n\t\treturn {\n\t\t\troot: {\n\t\t\t\t\"ui5-list-root\": true,\n\t\t\t\t\"ui5-content-native-scrollbars\": getEffectiveScrollbarStyle(),\n\t\t\t},\n\t\t};\n\t}\n\n\tprepareListItems() {\n\t\tconst slottedItems = this.getItemsForProcessing();\n\n\t\tslottedItems.forEach((item, key) => {\n\t\t\tconst isLastChild = key === slottedItems.length - 1;\n\t\t\tconst showBottomBorder = this.separators === ListSeparators.All\n\t\t\t\t|| (this.separators === ListSeparators.Inner && !isLastChild);\n\n\t\t\tif (item.hasConfigurableMode) {\n\t\t\t\t(item as ListItem)._mode = this.mode;\n\t\t\t}\n\t\t\titem.hasBorder = showBottomBorder;\n\t\t});\n\t}\n\n\tasync observeListEnd() {\n\t\tif (!this.listEndObserved) {\n\t\t\tawait renderFinished();\n\t\t\tthis.getIntersectionObserver().observe(this.listEndDOM!);\n\t\t\tthis.listEndObserved = true;\n\t\t}\n\t}\n\n\tunobserveListEnd() {\n\t\tif (this.growingIntersectionObserver) {\n\t\t\tthis.growingIntersectionObserver.disconnect();\n\t\t\tthis.growingIntersectionObserver = null;\n\t\t\tthis.listEndObserved = false;\n\t\t}\n\t}\n\n\tonInteresection(entries: Array<IntersectionObserverEntry>) {\n\t\tif (this.initialIntersection) {\n\t\t\tthis.initialIntersection = false;\n\t\t\treturn;\n\t\t}\n\t\tentries.forEach(entry => {\n\t\t\tif (entry.isIntersecting) {\n\t\t\t\tdebounce(this.loadMore.bind(this), INFINITE_SCROLL_DEBOUNCE_RATE);\n\t\t\t}\n\t\t});\n\t}\n\n\t/*\n\t* ITEM SELECTION BASED ON THE CURRENT MODE\n\t*/\n\tonSelectionRequested(e: CustomEvent<SelectionRequestEventDetail>) {\n\t\tconst previouslySelectedItems = this.getSelectedItems();\n\t\tlet selectionChange = false;\n\t\tthis._selectionRequested = true;\n\n\t\tif (this.mode !== ListMode.None && this[`handle${this.mode}`]) {\n\t\t\tselectionChange = this[`handle${this.mode}`](e.detail.item, !!e.detail.selected);\n\t\t}\n\n\t\tif (selectionChange) {\n\t\t\tconst changePrevented = !this.fireEvent<ListSelectionChangeEventDetail>(\"selection-change\", {\n\t\t\t\tselectedItems: this.getSelectedItems(),\n\t\t\t\tpreviouslySelectedItems,\n\t\t\t\tselectionComponentPressed: e.detail.selectionComponentPressed,\n\t\t\t\ttargetItem: e.detail.item,\n\t\t\t\tkey: e.detail.key,\n\t\t\t}, true);\n\t\t\tif (changePrevented) {\n\t\t\t\tthis._revertSelection(previouslySelectedItems);\n\t\t\t}\n\t\t}\n\t}\n\n\thandleSingleSelect(item: ListItemBase): boolean {\n\t\tif (item.selected) {\n\t\t\treturn false;\n\t\t}\n\n\t\tthis.deselectSelectedItems();\n\t\titem.selected = true;\n\n\t\treturn true;\n\t}\n\n\thandleSingleSelectBegin(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleSingleSelectEnd(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleSingleSelectAuto(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleMultiSelect(item: ListItemBase, selected: boolean): boolean {\n\t\titem.selected = selected;\n\t\treturn true;\n\t}\n\n\thandleDelete(item: ListItemBase): boolean {\n\t\tthis.fireEvent<ListItemDeleteEventDetail>(\"item-delete\", { item });\n\n\t\treturn true;\n\t}\n\n\tdeselectSelectedItems() {\n\t\tthis.getSelectedItems().forEach(item => { item.selected = false; });\n\t}\n\n\tgetSelectedItems(): Array<ListItemBase> {\n\t\treturn this.getItems().filter(item => item.selected);\n\t}\n\n\tgetEnabledItems(): Array<ListItemBase> {\n\t\treturn this.getItems().filter(item => !item.disabled);\n\t}\n\n\tgetItems(): Array<ListItemBase> {\n\t\treturn this.getSlottedNodes<ListItemBase>(\"items\");\n\t}\n\n\tgetItemsForProcessing(): Array<ListItemBase> {\n\t\treturn this.getItems();\n\t}\n\n\t_revertSelection(previouslySelectedItems: Array<ListItemBase>) {\n\t\tthis.getItems().forEach((item: ListItemBase) => {\n\t\t\tconst oldSelection = previouslySelectedItems.indexOf(item) !== -1;\n\t\t\tconst multiSelectCheckBox = item.shadowRoot!.querySelector<CheckBox>(\".ui5-li-multisel-cb\");\n\t\t\tconst singleSelectRadioButton = item.shadowRoot!.querySelector<RadioButton>(\".ui5-li-singlesel-radiobtn\");\n\n\t\t\titem.selected = oldSelection;\n\t\t\tif (multiSelectCheckBox) {\n\t\t\t\tmultiSelectCheckBox.checked = oldSelection;\n\t\t\t} else if (singleSelectRadioButton) {\n\t\t\t\tsingleSelectRadioButton.checked = oldSelection;\n\t\t\t}\n\t\t});\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isTabNext(e)) {\n\t\t\tthis._handleTabNext(e);\n\t\t}\n\t}\n\n\t_onLoadMoreKeydown(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\te.preventDefault();\n\t\t\tthis._loadMoreActive = true;\n\t\t}\n\n\t\tif (isEnter(e)) {\n\t\t\tthis._onLoadMoreClick();\n\t\t\tthis._loadMoreActive = true;\n\t\t}\n\n\t\tif (isTabNext(e)) {\n\t\t\tthis.focusAfterElement();\n\t\t}\n\n\t\tif (isTabPrevious(e)) {\n\t\t\tif (this.getPreviouslyFocusedItem()) {\n\t\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onLoadMoreKeyup(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\tthis._onLoadMoreClick();\n\t\t}\n\t\tthis._loadMoreActive = false;\n\t}\n\n\t_onLoadMoreMousedown() {\n\t\tthis._loadMoreActive = true;\n\t}\n\n\t_onLoadMoreMouseup() {\n\t\tthis._loadMoreActive = false;\n\t}\n\n\t_onLoadMoreClick() {\n\t\tthis.loadMore();\n\t}\n\n\tcheckListInViewport() {\n\t\tthis._inViewport = isElementInView(this.getDomRef()!);\n\t}\n\n\tloadMore() {\n\t\tthis.fireEvent(\"load-more\");\n\t}\n\n\t/*\n\t* KEYBOARD SUPPORT\n\t*/\n\t_handleTabNext(e: KeyboardEvent) {\n\t\tlet lastTabbableEl;\n\t\tconst target = getNormalizedTarget(e.target as HTMLElement);\n\n\t\tif (!lastTabbableEl) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (lastTabbableEl === target) {\n\t\t\tif (this.getFirstItem(x => x.selected && !x.disabled)) {\n\t\t\t\tthis.focusFirstSelectedItem();\n\t\t\t} else if (this.getPreviouslyFocusedItem()) {\n\t\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\n\t\t\te.stopImmediatePropagation();\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onfocusin(e: FocusEvent) {\n\t\tconst target = getNormalizedTarget(e.target as HTMLElement);\n\t\t// If the focusin event does not origin from one of the 'triggers' - ignore it.\n\t\tif (!this.isForwardElement(target)) {\n\t\t\te.stopImmediatePropagation();\n\t\t\treturn;\n\t\t}\n\n\t\t// The focus arrives in the List for the first time.\n\t\t// If there is selected item - focus it or focus the first item.\n\t\tif (!this.getPreviouslyFocusedItem()) {\n\t\t\tif (this.growsWithButton && this.isForwardAfterElement(target)) {\n\t\t\t\tthis.focusGrowingButton();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\t\t\te.stopImmediatePropagation();\n\t\t\treturn;\n\t\t}\n\n\t\t// The focus returns to the List,\n\t\t// focus the first selected item or the previously focused element.\n\t\tif (!this.getForwardingFocus()) {\n\t\t\tif (this.growsWithButton && this.isForwardAfterElement(target)) {\n\t\t\t\tthis.focusGrowingButton();\n\t\t\t\te.stopImmediatePropagation();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.setForwardingFocus(false);\n\t}\n\n\tisForwardElement(element: HTMLElement) {\n\t\tconst elementId = element.id;\n\t\tconst beforeElement = this.getBeforeElement();\n\n\t\tif (this._id === elementId || (beforeElement && beforeElement.id === elementId)) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn this.isForwardAfterElement(element);\n\t}\n\n\tisForwardAfterElement(element: HTMLElement) {\n\t\tconst elementId = element.id;\n\t\tconst afterElement = this.getAfterElement();\n\n\t\treturn afterElement && afterElement.id === elementId;\n\t}\n\n\tonItemFocused(e: CustomEvent) {\n\t\tconst target = e.target as ListItemBase;\n\n\t\te.stopPropagation();\n\n\t\tthis._itemNavigation.setCurrentItem(target);\n\t\tthis.fireEvent<ListItemFocusEventDetail>(\"item-focused\", { item: target });\n\n\t\tif (this.mode === ListMode.SingleSelectAuto) {\n\t\t\tconst detail: SelectionRequestEventDetail = {\n\t\t\t\titem: target,\n\t\t\t\tselectionComponentPressed: false,\n\t\t\t\tselected: true,\n\t\t\t\tkey: e.detail.key,\n\t\t\t};\n\n\t\t\tthis.onSelectionRequested({ detail } as CustomEvent<SelectionRequestEventDetail>);\n\t\t}\n\t}\n\n\tonItemPress(e: CustomEvent<PressEventDetail>) {\n\t\tconst pressedItem = e.detail.item;\n\n\t\tif (!this.fireEvent<ListItemClickEventDetail>(\"item-click\", { item: pressedItem }, true)) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (!this._selectionRequested && this.mode !== ListMode.Delete) {\n\t\t\tthis._selectionRequested = true;\n\t\t\tconst detail: SelectionRequestEventDetail = {\n\t\t\t\titem: pressedItem,\n\t\t\t\tselectionComponentPressed: false,\n\t\t\t\tselected: !pressedItem.selected,\n\t\t\t\tkey: e.detail.key,\n\t\t\t};\n\n\t\t\tthis.onSelectionRequested({ detail } as CustomEvent<SelectionRequestEventDetail>);\n\t\t}\n\n\t\tthis._selectionRequested = false;\n\t}\n\n\t// This is applicable to NotificationListItem\n\tonItemClose(e: CustomEvent<ListItemCloseEventDetail>) {\n\t\tconst target = e.target as UI5Element | null;\n\t\tconst shouldFireItemClose = target?.hasAttribute(\"ui5-li-notification\") || target?.hasAttribute(\"ui5-li-notification-group\");\n\n\t\tif (shouldFireItemClose) {\n\t\t\tthis.fireEvent<ListItemCloseEventDetail>(\"item-close\", { item: e.detail?.item });\n\t\t}\n\t}\n\n\tonItemToggle(e: CustomEvent<ListItemToggleEventDetail>) {\n\t\tthis.fireEvent<ListItemToggleEventDetail>(\"item-toggle\", { item: e.detail.item });\n\t}\n\n\tonForwardBefore(e: CustomEvent) {\n\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\t\tthis.focusBeforeElement();\n\t\te.stopPropagation();\n\t}\n\n\tonForwardAfter(e: CustomEvent) {\n\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\n\t\tif (!this.growsWithButton) {\n\t\t\tthis.focusAfterElement();\n\t\t} else {\n\t\t\tthis.focusGrowingButton();\n\t\t\te.preventDefault();\n\t\t}\n\n\t\te.stopPropagation();\n\t}\n\n\tfocusBeforeElement() {\n\t\tthis.setForwardingFocus(true);\n\t\tthis.getBeforeElement().focus();\n\t}\n\n\tfocusAfterElement() {\n\t\tthis.setForwardingFocus(true);\n\t\tthis.getAfterElement().focus();\n\t}\n\n\tfocusGrowingButton() {\n\t\tconst growingBtn = this.getGrowingButton();\n\n\t\tif (growingBtn) {\n\t\t\tgrowingBtn.focus();\n\t\t}\n\t}\n\n\tgetGrowingButton() {\n\t\treturn this.shadowRoot!.querySelector(`[id=\"${this._id}-growing-btn\"]`) as HTMLElement;\n\t}\n\n\t/**\n\t * Focuses the first list item and sets its tabindex to \"0\" via the ItemNavigation\n\t * @protected\n\t */\n\tfocusFirstItem() {\n\t\t// only enabled items are focusable\n\t\tconst firstItem = this.getFirstItem(x => !x.disabled);\n\n\t\tif (firstItem) {\n\t\t\tfirstItem.focus();\n\t\t}\n\t}\n\n\tfocusPreviouslyFocusedItem() {\n\t\tconst previouslyFocusedItem = this.getPreviouslyFocusedItem();\n\n\t\tif (previouslyFocusedItem) {\n\t\t\tpreviouslyFocusedItem.focus();\n\t\t}\n\t}\n\n\tfocusFirstSelectedItem() {\n\t\t// only enabled items are focusable\n\t\tconst firstSelectedItem = this.getFirstItem(x => x.selected && !x.disabled);\n\n\t\tif (firstSelectedItem) {\n\t\t\tfirstSelectedItem.focus();\n\t\t}\n\t}\n\n\t/**\n\t * Focuses a list item and sets its tabindex to \"0\" via the ItemNavigation\n\t * @protected\n\t * @param item\n\t */\n\tfocusItem(item: ListItemBase) {\n\t\tthis._itemNavigation.setCurrentItem(item);\n\t\titem.focus();\n\t}\n\n\tonFocusRequested(e: CustomEvent) {\n\t\tsetTimeout(() => {\n\t\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t}, 0);\n\t}\n\n\tsetForwardingFocus(forwardingFocus: boolean) {\n\t\tthis._forwardingFocus = forwardingFocus;\n\t}\n\n\tgetForwardingFocus() {\n\t\treturn this._forwardingFocus;\n\t}\n\n\tsetPreviouslyFocusedItem(item: ListItemBase) {\n\t\tthis._previouslyFocusedItem = item;\n\t}\n\n\tgetPreviouslyFocusedItem() {\n\t\treturn this._previouslyFocusedItem;\n\t}\n\n\tgetFirstItem(filter: (item: ListItemBase) => boolean): ListItemBase | null {\n\t\tconst slottedItems = this.getItems();\n\t\tlet firstItem = null;\n\n\t\tif (!filter) {\n\t\t\treturn slottedItems.length ? slottedItems[0] : null;\n\t\t}\n\n\t\tfor (let i = 0; i < slottedItems.length; i++) {\n\t\t\tif (filter(slottedItems[i])) {\n\t\t\t\tfirstItem = slottedItems[i];\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn firstItem;\n\t}\n\n\tgetAfterElement() {\n\t\tif (!this._afterElement) {\n\t\t\tthis._afterElement = this.shadowRoot!.querySelector(`[id=\"${this._id}-after\"]`) as HTMLElement;\n\t\t}\n\t\treturn this._afterElement;\n\t}\n\n\tgetBeforeElement() {\n\t\tif (!this._beforeElement) {\n\t\t\tthis._beforeElement = this.shadowRoot!.querySelector(`[id=\"${this._id}-before\"]`) as HTMLElement;\n\t\t}\n\t\treturn this._beforeElement;\n\t}\n\n\tgetIntersectionObserver() {\n\t\tif (!this.growingIntersectionObserver) {\n\t\t\tthis.growingIntersectionObserver = new IntersectionObserver(this.onInteresection.bind(this), {\n\t\t\t\troot: null,\n\t\t\t\trootMargin: \"0px\",\n\t\t\t\tthreshold: 1.0,\n\t\t\t});\n\t\t}\n\n\t\treturn this.growingIntersectionObserver;\n\t}\n}\n\nList.define();\n\nexport default List;\nexport type {\n\tListItemClickEventDetail,\n\tListItemFocusEventDetail,\n\tListItemDeleteEventDetail,\n\tListItemCloseEventDetail,\n\tListItemToggleEventDetail,\n\tListSelectionChangeEventDetail,\n};\n"]}
1
+ {"version":3,"file":"List.js","sourceRoot":"","sources":["../src/List.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport ResizeHandler from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport type { ResizeObserverCallback } from \"@ui5/webcomponents-base/dist/delegate/ResizeHandler.js\";\nimport ItemNavigation from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport type { ClassMap } from \"@ui5/webcomponents-base/dist/types.js\";\nimport { renderFinished } from \"@ui5/webcomponents-base/dist/Render.js\";\nimport {\n\tisTabNext,\n\tisSpace,\n\tisEnter,\n\tisTabPrevious,\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport Integer from \"@ui5/webcomponents-base/dist/types/Integer.js\";\nimport NavigationMode from \"@ui5/webcomponents-base/dist/types/NavigationMode.js\";\nimport { getEffectiveAriaLabelText } from \"@ui5/webcomponents-base/dist/util/AriaLabelHelper.js\";\nimport getNormalizedTarget from \"@ui5/webcomponents-base/dist/util/getNormalizedTarget.js\";\nimport getEffectiveScrollbarStyle from \"@ui5/webcomponents-base/dist/util/getEffectiveScrollbarStyle.js\";\nimport { getI18nBundle } from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport type I18nBundle from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport debounce from \"@ui5/webcomponents-base/dist/util/debounce.js\";\nimport isElementInView from \"@ui5/webcomponents-base/dist/util/isElementInView.js\";\nimport ListMode from \"./types/ListMode.js\";\nimport ListGrowingMode from \"./types/ListGrowingMode.js\";\nimport ListItemBase from \"./ListItemBase.js\";\nimport type ListItem from \"./ListItem.js\";\nimport type {\n\tSelectionRequestEventDetail,\n\tPressEventDetail,\n} from \"./ListItem.js\";\nimport ListSeparators from \"./types/ListSeparators.js\";\nimport BusyIndicator from \"./BusyIndicator.js\";\n\n// Template\nimport ListTemplate from \"./generated/templates/ListTemplate.lit.js\";\n\n// Styles\nimport listCss from \"./generated/themes/List.css.js\";\nimport browserScrollbarCSS from \"./generated/themes/BrowserScrollbar.css.js\";\n\n// Texts\nimport {\n\tLOAD_MORE_TEXT, ARIA_LABEL_LIST_SELECTABLE,\n\tARIA_LABEL_LIST_MULTISELECTABLE,\n\tARIA_LABEL_LIST_DELETABLE,\n} from \"./generated/i18n/i18n-defaults.js\";\nimport CheckBox from \"./CheckBox.js\";\nimport RadioButton from \"./RadioButton.js\";\n\nconst INFINITE_SCROLL_DEBOUNCE_RATE = 250; // ms\n\nconst PAGE_UP_DOWN_SIZE = 10;\n\n// ListItemBase-based events\ntype ListItemFocusEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListSelectionChangeEventDetail = {\n\tselectedItems: Array<ListItemBase>;\n\tpreviouslySelectedItems: Array<ListItemBase>;\n\tselectionComponentPressed: boolean;\n\ttargetItem: ListItemBase;\n\tkey?: string;\n}\n\ntype ListItemDeleteEventDetail = {\n\titem: ListItemBase,\n}\n\n// ListItem-based events\ntype ListItemCloseEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListItemToggleEventDetail = {\n\titem: ListItemBase,\n}\n\ntype ListItemClickEventDetail = {\n\titem: ListItemBase,\n}\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n *\n * The <code>ui5-list</code> component allows displaying a list of items, advanced keyboard\n * handling support for navigating between items, and predefined modes to improve the development efficiency.\n * <br><br>\n * The <code>ui5-list</code> is a container for the available list items:\n * <ul>\n * <li><code>ui5-li</code></li>\n * <li><code>ui5-li-custom</code></li>\n * <li><code>ui5-li-groupheader</code></li>\n * </ul>\n * <br><br>\n * To benefit from the built-in selection mechanism, you can use the available\n * selection modes, such as\n * <code>SingleSelect</code>, <code>MultiSelect</code> and <code>Delete</code>.\n * <br><br>\n * Additionally, the <code>ui5-list</code> provides header, footer, and customization for the list item separators.\n *\n * <br><br>\n * <h3>Keyboard Handling</h3>\n *\n * <h4>Basic Navigation</h4>\n * The <code>ui5-list</code> provides advanced keyboard handling.\n * When a list is focused the user can use the following keyboard\n * shortcuts in order to perform a navigation:\n * <br>\n *\n * <ul>\n * <li>[UP/DOWN] - Navigates up and down the items</li>\n * <li>[HOME] - Navigates to first item</li>\n * <li>[END] - Navigates to the last item</li>\n * </ul>\n *\n * The user can use the following keyboard shortcuts to perform actions (such as select, delete),\n * when the <code>mode</code> property is in use:\n * <ul>\n * <li>[SPACE] - Select an item (if <code>type</code> is 'Active') when <code>mode</code> is selection</li>\n * <li>[DELETE] - Delete an item if <code>mode</code> property is <code>Delete</code></li>\n * </ul>\n *\n * <h4>Fast Navigation</h4>\n * 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>.\n * In order to use this functionality, you need to import the following module:\n * <code>import \"@ui5/webcomponents-base/dist/features/F6Navigation.js\"</code>\n * <br><br>\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/List.js\";</code>\n * <br>\n * <code>import \"@ui5/webcomponents/dist/StandardListItem.js\";</code> (for <code>ui5-li</code>)\n * <br>\n * <code>import \"@ui5/webcomponents/dist/CustomListItem.js\";</code> (for <code>ui5-li-custom</code>)\n * <br>\n * <code>import \"@ui5/webcomponents/dist/GroupHeaderListItem.js\";</code> (for <code>ui5-li-groupheader</code>)\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.List\n * @extends sap.ui.webc.base.UI5Element\n * @tagname ui5-list\n * @appenddocs sap.ui.webc.main.StandardListItem sap.ui.webc.main.CustomListItem sap.ui.webc.main.GroupHeaderListItem\n * @public\n */\n@customElement({\n\ttag: \"ui5-list\",\n\tfastNavigation: true,\n\trenderer: litRender,\n\ttemplate: ListTemplate,\n\tstyles: [browserScrollbarCSS, listCss],\n\tdependencies: [BusyIndicator],\n})\n/**\n * Fired when an item is activated, unless the item's <code>type</code> property\n * is set to <code>Inactive</code>.\n *\n * @event sap.ui.webc.main.List#item-click\n * @allowPreventDefault\n * @param {HTMLElement} item The clicked item.\n * @public\n */\n@event(\"item-click\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the <code>Close</code> button of any item is clicked\n * <br><br>\n * <b>Note:</b> This event is only applicable to list items that can be closed (such as notification list items),\n * not to be confused with <code>item-delete</code>.\n *\n * @event sap.ui.webc.main.List#item-close\n * @param {HTMLElement} item the item about to be closed.\n * @public\n * @since 1.0.0-rc.8\n */\n@event(\"item-close\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the <code>Toggle</code> button of any item is clicked.\n * <br><br>\n * <b>Note:</b> This event is only applicable to list items that can be toggled (such as notification group list items).\n *\n * @event sap.ui.webc.main.List#item-toggle\n * @param {HTMLElement} item the toggled item.\n * @public\n * @since 1.0.0-rc.8\n */\n@event(\"item-toggle\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when the Delete button of any item is pressed.\n * <br><br>\n * <b>Note:</b> A Delete button is displayed on each item,\n * when the component <code>mode</code> property is set to <code>Delete</code>.\n *\n * @event sap.ui.webc.main.List#item-delete\n * @param {HTMLElement} item the deleted item.\n * @public\n */\n@event(\"item-delete\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\n\n/**\n * Fired when selection is changed by user interaction\n * in <code>SingleSelect</code>, <code>SingleSelectBegin</code>, <code>SingleSelectEnd</code> and <code>MultiSelect</code> modes.\n *\n * @event sap.ui.webc.main.List#selection-change\n * @allowPreventDefault\n * @param {Array} selectedItems An array of the selected items.\n * @param {Array} previouslySelectedItems An array of the previously selected items.\n * @public\n */\n@event(\"selection-change\", {\n\tdetail: {\n\t\tselectedItems: { type: Array },\n\t\tpreviouslySelectedItems: { type: Array },\n\t\ttargetItem: { type: HTMLElement }, // protected, holds the event target item\n\t\tselectionComponentPressed: { type: Boolean }, // protected, indicates if the user used the selection components to change the selection\n\t},\n})\n\n/**\n * Fired when the user scrolls to the bottom of the list.\n * <br><br>\n * <b>Note:</b> The event is fired when the <code>growing='Scroll'</code> property is enabled.\n *\n * @event sap.ui.webc.main.List#load-more\n * @public\n * @since 1.0.0-rc.6\n */\n@event(\"load-more\")\n\n/**\n * @private\n */\n@event(\"item-focused\", {\n\tdetail: {\n\t\titem: { type: HTMLElement },\n\t},\n})\nclass List extends UI5Element {\n\t/**\n\t * Defines the component header text.\n\t * <br><br>\n\t * <b>Note:</b> If <code>header</code> is set this property is ignored.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.headerText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\theaderText!: string;\n\n\t/**\n\t * Defines the footer text.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.footerText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tfooterText!: string;\n\n\t/**\n\t * Determines whether the component is indented.\n\t *\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.List.prototype.indent\n\t * @defaultvalue false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tindent!: boolean;\n\n\t/**\n\t * Defines the mode of the component.\n\t *\n\t * @type {sap.ui.webc.main.types.ListMode}\n\t * @name sap.ui.webc.main.List.prototype.mode\n\t * @defaultvalue \"None\"\n\t * @public\n\t */\n\t@property({ type: ListMode, defaultValue: ListMode.None })\n\tmode!: `${ListMode}`;\n\n\t/**\n\t * Defines the text that is displayed when the component contains no items.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.noDataText\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tnoDataText!: string;\n\n\t/**\n\t * Defines the item separator style that is used.\n\t *\n\t * @type {sap.ui.webc.main.types.ListSeparators}\n\t * @name sap.ui.webc.main.List.prototype.separators\n\t * @defaultvalue \"All\"\n\t * @public\n\t */\n\t@property({ type: ListSeparators, defaultValue: ListSeparators.All })\n\tseparators!: `${ListSeparators}`;\n\n\t/**\n\t * Defines whether the component will have growing capability either by pressing a <code>More</code> button,\n\t * or via user scroll. In both cases <code>load-more</code> event is fired.\n\t * <br><br>\n\t * <b>Restrictions:</b> <code>growing=\"Scroll\"</code> is not supported for Internet Explorer,\n\t * on IE the component will fallback to <code>growing=\"Button\"</code>.\n\t * @type {sap.ui.webc.main.types.ListGrowingMode}\n\t * @name sap.ui.webc.main.List.prototype.growing\n\t * @defaultvalue \"None\"\n\t * @since 1.0.0-rc.13\n\t * @public\n\t */\n\t@property({ type: ListGrowingMode, defaultValue: ListGrowingMode.None })\n\tgrowing!: `${ListGrowingMode}`;\n\n\t/**\n\t * Defines if the component would display a loading indicator over the list.\n\t *\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.List.prototype.busy\n\t * @defaultvalue false\n\t * @public\n\t * @since 1.0.0-rc.6\n\t */\n\t@property({ type: Boolean })\n\tbusy!: boolean;\n\n\t/**\n\t * Defines the delay in milliseconds, after which the busy indicator will show up for this component.\n\t *\n\t * @type {sap.ui.webc.base.types.Integer}\n\t * @name sap.ui.webc.main.List.prototype.busyDelay\n\t * @defaultValue 1000\n\t * @public\n\t */\n\t@property({ validator: Integer, defaultValue: 1000 })\n\tbusyDelay!: number;\n\n\t/**\n\t * Defines the accessible name of the component.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleName\n\t * @defaultvalue \"\"\n\t * @public\n\t * @since 1.0.0-rc.15\n\t */\n\t@property()\n\taccessibleName!: string;\n\n\t/**\n\t * Defines the IDs of the elements that label the input.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleNameRef\n\t * @defaultvalue \"\"\n\t * @public\n\t * @since 1.0.0-rc.15\n\t */\n\t@property({ defaultValue: \"\" })\n\taccessibleNameRef!: string;\n\n\t/**\n\t * Defines the accessible role of the component.\n\t * <br><br>\n\t * @public\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleRole\n\t * @defaultvalue \"list\"\n\t * @since 1.0.0-rc.15\n\t */\n\t@property({ defaultValue: \"list\" })\n\taccessibleRole!: string;\n\n\t/**\n\t * Defines the description for the accessible role of the component.\n\t * @protected\n\t * @type {string}\n\t * @name sap.ui.webc.main.List.prototype.accessibleRoleDescription\n\t * @defaultvalue undefined\n\t * @since 1.10.0\n\t */\n\t@property({ defaultValue: undefined, noAttribute: true })\n\taccessibleRoleDescription?: string;\n\n\t/**\n\t * Defines if the entire list is in view port.\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_inViewport!: boolean;\n\n\t/**\n\t * Defines the active state of the <code>More</code> button.\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_loadMoreActive!: boolean;\n\n\t/**\n\t * Defines the items of the component.\n\t * <br><br>\n\t * <b>Note:</b> Use <code>ui5-li</code>, <code>ui5-li-custom</code>, and <code>ui5-li-groupheader</code> for the intended design.\n\t *\n\t * @type {sap.ui.webc.main.IListItem[]}\n\t * @name sap.ui.webc.main.List.prototype.default\n\t * @slot items\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, \"default\": true })\n\titems!: Array<ListItemBase>;\n\n\t/**\n\t * Defines the component header.\n\t * <br><br>\n\t * <b>Note:</b> When <code>header</code> is set, the\n\t * <code>headerText</code> property is ignored.\n\t *\n\t * @type {HTMLElement[]}\n\t * @name sap.ui.webc.main.List.prototype.header\n\t * @slot\n\t * @public\n\t */\n\t@slot()\n\theader!: Array<HTMLElement>;\n\n\tstatic i18nBundle: I18nBundle;\n\t_previouslyFocusedItem: ListItemBase | null;\n\t_forwardingFocus: boolean;\n\tresizeListenerAttached: boolean;\n\tlistEndObserved: boolean;\n\t_handleResize: ResizeObserverCallback;\n\tinitialIntersection: boolean;\n\t_selectionRequested?: boolean;\n\tgrowingIntersectionObserver?: IntersectionObserver | null;\n\t_itemNavigation: ItemNavigation;\n\t_beforeElement?: HTMLElement | null;\n\t_afterElement?: HTMLElement | null;\n\n\tstatic async onDefine() {\n\t\tList.i18nBundle = await getI18nBundle(\"@ui5/webcomponents\");\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\tthis._previouslyFocusedItem = null;\n\n\t\t// Indicates that the List is forwarding the focus before or after the internal ul.\n\t\tthis._forwardingFocus = false;\n\n\t\t// Indicates that the List has already subscribed for resize.\n\t\tthis.resizeListenerAttached = false;\n\n\t\t// Indicates if the IntersectionObserver started observing the List\n\t\tthis.listEndObserved = false;\n\n\t\tthis._itemNavigation = new ItemNavigation(this, {\n\t\t\tskipItemsSize: PAGE_UP_DOWN_SIZE, // PAGE_UP and PAGE_DOWN will skip trough 10 items\n\t\t\tnavigationMode: NavigationMode.Vertical,\n\t\t\tgetItemsCallback: () => this.getEnabledItems(),\n\t\t});\n\n\t\tthis._handleResize = this.checkListInViewport.bind(this);\n\n\t\tthis._handleResize = this.checkListInViewport.bind(this);\n\n\t\t// Indicates the List bottom most part has been detected by the IntersectionObserver\n\t\t// for the first time.\n\t\tthis.initialIntersection = true;\n\t}\n\n\tonExitDOM() {\n\t\tthis.unobserveListEnd();\n\t\tthis.resizeListenerAttached = false;\n\t\tResizeHandler.deregister(this.getDomRef()!, this._handleResize);\n\t}\n\n\tonBeforeRendering() {\n\t\tthis.prepareListItems();\n\t}\n\n\tonAfterRendering() {\n\t\tif (this.growsOnScroll) {\n\t\t\tthis.observeListEnd();\n\t\t} else if (this.listEndObserved) {\n\t\t\tthis.unobserveListEnd();\n\t\t}\n\n\t\tif (this.grows) {\n\t\t\tthis.checkListInViewport();\n\t\t\tthis.attachForResize();\n\t\t}\n\t}\n\n\tattachForResize() {\n\t\tif (!this.resizeListenerAttached) {\n\t\t\tthis.resizeListenerAttached = true;\n\t\t\tResizeHandler.register(this.getDomRef()!, this._handleResize);\n\t\t}\n\t}\n\n\tget shouldRenderH1() {\n\t\treturn !this.header.length && this.headerText;\n\t}\n\n\tget headerID() {\n\t\treturn `${this._id}-header`;\n\t}\n\n\tget modeLabelID() {\n\t\treturn `${this._id}-modeLabel`;\n\t}\n\n\tget listEndDOM() {\n\t\treturn this.shadowRoot!.querySelector(\".ui5-list-end-marker\");\n\t}\n\n\tget hasData() {\n\t\treturn this.getItems().length !== 0;\n\t}\n\n\tget showNoDataText() {\n\t\treturn !this.hasData && this.noDataText;\n\t}\n\n\tget isDelete() {\n\t\treturn this.mode === ListMode.Delete;\n\t}\n\n\tget isSingleSelect() {\n\t\treturn [\n\t\t\tListMode.SingleSelect,\n\t\t\tListMode.SingleSelectBegin,\n\t\t\tListMode.SingleSelectEnd,\n\t\t\tListMode.SingleSelectAuto,\n\t\t].includes(this.mode as ListMode);\n\t}\n\n\tget isMultiSelect() {\n\t\treturn this.mode === ListMode.MultiSelect;\n\t}\n\n\tget ariaLabelledBy() {\n\t\tif (this.accessibleNameRef || this.accessibleName) {\n\t\t\treturn undefined;\n\t\t}\n\t\tconst ids = [];\n\n\t\tif (this.isMultiSelect || this.isSingleSelect || this.isDelete) {\n\t\t\tids.push(this.modeLabelID);\n\t\t}\n\n\t\tif (this.shouldRenderH1) {\n\t\t\tids.push(this.headerID);\n\t\t}\n\n\t\treturn ids.length ? ids.join(\" \") : undefined;\n\t}\n\n\tget ariaLabelTxt() {\n\t\treturn getEffectiveAriaLabelText(this);\n\t}\n\n\tget ariaLabelModeText(): string {\n\t\tif (this.hasData) {\n\t\t\tif (this.isMultiSelect) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_MULTISELECTABLE);\n\t\t\t}\n\t\t\tif (this.isSingleSelect) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_SELECTABLE);\n\t\t\t}\n\t\t\tif (this.isDelete) {\n\t\t\t\treturn List.i18nBundle.getText(ARIA_LABEL_LIST_DELETABLE);\n\t\t\t}\n\t\t}\n\n\t\treturn \"\";\n\t}\n\n\tget grows() {\n\t\treturn this.growing !== ListGrowingMode.None;\n\t}\n\n\tget growsOnScroll() {\n\t\treturn this.growing === ListGrowingMode.Scroll;\n\t}\n\n\tget growsWithButton() {\n\t\treturn this.growing === ListGrowingMode.Button;\n\t}\n\n\tget _growingButtonText(): string {\n\t\treturn List.i18nBundle.getText(LOAD_MORE_TEXT);\n\t}\n\n\tget busyIndPosition() {\n\t\tif (!this.grows) {\n\t\t\treturn \"absolute\";\n\t\t}\n\n\t\treturn this._inViewport ? \"absolute\" : \"sticky\";\n\t}\n\n\tget styles() {\n\t\treturn {\n\t\t\tbusyInd: {\n\t\t\t\tposition: this.busyIndPosition,\n\t\t\t},\n\t\t};\n\t}\n\n\tget classes(): ClassMap {\n\t\treturn {\n\t\t\troot: {\n\t\t\t\t\"ui5-list-root\": true,\n\t\t\t\t\"ui5-content-native-scrollbars\": getEffectiveScrollbarStyle(),\n\t\t\t},\n\t\t};\n\t}\n\n\tprepareListItems() {\n\t\tconst slottedItems = this.getItemsForProcessing();\n\n\t\tslottedItems.forEach((item, key) => {\n\t\t\tconst isLastChild = key === slottedItems.length - 1;\n\t\t\tconst showBottomBorder = this.separators === ListSeparators.All\n\t\t\t\t|| (this.separators === ListSeparators.Inner && !isLastChild);\n\n\t\t\tif (item.hasConfigurableMode) {\n\t\t\t\t(item as ListItem)._mode = this.mode;\n\t\t\t}\n\t\t\titem.hasBorder = showBottomBorder;\n\t\t});\n\t}\n\n\tasync observeListEnd() {\n\t\tif (!this.listEndObserved) {\n\t\t\tawait renderFinished();\n\t\t\tthis.getIntersectionObserver().observe(this.listEndDOM!);\n\t\t\tthis.listEndObserved = true;\n\t\t}\n\t}\n\n\tunobserveListEnd() {\n\t\tif (this.growingIntersectionObserver) {\n\t\t\tthis.growingIntersectionObserver.disconnect();\n\t\t\tthis.growingIntersectionObserver = null;\n\t\t\tthis.listEndObserved = false;\n\t\t}\n\t}\n\n\tonInteresection(entries: Array<IntersectionObserverEntry>) {\n\t\tif (this.initialIntersection) {\n\t\t\tthis.initialIntersection = false;\n\t\t\treturn;\n\t\t}\n\t\tentries.forEach(entry => {\n\t\t\tif (entry.isIntersecting) {\n\t\t\t\tdebounce(this.loadMore.bind(this), INFINITE_SCROLL_DEBOUNCE_RATE);\n\t\t\t}\n\t\t});\n\t}\n\n\t/*\n\t* ITEM SELECTION BASED ON THE CURRENT MODE\n\t*/\n\tonSelectionRequested(e: CustomEvent<SelectionRequestEventDetail>) {\n\t\tconst previouslySelectedItems = this.getSelectedItems();\n\t\tlet selectionChange = false;\n\t\tthis._selectionRequested = true;\n\n\t\tif (this.mode !== ListMode.None && this[`handle${this.mode}`]) {\n\t\t\tselectionChange = this[`handle${this.mode}`](e.detail.item, !!e.detail.selected);\n\t\t}\n\n\t\tif (selectionChange) {\n\t\t\tconst changePrevented = !this.fireEvent<ListSelectionChangeEventDetail>(\"selection-change\", {\n\t\t\t\tselectedItems: this.getSelectedItems(),\n\t\t\t\tpreviouslySelectedItems,\n\t\t\t\tselectionComponentPressed: e.detail.selectionComponentPressed,\n\t\t\t\ttargetItem: e.detail.item,\n\t\t\t\tkey: e.detail.key,\n\t\t\t}, true);\n\t\t\tif (changePrevented) {\n\t\t\t\tthis._revertSelection(previouslySelectedItems);\n\t\t\t}\n\t\t}\n\t}\n\n\thandleSingleSelect(item: ListItemBase): boolean {\n\t\tif (item.selected) {\n\t\t\treturn false;\n\t\t}\n\n\t\tthis.deselectSelectedItems();\n\t\titem.selected = true;\n\n\t\treturn true;\n\t}\n\n\thandleSingleSelectBegin(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleSingleSelectEnd(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleSingleSelectAuto(item: ListItemBase): boolean {\n\t\treturn this.handleSingleSelect(item);\n\t}\n\n\thandleMultiSelect(item: ListItemBase, selected: boolean): boolean {\n\t\titem.selected = selected;\n\t\treturn true;\n\t}\n\n\thandleDelete(item: ListItemBase): boolean {\n\t\tthis.fireEvent<ListItemDeleteEventDetail>(\"item-delete\", { item });\n\n\t\treturn true;\n\t}\n\n\tdeselectSelectedItems() {\n\t\tthis.getSelectedItems().forEach(item => { item.selected = false; });\n\t}\n\n\tgetSelectedItems(): Array<ListItemBase> {\n\t\treturn this.getItems().filter(item => item.selected);\n\t}\n\n\tgetEnabledItems(): Array<ListItemBase> {\n\t\treturn this.getItems().filter(item => !item.disabled);\n\t}\n\n\tgetItems(): Array<ListItemBase> {\n\t\treturn this.getSlottedNodes<ListItemBase>(\"items\");\n\t}\n\n\tgetItemsForProcessing(): Array<ListItemBase> {\n\t\treturn this.getItems();\n\t}\n\n\t_revertSelection(previouslySelectedItems: Array<ListItemBase>) {\n\t\tthis.getItems().forEach((item: ListItemBase) => {\n\t\t\tconst oldSelection = previouslySelectedItems.indexOf(item) !== -1;\n\t\t\tconst multiSelectCheckBox = item.shadowRoot!.querySelector<CheckBox>(\".ui5-li-multisel-cb\");\n\t\t\tconst singleSelectRadioButton = item.shadowRoot!.querySelector<RadioButton>(\".ui5-li-singlesel-radiobtn\");\n\n\t\t\titem.selected = oldSelection;\n\t\t\tif (multiSelectCheckBox) {\n\t\t\t\tmultiSelectCheckBox.checked = oldSelection;\n\t\t\t} else if (singleSelectRadioButton) {\n\t\t\t\tsingleSelectRadioButton.checked = oldSelection;\n\t\t\t}\n\t\t});\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isTabNext(e)) {\n\t\t\tthis._handleTabNext(e);\n\t\t}\n\t}\n\n\t_onLoadMoreKeydown(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\te.preventDefault();\n\t\t\tthis._loadMoreActive = true;\n\t\t}\n\n\t\tif (isEnter(e)) {\n\t\t\tthis._onLoadMoreClick();\n\t\t\tthis._loadMoreActive = true;\n\t\t}\n\n\t\tif (isTabNext(e)) {\n\t\t\tthis.focusAfterElement();\n\t\t}\n\n\t\tif (isTabPrevious(e)) {\n\t\t\tif (this.getPreviouslyFocusedItem()) {\n\t\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onLoadMoreKeyup(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\tthis._onLoadMoreClick();\n\t\t}\n\t\tthis._loadMoreActive = false;\n\t}\n\n\t_onLoadMoreMousedown() {\n\t\tthis._loadMoreActive = true;\n\t}\n\n\t_onLoadMoreMouseup() {\n\t\tthis._loadMoreActive = false;\n\t}\n\n\t_onLoadMoreClick() {\n\t\tthis.loadMore();\n\t}\n\n\tcheckListInViewport() {\n\t\tthis._inViewport = isElementInView(this.getDomRef()!);\n\t}\n\n\tloadMore() {\n\t\tthis.fireEvent(\"load-more\");\n\t}\n\n\t/*\n\t* KEYBOARD SUPPORT\n\t*/\n\t_handleTabNext(e: KeyboardEvent) {\n\t\tlet lastTabbableEl;\n\t\tconst target = getNormalizedTarget(e.target as HTMLElement);\n\n\t\tif (!lastTabbableEl) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (lastTabbableEl === target) {\n\t\t\tif (this.getFirstItem(x => x.selected && !x.disabled)) {\n\t\t\t\tthis.focusFirstSelectedItem();\n\t\t\t} else if (this.getPreviouslyFocusedItem()) {\n\t\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\n\t\t\te.stopImmediatePropagation();\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onfocusin(e: FocusEvent) {\n\t\tconst target = getNormalizedTarget(e.target as HTMLElement);\n\t\t// If the focusin event does not origin from one of the 'triggers' - ignore it.\n\t\tif (!this.isForwardElement(target)) {\n\t\t\te.stopImmediatePropagation();\n\t\t\treturn;\n\t\t}\n\n\t\t// The focus arrives in the List for the first time.\n\t\t// If there is selected item - focus it or focus the first item.\n\t\tif (!this.getPreviouslyFocusedItem()) {\n\t\t\tif (this.growsWithButton && this.isForwardAfterElement(target)) {\n\t\t\t\tthis.focusGrowingButton();\n\t\t\t} else {\n\t\t\t\tthis.focusFirstItem();\n\t\t\t}\n\t\t\te.stopImmediatePropagation();\n\t\t\treturn;\n\t\t}\n\n\t\t// The focus returns to the List,\n\t\t// focus the first selected item or the previously focused element.\n\t\tif (!this.getForwardingFocus()) {\n\t\t\tif (this.growsWithButton && this.isForwardAfterElement(target)) {\n\t\t\t\tthis.focusGrowingButton();\n\t\t\t\te.stopImmediatePropagation();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.setForwardingFocus(false);\n\t}\n\n\tisForwardElement(element: HTMLElement) {\n\t\tconst elementId = element.id;\n\t\tconst beforeElement = this.getBeforeElement();\n\n\t\tif (this._id === elementId || (beforeElement && beforeElement.id === elementId)) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn this.isForwardAfterElement(element);\n\t}\n\n\tisForwardAfterElement(element: HTMLElement) {\n\t\tconst elementId = element.id;\n\t\tconst afterElement = this.getAfterElement();\n\n\t\treturn afterElement && afterElement.id === elementId;\n\t}\n\n\tonItemTabIndexChange(e: CustomEvent) {\n\t\tconst target = e.target as ListItemBase;\n\t\tthis._itemNavigation.setCurrentItem(target);\n\t}\n\n\tonItemFocused(e: CustomEvent) {\n\t\tconst target = e.target as ListItemBase;\n\n\t\te.stopPropagation();\n\n\t\tthis._itemNavigation.setCurrentItem(target);\n\t\tthis.fireEvent<ListItemFocusEventDetail>(\"item-focused\", { item: target });\n\n\t\tif (this.mode === ListMode.SingleSelectAuto) {\n\t\t\tconst detail: SelectionRequestEventDetail = {\n\t\t\t\titem: target,\n\t\t\t\tselectionComponentPressed: false,\n\t\t\t\tselected: true,\n\t\t\t\tkey: e.detail.key,\n\t\t\t};\n\n\t\t\tthis.onSelectionRequested({ detail } as CustomEvent<SelectionRequestEventDetail>);\n\t\t}\n\t}\n\n\tonItemPress(e: CustomEvent<PressEventDetail>) {\n\t\tconst pressedItem = e.detail.item;\n\n\t\tif (!this.fireEvent<ListItemClickEventDetail>(\"item-click\", { item: pressedItem }, true)) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (!this._selectionRequested && this.mode !== ListMode.Delete) {\n\t\t\tthis._selectionRequested = true;\n\t\t\tconst detail: SelectionRequestEventDetail = {\n\t\t\t\titem: pressedItem,\n\t\t\t\tselectionComponentPressed: false,\n\t\t\t\tselected: !pressedItem.selected,\n\t\t\t\tkey: e.detail.key,\n\t\t\t};\n\n\t\t\tthis.onSelectionRequested({ detail } as CustomEvent<SelectionRequestEventDetail>);\n\t\t}\n\n\t\tthis._selectionRequested = false;\n\t}\n\n\t// This is applicable to NotificationListItem\n\tonItemClose(e: CustomEvent<ListItemCloseEventDetail>) {\n\t\tconst target = e.target as UI5Element | null;\n\t\tconst shouldFireItemClose = target?.hasAttribute(\"ui5-li-notification\") || target?.hasAttribute(\"ui5-li-notification-group\");\n\n\t\tif (shouldFireItemClose) {\n\t\t\tthis.fireEvent<ListItemCloseEventDetail>(\"item-close\", { item: e.detail?.item });\n\t\t}\n\t}\n\n\tonItemToggle(e: CustomEvent<ListItemToggleEventDetail>) {\n\t\tthis.fireEvent<ListItemToggleEventDetail>(\"item-toggle\", { item: e.detail.item });\n\t}\n\n\tonForwardBefore(e: CustomEvent) {\n\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\t\tthis.focusBeforeElement();\n\t\te.stopPropagation();\n\t}\n\n\tonForwardAfter(e: CustomEvent) {\n\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\n\t\tif (!this.growsWithButton) {\n\t\t\tthis.focusAfterElement();\n\t\t} else {\n\t\t\tthis.focusGrowingButton();\n\t\t\te.preventDefault();\n\t\t}\n\n\t\te.stopPropagation();\n\t}\n\n\tfocusBeforeElement() {\n\t\tthis.setForwardingFocus(true);\n\t\tthis.getBeforeElement().focus();\n\t}\n\n\tfocusAfterElement() {\n\t\tthis.setForwardingFocus(true);\n\t\tthis.getAfterElement().focus();\n\t}\n\n\tfocusGrowingButton() {\n\t\tconst growingBtn = this.getGrowingButton();\n\n\t\tif (growingBtn) {\n\t\t\tgrowingBtn.focus();\n\t\t}\n\t}\n\n\tgetGrowingButton() {\n\t\treturn this.shadowRoot!.querySelector(`[id=\"${this._id}-growing-btn\"]`) as HTMLElement;\n\t}\n\n\t/**\n\t * Focuses the first list item and sets its tabindex to \"0\" via the ItemNavigation\n\t * @protected\n\t */\n\tfocusFirstItem() {\n\t\t// only enabled items are focusable\n\t\tconst firstItem = this.getFirstItem(x => !x.disabled);\n\n\t\tif (firstItem) {\n\t\t\tfirstItem.focus();\n\t\t}\n\t}\n\n\tfocusPreviouslyFocusedItem() {\n\t\tconst previouslyFocusedItem = this.getPreviouslyFocusedItem();\n\n\t\tif (previouslyFocusedItem) {\n\t\t\tpreviouslyFocusedItem.focus();\n\t\t}\n\t}\n\n\tfocusFirstSelectedItem() {\n\t\t// only enabled items are focusable\n\t\tconst firstSelectedItem = this.getFirstItem(x => x.selected && !x.disabled);\n\n\t\tif (firstSelectedItem) {\n\t\t\tfirstSelectedItem.focus();\n\t\t}\n\t}\n\n\t/**\n\t * Focuses a list item and sets its tabindex to \"0\" via the ItemNavigation\n\t * @protected\n\t * @param item\n\t */\n\tfocusItem(item: ListItemBase) {\n\t\tthis._itemNavigation.setCurrentItem(item);\n\t\titem.focus();\n\t}\n\n\tonFocusRequested(e: CustomEvent) {\n\t\tsetTimeout(() => {\n\t\t\tthis.setPreviouslyFocusedItem(e.target as ListItemBase);\n\t\t\tthis.focusPreviouslyFocusedItem();\n\t\t}, 0);\n\t}\n\n\tsetForwardingFocus(forwardingFocus: boolean) {\n\t\tthis._forwardingFocus = forwardingFocus;\n\t}\n\n\tgetForwardingFocus() {\n\t\treturn this._forwardingFocus;\n\t}\n\n\tsetPreviouslyFocusedItem(item: ListItemBase) {\n\t\tthis._previouslyFocusedItem = item;\n\t}\n\n\tgetPreviouslyFocusedItem() {\n\t\treturn this._previouslyFocusedItem;\n\t}\n\n\tgetFirstItem(filter: (item: ListItemBase) => boolean): ListItemBase | null {\n\t\tconst slottedItems = this.getItems();\n\t\tlet firstItem = null;\n\n\t\tif (!filter) {\n\t\t\treturn slottedItems.length ? slottedItems[0] : null;\n\t\t}\n\n\t\tfor (let i = 0; i < slottedItems.length; i++) {\n\t\t\tif (filter(slottedItems[i])) {\n\t\t\t\tfirstItem = slottedItems[i];\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn firstItem;\n\t}\n\n\tgetAfterElement() {\n\t\tif (!this._afterElement) {\n\t\t\tthis._afterElement = this.shadowRoot!.querySelector(`[id=\"${this._id}-after\"]`) as HTMLElement;\n\t\t}\n\t\treturn this._afterElement;\n\t}\n\n\tgetBeforeElement() {\n\t\tif (!this._beforeElement) {\n\t\t\tthis._beforeElement = this.shadowRoot!.querySelector(`[id=\"${this._id}-before\"]`) as HTMLElement;\n\t\t}\n\t\treturn this._beforeElement;\n\t}\n\n\tgetIntersectionObserver() {\n\t\tif (!this.growingIntersectionObserver) {\n\t\t\tthis.growingIntersectionObserver = new IntersectionObserver(this.onInteresection.bind(this), {\n\t\t\t\troot: null,\n\t\t\t\trootMargin: \"0px\",\n\t\t\t\tthreshold: 1.0,\n\t\t\t});\n\t\t}\n\n\t\treturn this.growingIntersectionObserver;\n\t}\n}\n\nList.define();\n\nexport default List;\nexport type {\n\tListItemClickEventDetail,\n\tListItemFocusEventDetail,\n\tListItemDeleteEventDetail,\n\tListItemCloseEventDetail,\n\tListItemToggleEventDetail,\n\tListSelectionChangeEventDetail,\n};\n"]}
@@ -27,6 +27,7 @@ import styles from "./generated/themes/ListItemBase.css.js";
27
27
  */
28
28
  let ListItemBase = class ListItemBase extends UI5Element {
29
29
  _onfocusin(e) {
30
+ this.fireEvent("_request-tabindex-change", e);
30
31
  if (e.target !== this.getFocusDomRef()) {
31
32
  return;
32
33
  }
@@ -116,6 +117,7 @@ ListItemBase = __decorate([
116
117
  renderer: litRender,
117
118
  styles,
118
119
  }),
120
+ event("_request-tabindex-change"),
119
121
  event("_focused"),
120
122
  event("_forward-after"),
121
123
  event("_forward-before")
@@ -1 +1 @@
1
- {"version":3,"file":"ListItemBase.js","sourceRoot":"","sources":["../src/ListItemBase.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport type { ITabbable } from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport type { ClassMap } from \"@ui5/webcomponents-base/dist/types.js\";\nimport { getTabbableElements } from \"@ui5/webcomponents-base/dist/util/TabbableElements.js\";\nimport { isTabNext, isTabPrevious } from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport getActiveElement from \"@ui5/webcomponents-base/dist/util/getActiveElement.js\";\n\n// Styles\nimport styles from \"./generated/themes/ListItemBase.css.js\";\n\n/**\n * @class\n * A class to serve as a foundation\n * for the <code>ListItem</code> and <code>GroupHeaderListItem</code> classes.\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.ListItemBase\n * @extends sap.ui.webc.base.UI5Element\n * @public\n */\n@customElement({\n\trenderer: litRender,\n\tstyles,\n})\n@event(\"_focused\")\n@event(\"_forward-after\")\n@event(\"_forward-before\")\nclass ListItemBase extends UI5Element implements ITabbable {\n\t/**\n\t * Defines the selected state of the <code>ListItem</code>.\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.ListItemBase.prototype.selected\n\t * @defaultvalue false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tselected!: boolean;\n\n\t/**\n\t* Defines if the list item should display its bottom border.\n\t* @private\n\t*/\n\t@property({ type: Boolean })\n\thasBorder!: boolean;\n\n\t@property({ defaultValue: \"-1\", noAttribute: true })\n\t_tabIndex!: string;\n\n\t/**\n\t* Defines whether <code>ui5-li</code> is in disabled state.\n\t* <br><br>\n\t* <b>Note:</b> A disabled <code>ui5-li</code> is noninteractive.\n\t* @type {boolean}\n\t* @name sap.ui.webc.main.ListItemBase.prototype.disabled\n\t* @defaultvalue false\n\t* @protected\n\t* @since 1.0.0-rc.12\n\t*/\n\t@property({ type: Boolean })\n\tdisabled!: boolean;\n\n\t/**\n\t * Indicates if the element is on focus\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\tfocused!: boolean;\n\n\t_onfocusin(e: FocusEvent) {\n\t\tif (e.target !== this.getFocusDomRef()) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.focused = true;\n\t\tthis.fireEvent(\"_focused\", e);\n\t}\n\n\t_onfocusout() {\n\t\tthis.focused = false;\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isTabNext(e)) {\n\t\t\treturn this._handleTabNext(e);\n\t\t}\n\n\t\tif (isTabPrevious(e)) {\n\t\t\treturn this._handleTabPrevious(e);\n\t\t}\n\t}\n\n\t_onkeyup(e: KeyboardEvent) {} // eslint-disable-line\n\n\t_handleTabNext(e: KeyboardEvent) {\n\t\tif (this.shouldForwardTabAfter()) {\n\t\t\tif (!this.fireEvent(\"_forward-after\", {}, true)) {\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t}\n\t}\n\n\t_handleTabPrevious(e: KeyboardEvent) {\n\t\tconst target = e.target as HTMLElement;\n\n\t\tif (this.shouldForwardTabBefore(target)) {\n\t\t\tthis.fireEvent(\"_forward-before\");\n\t\t}\n\t}\n\n\t/*\n\t* Determines if th current list item either has no tabbable content or\n\t* [TAB] is performed onto the last tabbale content item.\n\t*/\n\tshouldForwardTabAfter() {\n\t\tconst aContent = getTabbableElements(this.getFocusDomRef()!);\n\n\t\treturn aContent.length === 0 || (aContent[aContent.length - 1] === getActiveElement());\n\t}\n\n\t/*\n\t* Determines if the current list item is target of [SHIFT+TAB].\n\t*/\n\tshouldForwardTabBefore(target: HTMLElement) {\n\t\treturn this.getFocusDomRef() === target;\n\t}\n\n\tget classes(): ClassMap {\n\t\treturn {\n\t\t\tmain: {\n\t\t\t\t\"ui5-li-root\": true,\n\t\t\t\t\"ui5-li--focusable\": !this.disabled,\n\t\t\t},\n\t\t};\n\t}\n\n\tget _ariaDisabled() {\n\t\treturn this.disabled ? true : undefined;\n\t}\n\n\tget hasConfigurableMode() {\n\t\treturn false;\n\t}\n\n\tget _effectiveTabIndex() {\n\t\tif (this.disabled) {\n\t\t\treturn -1;\n\t\t}\n\t\tif (this.selected) {\n\t\t\treturn 0;\n\t\t}\n\t\treturn this._tabIndex;\n\t}\n}\n\nexport default ListItemBase;\n"]}
1
+ {"version":3,"file":"ListItemBase.js","sourceRoot":"","sources":["../src/ListItemBase.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport type { ITabbable } from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport type { ClassMap } from \"@ui5/webcomponents-base/dist/types.js\";\nimport { getTabbableElements } from \"@ui5/webcomponents-base/dist/util/TabbableElements.js\";\nimport { isTabNext, isTabPrevious } from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport getActiveElement from \"@ui5/webcomponents-base/dist/util/getActiveElement.js\";\n\n// Styles\nimport styles from \"./generated/themes/ListItemBase.css.js\";\n\n/**\n * @class\n * A class to serve as a foundation\n * for the <code>ListItem</code> and <code>GroupHeaderListItem</code> classes.\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.ListItemBase\n * @extends sap.ui.webc.base.UI5Element\n * @public\n */\n@customElement({\n\trenderer: litRender,\n\tstyles,\n})\n@event(\"_request-tabindex-change\")\n@event(\"_focused\")\n@event(\"_forward-after\")\n@event(\"_forward-before\")\nclass ListItemBase extends UI5Element implements ITabbable {\n\t/**\n\t * Defines the selected state of the <code>ListItem</code>.\n\t * @type {boolean}\n\t * @name sap.ui.webc.main.ListItemBase.prototype.selected\n\t * @defaultvalue false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tselected!: boolean;\n\n\t/**\n\t* Defines if the list item should display its bottom border.\n\t* @private\n\t*/\n\t@property({ type: Boolean })\n\thasBorder!: boolean;\n\n\t@property({ defaultValue: \"-1\", noAttribute: true })\n\t_tabIndex!: string;\n\n\t/**\n\t* Defines whether <code>ui5-li</code> is in disabled state.\n\t* <br><br>\n\t* <b>Note:</b> A disabled <code>ui5-li</code> is noninteractive.\n\t* @type {boolean}\n\t* @name sap.ui.webc.main.ListItemBase.prototype.disabled\n\t* @defaultvalue false\n\t* @protected\n\t* @since 1.0.0-rc.12\n\t*/\n\t@property({ type: Boolean })\n\tdisabled!: boolean;\n\n\t/**\n\t * Indicates if the element is on focus\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\tfocused!: boolean;\n\n\t_onfocusin(e: FocusEvent) {\n\t\tthis.fireEvent(\"_request-tabindex-change\", e);\n\t\tif (e.target !== this.getFocusDomRef()) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.focused = true;\n\t\tthis.fireEvent(\"_focused\", e);\n\t}\n\n\t_onfocusout() {\n\t\tthis.focused = false;\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isTabNext(e)) {\n\t\t\treturn this._handleTabNext(e);\n\t\t}\n\n\t\tif (isTabPrevious(e)) {\n\t\t\treturn this._handleTabPrevious(e);\n\t\t}\n\t}\n\n\t_onkeyup(e: KeyboardEvent) {} // eslint-disable-line\n\n\t_handleTabNext(e: KeyboardEvent) {\n\t\tif (this.shouldForwardTabAfter()) {\n\t\t\tif (!this.fireEvent(\"_forward-after\", {}, true)) {\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t}\n\t}\n\n\t_handleTabPrevious(e: KeyboardEvent) {\n\t\tconst target = e.target as HTMLElement;\n\n\t\tif (this.shouldForwardTabBefore(target)) {\n\t\t\tthis.fireEvent(\"_forward-before\");\n\t\t}\n\t}\n\n\t/*\n\t* Determines if th current list item either has no tabbable content or\n\t* [TAB] is performed onto the last tabbale content item.\n\t*/\n\tshouldForwardTabAfter() {\n\t\tconst aContent = getTabbableElements(this.getFocusDomRef()!);\n\n\t\treturn aContent.length === 0 || (aContent[aContent.length - 1] === getActiveElement());\n\t}\n\n\t/*\n\t* Determines if the current list item is target of [SHIFT+TAB].\n\t*/\n\tshouldForwardTabBefore(target: HTMLElement) {\n\t\treturn this.getFocusDomRef() === target;\n\t}\n\n\tget classes(): ClassMap {\n\t\treturn {\n\t\t\tmain: {\n\t\t\t\t\"ui5-li-root\": true,\n\t\t\t\t\"ui5-li--focusable\": !this.disabled,\n\t\t\t},\n\t\t};\n\t}\n\n\tget _ariaDisabled() {\n\t\treturn this.disabled ? true : undefined;\n\t}\n\n\tget hasConfigurableMode() {\n\t\treturn false;\n\t}\n\n\tget _effectiveTabIndex() {\n\t\tif (this.disabled) {\n\t\t\treturn -1;\n\t\t}\n\t\tif (this.selected) {\n\t\t\treturn 0;\n\t\t}\n\t\treturn this._tabIndex;\n\t}\n}\n\nexport default ListItemBase;\n"]}
@@ -67,6 +67,9 @@ let SegmentedButton = SegmentedButton_1 = class SegmentedButton extends UI5Eleme
67
67
  this.style.setProperty(getScopedVarName("--_ui5_segmented_btn_items_count"), `${items.length}`);
68
68
  }
69
69
  normalizeSelection() {
70
+ if (!this.items.length) {
71
+ return;
72
+ }
70
73
  switch (this.mode) {
71
74
  case SegmentedButtonMode.SingleSelect: {
72
75
  const selectedItems = this.selectedItems;
@@ -1 +1 @@
1
- {"version":3,"file":"SegmentedButton.js","sourceRoot":"","sources":["../src/SegmentedButton.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport ItemNavigation from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport type I18nBundle from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport { getI18nBundle } from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport { getScopedVarName } from \"@ui5/webcomponents-base/dist/CustomElementsScope.js\";\nimport {\n\tisSpace,\n\tisEnter,\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport { SEGMENTEDBUTTON_ARIA_DESCRIPTION, SEGMENTEDBUTTON_ARIA_DESCRIBEDBY } from \"./generated/i18n/i18n-defaults.js\";\nimport SegmentedButtonItem from \"./SegmentedButtonItem.js\";\nimport SegmentedButtonMode from \"./types/SegmentedButtonMode.js\";\n\n// Template\nimport SegmentedButtonTemplate from \"./generated/templates/SegmentedButtonTemplate.lit.js\";\n\n// Styles\nimport SegmentedButtonCss from \"./generated/themes/SegmentedButton.css.js\";\n\ntype SegmentedButtonSelectionChangeEventDetail = {\n\tselectedItem: SegmentedButtonItem,\n\tselectedItems: Array<SegmentedButtonItem>,\n}\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n *\n * The <code>ui5-segmented-button</code> shows a group of items. When the user clicks or taps\n * one of the items, it stays in a pressed state. It automatically resizes the items\n * to fit proportionally within the component. When no width is set, the component uses the available width.\n * <br><br>\n * <b>Note:</b> There can be just one selected <code>item</code> at a time.\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/SegmentedButton\";</code>\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.SegmentedButton\n * @extends sap.ui.webc.base.UI5Element\n * @tagname ui5-segmented-button\n * @since 1.0.0-rc.6\n * @appenddocs sap.ui.webc.main.SegmentedButtonItem\n * @public\n */\n@customElement({\n\ttag: \"ui5-segmented-button\",\n\tlanguageAware: true,\n\trenderer: litRender,\n\ttemplate: SegmentedButtonTemplate,\n\tstyles: SegmentedButtonCss,\n\tdependencies: [SegmentedButtonItem],\n})\n/**\n * Fired when the selected item changes.\n *\n * @event sap.ui.webc.main.SegmentedButton#selection-change\n * @param {HTMLElement} selectedItem the pressed item. Note: deprecated since 1.14.0 and will be removed in the next major release, use the <code>selectedItems</code> parameter instead.\n * @param {HTMLElement[]} selectedItems an array of selected items. Note: available since 1.14.0.\n * @public\n */\n@event(\"selection-change\", {\n\tdetail: {\n\t\tselectedItem: { type: HTMLElement },\n\t\tselectedItems: { type: Array },\n\t},\n})\n\nclass SegmentedButton extends UI5Element {\n\t/**\n\t * Defines the accessible ARIA name of the component.\n\t *\n\t * @type {string}\n\t * @defaultvalue undefined\n\t * @public\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.accessibleName\n\t * @since 1.0.3\n\t */\n\t@property({ defaultValue: undefined })\n\taccessibleName?: string;\n\n\t/**\n\t * Defines the component selection mode.\n\t *\n\t * <br><br>\n\t * <b>The available values are:</b>\n\t *\n\t * <ul>\n\t * <li><code>SingleSelect</code></li>\n\t * <li><code>MultiSelect</code></li>\n\t * </ul>\n\t *\n\t * @type {sap.ui.webc.main.types.SegmentedButtonMode}\n\t * @defaultvalue \"SingleSelect\"\n\t * @public\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.mode\n\t * @since 1.14.0\n\t */\n\t@property({ type: SegmentedButtonMode, defaultValue: SegmentedButtonMode.SingleSelect })\n\tmode!: `${SegmentedButtonMode}`;\n\n\t/**\n\t * Defines the items of <code>ui5-segmented-button</code>.\n\t * <br><br>\n\t * <b>Note:</b> Multiple items are allowed.\n\t * <br><br>\n\t * <b>Note:</b> Use the <code>ui5-segmented-button-item</code> for the intended design.\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem[]}\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.default\n\t * @slot items\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, invalidateOnChildChange: true, \"default\": true })\n\titems!: Array<SegmentedButtonItem>;\n\n\tstatic i18nBundle: I18nBundle;\n\n\t_itemNavigation: ItemNavigation;\n\n\thasPreviouslyFocusedItem: boolean;\n\n\t_selectedItem?: SegmentedButtonItem;\n\n\tstatic async onDefine() {\n\t\tSegmentedButton.i18nBundle = await getI18nBundle(\"@ui5/webcomponents\");\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\tthis._itemNavigation = new ItemNavigation(this, {\n\t\t\tgetItemsCallback: () => this.getSlottedNodes<SegmentedButtonItem>(\"items\"),\n\t\t});\n\t\tthis.hasPreviouslyFocusedItem = false;\n\t}\n\n\tonBeforeRendering() {\n\t\tconst items = this.getSlottedNodes<SegmentedButtonItem>(\"items\");\n\n\t\titems.forEach((item, index, arr) => {\n\t\t\titem.posInSet = index + 1;\n\t\t\titem.sizeOfSet = arr.length;\n\t\t});\n\n\t\tthis.normalizeSelection();\n\n\t\tthis.style.setProperty(getScopedVarName(\"--_ui5_segmented_btn_items_count\"), `${items.length}`);\n\t}\n\n\tnormalizeSelection() {\n\t\tswitch (this.mode) {\n\t\tcase SegmentedButtonMode.SingleSelect: {\n\t\t\tconst selectedItems = this.selectedItems;\n\t\t\tconst selectedItemIndex = this._selectedItem ? selectedItems.indexOf(this._selectedItem) : -1;\n\t\t\tif (this._selectedItem && selectedItems.length > 1) {\n\t\t\t\tselectedItems.splice(selectedItemIndex, 1);\n\t\t\t}\n\t\t\tconst selectedItem = selectedItems.pop() || this.items[0];\n\t\t\tthis._applySingleSelection(selectedItem);\n\t\t\tbreak;\n\t\t}\n\t\tdefault:\n\t\t}\n\t}\n\n\t_selectItem(e: MouseEvent | KeyboardEvent) {\n\t\tconst target = e.target as SegmentedButtonItem;\n\t\tconst isTargetSegmentedButtonItem = target.hasAttribute(\"ui5-segmented-button-item\");\n\n\t\tif (target.disabled || target === this.getDomRef() || !isTargetSegmentedButtonItem) {\n\t\t\treturn;\n\t\t}\n\n\t\tswitch (this.mode) {\n\t\tcase SegmentedButtonMode.MultiSelect:\n\t\t\tif (e instanceof KeyboardEvent) {\n\t\t\t\ttarget.pressed = !target.pressed;\n\t\t\t}\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tthis._applySingleSelection(target);\n\t\t}\n\n\t\tthis.fireEvent<SegmentedButtonSelectionChangeEventDetail>(\"selection-change\", {\n\t\t\tselectedItem: target,\n\t\t\tselectedItems: this.selectedItems,\n\t\t});\n\n\t\tthis._itemNavigation.setCurrentItem(target);\n\t\ttarget.focus();\n\n\t\treturn this;\n\t}\n\n\t_applySingleSelection(item: SegmentedButtonItem) {\n\t\tthis.items.forEach(currentItem => {\n\t\t\tcurrentItem.pressed = false;\n\t\t});\n\t\titem.pressed = true;\n\t\tthis._selectedItem = item;\n\t}\n\n\t_onclick(e: MouseEvent) {\n\t\tthis._selectItem(e);\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isEnter(e)) {\n\t\t\tthis._selectItem(e);\n\t\t} else if (isSpace(e)) {\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onkeyup(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\tthis._selectItem(e);\n\t\t}\n\t}\n\n\t_onmousedown(e: MouseEvent) {\n\t\tconst eventTarget = e.target as SegmentedButtonItem;\n\t\tconst isTargetSegmentedButtonItem = eventTarget.hasAttribute(\"ui5-segmented-button-item\");\n\n\t\tif (isTargetSegmentedButtonItem) {\n\t\t\teventTarget.focus();\n\t\t\tthis._itemNavigation.setCurrentItem(eventTarget);\n\t\t\tthis.hasPreviouslyFocusedItem = true;\n\t\t}\n\t}\n\n\t_onfocusin(e: FocusEvent) {\n\t\t// If the component was previously focused,\n\t\t// update the ItemNavigation to sync the button's tabindex values\n\t\tif (this.hasPreviouslyFocusedItem) {\n\t\t\tthis._itemNavigation.setCurrentItem(e.target as SegmentedButtonItem);\n\t\t\treturn;\n\t\t}\n\n\t\t// If the component is focused for the first time\n\t\t// focus the selected item if such is present\n\t\tif (this.selectedItems.length) {\n\t\t\tthis.selectedItems[0].focus();\n\t\t\tthis._itemNavigation.setCurrentItem(this.selectedItems[0]);\n\t\t\tthis.hasPreviouslyFocusedItem = true;\n\t\t}\n\t}\n\n\t/**\n\t * Currently selected item.\n\t *\n\t * @readonly\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem}\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.selectedItem\n\t * @deprecated since 1.14.0. This method will be removed in the next major release.\n\t * Please use the <code>selectedItems</code> property instead.\n\t * @public\n\t */\n\tget selectedItem() {\n\t\treturn this._selectedItem;\n\t}\n\n\t/**\n\t * Returns an array of the currently selected items.\n\t * @readonly\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.selectedItems\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem[]}\n\t * @since 1.14.0\n\t * @public\n\t */\n\tget selectedItems(): Array<SegmentedButtonItem> {\n\t\treturn this.items.filter(item => item.pressed);\n\t}\n\n\tget ariaDescribedBy() {\n\t\treturn SegmentedButton.i18nBundle.getText(SEGMENTEDBUTTON_ARIA_DESCRIBEDBY);\n\t}\n\n\tget ariaDescription() {\n\t\treturn SegmentedButton.i18nBundle.getText(SEGMENTEDBUTTON_ARIA_DESCRIPTION);\n\t}\n}\n\nSegmentedButton.define();\n\nexport default SegmentedButton;\nexport type {\n\tSegmentedButtonSelectionChangeEventDetail,\n};\n"]}
1
+ {"version":3,"file":"SegmentedButton.js","sourceRoot":"","sources":["../src/SegmentedButton.ts"],"names":[],"mappings":"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","sourcesContent":["import UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport ItemNavigation from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport litRender from \"@ui5/webcomponents-base/dist/renderer/LitRenderer.js\";\nimport type I18nBundle from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport { getI18nBundle } from \"@ui5/webcomponents-base/dist/i18nBundle.js\";\nimport { getScopedVarName } from \"@ui5/webcomponents-base/dist/CustomElementsScope.js\";\nimport {\n\tisSpace,\n\tisEnter,\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport { SEGMENTEDBUTTON_ARIA_DESCRIPTION, SEGMENTEDBUTTON_ARIA_DESCRIBEDBY } from \"./generated/i18n/i18n-defaults.js\";\nimport SegmentedButtonItem from \"./SegmentedButtonItem.js\";\nimport SegmentedButtonMode from \"./types/SegmentedButtonMode.js\";\n\n// Template\nimport SegmentedButtonTemplate from \"./generated/templates/SegmentedButtonTemplate.lit.js\";\n\n// Styles\nimport SegmentedButtonCss from \"./generated/themes/SegmentedButton.css.js\";\n\ntype SegmentedButtonSelectionChangeEventDetail = {\n\tselectedItem: SegmentedButtonItem,\n\tselectedItems: Array<SegmentedButtonItem>,\n}\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n *\n * The <code>ui5-segmented-button</code> shows a group of items. When the user clicks or taps\n * one of the items, it stays in a pressed state. It automatically resizes the items\n * to fit proportionally within the component. When no width is set, the component uses the available width.\n * <br><br>\n * <b>Note:</b> There can be just one selected <code>item</code> at a time.\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/SegmentedButton\";</code>\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.SegmentedButton\n * @extends sap.ui.webc.base.UI5Element\n * @tagname ui5-segmented-button\n * @since 1.0.0-rc.6\n * @appenddocs sap.ui.webc.main.SegmentedButtonItem\n * @public\n */\n@customElement({\n\ttag: \"ui5-segmented-button\",\n\tlanguageAware: true,\n\trenderer: litRender,\n\ttemplate: SegmentedButtonTemplate,\n\tstyles: SegmentedButtonCss,\n\tdependencies: [SegmentedButtonItem],\n})\n/**\n * Fired when the selected item changes.\n *\n * @event sap.ui.webc.main.SegmentedButton#selection-change\n * @param {HTMLElement} selectedItem the pressed item. Note: deprecated since 1.14.0 and will be removed in the next major release, use the <code>selectedItems</code> parameter instead.\n * @param {HTMLElement[]} selectedItems an array of selected items. Note: available since 1.14.0.\n * @public\n */\n@event(\"selection-change\", {\n\tdetail: {\n\t\tselectedItem: { type: HTMLElement },\n\t\tselectedItems: { type: Array },\n\t},\n})\n\nclass SegmentedButton extends UI5Element {\n\t/**\n\t * Defines the accessible ARIA name of the component.\n\t *\n\t * @type {string}\n\t * @defaultvalue undefined\n\t * @public\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.accessibleName\n\t * @since 1.0.3\n\t */\n\t@property({ defaultValue: undefined })\n\taccessibleName?: string;\n\n\t/**\n\t * Defines the component selection mode.\n\t *\n\t * <br><br>\n\t * <b>The available values are:</b>\n\t *\n\t * <ul>\n\t * <li><code>SingleSelect</code></li>\n\t * <li><code>MultiSelect</code></li>\n\t * </ul>\n\t *\n\t * @type {sap.ui.webc.main.types.SegmentedButtonMode}\n\t * @defaultvalue \"SingleSelect\"\n\t * @public\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.mode\n\t * @since 1.14.0\n\t */\n\t@property({ type: SegmentedButtonMode, defaultValue: SegmentedButtonMode.SingleSelect })\n\tmode!: `${SegmentedButtonMode}`;\n\n\t/**\n\t * Defines the items of <code>ui5-segmented-button</code>.\n\t * <br><br>\n\t * <b>Note:</b> Multiple items are allowed.\n\t * <br><br>\n\t * <b>Note:</b> Use the <code>ui5-segmented-button-item</code> for the intended design.\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem[]}\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.default\n\t * @slot items\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, invalidateOnChildChange: true, \"default\": true })\n\titems!: Array<SegmentedButtonItem>;\n\n\tstatic i18nBundle: I18nBundle;\n\n\t_itemNavigation: ItemNavigation;\n\n\thasPreviouslyFocusedItem: boolean;\n\n\t_selectedItem?: SegmentedButtonItem;\n\n\tstatic async onDefine() {\n\t\tSegmentedButton.i18nBundle = await getI18nBundle(\"@ui5/webcomponents\");\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\tthis._itemNavigation = new ItemNavigation(this, {\n\t\t\tgetItemsCallback: () => this.getSlottedNodes<SegmentedButtonItem>(\"items\"),\n\t\t});\n\t\tthis.hasPreviouslyFocusedItem = false;\n\t}\n\n\tonBeforeRendering() {\n\t\tconst items = this.getSlottedNodes<SegmentedButtonItem>(\"items\");\n\n\t\titems.forEach((item, index, arr) => {\n\t\t\titem.posInSet = index + 1;\n\t\t\titem.sizeOfSet = arr.length;\n\t\t});\n\n\t\tthis.normalizeSelection();\n\n\t\tthis.style.setProperty(getScopedVarName(\"--_ui5_segmented_btn_items_count\"), `${items.length}`);\n\t}\n\n\tnormalizeSelection() {\n\t\tif (!this.items.length) {\n\t\t\treturn;\n\t\t}\n\n\t\tswitch (this.mode) {\n\t\tcase SegmentedButtonMode.SingleSelect: {\n\t\t\tconst selectedItems = this.selectedItems;\n\t\t\tconst selectedItemIndex = this._selectedItem ? selectedItems.indexOf(this._selectedItem) : -1;\n\t\t\tif (this._selectedItem && selectedItems.length > 1) {\n\t\t\t\tselectedItems.splice(selectedItemIndex, 1);\n\t\t\t}\n\t\t\tconst selectedItem = selectedItems.pop() || this.items[0];\n\t\t\tthis._applySingleSelection(selectedItem);\n\t\t\tbreak;\n\t\t}\n\t\tdefault:\n\t\t}\n\t}\n\n\t_selectItem(e: MouseEvent | KeyboardEvent) {\n\t\tconst target = e.target as SegmentedButtonItem;\n\t\tconst isTargetSegmentedButtonItem = target.hasAttribute(\"ui5-segmented-button-item\");\n\n\t\tif (target.disabled || target === this.getDomRef() || !isTargetSegmentedButtonItem) {\n\t\t\treturn;\n\t\t}\n\n\t\tswitch (this.mode) {\n\t\tcase SegmentedButtonMode.MultiSelect:\n\t\t\tif (e instanceof KeyboardEvent) {\n\t\t\t\ttarget.pressed = !target.pressed;\n\t\t\t}\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tthis._applySingleSelection(target);\n\t\t}\n\n\t\tthis.fireEvent<SegmentedButtonSelectionChangeEventDetail>(\"selection-change\", {\n\t\t\tselectedItem: target,\n\t\t\tselectedItems: this.selectedItems,\n\t\t});\n\n\t\tthis._itemNavigation.setCurrentItem(target);\n\t\ttarget.focus();\n\n\t\treturn this;\n\t}\n\n\t_applySingleSelection(item: SegmentedButtonItem) {\n\t\tthis.items.forEach(currentItem => {\n\t\t\tcurrentItem.pressed = false;\n\t\t});\n\t\titem.pressed = true;\n\t\tthis._selectedItem = item;\n\t}\n\n\t_onclick(e: MouseEvent) {\n\t\tthis._selectItem(e);\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\tif (isEnter(e)) {\n\t\t\tthis._selectItem(e);\n\t\t} else if (isSpace(e)) {\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\t_onkeyup(e: KeyboardEvent) {\n\t\tif (isSpace(e)) {\n\t\t\tthis._selectItem(e);\n\t\t}\n\t}\n\n\t_onmousedown(e: MouseEvent) {\n\t\tconst eventTarget = e.target as SegmentedButtonItem;\n\t\tconst isTargetSegmentedButtonItem = eventTarget.hasAttribute(\"ui5-segmented-button-item\");\n\n\t\tif (isTargetSegmentedButtonItem) {\n\t\t\teventTarget.focus();\n\t\t\tthis._itemNavigation.setCurrentItem(eventTarget);\n\t\t\tthis.hasPreviouslyFocusedItem = true;\n\t\t}\n\t}\n\n\t_onfocusin(e: FocusEvent) {\n\t\t// If the component was previously focused,\n\t\t// update the ItemNavigation to sync the button's tabindex values\n\t\tif (this.hasPreviouslyFocusedItem) {\n\t\t\tthis._itemNavigation.setCurrentItem(e.target as SegmentedButtonItem);\n\t\t\treturn;\n\t\t}\n\n\t\t// If the component is focused for the first time\n\t\t// focus the selected item if such is present\n\t\tif (this.selectedItems.length) {\n\t\t\tthis.selectedItems[0].focus();\n\t\t\tthis._itemNavigation.setCurrentItem(this.selectedItems[0]);\n\t\t\tthis.hasPreviouslyFocusedItem = true;\n\t\t}\n\t}\n\n\t/**\n\t * Currently selected item.\n\t *\n\t * @readonly\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem}\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.selectedItem\n\t * @deprecated since 1.14.0. This method will be removed in the next major release.\n\t * Please use the <code>selectedItems</code> property instead.\n\t * @public\n\t */\n\tget selectedItem() {\n\t\treturn this._selectedItem;\n\t}\n\n\t/**\n\t * Returns an array of the currently selected items.\n\t * @readonly\n\t * @name sap.ui.webc.main.SegmentedButton.prototype.selectedItems\n\t * @type {sap.ui.webc.main.ISegmentedButtonItem[]}\n\t * @since 1.14.0\n\t * @public\n\t */\n\tget selectedItems(): Array<SegmentedButtonItem> {\n\t\treturn this.items.filter(item => item.pressed);\n\t}\n\n\tget ariaDescribedBy() {\n\t\treturn SegmentedButton.i18nBundle.getText(SEGMENTEDBUTTON_ARIA_DESCRIBEDBY);\n\t}\n\n\tget ariaDescription() {\n\t\treturn SegmentedButton.i18nBundle.getText(SEGMENTEDBUTTON_ARIA_DESCRIPTION);\n\t}\n}\n\nSegmentedButton.define();\n\nexport default SegmentedButton;\nexport type {\n\tSegmentedButtonSelectionChangeEventDetail,\n};\n"]}
@@ -81,7 +81,9 @@ import { TIMEPICKER_INPUT_DESCRIPTION, } from "./generated/i18n/i18n-defaults.js
81
81
  */
82
82
  let TimePicker = TimePicker_1 = class TimePicker extends TimePickerBase {
83
83
  onBeforeRendering() {
84
- this.value = this.normalizeValue(this.value) || this.value;
84
+ if (this.value) {
85
+ this.value = this.normalizeValue(this.value) || this.value;
86
+ }
85
87
  }
86
88
  get _formatPattern() {
87
89
  const hasHours = !!this.formatPattern.match(/H/i);
@@ -1 +1 @@
1
- {"version":3,"file":"TimePicker.js","sourceRoot":"","sources":["../src/TimePicker.ts"],"names":[],"mappings":";;;;;;;AAAA,OAAO,SAAS,MAAM,kDAAkD,CAAC;AACzE,OAAO,2BAA2B,MAAM,qEAAqE,CAAC;AAC9G,OAAO,QAAQ,MAAM,qDAAqD,CAAC;AAC3E,OAAO,aAAa,MAAM,0DAA0D,CAAC;AACrF,OAAO,cAAc,MAAM,qBAAqB,CAAC;AAOjD,OAAO,EACN,4BAA4B,GAC5B,MAAM,mCAAmC,CAAC;AAE3C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmEG;AAEH,IAAM,UAAU,kBAAhB,MAAM,UAAW,SAAQ,cAAc;IAiCtC,iBAAiB;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAM,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC;IAC7D,CAAC;IAED,IAAI,cAAc;QACjB,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClD,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,QAAQ,CAAC;QAElD,MAAM,UAAU,GAAG,2BAA2B,CAAC,SAAS,EAAE,CAAC,CAAC;QAC5D,OAAO,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;IAC5E,CAAC;IAED,IAAI,cAAc;QACjB,2DAA2D;QAC3D,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,cAAc,CAAC,OAAiB,CAAC;IAC1D,CAAC;IAED,IAAI,YAAY;QACf,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAChF,CAAC;IAED;;;;;;;OAOG;IACH,IAAI,SAAS;QACZ,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,eAAyB,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,OAAO;QACV,OAAO;YACN,qBAAqB,EAAE,IAAI,CAAC,mBAAmB;YAC/C,cAAc,EAAE,QAAQ;YACxB,kBAAkB,EAAE,MAAM;YAC1B,cAAc,EAAE,GAAG,IAAI,CAAC,GAAG,qBAAqB;SAChD,CAAC;IACH,CAAC;IAED,IAAI,mBAAmB;QACtB,OAAO,YAAU,CAAC,UAAU,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC;IACpE,CAAC;CACD,CAAA;AA/DA;IADC,QAAQ,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,CAAC;+CACjB;AAgBrB;IADC,QAAQ,EAAE;iDACY;AA/BlB,UAAU;IADf,aAAa,CAAC,iBAAiB,CAAC;GAC3B,UAAU,CA8Ef;AAED,UAAU,CAAC,MAAM,EAAE,CAAC;AAEpB,eAAe,UAAU,CAAC","sourcesContent":["import getLocale from \"@ui5/webcomponents-base/dist/locale/getLocale.js\";\nimport getCachedLocaleDataInstance from \"@ui5/webcomponents-localization/dist/getCachedLocaleDataInstance.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport TimePickerBase from \"./TimePickerBase.js\";\n\nimport type {\n\tTimePickerBaseChangeEventDetail as TimePickerChangeEventDetail,\n\tTimePickerBaseInputEventDetail as TimePickerInputEventDetail,\n} from \"./TimePickerBase.js\";\n\nimport {\n\tTIMEPICKER_INPUT_DESCRIPTION,\n} from \"./generated/i18n/i18n-defaults.js\";\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n * The <code>ui5-time-picker</code> component provides an input field with assigned clocks which are opened on user action.\n * The <code>ui5-time-picker</code> allows users to select a localized time using touch, mouse, or keyboard input.\n * It consists of two parts: the time input field and the clocks.\n *\n * <h3>Usage</h3>\n * The user can enter a time by:\n * <ul>\n * <li>Using the clocks that are displayed in a popup</li>\n * <li>Typing it in directly in the input field</li>\n * </ul>\n * <br><br>\n * When the user makes an entry and chooses the enter key, the clocks show the corresponding time (hours, minutes and seconds separately).\n * When the user directly triggers the clocks display, the actual time is displayed.\n * For the <code>ui5-time-picker</code>\n *\n * <h3>Formatting</h3>\n *\n * If a time is entered by typing it into\n * the input field, it must fit to the used time format.\n * <br><br>\n * Supported format options are pattern-based on Unicode LDML Date Format notation.\n * For more information, see <ui5-link target=\"_blank\" href=\"http://unicode.org/reports/tr35/#Date_Field_Symbol_Table\">UTS #35: Unicode Locale Data Markup Language</ui5-link>.\n * <br><br>\n * For example, if the <code>format-pattern</code> is \"HH:mm:ss\",\n * a valid value string is \"11:42:35\" and the same is displayed in the input.\n *\n * <h3>Keyboard handling</h3>\n * [F4], [ALT]+[UP], [ALT]+[DOWN] Open/Close picker dialog and move focus to it.\n * <br>\n * When closed:\n * <ul>\n * <li>[PAGEUP] - Increments hours by 1. If 12 am is reached, increment hours to 1 pm and vice versa.</li>\n * <li>[PAGEDOWN] - Decrements the corresponding field by 1. If 1 pm is reached, decrement hours to 12 am and vice versa.</li>\n * <li>[SHIFT]+[PAGEUP] - Increments minutes by 1.</li>\n * <li>[SHIFT]+[PAGEDOWN] - Decrements minutes by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEUP] - Increments seconds by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEDOWN] - Decrements seconds by 1.</li>\n * <li>\n * </ul>\n * When opened:\n * <ul>\n * <li>[PAGEUP] - Increments hours by 1. If 12 am is reached, increment hours to 1 pm and vice versa.</li>\n * <li>[PAGEDOWN] - Decrements the corresponding field by 1. If 1 pm is reached, decrement hours to 12 am and vice versa.</li>\n * <li>[SHIFT]+[PAGEUP] - Increments minutes by 1.</li>\n * <li>[SHIFT]+[PAGEDOWN] - Decrements minutes by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEUP] - Increments seconds by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEDOWN] - Decrements seconds by 1.</li>\n * <li>[A] or [P] - Selects AM or PM respectively.</li>\n * <li>[0]-[9] - Allows direct time selecting (hours/minutes/seconds).</li>\n * <li>[:] - Allows switching between hours/minutes/seconds clocks. If the last clock is displayed and [:] is pressed, the first clock is beind displayed.</li>\n * </ul>\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/TimePicker.js\";</code>\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.TimePicker\n * @extends sap.ui.webc.main.TimePickerBase\n * @tagname ui5-time-picker\n * @public\n * @since 1.0.0-rc.6\n */\n@customElement(\"ui5-time-picker\")\nclass TimePicker extends TimePickerBase {\n\t/**\n\t * Defines a short hint, intended to aid the user with data entry when the\n\t * component has no value.\n\t *\n\t * <br><br>\n\t * <b>Note:</b> When no placeholder is set, the format pattern is displayed as a placeholder.\n\t * Passing an empty string as the value of this property will make the component appear empty - without placeholder or format pattern.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.TimePicker.prototype.placeholder\n\t * @defaultvalue undefined\n\t * @public\n\t */\n\t@property({ defaultValue: undefined })\n\tplaceholder?: string;\n\n\t/**\n\t * Determines the format, displayed in the input field.\n\t *\n\t * Example:\n\t * HH:mm:ss -> 11:42:35\n\t * hh:mm:ss a -> 2:23:15 PM\n\t * mm:ss -> 12:04 (only minutes and seconds)\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.TimePicker.prototype.formatPattern\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tformatPattern!: string;\n\n\tonBeforeRendering() {\n\t\tthis.value = this.normalizeValue(this.value!) || this.value;\n\t}\n\n\tget _formatPattern() {\n\t\tconst hasHours = !!this.formatPattern.match(/H/i);\n\t\tconst fallback = !this.formatPattern || !hasHours;\n\n\t\tconst localeData = getCachedLocaleDataInstance(getLocale());\n\t\treturn fallback ? localeData.getTimePattern(\"medium\") : this.formatPattern;\n\t}\n\n\tget _displayFormat() {\n\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\treturn this.getFormat().oFormatOptions.pattern as string;\n\t}\n\n\tget _placeholder() {\n\t\treturn this.placeholder !== undefined ? this.placeholder : this._displayFormat;\n\t}\n\n\t/**\n\t * Currently selected time represented as JavaScript Date instance\n\t *\n\t * @readonly\n\t * @type {Date}\n\t * @public\n\t * @name sap.ui.webc.main.TimePicker.prototype.dateValue\n\t */\n\tget dateValue() {\n\t\treturn this.getFormat().parse(this._effectiveValue as string);\n\t}\n\n\tget accInfo() {\n\t\treturn {\n\t\t\t\"ariaRoledescription\": this.dateAriaDescription,\n\t\t\t\"ariaHasPopup\": \"dialog\",\n\t\t\t\"ariaAutoComplete\": \"none\",\n\t\t\t\"ariaControls\": `${this._id}-responsive-popover`,\n\t\t};\n\t}\n\n\tget dateAriaDescription() {\n\t\treturn TimePicker.i18nBundle.getText(TIMEPICKER_INPUT_DESCRIPTION);\n\t}\n}\n\nTimePicker.define();\n\nexport default TimePicker;\nexport type {\n\tTimePickerChangeEventDetail,\n\tTimePickerInputEventDetail,\n};\n"]}
1
+ {"version":3,"file":"TimePicker.js","sourceRoot":"","sources":["../src/TimePicker.ts"],"names":[],"mappings":";;;;;;;AAAA,OAAO,SAAS,MAAM,kDAAkD,CAAC;AACzE,OAAO,2BAA2B,MAAM,qEAAqE,CAAC;AAC9G,OAAO,QAAQ,MAAM,qDAAqD,CAAC;AAC3E,OAAO,aAAa,MAAM,0DAA0D,CAAC;AACrF,OAAO,cAAc,MAAM,qBAAqB,CAAC;AAOjD,OAAO,EACN,4BAA4B,GAC5B,MAAM,mCAAmC,CAAC;AAE3C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmEG;AAEH,IAAM,UAAU,kBAAhB,MAAM,UAAW,SAAQ,cAAc;IAiCtC,iBAAiB;QAChB,IAAI,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC;SAC3D;IACF,CAAC;IAED,IAAI,cAAc;QACjB,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClD,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,QAAQ,CAAC;QAElD,MAAM,UAAU,GAAG,2BAA2B,CAAC,SAAS,EAAE,CAAC,CAAC;QAC5D,OAAO,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;IAC5E,CAAC;IAED,IAAI,cAAc;QACjB,2DAA2D;QAC3D,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,cAAc,CAAC,OAAiB,CAAC;IAC1D,CAAC;IAED,IAAI,YAAY;QACf,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAChF,CAAC;IAED;;;;;;;OAOG;IACH,IAAI,SAAS;QACZ,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,eAAyB,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,OAAO;QACV,OAAO;YACN,qBAAqB,EAAE,IAAI,CAAC,mBAAmB;YAC/C,cAAc,EAAE,QAAQ;YACxB,kBAAkB,EAAE,MAAM;YAC1B,cAAc,EAAE,GAAG,IAAI,CAAC,GAAG,qBAAqB;SAChD,CAAC;IACH,CAAC;IAED,IAAI,mBAAmB;QACtB,OAAO,YAAU,CAAC,UAAU,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC;IACpE,CAAC;CACD,CAAA;AAjEA;IADC,QAAQ,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,CAAC;+CACjB;AAgBrB;IADC,QAAQ,EAAE;iDACY;AA/BlB,UAAU;IADf,aAAa,CAAC,iBAAiB,CAAC;GAC3B,UAAU,CAgFf;AAED,UAAU,CAAC,MAAM,EAAE,CAAC;AAEpB,eAAe,UAAU,CAAC","sourcesContent":["import getLocale from \"@ui5/webcomponents-base/dist/locale/getLocale.js\";\nimport getCachedLocaleDataInstance from \"@ui5/webcomponents-localization/dist/getCachedLocaleDataInstance.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport TimePickerBase from \"./TimePickerBase.js\";\n\nimport type {\n\tTimePickerBaseChangeEventDetail as TimePickerChangeEventDetail,\n\tTimePickerBaseInputEventDetail as TimePickerInputEventDetail,\n} from \"./TimePickerBase.js\";\n\nimport {\n\tTIMEPICKER_INPUT_DESCRIPTION,\n} from \"./generated/i18n/i18n-defaults.js\";\n\n/**\n * @class\n *\n * <h3 class=\"comment-api-title\">Overview</h3>\n * The <code>ui5-time-picker</code> component provides an input field with assigned clocks which are opened on user action.\n * The <code>ui5-time-picker</code> allows users to select a localized time using touch, mouse, or keyboard input.\n * It consists of two parts: the time input field and the clocks.\n *\n * <h3>Usage</h3>\n * The user can enter a time by:\n * <ul>\n * <li>Using the clocks that are displayed in a popup</li>\n * <li>Typing it in directly in the input field</li>\n * </ul>\n * <br><br>\n * When the user makes an entry and chooses the enter key, the clocks show the corresponding time (hours, minutes and seconds separately).\n * When the user directly triggers the clocks display, the actual time is displayed.\n * For the <code>ui5-time-picker</code>\n *\n * <h3>Formatting</h3>\n *\n * If a time is entered by typing it into\n * the input field, it must fit to the used time format.\n * <br><br>\n * Supported format options are pattern-based on Unicode LDML Date Format notation.\n * For more information, see <ui5-link target=\"_blank\" href=\"http://unicode.org/reports/tr35/#Date_Field_Symbol_Table\">UTS #35: Unicode Locale Data Markup Language</ui5-link>.\n * <br><br>\n * For example, if the <code>format-pattern</code> is \"HH:mm:ss\",\n * a valid value string is \"11:42:35\" and the same is displayed in the input.\n *\n * <h3>Keyboard handling</h3>\n * [F4], [ALT]+[UP], [ALT]+[DOWN] Open/Close picker dialog and move focus to it.\n * <br>\n * When closed:\n * <ul>\n * <li>[PAGEUP] - Increments hours by 1. If 12 am is reached, increment hours to 1 pm and vice versa.</li>\n * <li>[PAGEDOWN] - Decrements the corresponding field by 1. If 1 pm is reached, decrement hours to 12 am and vice versa.</li>\n * <li>[SHIFT]+[PAGEUP] - Increments minutes by 1.</li>\n * <li>[SHIFT]+[PAGEDOWN] - Decrements minutes by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEUP] - Increments seconds by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEDOWN] - Decrements seconds by 1.</li>\n * <li>\n * </ul>\n * When opened:\n * <ul>\n * <li>[PAGEUP] - Increments hours by 1. If 12 am is reached, increment hours to 1 pm and vice versa.</li>\n * <li>[PAGEDOWN] - Decrements the corresponding field by 1. If 1 pm is reached, decrement hours to 12 am and vice versa.</li>\n * <li>[SHIFT]+[PAGEUP] - Increments minutes by 1.</li>\n * <li>[SHIFT]+[PAGEDOWN] - Decrements minutes by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEUP] - Increments seconds by 1.</li>\n * <li>[SHIFT]+[CTRL]+[PAGEDOWN] - Decrements seconds by 1.</li>\n * <li>[A] or [P] - Selects AM or PM respectively.</li>\n * <li>[0]-[9] - Allows direct time selecting (hours/minutes/seconds).</li>\n * <li>[:] - Allows switching between hours/minutes/seconds clocks. If the last clock is displayed and [:] is pressed, the first clock is beind displayed.</li>\n * </ul>\n *\n * <h3>ES6 Module Import</h3>\n *\n * <code>import \"@ui5/webcomponents/dist/TimePicker.js\";</code>\n *\n * @constructor\n * @author SAP SE\n * @alias sap.ui.webc.main.TimePicker\n * @extends sap.ui.webc.main.TimePickerBase\n * @tagname ui5-time-picker\n * @public\n * @since 1.0.0-rc.6\n */\n@customElement(\"ui5-time-picker\")\nclass TimePicker extends TimePickerBase {\n\t/**\n\t * Defines a short hint, intended to aid the user with data entry when the\n\t * component has no value.\n\t *\n\t * <br><br>\n\t * <b>Note:</b> When no placeholder is set, the format pattern is displayed as a placeholder.\n\t * Passing an empty string as the value of this property will make the component appear empty - without placeholder or format pattern.\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.TimePicker.prototype.placeholder\n\t * @defaultvalue undefined\n\t * @public\n\t */\n\t@property({ defaultValue: undefined })\n\tplaceholder?: string;\n\n\t/**\n\t * Determines the format, displayed in the input field.\n\t *\n\t * Example:\n\t * HH:mm:ss -> 11:42:35\n\t * hh:mm:ss a -> 2:23:15 PM\n\t * mm:ss -> 12:04 (only minutes and seconds)\n\t *\n\t * @type {string}\n\t * @name sap.ui.webc.main.TimePicker.prototype.formatPattern\n\t * @defaultvalue \"\"\n\t * @public\n\t */\n\t@property()\n\tformatPattern!: string;\n\n\tonBeforeRendering() {\n\t\tif (this.value) {\n\t\t\tthis.value = this.normalizeValue(this.value) || this.value;\n\t\t}\n\t}\n\n\tget _formatPattern() {\n\t\tconst hasHours = !!this.formatPattern.match(/H/i);\n\t\tconst fallback = !this.formatPattern || !hasHours;\n\n\t\tconst localeData = getCachedLocaleDataInstance(getLocale());\n\t\treturn fallback ? localeData.getTimePattern(\"medium\") : this.formatPattern;\n\t}\n\n\tget _displayFormat() {\n\t\t// @ts-ignore oFormatOptions is a private API of DateFormat\n\t\treturn this.getFormat().oFormatOptions.pattern as string;\n\t}\n\n\tget _placeholder() {\n\t\treturn this.placeholder !== undefined ? this.placeholder : this._displayFormat;\n\t}\n\n\t/**\n\t * Currently selected time represented as JavaScript Date instance\n\t *\n\t * @readonly\n\t * @type {Date}\n\t * @public\n\t * @name sap.ui.webc.main.TimePicker.prototype.dateValue\n\t */\n\tget dateValue() {\n\t\treturn this.getFormat().parse(this._effectiveValue as string);\n\t}\n\n\tget accInfo() {\n\t\treturn {\n\t\t\t\"ariaRoledescription\": this.dateAriaDescription,\n\t\t\t\"ariaHasPopup\": \"dialog\",\n\t\t\t\"ariaAutoComplete\": \"none\",\n\t\t\t\"ariaControls\": `${this._id}-responsive-popover`,\n\t\t};\n\t}\n\n\tget dateAriaDescription() {\n\t\treturn TimePicker.i18nBundle.getText(TIMEPICKER_INPUT_DESCRIPTION);\n\t}\n}\n\nTimePicker.define();\n\nexport default TimePicker;\nexport type {\n\tTimePickerChangeEventDetail,\n\tTimePickerInputEventDetail,\n};\n"]}
package/dist/Tree.d.ts CHANGED
@@ -140,20 +140,6 @@ declare class Tree extends UI5Element {
140
140
  * @since 1.10.0
141
141
  */
142
142
  accessibleRoleDescription?: string;
143
- /**
144
- * Shows the toggle button at the end, rather than at the beginning of the items
145
- *
146
- * @protected
147
- * @since 1.0.0-rc.8
148
- */
149
- _toggleButtonEnd: boolean;
150
- /**
151
- * Represents the tree in a very minimal state - icons only with no text and no toggle buttons
152
- *
153
- * @protected
154
- * @since 1.0.0-rc.8
155
- */
156
- _minimal: boolean;
157
143
  /**
158
144
  * Defines the items of the component. Tree items may have other tree items as children.
159
145
  * <br><br>
@@ -180,7 +166,7 @@ declare class Tree extends UI5Element {
180
166
  onBeforeRendering(): void;
181
167
  onAfterRendering(): void;
182
168
  get list(): TreeList;
183
- get _role(): "menubar" | "tree";
169
+ get _role(): string;
184
170
  get _label(): string | undefined;
185
171
  get _hasHeader(): boolean;
186
172
  _onListItemStepIn(e: CustomEvent<TreeItemBaseStepInEventDetail>): void;
package/dist/Tree.js CHANGED
@@ -85,7 +85,7 @@ let Tree = class Tree extends UI5Element {
85
85
  return this.getDomRef();
86
86
  }
87
87
  get _role() {
88
- return this._minimal ? "menubar" : "tree";
88
+ return "tree";
89
89
  }
90
90
  get _label() {
91
91
  return getEffectiveAriaLabelText(this);
@@ -160,8 +160,6 @@ let Tree = class Tree extends UI5Element {
160
160
  const parent = item.parentNode;
161
161
  const ariaSetSize = (parent && parent.children.length) || this.items.length;
162
162
  item.setAttribute("level", level.toString());
163
- item._toggleButtonEnd = this._toggleButtonEnd;
164
- item._minimal = this._minimal;
165
163
  item._setsize = ariaSetSize;
166
164
  item._posinset = index + 1;
167
165
  });
@@ -226,12 +224,6 @@ __decorate([
226
224
  __decorate([
227
225
  property({ defaultValue: undefined, noAttribute: true })
228
226
  ], Tree.prototype, "accessibleRoleDescription", void 0);
229
- __decorate([
230
- property({ type: Boolean })
231
- ], Tree.prototype, "_toggleButtonEnd", void 0);
232
- __decorate([
233
- property({ type: Boolean })
234
- ], Tree.prototype, "_minimal", void 0);
235
227
  __decorate([
236
228
  slot({ type: HTMLElement, invalidateOnChildChange: true, "default": true })
237
229
  ], Tree.prototype, "items", void 0);