@ui5/webcomponents 2.8.0-rc.2 → 2.8.0

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 (755) hide show
  1. package/CHANGELOG.md +47 -0
  2. package/cypress/specs/AvatarGroup.cy.tsx +36 -0
  3. package/cypress/specs/Dialog.cy.tsx +89 -0
  4. package/cypress/specs/Input.cy.tsx +170 -1
  5. package/cypress/specs/Link.cy.tsx +199 -14
  6. package/cypress/specs/Popover.cy.tsx +176 -0
  7. package/cypress/specs/Select.cy.tsx +15 -0
  8. package/cypress/specs/TabContainer.cy.tsx +29 -0
  9. package/cypress/specs/Table.cy.tsx +5 -24
  10. package/cypress/specs/TableDragAndDrop.cy.tsx +1 -1
  11. package/cypress/specs/TableNavigation.cy.tsx +223 -0
  12. package/cypress/specs/TableNavigationFixedHeader.cy.tsx +199 -0
  13. package/cypress/specs/TableSelection.cy.tsx +37 -0
  14. package/cypress/specs/TableSelections.cy.tsx +296 -0
  15. package/cypress/specs/Text.cy.tsx +19 -3
  16. package/cypress/specs/Tokenizer.cy.tsx +36 -0
  17. package/cypress/specs/Toolbar.cy.tsx +22 -0
  18. package/dist/.tsbuildinfo +1 -1
  19. package/dist/Avatar.d.ts +4 -1
  20. package/dist/Avatar.js.map +1 -1
  21. package/dist/AvatarGroup.js +1 -0
  22. package/dist/AvatarGroup.js.map +1 -1
  23. package/dist/ColorPicker.d.ts +4 -1
  24. package/dist/ColorPicker.js +1 -1
  25. package/dist/ColorPicker.js.map +1 -1
  26. package/dist/ComboBoxItemGroupTemplate.js +2 -2
  27. package/dist/ComboBoxItemGroupTemplate.js.map +1 -1
  28. package/dist/Input.d.ts +1 -1
  29. package/dist/Input.js +10 -5
  30. package/dist/Input.js.map +1 -1
  31. package/dist/List.d.ts +5 -2
  32. package/dist/List.js +24 -2
  33. package/dist/List.js.map +1 -1
  34. package/dist/ListBoxItemGroupTemplate.d.ts +4 -0
  35. package/dist/ListBoxItemGroupTemplate.js +13 -0
  36. package/dist/ListBoxItemGroupTemplate.js.map +1 -0
  37. package/dist/ListItemGroupHeader.d.ts +6 -0
  38. package/dist/ListItemGroupHeader.js +20 -3
  39. package/dist/ListItemGroupHeader.js.map +1 -1
  40. package/dist/ListItemGroupHeaderTemplate.js +3 -3
  41. package/dist/ListItemGroupHeaderTemplate.js.map +1 -1
  42. package/dist/ListItemGroupTemplate.d.ts +1 -3
  43. package/dist/ListItemGroupTemplate.js +5 -8
  44. package/dist/ListItemGroupTemplate.js.map +1 -1
  45. package/dist/ListTemplate.js +1 -1
  46. package/dist/ListTemplate.js.map +1 -1
  47. package/dist/MultiComboBoxItemGroupTemplate.js +2 -2
  48. package/dist/MultiComboBoxItemGroupTemplate.js.map +1 -1
  49. package/dist/Popover.d.ts +0 -6
  50. package/dist/Popover.js +0 -9
  51. package/dist/Popover.js.map +1 -1
  52. package/dist/Popup.js +3 -1
  53. package/dist/Popup.js.map +1 -1
  54. package/dist/Select.d.ts +7 -0
  55. package/dist/Select.js +3 -0
  56. package/dist/Select.js.map +1 -1
  57. package/dist/SelectTemplate.js +2 -2
  58. package/dist/SelectTemplate.js.map +1 -1
  59. package/dist/SuggestionItemGroup.js +2 -0
  60. package/dist/SuggestionItemGroup.js.map +1 -1
  61. package/dist/TabContainer.d.ts +11 -0
  62. package/dist/TabContainer.js +18 -4
  63. package/dist/TabContainer.js.map +1 -1
  64. package/dist/TabContainerTemplate.js +1 -0
  65. package/dist/TabContainerTemplate.js.map +1 -1
  66. package/dist/Table.d.ts +17 -11
  67. package/dist/Table.js +16 -35
  68. package/dist/Table.js.map +1 -1
  69. package/dist/TableCell.d.ts +1 -0
  70. package/dist/TableCell.js +8 -1
  71. package/dist/TableCell.js.map +1 -1
  72. package/dist/TableCellBase.js +2 -2
  73. package/dist/TableCellBase.js.map +1 -1
  74. package/dist/TableCellTemplate.d.ts +2 -0
  75. package/dist/TableCellTemplate.js +6 -0
  76. package/dist/TableCellTemplate.js.map +1 -0
  77. package/dist/TableGrowing.js +4 -4
  78. package/dist/TableGrowing.js.map +1 -1
  79. package/dist/TableGrowingTemplate.d.ts +2 -0
  80. package/dist/TableGrowingTemplate.js +6 -0
  81. package/dist/TableGrowingTemplate.js.map +1 -0
  82. package/dist/TableHeaderCell.d.ts +0 -3
  83. package/dist/TableHeaderCell.js +1 -10
  84. package/dist/TableHeaderCell.js.map +1 -1
  85. package/dist/TableHeaderCellActionBase.js +5 -6
  86. package/dist/TableHeaderCellActionBase.js.map +1 -1
  87. package/dist/TableHeaderCellActionBaseTemplate.d.ts +2 -0
  88. package/dist/TableHeaderCellActionBaseTemplate.js +6 -0
  89. package/dist/TableHeaderCellActionBaseTemplate.js.map +1 -0
  90. package/dist/TableHeaderCellTemplate.d.ts +2 -0
  91. package/dist/TableHeaderCellTemplate.js +19 -0
  92. package/dist/TableHeaderCellTemplate.js.map +1 -0
  93. package/dist/TableHeaderRow.d.ts +2 -3
  94. package/dist/TableHeaderRow.js +1 -6
  95. package/dist/TableHeaderRow.js.map +1 -1
  96. package/dist/TableHeaderRowTemplate.d.ts +2 -0
  97. package/dist/TableHeaderRowTemplate.js +11 -0
  98. package/dist/TableHeaderRowTemplate.js.map +1 -0
  99. package/dist/TableNavigation.js +3 -3
  100. package/dist/TableNavigation.js.map +1 -1
  101. package/dist/TableRow.d.ts +7 -5
  102. package/dist/TableRow.js +4 -14
  103. package/dist/TableRow.js.map +1 -1
  104. package/dist/TableRowAction.d.ts +9 -8
  105. package/dist/TableRowAction.js +9 -11
  106. package/dist/TableRowAction.js.map +1 -1
  107. package/dist/TableRowActionBase.js +3 -6
  108. package/dist/TableRowActionBase.js.map +1 -1
  109. package/dist/TableRowActionBaseTemplate.d.ts +2 -0
  110. package/dist/TableRowActionBaseTemplate.js +13 -0
  111. package/dist/TableRowActionBaseTemplate.js.map +1 -0
  112. package/dist/TableRowBase.d.ts +4 -4
  113. package/dist/TableRowBase.js +10 -10
  114. package/dist/TableRowBase.js.map +1 -1
  115. package/dist/TableRowTemplate.d.ts +2 -0
  116. package/dist/TableRowTemplate.js +17 -0
  117. package/dist/TableRowTemplate.js.map +1 -0
  118. package/dist/TableSelection.d.ts +9 -7
  119. package/dist/TableSelection.js +34 -30
  120. package/dist/TableSelection.js.map +1 -1
  121. package/dist/TableSelectionBase.d.ts +79 -0
  122. package/dist/TableSelectionBase.js +108 -0
  123. package/dist/TableSelectionBase.js.map +1 -0
  124. package/dist/TableSelectionMulti.d.ts +92 -0
  125. package/dist/TableSelectionMulti.js +260 -0
  126. package/dist/TableSelectionMulti.js.map +1 -0
  127. package/dist/TableSelectionSingle.d.ts +49 -0
  128. package/dist/TableSelectionSingle.js +67 -0
  129. package/dist/TableSelectionSingle.js.map +1 -0
  130. package/dist/TableTemplate.d.ts +2 -0
  131. package/dist/TableTemplate.js +18 -0
  132. package/dist/TableTemplate.js.map +1 -0
  133. package/dist/TableUtils.js +1 -1
  134. package/dist/TableUtils.js.map +1 -1
  135. package/dist/Tokenizer.js +2 -2
  136. package/dist/Tokenizer.js.map +1 -1
  137. package/dist/Toolbar.d.ts +3 -0
  138. package/dist/Toolbar.js +4 -1
  139. package/dist/Toolbar.js.map +1 -1
  140. package/dist/ToolbarPopoverTemplate.js +1 -1
  141. package/dist/ToolbarPopoverTemplate.js.map +1 -1
  142. package/dist/bundle.esm.js +2 -0
  143. package/dist/bundle.esm.js.map +1 -1
  144. package/dist/css/themes/Avatar.css +1 -1
  145. package/dist/css/themes/AvatarGroup.css +1 -1
  146. package/dist/css/themes/Bar.css +1 -1
  147. package/dist/css/themes/Breadcrumbs.css +1 -1
  148. package/dist/css/themes/BusyIndicator.css +1 -1
  149. package/dist/css/themes/Button.css +1 -1
  150. package/dist/css/themes/ButtonBadge.css +1 -1
  151. package/dist/css/themes/Calendar.css +1 -1
  152. package/dist/css/themes/CalendarHeader.css +1 -1
  153. package/dist/css/themes/CalendarLegend.css +1 -1
  154. package/dist/css/themes/CalendarLegendItem.css +1 -1
  155. package/dist/css/themes/Card.css +1 -1
  156. package/dist/css/themes/CardHeader.css +1 -1
  157. package/dist/css/themes/Carousel.css +1 -1
  158. package/dist/css/themes/CheckBox.css +1 -1
  159. package/dist/css/themes/ColorPalette.css +1 -1
  160. package/dist/css/themes/ColorPaletteItem.css +1 -1
  161. package/dist/css/themes/ColorPalettePopover.css +1 -1
  162. package/dist/css/themes/ColorPicker.css +1 -1
  163. package/dist/css/themes/ComboBox.css +1 -1
  164. package/dist/css/themes/ComboBoxItem.css +1 -1
  165. package/dist/css/themes/DatePicker.css +1 -1
  166. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  167. package/dist/css/themes/DayPicker.css +1 -1
  168. package/dist/css/themes/Dialog.css +1 -1
  169. package/dist/css/themes/FileUploader.css +1 -1
  170. package/dist/css/themes/Form.css +1 -1
  171. package/dist/css/themes/FormItem.css +1 -1
  172. package/dist/css/themes/FormItemSpan.css +1 -1
  173. package/dist/css/themes/GrowingButton.css +1 -1
  174. package/dist/css/themes/Icon.css +1 -1
  175. package/dist/css/themes/Input.css +1 -1
  176. package/dist/css/themes/InputIcon.css +1 -1
  177. package/dist/css/themes/InputSharedStyles.css +1 -1
  178. package/dist/css/themes/Link.css +1 -1
  179. package/dist/css/themes/List.css +1 -1
  180. package/dist/css/themes/ListItem.css +1 -1
  181. package/dist/css/themes/ListItemBase.css +1 -1
  182. package/dist/css/themes/ListItemCustom.css +1 -1
  183. package/dist/css/themes/ListItemGroup.css +1 -1
  184. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  185. package/dist/css/themes/ListItemIcon.css +1 -1
  186. package/dist/css/themes/Menu.css +1 -1
  187. package/dist/css/themes/MenuItem.css +1 -1
  188. package/dist/css/themes/MessageStrip.css +1 -1
  189. package/dist/css/themes/MonthPicker.css +1 -1
  190. package/dist/css/themes/MultiComboBox.css +1 -1
  191. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  192. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  193. package/dist/css/themes/MultiInput.css +1 -1
  194. package/dist/css/themes/OptionBase.css +1 -1
  195. package/dist/css/themes/Panel.css +1 -1
  196. package/dist/css/themes/Popover.css +1 -1
  197. package/dist/css/themes/PopupsCommon.css +1 -1
  198. package/dist/css/themes/ProgressIndicator.css +1 -1
  199. package/dist/css/themes/RadioButton.css +1 -1
  200. package/dist/css/themes/RangeSlider.css +1 -1
  201. package/dist/css/themes/RatingIndicator.css +1 -1
  202. package/dist/css/themes/ResponsivePopover.css +1 -1
  203. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  204. package/dist/css/themes/SegmentedButton.css +1 -1
  205. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  206. package/dist/css/themes/Select.css +1 -1
  207. package/dist/css/themes/SliderBase.css +1 -1
  208. package/dist/css/themes/SplitButton.css +1 -1
  209. package/dist/css/themes/StepInput.css +1 -1
  210. package/dist/css/themes/SuggestionItem.css +1 -1
  211. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  212. package/dist/css/themes/Switch.css +1 -1
  213. package/dist/css/themes/TabContainer.css +1 -1
  214. package/dist/css/themes/TabInOverflow.css +1 -1
  215. package/dist/css/themes/TabInStrip.css +1 -1
  216. package/dist/css/themes/TabSemanticIcon.css +1 -1
  217. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  218. package/dist/css/themes/Table.css +1 -1
  219. package/dist/css/themes/TableCell.css +1 -1
  220. package/dist/css/themes/TableCellBase.css +1 -1
  221. package/dist/css/themes/TableGrowing.css +1 -1
  222. package/dist/css/themes/TableHeaderRow.css +1 -1
  223. package/dist/css/themes/TableRow.css +1 -1
  224. package/dist/css/themes/TableRowActionBase.css +1 -1
  225. package/dist/css/themes/TableRowBase.css +1 -1
  226. package/dist/css/themes/Tag.css +1 -1
  227. package/dist/css/themes/Text.css +1 -1
  228. package/dist/css/themes/TextArea.css +1 -1
  229. package/dist/css/themes/TimePicker.css +1 -1
  230. package/dist/css/themes/Toast.css +1 -1
  231. package/dist/css/themes/ToggleButton.css +1 -1
  232. package/dist/css/themes/Token.css +1 -1
  233. package/dist/css/themes/Tokenizer.css +1 -1
  234. package/dist/css/themes/TokenizerPopover.css +1 -1
  235. package/dist/css/themes/Toolbar.css +1 -1
  236. package/dist/css/themes/ToolbarPopover.css +1 -1
  237. package/dist/css/themes/TreeItem.css +1 -1
  238. package/dist/css/themes/ValueStateMessage.css +1 -1
  239. package/dist/css/themes/YearPicker.css +1 -1
  240. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  241. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  242. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  243. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  244. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  245. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  246. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  247. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  248. package/dist/custom-elements-internal.json +762 -31
  249. package/dist/custom-elements.json +725 -31
  250. package/dist/features/InputSuggestions.js +0 -2
  251. package/dist/features/InputSuggestions.js.map +1 -1
  252. package/dist/features/InputSuggestionsTemplate.js +2 -1
  253. package/dist/features/InputSuggestionsTemplate.js.map +1 -1
  254. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  255. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  256. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  257. package/dist/generated/assets/i18n/messagebundle_cnr.json +1 -1
  258. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  259. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -1
  260. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  261. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  262. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  263. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  264. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -1
  265. package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -1
  266. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  267. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -1
  268. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  269. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  270. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  271. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -1
  272. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  273. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  274. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  275. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  276. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  277. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  278. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  279. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  280. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  281. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  282. package/dist/generated/assets/i18n/messagebundle_mk.json +1 -1
  283. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  284. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  285. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  286. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  287. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  288. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -1
  289. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  290. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  291. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  292. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  293. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  294. package/dist/generated/assets/i18n/messagebundle_sr.json +1 -1
  295. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  296. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  297. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  298. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  299. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  300. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  301. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  302. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  303. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  304. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  305. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  306. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  307. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  308. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  309. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  310. package/dist/generated/i18n/i18n-defaults.d.ts +4 -1
  311. package/dist/generated/i18n/i18n-defaults.js +4 -1
  312. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  313. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  314. package/dist/generated/themes/Avatar.css.js +1 -1
  315. package/dist/generated/themes/Avatar.css.js.map +1 -1
  316. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  317. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  318. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  319. package/dist/generated/themes/Bar.css.d.ts +1 -1
  320. package/dist/generated/themes/Bar.css.js +1 -1
  321. package/dist/generated/themes/Bar.css.js.map +1 -1
  322. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  323. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  324. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  325. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  326. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  327. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  328. package/dist/generated/themes/Button.css.d.ts +1 -1
  329. package/dist/generated/themes/Button.css.js +1 -1
  330. package/dist/generated/themes/Button.css.js.map +1 -1
  331. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  332. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  333. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  334. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  335. package/dist/generated/themes/Calendar.css.js +1 -1
  336. package/dist/generated/themes/Calendar.css.js.map +1 -1
  337. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  338. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  339. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  340. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  341. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  342. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  343. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  344. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  345. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  346. package/dist/generated/themes/Card.css.d.ts +1 -1
  347. package/dist/generated/themes/Card.css.js +1 -1
  348. package/dist/generated/themes/Card.css.js.map +1 -1
  349. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  350. package/dist/generated/themes/CardHeader.css.js +1 -1
  351. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  352. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  353. package/dist/generated/themes/Carousel.css.js +1 -1
  354. package/dist/generated/themes/Carousel.css.js.map +1 -1
  355. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  356. package/dist/generated/themes/CheckBox.css.js +1 -1
  357. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  358. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  359. package/dist/generated/themes/ColorPalette.css.js +1 -1
  360. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  361. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  362. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  363. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  364. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  365. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  366. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  367. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  368. package/dist/generated/themes/ColorPicker.css.js +1 -1
  369. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  370. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  371. package/dist/generated/themes/ComboBox.css.js +1 -1
  372. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  373. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  374. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  375. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  376. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  377. package/dist/generated/themes/DatePicker.css.js +1 -1
  378. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  379. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  380. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  381. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  382. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  383. package/dist/generated/themes/DayPicker.css.js +1 -1
  384. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  385. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  386. package/dist/generated/themes/Dialog.css.js +1 -1
  387. package/dist/generated/themes/Dialog.css.js.map +1 -1
  388. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  389. package/dist/generated/themes/FileUploader.css.js +1 -1
  390. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  391. package/dist/generated/themes/Form.css.d.ts +1 -1
  392. package/dist/generated/themes/Form.css.js +1 -1
  393. package/dist/generated/themes/Form.css.js.map +1 -1
  394. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  395. package/dist/generated/themes/FormItem.css.js +1 -1
  396. package/dist/generated/themes/FormItem.css.js.map +1 -1
  397. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  398. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  399. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  400. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  401. package/dist/generated/themes/GrowingButton.css.js +1 -1
  402. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  403. package/dist/generated/themes/Icon.css.d.ts +1 -1
  404. package/dist/generated/themes/Icon.css.js +1 -1
  405. package/dist/generated/themes/Icon.css.js.map +1 -1
  406. package/dist/generated/themes/Input.css.d.ts +1 -1
  407. package/dist/generated/themes/Input.css.js +1 -1
  408. package/dist/generated/themes/Input.css.js.map +1 -1
  409. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  410. package/dist/generated/themes/InputIcon.css.js +1 -1
  411. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  412. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  413. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  414. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  415. package/dist/generated/themes/Link.css.d.ts +1 -1
  416. package/dist/generated/themes/Link.css.js +1 -1
  417. package/dist/generated/themes/Link.css.js.map +1 -1
  418. package/dist/generated/themes/List.css.d.ts +1 -1
  419. package/dist/generated/themes/List.css.js +1 -1
  420. package/dist/generated/themes/List.css.js.map +1 -1
  421. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  422. package/dist/generated/themes/ListItem.css.js +1 -1
  423. package/dist/generated/themes/ListItem.css.js.map +1 -1
  424. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  425. package/dist/generated/themes/ListItemBase.css.js +1 -1
  426. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  427. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  428. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  429. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  430. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  431. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  432. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  433. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  434. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  435. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  436. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  437. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  438. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  439. package/dist/generated/themes/Menu.css.d.ts +1 -1
  440. package/dist/generated/themes/Menu.css.js +1 -1
  441. package/dist/generated/themes/Menu.css.js.map +1 -1
  442. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  443. package/dist/generated/themes/MenuItem.css.js +1 -1
  444. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  445. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  446. package/dist/generated/themes/MessageStrip.css.js +1 -1
  447. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  448. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  449. package/dist/generated/themes/MonthPicker.css.js +1 -1
  450. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  451. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  452. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  453. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  454. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  455. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  456. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  457. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  458. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  459. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  460. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  461. package/dist/generated/themes/MultiInput.css.js +1 -1
  462. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  463. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  464. package/dist/generated/themes/OptionBase.css.js +1 -1
  465. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  466. package/dist/generated/themes/Panel.css.d.ts +1 -1
  467. package/dist/generated/themes/Panel.css.js +1 -1
  468. package/dist/generated/themes/Panel.css.js.map +1 -1
  469. package/dist/generated/themes/Popover.css.d.ts +1 -1
  470. package/dist/generated/themes/Popover.css.js +1 -1
  471. package/dist/generated/themes/Popover.css.js.map +1 -1
  472. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  473. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  474. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  475. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  476. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  477. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  478. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  479. package/dist/generated/themes/RadioButton.css.js +1 -1
  480. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  481. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  482. package/dist/generated/themes/RangeSlider.css.js +1 -1
  483. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  484. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  485. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  486. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  487. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  488. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  489. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  490. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  491. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  492. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  493. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  494. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  495. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  496. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  497. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  498. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  499. package/dist/generated/themes/Select.css.d.ts +1 -1
  500. package/dist/generated/themes/Select.css.js +1 -1
  501. package/dist/generated/themes/Select.css.js.map +1 -1
  502. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  503. package/dist/generated/themes/SliderBase.css.js +1 -1
  504. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  505. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  506. package/dist/generated/themes/SplitButton.css.js +1 -1
  507. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  508. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  509. package/dist/generated/themes/StepInput.css.js +1 -1
  510. package/dist/generated/themes/StepInput.css.js.map +1 -1
  511. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  512. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  513. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  514. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  515. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  516. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  517. package/dist/generated/themes/Switch.css.d.ts +1 -1
  518. package/dist/generated/themes/Switch.css.js +1 -1
  519. package/dist/generated/themes/Switch.css.js.map +1 -1
  520. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  521. package/dist/generated/themes/TabContainer.css.js +1 -1
  522. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  523. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  524. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  525. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  526. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  527. package/dist/generated/themes/TabInStrip.css.js +1 -1
  528. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  529. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  530. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  531. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  532. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  533. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  534. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  535. package/dist/generated/themes/Table.css.d.ts +1 -1
  536. package/dist/generated/themes/Table.css.js +1 -1
  537. package/dist/generated/themes/Table.css.js.map +1 -1
  538. package/dist/generated/themes/TableCell.css.d.ts +1 -1
  539. package/dist/generated/themes/TableCell.css.js +1 -1
  540. package/dist/generated/themes/TableCell.css.js.map +1 -1
  541. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  542. package/dist/generated/themes/TableCellBase.css.js +1 -1
  543. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  544. package/dist/generated/themes/TableGrowing.css.d.ts +1 -1
  545. package/dist/generated/themes/TableGrowing.css.js +1 -1
  546. package/dist/generated/themes/TableGrowing.css.js.map +1 -1
  547. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  548. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  549. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  550. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  551. package/dist/generated/themes/TableRow.css.js +1 -1
  552. package/dist/generated/themes/TableRow.css.js.map +1 -1
  553. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  554. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  555. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  556. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  557. package/dist/generated/themes/TableRowBase.css.js +1 -1
  558. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  559. package/dist/generated/themes/Tag.css.d.ts +1 -1
  560. package/dist/generated/themes/Tag.css.js +1 -1
  561. package/dist/generated/themes/Tag.css.js.map +1 -1
  562. package/dist/generated/themes/Text.css.d.ts +1 -1
  563. package/dist/generated/themes/Text.css.js +1 -1
  564. package/dist/generated/themes/Text.css.js.map +1 -1
  565. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  566. package/dist/generated/themes/TextArea.css.js +1 -1
  567. package/dist/generated/themes/TextArea.css.js.map +1 -1
  568. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  569. package/dist/generated/themes/TimePicker.css.js +1 -1
  570. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  571. package/dist/generated/themes/Toast.css.d.ts +1 -1
  572. package/dist/generated/themes/Toast.css.js +1 -1
  573. package/dist/generated/themes/Toast.css.js.map +1 -1
  574. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  575. package/dist/generated/themes/ToggleButton.css.js +1 -1
  576. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  577. package/dist/generated/themes/Token.css.d.ts +1 -1
  578. package/dist/generated/themes/Token.css.js +1 -1
  579. package/dist/generated/themes/Token.css.js.map +1 -1
  580. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  581. package/dist/generated/themes/Tokenizer.css.js +1 -1
  582. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  583. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  584. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  585. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  586. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  587. package/dist/generated/themes/Toolbar.css.js +1 -1
  588. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  589. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  590. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  591. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  592. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  593. package/dist/generated/themes/TreeItem.css.js +1 -1
  594. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  595. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  596. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  597. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  598. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  599. package/dist/generated/themes/YearPicker.css.js +1 -1
  600. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  601. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  602. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  603. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  604. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  605. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  606. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  607. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  608. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  609. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  610. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  611. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  612. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  613. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  614. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  615. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  616. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  617. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  618. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  619. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  620. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  621. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  622. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  623. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  624. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  625. package/dist/popup-utils/PopoverRegistry.js +2 -2
  626. package/dist/popup-utils/PopoverRegistry.js.map +1 -1
  627. package/dist/types/ListItemAccessibleRole.d.ts +5 -0
  628. package/dist/types/ListItemAccessibleRole.js +5 -0
  629. package/dist/types/ListItemAccessibleRole.js.map +1 -1
  630. package/dist/types/TableSelectionMode.d.ts +1 -0
  631. package/dist/types/TableSelectionMode.js +1 -0
  632. package/dist/types/TableSelectionMode.js.map +1 -1
  633. package/dist/vscode.html-custom-data.json +51 -10
  634. package/dist/web-types.json +99 -23
  635. package/package.json +9 -9
  636. package/src/ComboBoxItemGroupTemplate.tsx +2 -2
  637. package/src/ListBoxItemGroupTemplate.tsx +33 -0
  638. package/src/ListItemGroupHeaderTemplate.tsx +5 -3
  639. package/src/ListItemGroupTemplate.tsx +21 -19
  640. package/src/ListTemplate.tsx +1 -0
  641. package/src/MultiComboBoxItemGroupTemplate.tsx +2 -2
  642. package/src/SelectTemplate.tsx +2 -0
  643. package/src/TabContainerTemplate.tsx +1 -0
  644. package/src/TableCellTemplate.tsx +15 -0
  645. package/src/TableGrowingTemplate.tsx +23 -0
  646. package/src/TableHeaderCellActionBaseTemplate.tsx +13 -0
  647. package/src/TableHeaderCellTemplate.tsx +27 -0
  648. package/src/TableHeaderRowTemplate.tsx +44 -0
  649. package/src/TableRowActionBaseTemplate.tsx +28 -0
  650. package/src/TableRowTemplate.tsx +76 -0
  651. package/src/TableTemplate.tsx +76 -0
  652. package/src/ToolbarPopoverTemplate.tsx +1 -0
  653. package/src/features/InputSuggestionsTemplate.tsx +2 -0
  654. package/src/i18n/messagebundle.properties +9 -0
  655. package/src/i18n/messagebundle_ar.properties +2 -0
  656. package/src/i18n/messagebundle_bg.properties +2 -0
  657. package/src/i18n/messagebundle_ca.properties +2 -0
  658. package/src/i18n/messagebundle_cnr.properties +2 -0
  659. package/src/i18n/messagebundle_cs.properties +2 -0
  660. package/src/i18n/messagebundle_cy.properties +2 -0
  661. package/src/i18n/messagebundle_da.properties +2 -0
  662. package/src/i18n/messagebundle_de.properties +2 -0
  663. package/src/i18n/messagebundle_el.properties +2 -0
  664. package/src/i18n/messagebundle_en.properties +2 -0
  665. package/src/i18n/messagebundle_en_GB.properties +2 -0
  666. package/src/i18n/messagebundle_en_US_saprigi.properties +4 -0
  667. package/src/i18n/messagebundle_es.properties +2 -0
  668. package/src/i18n/messagebundle_es_MX.properties +2 -0
  669. package/src/i18n/messagebundle_et.properties +2 -0
  670. package/src/i18n/messagebundle_fi.properties +2 -0
  671. package/src/i18n/messagebundle_fr.properties +2 -0
  672. package/src/i18n/messagebundle_fr_CA.properties +2 -0
  673. package/src/i18n/messagebundle_hi.properties +2 -0
  674. package/src/i18n/messagebundle_hr.properties +2 -0
  675. package/src/i18n/messagebundle_hu.properties +2 -0
  676. package/src/i18n/messagebundle_id.properties +2 -0
  677. package/src/i18n/messagebundle_it.properties +2 -0
  678. package/src/i18n/messagebundle_iw.properties +2 -0
  679. package/src/i18n/messagebundle_ja.properties +2 -0
  680. package/src/i18n/messagebundle_kk.properties +2 -0
  681. package/src/i18n/messagebundle_ko.properties +2 -0
  682. package/src/i18n/messagebundle_lt.properties +2 -0
  683. package/src/i18n/messagebundle_lv.properties +2 -0
  684. package/src/i18n/messagebundle_mk.properties +2 -0
  685. package/src/i18n/messagebundle_ms.properties +2 -0
  686. package/src/i18n/messagebundle_nl.properties +2 -0
  687. package/src/i18n/messagebundle_no.properties +2 -0
  688. package/src/i18n/messagebundle_pl.properties +2 -0
  689. package/src/i18n/messagebundle_pt.properties +2 -0
  690. package/src/i18n/messagebundle_pt_PT.properties +2 -0
  691. package/src/i18n/messagebundle_ro.properties +2 -0
  692. package/src/i18n/messagebundle_ru.properties +2 -0
  693. package/src/i18n/messagebundle_sh.properties +2 -0
  694. package/src/i18n/messagebundle_sk.properties +2 -0
  695. package/src/i18n/messagebundle_sl.properties +2 -0
  696. package/src/i18n/messagebundle_sr.properties +2 -0
  697. package/src/i18n/messagebundle_sv.properties +2 -0
  698. package/src/i18n/messagebundle_th.properties +2 -0
  699. package/src/i18n/messagebundle_tr.properties +2 -0
  700. package/src/i18n/messagebundle_uk.properties +2 -0
  701. package/src/i18n/messagebundle_vi.properties +2 -0
  702. package/src/i18n/messagebundle_zh_CN.properties +2 -0
  703. package/src/i18n/messagebundle_zh_TW.properties +2 -0
  704. package/src/themes/Avatar.css +51 -2
  705. package/src/themes/Menu.css +7 -0
  706. package/src/themes/PopupsCommon.css +7 -4
  707. package/src/themes/TabContainer.css +4 -0
  708. package/src/themes/TableCell.css +5 -1
  709. package/src/themes/TableCellBase.css +1 -1
  710. package/src/themes/TableGrowing.css +4 -1
  711. package/src/themes/Text.css +9 -5
  712. package/src/themes/Toast.css +1 -1
  713. package/src/themes/Token.css +10 -10
  714. package/src/themes/base/Avatar-parameters.css +1 -1
  715. package/src/themes/base/Toast-parameters.css +2 -2
  716. package/src/themes/sap_horizon/Avatar-parameters.css +3 -2
  717. package/src/themes/sap_horizon/Switch-parameters.css +7 -7
  718. package/src/themes/sap_horizon_dark/Avatar-parameters.css +2 -1
  719. package/src/themes/sap_horizon_dark/Switch-parameters.css +7 -7
  720. package/src/themes/sap_horizon_hcb/Avatar-parameters.css +3 -2
  721. package/src/themes/sap_horizon_hcb/Switch-parameters.css +7 -28
  722. package/src/themes/sap_horizon_hcw/Avatar-parameters.css +3 -2
  723. package/src/themes/sap_horizon_hcw/Switch-parameters.css +7 -7
  724. package/dist/SuggestionItemGroupTemplate.d.ts +0 -2
  725. package/dist/SuggestionItemGroupTemplate.js +0 -5
  726. package/dist/SuggestionItemGroupTemplate.js.map +0 -1
  727. package/dist/generated/templates/TableGrowingTemplate.lit.d.ts +0 -3
  728. package/dist/generated/templates/TableGrowingTemplate.lit.js +0 -8
  729. package/dist/generated/templates/TableGrowingTemplate.lit.js.map +0 -1
  730. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.d.ts +0 -3
  731. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.js +0 -7
  732. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.js.map +0 -1
  733. package/dist/generated/templates/TableHeaderCellTemplate.lit.d.ts +0 -3
  734. package/dist/generated/templates/TableHeaderCellTemplate.lit.js +0 -8
  735. package/dist/generated/templates/TableHeaderCellTemplate.lit.js.map +0 -1
  736. package/dist/generated/templates/TableHeaderRowTemplate.lit.d.ts +0 -3
  737. package/dist/generated/templates/TableHeaderRowTemplate.lit.js +0 -12
  738. package/dist/generated/templates/TableHeaderRowTemplate.lit.js.map +0 -1
  739. package/dist/generated/templates/TableRowActionBaseTemplate.lit.d.ts +0 -3
  740. package/dist/generated/templates/TableRowActionBaseTemplate.lit.js +0 -11
  741. package/dist/generated/templates/TableRowActionBaseTemplate.lit.js.map +0 -1
  742. package/dist/generated/templates/TableRowTemplate.lit.d.ts +0 -3
  743. package/dist/generated/templates/TableRowTemplate.lit.js +0 -18
  744. package/dist/generated/templates/TableRowTemplate.lit.js.map +0 -1
  745. package/dist/generated/templates/TableTemplate.lit.d.ts +0 -3
  746. package/dist/generated/templates/TableTemplate.lit.js +0 -12
  747. package/dist/generated/templates/TableTemplate.lit.js.map +0 -1
  748. package/src/SuggestionItemGroupTemplate.tsx +0 -6
  749. package/src/Table.hbs +0 -63
  750. package/src/TableGrowing.hbs +0 -17
  751. package/src/TableHeaderCell.hbs +0 -5
  752. package/src/TableHeaderCellActionBase.hbs +0 -6
  753. package/src/TableHeaderRow.hbs +0 -28
  754. package/src/TableRow.hbs +0 -55
  755. package/src/TableRowActionBase.hbs +0 -16
@@ -0,0 +1,199 @@
1
+ import Table from "../../src/Table.js";
2
+ import TableHeaderRow from "../../src/TableHeaderRow.js";
3
+ import TableHeaderCell from "../../src/TableHeaderCell.js";
4
+ import TableRow from "../../src/TableRow.js";
5
+ import TableCell from "../../src/TableCell.js";
6
+ import Label from "../../src/Label.js";
7
+ import Bar from "../../src/Bar.js";
8
+ import Title from "../../src/Title.js";
9
+ import Slider from "../../src/Slider.js";
10
+
11
+ describe("Table - Keyboard Navigation with Fixed Headers", () => {
12
+ function isDisplayedInsideViewport(element: string) {
13
+ cy.get(element).then($el => {
14
+ const el = $el[0];
15
+ const rect = el.getBoundingClientRect();
16
+
17
+ expect(rect.top).to.be.at.least(0);
18
+ expect(rect.left).to.be.at.least(0);
19
+ expect(rect.bottom).to.be.lessThan(Cypress.config("viewportHeight"));
20
+ expect(rect.right).to.be.lessThan(Cypress.config("viewportWidth"));
21
+ });
22
+ }
23
+
24
+ it("scrollable container - focused row should always be below the header", () => {
25
+ cy.mount(
26
+ <div style="height:300px; overflow:auto;">
27
+ <Bar id="toolbar" design="Header" accessible-name-ref="title" style="position: sticky; top: 0; z-index: 2; height: 50px;">
28
+ <Title tabindex={0} level="H3" id="title" slot="startContent">My Selectable Products (3)</Title>
29
+ <Slider id="slider" min={0} max={100} step={1} value={100}
30
+ label-interval="0"/>
31
+ </Bar>
32
+ <Table id="table0" overflow-mode="Popin" sticky-top="50px" accessible-name-ref="title" no-data-text="No data found">
33
+ <TableHeaderRow sticky slot="headerRow">
34
+ <TableHeaderCell id="colA" min-width="300px"><span>ColumnA</span></TableHeaderCell>
35
+ <TableHeaderCell id="colB" min-width="200px">Column B</TableHeaderCell>
36
+ <TableHeaderCell id="colC" min-width="200px">Column C</TableHeaderCell>
37
+ <TableHeaderCell id="colD" min-width="150px">Column D</TableHeaderCell>
38
+ </TableHeaderRow>
39
+ <TableRow id="row-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
40
+ <TableRow id="row-2"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
41
+ <TableRow id="row-3"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
42
+ <TableRow id="row-4"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
43
+ <TableRow id="row-5"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
44
+ <TableRow id="row-6"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
45
+ <TableRow id="row-7"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
46
+ <TableRow id="row-8"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
47
+ <TableRow id="row-9"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
48
+ <TableRow id="row-10"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
49
+ <TableRow id="row-11"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
50
+ <TableRow id="row-12"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
51
+ <TableRow id="row-13"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
52
+ <TableRow id="row-14"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
53
+ <TableRow id="row-15"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
54
+ <TableRow id="row-16"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
55
+ <TableRow id="row-17"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
56
+ <TableRow id="row-18"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
57
+ <TableRow id="row-19"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
58
+ <TableRow id="row-20"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
59
+ <TableRow id="row-21"> <TableCell>A</TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
60
+ </Table>
61
+ </div>
62
+ );
63
+
64
+ cy.get("#table0").children("ui5-table-row").as("rows");
65
+ cy.get("#table0").children("ui5-table-header-row").as("headerRow");
66
+ cy.get("@rows").get("#row-21").as("lastRow");
67
+
68
+ cy.get("@lastRow").scrollIntoView();
69
+ cy.get("@lastRow").click("left");
70
+ cy.get("@lastRow").should("be.focused");
71
+
72
+ for (let i = 20; i > 0; i--) {
73
+ cy.realPress("{uparrow}");
74
+ cy.get("@rows").get(`#row-${i}`).should("be.focused");
75
+
76
+ isDisplayedInsideViewport("@headerRow");
77
+
78
+ cy.get("@headerRow").then($headerRow => {
79
+ cy.get("@rows").get(`#row-${i}`).then($row => {
80
+ const headerRowBottom = $headerRow[0].getBoundingClientRect().bottom;
81
+ const focusedRowTop = $row[0].getBoundingClientRect().top;
82
+
83
+ expect(focusedRowTop).to.be.at.least(headerRowBottom);
84
+ });
85
+ });
86
+ }
87
+ });
88
+
89
+ it("scrollable table - focused row should always be below the header", () => {
90
+ cy.mount(
91
+ <Table id="table1" overflow-mode="Popin" sticky-top="0" accessible-name-ref="title" no-data-text="No data found" style="height: 300px; overflow: auto;">
92
+ <TableHeaderRow sticky slot="headerRow">
93
+ <TableHeaderCell id="colA" min-width="300px"><span>ColumnA</span></TableHeaderCell>
94
+ <TableHeaderCell id="colB" min-width="200px">Column B</TableHeaderCell>
95
+ <TableHeaderCell id="colC" min-width="200px">Column C</TableHeaderCell>
96
+ <TableHeaderCell id="colD" min-width="150px">Column D</TableHeaderCell>
97
+ </TableHeaderRow>
98
+ <TableRow id="row-1-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
99
+ <TableRow id="row-2-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
100
+ <TableRow id="row-3-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
101
+ <TableRow id="row-4-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
102
+ <TableRow id="row-5-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
103
+ <TableRow id="row-6-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
104
+ <TableRow id="row-7-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
105
+ <TableRow id="row-8-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
106
+ <TableRow id="row-9-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
107
+ <TableRow id="row-10-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
108
+ <TableRow id="row-11-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
109
+ <TableRow id="row-12-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
110
+ <TableRow id="row-13-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
111
+ <TableRow id="row-14-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
112
+ <TableRow id="row-15-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
113
+ <TableRow id="row-16-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
114
+ <TableRow id="row-17-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
115
+ <TableRow id="row-18-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
116
+ <TableRow id="row-19-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
117
+ <TableRow id="row-20-1"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
118
+ <TableRow id="row-21-1"> <TableCell>A</TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
119
+ </Table>
120
+ );
121
+
122
+ cy.get("#table1").children("ui5-table-row").as("rows");
123
+ cy.get("#table1").children("ui5-table-header-row").as("headerRow");
124
+ cy.get("@rows").get("#row-21-1").as("lastRow");
125
+
126
+ cy.get("@lastRow").scrollIntoView();
127
+ cy.get("@lastRow").click("left");
128
+ cy.get("@lastRow").should("be.focused");
129
+
130
+ for (let i = 20; i > 0; i--) {
131
+ cy.realPress("{uparrow}");
132
+ cy.get("@rows").get(`#row-${i}-1`).should("be.focused");
133
+
134
+ isDisplayedInsideViewport("@headerRow");
135
+
136
+ cy.get("@headerRow").then($headerRow => {
137
+ cy.get("@rows").get(`#row-${i}-1`).then($row => {
138
+ const headerRowBottom = $headerRow[0].getBoundingClientRect().bottom;
139
+ const focusedRowTop = $row[0].getBoundingClientRect().top;
140
+
141
+ expect(focusedRowTop).to.be.at.least(headerRowBottom);
142
+ });
143
+ });
144
+ }
145
+ });
146
+
147
+ it("body as scroll container - focused row should always be below the header", () => {
148
+ cy.mount(
149
+ <>
150
+ <Bar id="toolbar2" design="Header" accessible-name-ref="title" style="position: sticky; top: 0; z-index: 2; height: 50px;">
151
+ <Title tabindex={0} level="H3" id="title" slot="startContent">My Selectable Products (3)</Title>
152
+ <Slider id="slider" min={0} max={100} step={1} value={100}
153
+ label-interval="0"></Slider>
154
+ </Bar>
155
+ <Table id="table2" overflow-mode="Popin" sticky-top="50px" accessible-name-ref="title" no-data-text="No data found">
156
+ <TableHeaderRow sticky slot="headerRow">
157
+ <TableHeaderCell id="colA" min-width="300px"><span>ColumnA</span></TableHeaderCell>
158
+ <TableHeaderCell id="colB" min-width="200px">Column B</TableHeaderCell>
159
+ <TableHeaderCell id="colC" min-width="200px">Column C</TableHeaderCell>
160
+ <TableHeaderCell id="colD" min-width="150px">Column D</TableHeaderCell>
161
+ </TableHeaderRow>
162
+ ${Array.from({ length: 100 }).map((row, index) =>
163
+ <TableRow id={`row-${index + 1}-2`}>
164
+ <TableCell><Label><b>Notebook Basic ${index + 1}</b><br/>HT-100${index + 1}</Label></TableCell>
165
+ <TableCell><Label>Technocom</Label></TableCell>
166
+ <TableCell><Label>32 x 21 x 4 cm</Label></TableCell>
167
+ <TableCell><Label style="color: #2b7c2b"><b>3.7</b> KG</Label></TableCell>
168
+ <TableCell style="text-align: end;"><Label style="text-align: end;"><b>29</b> EUR</Label></TableCell>
169
+ </TableRow>
170
+ )}
171
+ </Table>
172
+ </>
173
+ );
174
+
175
+ cy.get("#table2").children("ui5-table-row").as("rows");
176
+ cy.get("#table2").children("ui5-table-header-row").as("headerRow");
177
+ cy.get("@rows").get("#row-100-2").as("lastRow");
178
+
179
+ cy.get("@lastRow").scrollIntoView();
180
+ cy.get("@lastRow").click("left");
181
+ cy.get("@lastRow").should("be.focused");
182
+
183
+ for (let i = 99; i > 0; i--) {
184
+ cy.realPress("{uparrow}");
185
+ cy.get("@rows").get(`#row-${i}-2`).should("be.focused");
186
+
187
+ isDisplayedInsideViewport("@headerRow");
188
+
189
+ cy.get("@headerRow").then($headerRow => {
190
+ cy.get("@rows").get(`#row-${i}-2`).then($row => {
191
+ const headerRowBottom = $headerRow[0].getBoundingClientRect().bottom;
192
+ const focusedRowTop = $row[0].getBoundingClientRect().top;
193
+
194
+ expect(focusedRowTop).to.be.at.least(headerRowBottom);
195
+ });
196
+ });
197
+ }
198
+ });
199
+ });
@@ -241,3 +241,40 @@ Object.entries(testConfig).forEach(([mode, testConfigEntry]) => {
241
241
  });
242
242
  });
243
243
  });
244
+
245
+ describe("TableSelection - Multi", () => {
246
+ it("updates the header row checkbox when rows are added or removed", () => {
247
+ cy.mount(
248
+ <Table id="table1">
249
+ <TableSelection id="selection" selected="1 2" slot="features"></TableSelection>
250
+ <TableHeaderRow id="headerRow" slot="headerRow">
251
+ <TableHeaderCell>ColumnA</TableHeaderCell>
252
+ </TableHeaderRow>
253
+ <TableRow id="row1" rowKey="1">
254
+ <TableCell><Label>Cell A</Label></TableCell>
255
+ </TableRow>
256
+ <TableRow id="row2" rowKey="2">
257
+ <TableCell><Label>Cell A</Label></TableCell>
258
+ </TableRow>
259
+ </Table>
260
+ );
261
+
262
+ cy.get("#headerRow").shadow().find("#selection-cell").as("headerRowSelectionCell");
263
+ cy.get("@headerRowSelectionCell").find("#selection-component").as("headerRowCheckBox");
264
+ cy.get("@headerRowCheckBox").should("have.attr", "checked");
265
+ cy.get("#table1").then($table => {
266
+ $table.append(
267
+ `<ui5-table-row id="row3" row-key="3">
268
+ <ui5-table-cell>Cell A</ui5-table-cell>
269
+ <ui5-table-cell>Cell B</ui5-table-cell>
270
+ </ui5-table-row>`
271
+ );
272
+ });
273
+ cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
274
+ cy.get("#row3").invoke("remove");
275
+ cy.get("@headerRowCheckBox").should("have.attr", "checked");
276
+ cy.get("#row2").invoke("remove");
277
+ cy.get("#row1").invoke("remove");
278
+ cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
279
+ });
280
+ });
@@ -0,0 +1,296 @@
1
+ import Label from "../../src/Label.js";
2
+ import Table from "../../src/Table.js";
3
+ import TableHeaderRow from "../../src/TableHeaderRow.js";
4
+ import TableHeaderCell from "../../src/TableHeaderCell.js";
5
+ import TableRow from "../../src/TableRow.js";
6
+ import TableCell from "../../src/TableCell.js";
7
+ import TableSelectionSingle from "../../src/TableSelectionSingle.js";
8
+ import TableSelectionMulti from "../../src/TableSelectionMulti.js";
9
+ import type TableSelectionBase from "../../src/TableSelectionBase.js";
10
+
11
+ function mountTestpage(selectionMode: string) {
12
+ cy.mount(
13
+ <>
14
+ <Table id="table0" noDataText="No data found">
15
+ {selectionMode === "Single" && (
16
+ <TableSelectionSingle id="selection" slot="features"></TableSelectionSingle>
17
+ )}
18
+ {selectionMode === "Multiple" && (
19
+ <TableSelectionMulti id="selection" slot="features"></TableSelectionMulti>
20
+ )}
21
+ <TableHeaderRow slot="headerRow">
22
+ <TableHeaderCell id="colA"><span>ColumnA</span></TableHeaderCell>
23
+ <TableHeaderCell id="colB">Column B</TableHeaderCell>
24
+ <TableHeaderCell id="colC">Column C</TableHeaderCell>
25
+ <TableHeaderCell id="colD">Column D</TableHeaderCell>
26
+ </TableHeaderRow>
27
+ <TableRow rowKey="0">
28
+ <TableCell><Label>Cell A</Label></TableCell>
29
+ <TableCell><Label>Cell B</Label></TableCell>
30
+ <TableCell><Label>Cell C</Label></TableCell>
31
+ <TableCell><Label>Cell D</Label></TableCell>
32
+ </TableRow>
33
+ <TableRow rowKey="1">
34
+ <TableCell><Label>Cell A</Label></TableCell>
35
+ <TableCell><Label>Cell B</Label></TableCell>
36
+ <TableCell><Label>Cell C</Label></TableCell>
37
+ <TableCell><Label>Cell D</Label></TableCell>
38
+ </TableRow>
39
+ <TableRow rowKey="2">
40
+ <TableCell><Label>Cell A</Label></TableCell>
41
+ <TableCell><Label>Cell B</Label></TableCell>
42
+ <TableCell><Label>Cell C</Label></TableCell>
43
+ <TableCell><Label>Cell D</Label></TableCell>
44
+ </TableRow>
45
+ <TableRow rowKey="3">
46
+ <TableCell><Label>Cell A</Label></TableCell>
47
+ <TableCell><Label>Cell B</Label></TableCell>
48
+ <TableCell><Label>Cell C</Label></TableCell>
49
+ <TableCell><Label>Cell D</Label></TableCell>
50
+ </TableRow>
51
+ <TableRow rowKey="4">
52
+ <TableCell><Label>Cell A</Label></TableCell>
53
+ <TableCell><Label>Cell B</Label></TableCell>
54
+ <TableCell><Label>Cell C</Label></TableCell>
55
+ <TableCell><Label>Cell D</Label></TableCell>
56
+ </TableRow>
57
+ </Table>
58
+ </>
59
+ );
60
+
61
+ cy.get("#table0").children("ui5-table-header-row").first().as("headerRow");
62
+ cy.get("#table0").children("ui5-table-row").get("[row-key=\"0\"]").as("row0");
63
+ cy.get("#table0").children("ui5-table-row").get("[row-key=\"4\"]").as("row4");
64
+ }
65
+
66
+ describe("Mode - None", () => {
67
+ before(() => {
68
+ mountTestpage("None");
69
+ });
70
+
71
+ it("selection should be not active", () => {
72
+ cy.get("@headerRow").shadow().find("#selection-cell")
73
+ .should("not.exist");
74
+ cy.get("@row0").shadow().find("#selection-cell")
75
+ .should("not.exist");
76
+ });
77
+ });
78
+
79
+ const testConfig = {
80
+ "Single": {
81
+ "config": {
82
+ "mode": "Single",
83
+ },
84
+ "cases": {
85
+ "BOXES": {
86
+ "header": {
87
+ "exists": true,
88
+ "checkbox": false,
89
+ },
90
+ "row": {
91
+ "exists": true,
92
+ "checkbox": true,
93
+ },
94
+ },
95
+ "SPACE": {
96
+ "space_0": "0",
97
+ "space_4": "4",
98
+ },
99
+ "ARROWS_BOX": {
100
+ "arrow_initial": "0",
101
+ "arrow_down": "1",
102
+ "arrow_up": "0",
103
+ },
104
+ "MOUSE": {
105
+ "mouse_0": "0",
106
+ "mouse_4": "4",
107
+ },
108
+ "RANGE_MOUSE": {
109
+ "range_mouse_initial": "0",
110
+ "range_mouse_final": "4",
111
+ "range_mouse_edge": "0",
112
+ },
113
+ "RANGE_KEYBOARD": {
114
+ "initial": "0",
115
+ "block_1": "0",
116
+ "block_2": "3",
117
+ },
118
+ },
119
+ },
120
+ "Multiple": {
121
+ "config": {
122
+ "mode": "Multiple",
123
+ },
124
+ "cases": {
125
+ "BOXES": {
126
+ "header": {
127
+ "exists": true,
128
+ "checkbox": true
129
+ },
130
+ "row": {
131
+ "exists": true,
132
+ "checkbox": true
133
+ }
134
+ },
135
+ "SPACE": {
136
+ "space_0": "0",
137
+ "space_4": "0 4"
138
+ },
139
+ "ARROWS_BOX": {
140
+ "arrow_initial": "0",
141
+ "arrow_down": "0",
142
+ "arrow_up": "0"
143
+ },
144
+ "MOUSE": {
145
+ "mouse_0": "0",
146
+ "mouse_4": "0 4"
147
+ },
148
+ "RANGE_MOUSE": {
149
+ "range_mouse_initial": "0",
150
+ "range_mouse_final": "0 1 2 3 4",
151
+ "range_mouse_edge": "0 1 2 3 4"
152
+ },
153
+ "RANGE_KEYBOARD": {
154
+ "initial": "0",
155
+ "block_1": "0 1",
156
+ "block_2": "0 1 3 4"
157
+ }
158
+ }
159
+ }
160
+ };
161
+
162
+ // I've had to check the attribute this way because
163
+ // should("have.attr"... and similar functions always returned '' instead of the actual value
164
+ // It could be a timing issue but .wait didn't help either
165
+ function checkSelection(expectedSelected: string) {
166
+ cy.get("#selection").then($selection => {
167
+ const selection = $selection.get(0) as TableSelectionBase;
168
+ expect(selection.getAttribute("selected")).to.equal(expectedSelected);
169
+
170
+ if (selection.isMultiSelectable()) {
171
+ const selectedRows = (selection as TableSelectionMulti).getSelectedRows();
172
+ expect(selectedRows.map(row => selection.getRowKey(row)).join(" ")).to.equal(expectedSelected);
173
+ const selectedAsSet = (selection as TableSelectionMulti).getSelectedAsSet();
174
+ expect([...selectedAsSet].join(" ")).to.equal(expectedSelected);
175
+ } else {
176
+ const selectedRow = (selection as TableSelectionSingle).getSelectedRow();
177
+ expect(selectedRow!.rowKey).to.equal(expectedSelected);
178
+ expect(selectedRow).to.equal(selection.getRowByKey(expectedSelected));
179
+ }
180
+ });
181
+ }
182
+
183
+ Object.entries(testConfig).forEach(([mode, testConfigEntry]) => {
184
+ describe(`Mode - ${mode}`, () => {
185
+ beforeEach(() => {
186
+ mountTestpage(testConfigEntry.config.mode);
187
+ });
188
+
189
+ it("Correct boxes are shown", () => {
190
+ cy.get("@headerRow").shadow().find("#selection-cell")
191
+ .should(testConfigEntry.cases.BOXES.header.exists ? "exist" : "not.exist");
192
+ cy.get("@row0").shadow().find("#selection-cell")
193
+ .should(testConfigEntry.cases.BOXES.row.exists ? "exist" : "not.exist");
194
+
195
+ cy.get("@headerRow").shadow().find("#selection-component")
196
+ .should(testConfigEntry.cases.BOXES.header.checkbox ? "exist" : "not.exist");
197
+ cy.get("@row0").shadow().find("#selection-component")
198
+ .should(testConfigEntry.cases.BOXES.row.checkbox ? "exist" : "not.exist");
199
+ });
200
+
201
+ it("select row via SPACE", () => {
202
+ cy.get("@row0").realClick({ position: "left" });
203
+ cy.get("@row0").realPress("Space");
204
+ checkSelection(testConfigEntry.cases.SPACE.space_0);
205
+
206
+ cy.get("@row4").realClick();
207
+ cy.get("@row4").realPress("Space");
208
+ checkSelection(testConfigEntry.cases.SPACE.space_4);
209
+ });
210
+
211
+ it("select row via arrows (radio focus)", () => {
212
+ cy.get("@row0").shadow().find("#selection-component").realClick();
213
+ checkSelection(testConfigEntry.cases.ARROWS_BOX.arrow_initial);
214
+
215
+ cy.realPress("ArrowDown");
216
+ checkSelection(testConfigEntry.cases.ARROWS_BOX.arrow_down);
217
+
218
+ cy.realPress("ArrowUp");
219
+ checkSelection(testConfigEntry.cases.ARROWS_BOX.arrow_up);
220
+ });
221
+
222
+ it("select row via mouse", () => {
223
+ cy.get("@row0").shadow().find("#selection-component").realClick();
224
+ checkSelection(testConfigEntry.cases.MOUSE.mouse_0);
225
+
226
+ cy.get("@row4").shadow().find("#selection-component").realClick();
227
+ checkSelection(testConfigEntry.cases.MOUSE.mouse_4);
228
+ });
229
+
230
+ it("range selection with mouse", () => {
231
+ cy.get("@row0").shadow().find("#selection-component").realClick();
232
+ checkSelection(testConfigEntry.cases.RANGE_MOUSE.range_mouse_initial);
233
+
234
+ // Need to simulate keydown with SHIFT key to set range selection flag shiftKeyPressed
235
+ // Cypress does not trigger keydown when just calling realClick with shiftKey: true
236
+ // That is why selection of the row is not supressed, and we end up with 0 4 1 2 3
237
+ cy.get("@row4").trigger("keydown", { bubbles: true, key: "Shift", shiftKey: true });
238
+ cy.get("@row4").shadow().find("#selection-component").realClick({ shiftKey: true });
239
+ checkSelection(testConfigEntry.cases.RANGE_MOUSE.range_mouse_final);
240
+
241
+ cy.get("@row4").trigger("keydown", { bubbles: true, key: "Shift", shiftKey: true });
242
+ cy.get("@row0").shadow().find("#selection-component").realClick();
243
+ checkSelection(testConfigEntry.cases.RANGE_MOUSE.range_mouse_edge);
244
+ });
245
+
246
+ it("range selection with keyboard", () => {
247
+ cy.get("@row0").realClick({ position: "center" });
248
+ cy.get("@row0").realPress("Space");
249
+ checkSelection(testConfigEntry.cases.RANGE_KEYBOARD.initial);
250
+
251
+ cy.realPress(["Shift", "ArrowDown", "ArrowDown", "ArrowDown", "ArrowUp", "ArrowUp"]);
252
+ checkSelection(testConfigEntry.cases.RANGE_KEYBOARD.block_1);
253
+
254
+ cy.realPress(["ArrowDown", "ArrowDown", "Space"]);
255
+ cy.realPress(["Shift", "ArrowDown"]);
256
+ checkSelection(testConfigEntry.cases.RANGE_KEYBOARD.block_2);
257
+ });
258
+ });
259
+ });
260
+
261
+ describe("TableSelectionMulti", () => {
262
+ it("updates the header row checkbox when rows are added or removed", () => {
263
+ cy.mount(
264
+ <Table id="table1">
265
+ <TableSelectionMulti id="selection" selected="1 2" slot="features"></TableSelectionMulti>
266
+ <TableHeaderRow id="headerRow" slot="headerRow">
267
+ <TableHeaderCell>ColumnA</TableHeaderCell>
268
+ </TableHeaderRow>
269
+ <TableRow id="row1" rowKey="1">
270
+ <TableCell><Label>Cell A</Label></TableCell>
271
+ </TableRow>
272
+ <TableRow id="row2" rowKey="2">
273
+ <TableCell><Label>Cell A</Label></TableCell>
274
+ </TableRow>
275
+ </Table>
276
+ );
277
+
278
+ cy.get("#headerRow").shadow().find("#selection-cell").as("headerRowSelectionCell");
279
+ cy.get("@headerRowSelectionCell").find("#selection-component").as("headerRowCheckBox");
280
+ cy.get("@headerRowCheckBox").should("have.attr", "checked");
281
+ cy.get("#table1").then($table => {
282
+ $table.append(
283
+ `<ui5-table-row id="row3" row-key="3">
284
+ <ui5-table-cell>Cell A</ui5-table-cell>
285
+ <ui5-table-cell>Cell B</ui5-table-cell>
286
+ </ui5-table-row>`
287
+ );
288
+ });
289
+ cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
290
+ cy.get("#row3").invoke("remove");
291
+ cy.get("@headerRowCheckBox").should("have.attr", "checked");
292
+ cy.get("#row2").invoke("remove");
293
+ cy.get("#row1").invoke("remove");
294
+ cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
295
+ });
296
+ });
@@ -13,12 +13,28 @@ describe("Text", () => {
13
13
 
14
14
  it("tests maxLines default behavior", () => {
15
15
  cy.mount(<Text >Text</Text>);
16
- cy.get("[ui5-text]").should("have.css", "-webkit-line-clamp", "none");
16
+ cy.get("[ui5-text]")
17
+ .should("have.css", "-webkit-box-orient", "vertical")
18
+ .should("have.css", "-webkit-line-clamp", "none");
17
19
  });
18
20
 
19
- it("tests maxLines", () => {
21
+ it("tests maxLines = 1", () => {
20
22
  cy.mount(<Text maxLines={1}>Text</Text>);
21
- cy.get("[ui5-text]").should("have.css", "-webkit-line-clamp", "1");
23
+
24
+ cy.get("[ui5-text]")
25
+ .should("have.css", "display", "inline-block")
26
+ .should("have.css", "overflow", "hidden")
27
+ .should("have.css", "text-overflow", "ellipsis")
28
+ .should("have.css", "white-space", "nowrap");
29
+ });
30
+
31
+ it("tests maxLines > 1", () => {
32
+ cy.mount(<Text maxLines={2}>Text</Text>);
33
+
34
+ cy.get("[ui5-text]")
35
+ .should("have.css", "overflow", "hidden")
36
+ .should("have.css", "-webkit-line-clamp", "2")
37
+ .should("have.css", "-webkit-box-orient", "vertical");
22
38
  });
23
39
 
24
40
  it("tests emptyIndicatorMode", () => {
@@ -170,4 +170,40 @@ describe("Tokenizer - multi-line and Clear All", () => {
170
170
  .find("[ui5-token]")
171
171
  .should("have.length", 6);
172
172
  });
173
+
174
+ it("handles overflow mechanism as expected", () => {
175
+ cy.mount(
176
+ <Tokenizer style={{ width: "100%" }}>
177
+ <Token text="Andora"></Token>
178
+ <Token text="Bulgaria"></Token>
179
+ <Token text="Canada"></Token>
180
+ <Token text="Denmark"></Token>
181
+ <Token text="Estonia"></Token>
182
+ <Token text="Andora"></Token>
183
+ </Tokenizer>
184
+ );
185
+
186
+ cy.get("ui5-token")
187
+ .eq(5)
188
+ .as("lastToken");
189
+
190
+ cy.get("@lastToken")
191
+ .should("be.visible");
192
+
193
+ cy.viewport(500, 600);
194
+
195
+ cy.get("ui5-tokenizer")
196
+ .shadow()
197
+ .find("span")
198
+ .should("have.attr", "aria-haspopup", "dialog")
199
+ .as("n-more");
200
+
201
+ cy.get("@lastToken")
202
+ .should("be.hidden");
203
+
204
+ cy.viewport(600, 600);
205
+
206
+ cy.get("@lastToken")
207
+ .should("be.visible");
208
+ });
173
209
  });
@@ -170,3 +170,25 @@ describe("Toolbar general interaction", () => {
170
170
  .should("have.been.calledOnce");
171
171
  });
172
172
  });
173
+
174
+ describe("Accessibility", () => {
175
+ it("Should apply accessibile-name to the popover", () => {
176
+ cy.mount(
177
+ <Toolbar>
178
+ <ToolbarButton text="Button 1"></ToolbarButton>
179
+ <ToolbarButton text="Button 2"></ToolbarButton>
180
+ <ToolbarButton text="Button 3"></ToolbarButton>
181
+ <ToolbarSelect accessible-name="Select">
182
+ <ToolbarSelectOption>1</ToolbarSelectOption>
183
+ <ToolbarSelectOption>2</ToolbarSelectOption>
184
+ <ToolbarSelectOption>3</ToolbarSelectOption>
185
+ </ToolbarSelect>
186
+ </Toolbar>
187
+ );
188
+
189
+ cy.get("ui5-toolbar")
190
+ .shadow()
191
+ .find(".ui5-overflow-popover")
192
+ .should("have.attr", "accessible-name", "Available Values");
193
+ });
194
+ });