@ui5/webcomponents 2.8.0-rc.1 → 2.8.0-rc.3

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 (690) hide show
  1. package/CHANGELOG.md +47 -0
  2. package/cypress/specs/Avatar.cy.tsx +15 -0
  3. package/cypress/specs/Dialog.cy.tsx +89 -0
  4. package/cypress/specs/Input.cy.tsx +230 -1
  5. package/cypress/specs/Popover.cy.tsx +242 -0
  6. package/cypress/specs/Select.cy.tsx +15 -0
  7. package/cypress/specs/Table.cy.tsx +86 -83
  8. package/cypress/specs/TableNavigation.cy.tsx +223 -0
  9. package/cypress/specs/TableNavigationFixedHeader.cy.tsx +199 -0
  10. package/cypress/specs/TableSelection.cy.tsx +280 -0
  11. package/cypress/specs/TableSelections.cy.tsx +296 -0
  12. package/cypress/specs/Text.cy.tsx +19 -3
  13. package/cypress/specs/Tokenizer.cy.tsx +36 -0
  14. package/cypress/specs/base/Events.cy.tsx +4 -5
  15. package/dist/.tsbuildinfo +1 -1
  16. package/dist/Avatar.d.ts +4 -1
  17. package/dist/Avatar.js.map +1 -1
  18. package/dist/AvatarTemplate.js +1 -1
  19. package/dist/AvatarTemplate.js.map +1 -1
  20. package/dist/ComboBoxItemGroupTemplate.js +2 -2
  21. package/dist/ComboBoxItemGroupTemplate.js.map +1 -1
  22. package/dist/ExpandableText.d.ts +0 -1
  23. package/dist/ExpandableText.js +0 -7
  24. package/dist/ExpandableText.js.map +1 -1
  25. package/dist/ExpandableTextTemplate.js +1 -1
  26. package/dist/ExpandableTextTemplate.js.map +1 -1
  27. package/dist/Input.d.ts +1 -1
  28. package/dist/Input.js +11 -8
  29. package/dist/Input.js.map +1 -1
  30. package/dist/InputPopoverTemplate.d.ts +4 -1
  31. package/dist/InputPopoverTemplate.js +3 -2
  32. package/dist/InputPopoverTemplate.js.map +1 -1
  33. package/dist/InputTemplate.d.ts +3 -1
  34. package/dist/InputTemplate.js +2 -1
  35. package/dist/InputTemplate.js.map +1 -1
  36. package/dist/List.d.ts +5 -2
  37. package/dist/List.js +24 -2
  38. package/dist/List.js.map +1 -1
  39. package/dist/ListBoxItemGroupTemplate.d.ts +4 -0
  40. package/dist/ListBoxItemGroupTemplate.js +13 -0
  41. package/dist/ListBoxItemGroupTemplate.js.map +1 -0
  42. package/dist/ListItemGroupHeader.d.ts +6 -0
  43. package/dist/ListItemGroupHeader.js +20 -3
  44. package/dist/ListItemGroupHeader.js.map +1 -1
  45. package/dist/ListItemGroupHeaderTemplate.js +3 -3
  46. package/dist/ListItemGroupHeaderTemplate.js.map +1 -1
  47. package/dist/ListItemGroupTemplate.d.ts +1 -3
  48. package/dist/ListItemGroupTemplate.js +5 -8
  49. package/dist/ListItemGroupTemplate.js.map +1 -1
  50. package/dist/ListTemplate.js +2 -2
  51. package/dist/ListTemplate.js.map +1 -1
  52. package/dist/MultiComboBoxItemGroupTemplate.js +2 -2
  53. package/dist/MultiComboBoxItemGroupTemplate.js.map +1 -1
  54. package/dist/Popover.d.ts +0 -6
  55. package/dist/Popover.js +8 -14
  56. package/dist/Popover.js.map +1 -1
  57. package/dist/Popup.js +3 -1
  58. package/dist/Popup.js.map +1 -1
  59. package/dist/Select.d.ts +7 -0
  60. package/dist/Select.js +4 -3
  61. package/dist/Select.js.map +1 -1
  62. package/dist/SelectTemplate.js +2 -2
  63. package/dist/SelectTemplate.js.map +1 -1
  64. package/dist/SuggestionItemGroup.js +2 -0
  65. package/dist/SuggestionItemGroup.js.map +1 -1
  66. package/dist/Table.d.ts +13 -7
  67. package/dist/Table.js +26 -28
  68. package/dist/Table.js.map +1 -1
  69. package/dist/TableCellBase.d.ts +1 -0
  70. package/dist/TableCellBase.js +4 -0
  71. package/dist/TableCellBase.js.map +1 -1
  72. package/dist/TableHeaderCell.d.ts +11 -0
  73. package/dist/TableHeaderCell.js +14 -0
  74. package/dist/TableHeaderCell.js.map +1 -1
  75. package/dist/TableHeaderCellActionAI.d.ts +1 -0
  76. package/dist/TableHeaderCellActionAI.js +1 -0
  77. package/dist/TableHeaderCellActionAI.js.map +1 -1
  78. package/dist/TableHeaderRow.d.ts +0 -1
  79. package/dist/TableHeaderRow.js +1 -4
  80. package/dist/TableHeaderRow.js.map +1 -1
  81. package/dist/TableRow.d.ts +5 -3
  82. package/dist/TableRow.js +2 -9
  83. package/dist/TableRow.js.map +1 -1
  84. package/dist/TableRowAction.d.ts +10 -8
  85. package/dist/TableRowAction.js +10 -11
  86. package/dist/TableRowAction.js.map +1 -1
  87. package/dist/TableRowActionNavigation.d.ts +1 -0
  88. package/dist/TableRowActionNavigation.js +1 -0
  89. package/dist/TableRowActionNavigation.js.map +1 -1
  90. package/dist/TableRowBase.d.ts +2 -2
  91. package/dist/TableRowBase.js +9 -7
  92. package/dist/TableRowBase.js.map +1 -1
  93. package/dist/TableSelection.d.ts +9 -7
  94. package/dist/TableSelection.js +34 -30
  95. package/dist/TableSelection.js.map +1 -1
  96. package/dist/TableSelectionBase.d.ts +79 -0
  97. package/dist/TableSelectionBase.js +108 -0
  98. package/dist/TableSelectionBase.js.map +1 -0
  99. package/dist/TableSelectionMulti.d.ts +92 -0
  100. package/dist/TableSelectionMulti.js +260 -0
  101. package/dist/TableSelectionMulti.js.map +1 -0
  102. package/dist/TableSelectionSingle.d.ts +49 -0
  103. package/dist/TableSelectionSingle.js +67 -0
  104. package/dist/TableSelectionSingle.js.map +1 -0
  105. package/dist/Tokenizer.js +2 -2
  106. package/dist/Tokenizer.js.map +1 -1
  107. package/dist/bundle.esm.js +2 -0
  108. package/dist/bundle.esm.js.map +1 -1
  109. package/dist/css/themes/Avatar.css +1 -1
  110. package/dist/css/themes/AvatarGroup.css +1 -1
  111. package/dist/css/themes/Bar.css +1 -1
  112. package/dist/css/themes/Breadcrumbs.css +1 -1
  113. package/dist/css/themes/BusyIndicator.css +1 -1
  114. package/dist/css/themes/Button.css +1 -1
  115. package/dist/css/themes/ButtonBadge.css +1 -1
  116. package/dist/css/themes/Calendar.css +1 -1
  117. package/dist/css/themes/CalendarHeader.css +1 -1
  118. package/dist/css/themes/CalendarLegend.css +1 -1
  119. package/dist/css/themes/CalendarLegendItem.css +1 -1
  120. package/dist/css/themes/Card.css +1 -1
  121. package/dist/css/themes/CardHeader.css +1 -1
  122. package/dist/css/themes/Carousel.css +1 -1
  123. package/dist/css/themes/CheckBox.css +1 -1
  124. package/dist/css/themes/ColorPalette.css +1 -1
  125. package/dist/css/themes/ColorPaletteItem.css +1 -1
  126. package/dist/css/themes/ColorPalettePopover.css +1 -1
  127. package/dist/css/themes/ColorPicker.css +1 -1
  128. package/dist/css/themes/ComboBox.css +1 -1
  129. package/dist/css/themes/ComboBoxItem.css +1 -1
  130. package/dist/css/themes/DatePicker.css +1 -1
  131. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  132. package/dist/css/themes/DayPicker.css +1 -1
  133. package/dist/css/themes/Dialog.css +1 -1
  134. package/dist/css/themes/FileUploader.css +1 -1
  135. package/dist/css/themes/Form.css +1 -1
  136. package/dist/css/themes/FormItem.css +1 -1
  137. package/dist/css/themes/FormItemSpan.css +1 -1
  138. package/dist/css/themes/GrowingButton.css +1 -1
  139. package/dist/css/themes/Icon.css +1 -1
  140. package/dist/css/themes/Input.css +1 -1
  141. package/dist/css/themes/InputIcon.css +1 -1
  142. package/dist/css/themes/InputSharedStyles.css +1 -1
  143. package/dist/css/themes/Link.css +1 -1
  144. package/dist/css/themes/List.css +1 -1
  145. package/dist/css/themes/ListItem.css +1 -1
  146. package/dist/css/themes/ListItemBase.css +1 -1
  147. package/dist/css/themes/ListItemCustom.css +1 -1
  148. package/dist/css/themes/ListItemGroup.css +1 -1
  149. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  150. package/dist/css/themes/ListItemIcon.css +1 -1
  151. package/dist/css/themes/Menu.css +1 -1
  152. package/dist/css/themes/MenuItem.css +1 -1
  153. package/dist/css/themes/MessageStrip.css +1 -1
  154. package/dist/css/themes/MonthPicker.css +1 -1
  155. package/dist/css/themes/MultiComboBox.css +1 -1
  156. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  157. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  158. package/dist/css/themes/MultiInput.css +1 -1
  159. package/dist/css/themes/OptionBase.css +1 -1
  160. package/dist/css/themes/Panel.css +1 -1
  161. package/dist/css/themes/Popover.css +1 -1
  162. package/dist/css/themes/PopupsCommon.css +1 -1
  163. package/dist/css/themes/ProgressIndicator.css +1 -1
  164. package/dist/css/themes/RadioButton.css +1 -1
  165. package/dist/css/themes/RangeSlider.css +1 -1
  166. package/dist/css/themes/RatingIndicator.css +1 -1
  167. package/dist/css/themes/ResponsivePopover.css +1 -1
  168. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  169. package/dist/css/themes/SegmentedButton.css +1 -1
  170. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  171. package/dist/css/themes/Select.css +1 -1
  172. package/dist/css/themes/SliderBase.css +1 -1
  173. package/dist/css/themes/SplitButton.css +1 -1
  174. package/dist/css/themes/StepInput.css +1 -1
  175. package/dist/css/themes/SuggestionItem.css +1 -1
  176. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  177. package/dist/css/themes/Switch.css +1 -1
  178. package/dist/css/themes/TabContainer.css +1 -1
  179. package/dist/css/themes/TabInOverflow.css +1 -1
  180. package/dist/css/themes/TabInStrip.css +1 -1
  181. package/dist/css/themes/TabSemanticIcon.css +1 -1
  182. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  183. package/dist/css/themes/Table.css +1 -1
  184. package/dist/css/themes/TableCellBase.css +1 -1
  185. package/dist/css/themes/TableHeaderRow.css +1 -1
  186. package/dist/css/themes/TableRow.css +1 -1
  187. package/dist/css/themes/TableRowActionBase.css +1 -1
  188. package/dist/css/themes/TableRowBase.css +1 -1
  189. package/dist/css/themes/Tag.css +1 -1
  190. package/dist/css/themes/Text.css +1 -1
  191. package/dist/css/themes/TextArea.css +1 -1
  192. package/dist/css/themes/TimePicker.css +1 -1
  193. package/dist/css/themes/Toast.css +1 -1
  194. package/dist/css/themes/ToggleButton.css +1 -1
  195. package/dist/css/themes/Token.css +1 -1
  196. package/dist/css/themes/Tokenizer.css +1 -1
  197. package/dist/css/themes/TokenizerPopover.css +1 -1
  198. package/dist/css/themes/Toolbar.css +1 -1
  199. package/dist/css/themes/ToolbarPopover.css +1 -1
  200. package/dist/css/themes/TreeItem.css +1 -1
  201. package/dist/css/themes/ValueStateMessage.css +1 -1
  202. package/dist/css/themes/YearPicker.css +1 -1
  203. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  204. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  205. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  206. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  207. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  208. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  209. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  210. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  211. package/dist/custom-elements-internal.json +772 -34
  212. package/dist/custom-elements.json +725 -31
  213. package/dist/features/InputSuggestions.js +0 -2
  214. package/dist/features/InputSuggestions.js.map +1 -1
  215. package/dist/features/InputSuggestionsTemplate.d.ts +5 -1
  216. package/dist/features/InputSuggestionsTemplate.js +9 -5
  217. package/dist/features/InputSuggestionsTemplate.js.map +1 -1
  218. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  219. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  220. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  221. package/dist/generated/assets/i18n/messagebundle_cnr.json +1 -1
  222. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  223. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -1
  224. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  225. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  226. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  227. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  228. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -1
  229. package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -1
  230. package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -1
  231. package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -1
  232. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  233. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -1
  234. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  235. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  236. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  237. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -1
  238. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  239. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  240. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  241. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  242. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  243. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  244. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  245. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  246. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  247. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  248. package/dist/generated/assets/i18n/messagebundle_mk.json +1 -1
  249. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  250. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  251. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  252. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  253. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  254. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -1
  255. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  256. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  257. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  258. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  259. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  260. package/dist/generated/assets/i18n/messagebundle_sr.json +1 -1
  261. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  262. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  263. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  264. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  265. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  266. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  267. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  268. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  269. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  270. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  271. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  272. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  273. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  274. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  275. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  276. package/dist/generated/i18n/i18n-defaults.d.ts +3 -1
  277. package/dist/generated/i18n/i18n-defaults.js +3 -1
  278. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  279. package/dist/generated/templates/TableHeaderRowTemplate.lit.js +1 -1
  280. package/dist/generated/templates/TableHeaderRowTemplate.lit.js.map +1 -1
  281. package/dist/generated/templates/TableRowTemplate.lit.js +2 -2
  282. package/dist/generated/templates/TableRowTemplate.lit.js.map +1 -1
  283. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  284. package/dist/generated/themes/Avatar.css.js +1 -1
  285. package/dist/generated/themes/Avatar.css.js.map +1 -1
  286. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  287. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  288. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  289. package/dist/generated/themes/Bar.css.d.ts +1 -1
  290. package/dist/generated/themes/Bar.css.js +1 -1
  291. package/dist/generated/themes/Bar.css.js.map +1 -1
  292. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  293. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  294. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  295. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  296. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  297. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  298. package/dist/generated/themes/Button.css.d.ts +1 -1
  299. package/dist/generated/themes/Button.css.js +1 -1
  300. package/dist/generated/themes/Button.css.js.map +1 -1
  301. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  302. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  303. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  304. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  305. package/dist/generated/themes/Calendar.css.js +1 -1
  306. package/dist/generated/themes/Calendar.css.js.map +1 -1
  307. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  308. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  309. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  310. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  311. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  312. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  313. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  314. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  315. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  316. package/dist/generated/themes/Card.css.d.ts +1 -1
  317. package/dist/generated/themes/Card.css.js +1 -1
  318. package/dist/generated/themes/Card.css.js.map +1 -1
  319. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  320. package/dist/generated/themes/CardHeader.css.js +1 -1
  321. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  322. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  323. package/dist/generated/themes/Carousel.css.js +1 -1
  324. package/dist/generated/themes/Carousel.css.js.map +1 -1
  325. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  326. package/dist/generated/themes/CheckBox.css.js +1 -1
  327. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  328. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  329. package/dist/generated/themes/ColorPalette.css.js +1 -1
  330. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  331. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  332. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  333. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  334. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  335. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  336. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  337. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  338. package/dist/generated/themes/ColorPicker.css.js +1 -1
  339. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  340. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  341. package/dist/generated/themes/ComboBox.css.js +1 -1
  342. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  343. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  344. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  345. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  346. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  347. package/dist/generated/themes/DatePicker.css.js +1 -1
  348. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  349. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  350. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  351. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  352. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  353. package/dist/generated/themes/DayPicker.css.js +1 -1
  354. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  355. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  356. package/dist/generated/themes/Dialog.css.js +1 -1
  357. package/dist/generated/themes/Dialog.css.js.map +1 -1
  358. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  359. package/dist/generated/themes/FileUploader.css.js +1 -1
  360. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  361. package/dist/generated/themes/Form.css.d.ts +1 -1
  362. package/dist/generated/themes/Form.css.js +1 -1
  363. package/dist/generated/themes/Form.css.js.map +1 -1
  364. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  365. package/dist/generated/themes/FormItem.css.js +1 -1
  366. package/dist/generated/themes/FormItem.css.js.map +1 -1
  367. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  368. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  369. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  370. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  371. package/dist/generated/themes/GrowingButton.css.js +1 -1
  372. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  373. package/dist/generated/themes/Icon.css.d.ts +1 -1
  374. package/dist/generated/themes/Icon.css.js +1 -1
  375. package/dist/generated/themes/Icon.css.js.map +1 -1
  376. package/dist/generated/themes/Input.css.d.ts +1 -1
  377. package/dist/generated/themes/Input.css.js +1 -1
  378. package/dist/generated/themes/Input.css.js.map +1 -1
  379. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  380. package/dist/generated/themes/InputIcon.css.js +1 -1
  381. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  382. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  383. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  384. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  385. package/dist/generated/themes/Link.css.d.ts +1 -1
  386. package/dist/generated/themes/Link.css.js +1 -1
  387. package/dist/generated/themes/Link.css.js.map +1 -1
  388. package/dist/generated/themes/List.css.d.ts +1 -1
  389. package/dist/generated/themes/List.css.js +1 -1
  390. package/dist/generated/themes/List.css.js.map +1 -1
  391. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  392. package/dist/generated/themes/ListItem.css.js +1 -1
  393. package/dist/generated/themes/ListItem.css.js.map +1 -1
  394. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  395. package/dist/generated/themes/ListItemBase.css.js +1 -1
  396. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  397. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  398. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  399. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  400. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  401. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  402. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  403. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  404. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  405. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  406. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  407. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  408. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  409. package/dist/generated/themes/Menu.css.d.ts +1 -1
  410. package/dist/generated/themes/Menu.css.js +1 -1
  411. package/dist/generated/themes/Menu.css.js.map +1 -1
  412. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  413. package/dist/generated/themes/MenuItem.css.js +1 -1
  414. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  415. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  416. package/dist/generated/themes/MessageStrip.css.js +1 -1
  417. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  418. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  419. package/dist/generated/themes/MonthPicker.css.js +1 -1
  420. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  421. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  422. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  423. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  424. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  425. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  426. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  427. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  428. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  429. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  430. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  431. package/dist/generated/themes/MultiInput.css.js +1 -1
  432. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  433. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  434. package/dist/generated/themes/OptionBase.css.js +1 -1
  435. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  436. package/dist/generated/themes/Panel.css.d.ts +1 -1
  437. package/dist/generated/themes/Panel.css.js +1 -1
  438. package/dist/generated/themes/Panel.css.js.map +1 -1
  439. package/dist/generated/themes/Popover.css.d.ts +1 -1
  440. package/dist/generated/themes/Popover.css.js +1 -1
  441. package/dist/generated/themes/Popover.css.js.map +1 -1
  442. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  443. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  444. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  445. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  446. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  447. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  448. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  449. package/dist/generated/themes/RadioButton.css.js +1 -1
  450. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  451. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  452. package/dist/generated/themes/RangeSlider.css.js +1 -1
  453. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  454. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  455. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  456. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  457. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  458. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  459. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  460. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  461. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  462. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  463. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  464. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  465. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  466. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  467. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  468. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  469. package/dist/generated/themes/Select.css.d.ts +1 -1
  470. package/dist/generated/themes/Select.css.js +1 -1
  471. package/dist/generated/themes/Select.css.js.map +1 -1
  472. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  473. package/dist/generated/themes/SliderBase.css.js +1 -1
  474. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  475. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  476. package/dist/generated/themes/SplitButton.css.js +1 -1
  477. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  478. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  479. package/dist/generated/themes/StepInput.css.js +1 -1
  480. package/dist/generated/themes/StepInput.css.js.map +1 -1
  481. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  482. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  483. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  484. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  485. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  486. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  487. package/dist/generated/themes/Switch.css.d.ts +1 -1
  488. package/dist/generated/themes/Switch.css.js +1 -1
  489. package/dist/generated/themes/Switch.css.js.map +1 -1
  490. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  491. package/dist/generated/themes/TabContainer.css.js +1 -1
  492. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  493. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  494. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  495. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  496. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  497. package/dist/generated/themes/TabInStrip.css.js +1 -1
  498. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  499. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  500. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  501. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  502. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  503. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  504. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  505. package/dist/generated/themes/Table.css.d.ts +1 -1
  506. package/dist/generated/themes/Table.css.js +1 -1
  507. package/dist/generated/themes/Table.css.js.map +1 -1
  508. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  509. package/dist/generated/themes/TableCellBase.css.js +1 -1
  510. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  511. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  512. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  513. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  514. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  515. package/dist/generated/themes/TableRow.css.js +1 -1
  516. package/dist/generated/themes/TableRow.css.js.map +1 -1
  517. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  518. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  519. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  520. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  521. package/dist/generated/themes/TableRowBase.css.js +1 -1
  522. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  523. package/dist/generated/themes/Tag.css.d.ts +1 -1
  524. package/dist/generated/themes/Tag.css.js +1 -1
  525. package/dist/generated/themes/Tag.css.js.map +1 -1
  526. package/dist/generated/themes/Text.css.d.ts +1 -1
  527. package/dist/generated/themes/Text.css.js +1 -1
  528. package/dist/generated/themes/Text.css.js.map +1 -1
  529. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  530. package/dist/generated/themes/TextArea.css.js +1 -1
  531. package/dist/generated/themes/TextArea.css.js.map +1 -1
  532. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  533. package/dist/generated/themes/TimePicker.css.js +1 -1
  534. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  535. package/dist/generated/themes/Toast.css.d.ts +1 -1
  536. package/dist/generated/themes/Toast.css.js +1 -1
  537. package/dist/generated/themes/Toast.css.js.map +1 -1
  538. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  539. package/dist/generated/themes/ToggleButton.css.js +1 -1
  540. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  541. package/dist/generated/themes/Token.css.d.ts +1 -1
  542. package/dist/generated/themes/Token.css.js +1 -1
  543. package/dist/generated/themes/Token.css.js.map +1 -1
  544. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  545. package/dist/generated/themes/Tokenizer.css.js +1 -1
  546. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  547. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  548. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  549. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  550. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  551. package/dist/generated/themes/Toolbar.css.js +1 -1
  552. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  553. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  554. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  555. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  556. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  557. package/dist/generated/themes/TreeItem.css.js +1 -1
  558. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  559. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  560. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  561. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  562. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  563. package/dist/generated/themes/YearPicker.css.js +1 -1
  564. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  565. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  566. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  567. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  568. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  569. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  570. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  571. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  572. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  573. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  574. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  575. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  576. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  577. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  578. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  579. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  580. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  581. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  582. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  583. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  584. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  585. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  586. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  587. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  588. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  589. package/dist/types/ListItemAccessibleRole.d.ts +5 -0
  590. package/dist/types/ListItemAccessibleRole.js +5 -0
  591. package/dist/types/ListItemAccessibleRole.js.map +1 -1
  592. package/dist/types/TableCellHorizontalAlign.d.ts +1 -0
  593. package/dist/types/TableCellHorizontalAlign.js +1 -0
  594. package/dist/types/TableCellHorizontalAlign.js.map +1 -1
  595. package/dist/types/TableGrowingMode.d.ts +1 -0
  596. package/dist/types/TableGrowingMode.js +1 -0
  597. package/dist/types/TableGrowingMode.js.map +1 -1
  598. package/dist/types/TableOverflowMode.d.ts +1 -0
  599. package/dist/types/TableOverflowMode.js +1 -0
  600. package/dist/types/TableOverflowMode.js.map +1 -1
  601. package/dist/types/TableSelectionMode.d.ts +2 -0
  602. package/dist/types/TableSelectionMode.js +2 -0
  603. package/dist/types/TableSelectionMode.js.map +1 -1
  604. package/dist/vscode.html-custom-data.json +51 -10
  605. package/dist/web-types.json +99 -23
  606. package/package.json +10 -10
  607. package/src/AvatarTemplate.tsx +1 -1
  608. package/src/ComboBoxItemGroupTemplate.tsx +2 -2
  609. package/src/ExpandableTextTemplate.tsx +0 -1
  610. package/src/InputPopoverTemplate.tsx +5 -2
  611. package/src/InputTemplate.tsx +5 -3
  612. package/src/ListBoxItemGroupTemplate.tsx +33 -0
  613. package/src/ListItemGroupHeaderTemplate.tsx +5 -3
  614. package/src/ListItemGroupTemplate.tsx +21 -19
  615. package/src/ListTemplate.tsx +2 -1
  616. package/src/MultiComboBoxItemGroupTemplate.tsx +2 -2
  617. package/src/SelectTemplate.tsx +2 -0
  618. package/src/TableHeaderRow.hbs +1 -1
  619. package/src/TableRow.hbs +2 -2
  620. package/src/features/InputSuggestionsTemplate.tsx +12 -6
  621. package/src/i18n/messagebundle.properties +6 -0
  622. package/src/i18n/messagebundle_ar.properties +2 -0
  623. package/src/i18n/messagebundle_bg.properties +2 -0
  624. package/src/i18n/messagebundle_ca.properties +2 -0
  625. package/src/i18n/messagebundle_cnr.properties +2 -0
  626. package/src/i18n/messagebundle_cs.properties +2 -0
  627. package/src/i18n/messagebundle_cy.properties +2 -0
  628. package/src/i18n/messagebundle_da.properties +2 -0
  629. package/src/i18n/messagebundle_de.properties +2 -0
  630. package/src/i18n/messagebundle_el.properties +2 -0
  631. package/src/i18n/messagebundle_en.properties +2 -0
  632. package/src/i18n/messagebundle_en_GB.properties +2 -0
  633. package/src/i18n/messagebundle_en_US_sappsd.properties +2 -0
  634. package/src/i18n/messagebundle_en_US_saprigi.properties +2 -0
  635. package/src/i18n/messagebundle_en_US_saptrc.properties +2 -0
  636. package/src/i18n/messagebundle_es.properties +2 -0
  637. package/src/i18n/messagebundle_es_MX.properties +2 -0
  638. package/src/i18n/messagebundle_et.properties +2 -0
  639. package/src/i18n/messagebundle_fi.properties +2 -0
  640. package/src/i18n/messagebundle_fr.properties +2 -0
  641. package/src/i18n/messagebundle_fr_CA.properties +2 -0
  642. package/src/i18n/messagebundle_hi.properties +2 -0
  643. package/src/i18n/messagebundle_hr.properties +2 -0
  644. package/src/i18n/messagebundle_hu.properties +2 -0
  645. package/src/i18n/messagebundle_id.properties +2 -0
  646. package/src/i18n/messagebundle_it.properties +2 -0
  647. package/src/i18n/messagebundle_iw.properties +2 -0
  648. package/src/i18n/messagebundle_ja.properties +2 -0
  649. package/src/i18n/messagebundle_kk.properties +2 -0
  650. package/src/i18n/messagebundle_ko.properties +2 -0
  651. package/src/i18n/messagebundle_lt.properties +2 -0
  652. package/src/i18n/messagebundle_lv.properties +2 -0
  653. package/src/i18n/messagebundle_mk.properties +2 -0
  654. package/src/i18n/messagebundle_ms.properties +2 -0
  655. package/src/i18n/messagebundle_nl.properties +2 -0
  656. package/src/i18n/messagebundle_no.properties +2 -0
  657. package/src/i18n/messagebundle_pl.properties +2 -0
  658. package/src/i18n/messagebundle_pt.properties +2 -0
  659. package/src/i18n/messagebundle_pt_PT.properties +2 -0
  660. package/src/i18n/messagebundle_ro.properties +2 -0
  661. package/src/i18n/messagebundle_ru.properties +2 -0
  662. package/src/i18n/messagebundle_sh.properties +2 -0
  663. package/src/i18n/messagebundle_sk.properties +2 -0
  664. package/src/i18n/messagebundle_sl.properties +2 -0
  665. package/src/i18n/messagebundle_sr.properties +2 -0
  666. package/src/i18n/messagebundle_sv.properties +2 -0
  667. package/src/i18n/messagebundle_th.properties +2 -0
  668. package/src/i18n/messagebundle_tr.properties +2 -0
  669. package/src/i18n/messagebundle_uk.properties +2 -0
  670. package/src/i18n/messagebundle_vi.properties +2 -0
  671. package/src/i18n/messagebundle_zh_CN.properties +2 -0
  672. package/src/i18n/messagebundle_zh_TW.properties +2 -0
  673. package/src/themes/Avatar.css +51 -2
  674. package/src/themes/CheckBox.css +1 -1
  675. package/src/themes/List.css +1 -1
  676. package/src/themes/Menu.css +7 -0
  677. package/src/themes/PopupsCommon.css +7 -4
  678. package/src/themes/Tag.css +1 -6
  679. package/src/themes/Text.css +9 -5
  680. package/src/themes/Toast.css +1 -1
  681. package/src/themes/base/Avatar-parameters.css +1 -1
  682. package/src/themes/base/Toast-parameters.css +2 -2
  683. package/src/themes/sap_horizon/Avatar-parameters.css +3 -2
  684. package/src/themes/sap_horizon_dark/Avatar-parameters.css +2 -1
  685. package/src/themes/sap_horizon_hcb/Avatar-parameters.css +3 -2
  686. package/src/themes/sap_horizon_hcw/Avatar-parameters.css +3 -2
  687. package/dist/SuggestionItemGroupTemplate.d.ts +0 -2
  688. package/dist/SuggestionItemGroupTemplate.js +0 -5
  689. package/dist/SuggestionItemGroupTemplate.js.map +0 -1
  690. package/src/SuggestionItemGroupTemplate.tsx +0 -6
@@ -2,7 +2,7 @@ import Table from "../../src/Table.js";
2
2
  import TableHeaderRow from "../../src/TableHeaderRow.js";
3
3
  import TableCell from "../../src/TableCell.js";
4
4
  import TableRow from "../../src/TableRow.js";
5
- import TableSelection from "../../src/TableSelection.js";
5
+ import TableSelectionMulti from "../../src/TableSelectionMulti.js";
6
6
  import TableHeaderCell from "../../src/TableHeaderCell.js";
7
7
  import TableHeaderCellActionAI from "../../src/TableHeaderCellActionAI.js";
8
8
  import Label from "../../src/Label.js";
@@ -60,38 +60,64 @@ describe("Table - Rendering", () => {
60
60
  });
61
61
 
62
62
  describe("Table - Popin Mode", () => {
63
- beforeEach(() => {
63
+ function checkPopinState(expectedState: { poppedIn: string[], hidden: string[] }) {
64
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
65
+ const id = $cell.attr("id") ?? "";
66
+ const shouldBePoppedIn = expectedState.poppedIn.includes(id);
67
+ const shouldBeHidden = expectedState.hidden.includes(id);
68
+ const roleCondition = shouldBePoppedIn || shouldBeHidden ? "not.have.attr" : "have.attr";
69
+
70
+ cy.wrap($cell)
71
+ .should(roleCondition, "role", ROLE_COLUMN_HEADER);
72
+ cy.get("ui5-table-header-row")
73
+ .shadow()
74
+ .find(`slot[name=default-${index + 1}]`)
75
+ .should(shouldBePoppedIn || shouldBeHidden ? "not.exist" : "exist");
76
+ });
77
+
78
+ cy.get("ui5-table-row").each($row => {
79
+ cy.wrap($row).find("ui5-table-cell").each(($cell, index) => {
80
+ const id = $cell.attr("id") ?? "NOT_FOUND";
81
+ const shouldBeHidden = expectedState.hidden.some(hiddenId => id.includes(hiddenId));
82
+ cy.wrap($row).shadow().find(`slot[name=default-${index + 1}]`)
83
+ .should(shouldBeHidden ? "not.exist" : "exist");
84
+ });
85
+ });
86
+ }
87
+
88
+ function mounTable(popinHidden = false) {
64
89
  cy.mount(
65
90
  <Table id="table" overflowMode="Popin">
66
91
  <TableHeaderRow slot="headerRow">
67
92
  <TableHeaderCell id="colA" minWidth="300px"><span>ColumnA</span></TableHeaderCell>
68
93
  <TableHeaderCell id="colB" minWidth="200px">Column B</TableHeaderCell>
69
94
  <TableHeaderCell id="colC" minWidth="200px">Column C</TableHeaderCell>
70
- <TableHeaderCell id="colD" minWidth="150px" popinText="Column ?">Column D</TableHeaderCell>
95
+ <TableHeaderCell id="colD" minWidth="150px" popinText="Column ?" popinHidden={popinHidden}>Column D</TableHeaderCell>
71
96
  </TableHeaderRow>
72
97
  <TableRow>
73
- <TableCell><Label>Cell A</Label></TableCell>
74
- <TableCell><Label>Cell B</Label></TableCell>
75
- <TableCell><Label>Cell C</Label></TableCell>
76
- <TableCell><Label>Cell D</Label></TableCell>
98
+ <TableCell id="row-1-colA"><Label>Cell A</Label></TableCell>
99
+ <TableCell id="row-1-colB"><Label>Cell B</Label></TableCell>
100
+ <TableCell id="row-1-colC"><Label>Cell C</Label></TableCell>
101
+ <TableCell id="row-1-colD"><Label>Cell D</Label></TableCell>
77
102
  </TableRow>
78
103
  <TableRow>
79
- <TableCell><Label>Cell A</Label></TableCell>
80
- <TableCell><Label>Cell B</Label></TableCell>
81
- <TableCell><Label>Cell C</Label></TableCell>
82
- <TableCell><Label>Cell D</Label></TableCell>
104
+ <TableCell id="row-2-colA"><Label>Cell A</Label></TableCell>
105
+ <TableCell id="row-2-colB"><Label>Cell B</Label></TableCell>
106
+ <TableCell id="row-2-colC"><Label>Cell C</Label></TableCell>
107
+ <TableCell id="row-2-colD"><Label>Cell D</Label></TableCell>
83
108
  </TableRow>
84
109
  <TableRow>
85
- <TableCell><Label>Cell A</Label></TableCell>
86
- <TableCell><Label>Cell B</Label></TableCell>
87
- <TableCell><Label>Cell C</Label></TableCell>
88
- <TableCell><Label>Cell D</Label></TableCell>
110
+ <TableCell id="row-3-colA"><Label>Cell A</Label></TableCell>
111
+ <TableCell id="row-3-colB"><Label>Cell B</Label></TableCell>
112
+ <TableCell id="row-3-colC"><Label>Cell C</Label></TableCell>
113
+ <TableCell id="row-3-colD"><Label>Cell D</Label></TableCell>
89
114
  </TableRow>
90
115
  </Table>
91
116
  );
92
- });
117
+ }
93
118
 
94
119
  it("no pop-in width 'optimal' table width", () => {
120
+ mounTable();
95
121
  cy.get("ui5-table").then($table => {
96
122
  $table.css("width", "850px");
97
123
  });
@@ -103,17 +129,11 @@ describe("Table - Popin Mode", () => {
103
129
  cy.get("ui5-table-header-cell")
104
130
  .should("have.length", 4);
105
131
 
106
- cy.get("ui5-table-header-cell").each(($cell, index) => {
107
- cy.wrap($cell)
108
- .should("have.attr", "role", ROLE_COLUMN_HEADER);
109
- cy.get("ui5-table-header-row")
110
- .shadow()
111
- .find(`slot[name=default-${index + 1}]`)
112
- .should("exist");
113
- });
132
+ checkPopinState({ poppedIn: [], hidden: [] });
114
133
  });
115
134
 
116
135
  it("test with one by one popping in", () => {
136
+ mounTable();
117
137
  const testWidths = [
118
138
  { width: 850, poppedIn: [] },
119
139
  { width: 700, poppedIn: ["colD"] },
@@ -127,22 +147,12 @@ describe("Table - Popin Mode", () => {
127
147
  $table.css("width", `${width}px`);
128
148
  });
129
149
 
130
- cy.get("ui5-table-header-cell").each(($cell, index) => {
131
- const id = $cell.attr("id") ?? "";
132
- const shouldBePoppedIn = poppedIn.includes(id);
133
- const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
134
-
135
- cy.wrap($cell)
136
- .should(roleCondition, "role", ROLE_COLUMN_HEADER);
137
- cy.get("ui5-table-header-row")
138
- .shadow()
139
- .find(`slot[name=default-${index + 1}]`)
140
- .should(shouldBePoppedIn ? "not.exist" : "exist");
141
- });
150
+ checkPopinState({ poppedIn, hidden: [] });
142
151
  });
143
152
  });
144
153
 
145
154
  it("test with one by one popping out", () => {
155
+ mounTable();
146
156
  const testWidths = [
147
157
  { width: 150, poppedIn: ["colD", "colC", "colB"] },
148
158
  { width: 300, poppedIn: ["colD", "colC", "colB"] },
@@ -156,22 +166,12 @@ describe("Table - Popin Mode", () => {
156
166
  $table.css("width", `${width}px`);
157
167
  });
158
168
 
159
- cy.get("ui5-table-header-cell").each(($cell, index) => {
160
- const id = $cell.attr("id") ?? "";
161
- const shouldBePoppedIn = poppedIn.includes(id);
162
- const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
163
-
164
- cy.wrap($cell)
165
- .should(roleCondition, "role", ROLE_COLUMN_HEADER);
166
- cy.get("ui5-table-header-row")
167
- .shadow()
168
- .find(`slot[name=default-${index + 1}]`)
169
- .should(shouldBePoppedIn ? "not.exist" : "exist");
170
- });
169
+ checkPopinState({ poppedIn, hidden: [] });
171
170
  });
172
171
  });
173
172
 
174
173
  it("test with random widths", () => {
174
+ mounTable();
175
175
  const expectedStates = [
176
176
  { width: 500, poppedIn: ["colD", "colC", "colB"] },
177
177
  { width: 700, poppedIn: ["colD", "colC"] },
@@ -187,24 +187,12 @@ describe("Table - Popin Mode", () => {
187
187
  });
188
188
 
189
189
  const expectedState = expectedStates.find(state => state.width >= randomWidth);
190
- // eslint-disable-next-line cypress/no-unnecessary-waiting, no-loop-func
191
- cy.get("ui5-table-header-cell").each(($cell, index) => {
192
- const id = $cell.attr("id") ?? "";
193
- const shouldBePoppedIn = expectedState?.poppedIn.includes(id);
194
- const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
195
-
196
- cy.wrap($cell)
197
- .should(roleCondition, "role", ROLE_COLUMN_HEADER);
198
-
199
- cy.get("ui5-table-header-row")
200
- .shadow()
201
- .find(`slot[name=default-${index + 1}]`)
202
- .should(shouldBePoppedIn ? "not.exist" : "exist");
203
- });
190
+ checkPopinState({ poppedIn: expectedState?.poppedIn ?? [], hidden: [] });
204
191
  }
205
192
  });
206
193
 
207
194
  it("should show the popin-text in the popin area", () => {
195
+ mounTable();
208
196
  cy.get("ui5-table").then($table => {
209
197
  $table.css("width", "150px");
210
198
  });
@@ -232,6 +220,40 @@ describe("Table - Popin Mode", () => {
232
220
  return popinCellCount && popinCellCount === validPopinTextCount;
233
221
  }).should("be.true");
234
222
  });
223
+
224
+ it("should hide column in popin if popinHidden is set", () => {
225
+ mounTable(true);
226
+
227
+ const testWidths = [
228
+ { width: 150, poppedIn: ["colC", "colB"], hidden: ["colD"] },
229
+ { width: 300, poppedIn: ["colC", "colB"], hidden: ["colD"] },
230
+ { width: 500, poppedIn: ["colC"], hidden: ["colD"] },
231
+ { width: 700, poppedIn: [], hidden: ["colD"] },
232
+ { width: 850, poppedIn: [], hidden: [] },
233
+ ];
234
+
235
+ testWidths.forEach(({ width, poppedIn, hidden }) => {
236
+ cy.get("ui5-table").then($table => {
237
+ $table.css("width", `${width}px`);
238
+ });
239
+
240
+ checkPopinState({ poppedIn, hidden });
241
+ });
242
+ });
243
+
244
+ it("should hide popin if popinHidden, shows it if changed on runtime", () => {
245
+ mounTable(true);
246
+ cy.get("ui5-table").then($table => {
247
+ $table.css("width", "150px");
248
+ });
249
+
250
+ checkPopinState({ poppedIn: ["colC", "colB"], hidden: ["colD"] });
251
+
252
+ cy.get("#colD")
253
+ .invoke("removeAttr", "popin-hidden");
254
+
255
+ checkPopinState({ poppedIn: ["colC", "colB", "colD"], hidden: [] });
256
+ });
235
257
  });
236
258
 
237
259
  describe("Table - Horizontal alignment of cells", () => {
@@ -509,7 +531,7 @@ describe("Table - Horizontal Scrolling", () => {
509
531
  beforeEach(() => {
510
532
  cy.mount(
511
533
  <Table id="table" overflowMode="Scroll" stickyTop="0px" style={{ width: "300px", overflow: "auto" }} accessibleNameRef="title">
512
- <TableSelection id="selection" selected="0 2" slot="features"></TableSelection>
534
+ <TableSelectionMulti id="selection" selected="0 2" slot="features"></TableSelectionMulti>
513
535
  <TableHeaderRow slot="headerRow" sticky>
514
536
  <TableHeaderCell id="produtCol" width="200px"><span>Product</span></TableHeaderCell>
515
537
  <TableHeaderCell id="supplierCol" width="200px">Supplier</TableHeaderCell>
@@ -671,7 +693,7 @@ describe("Table - Interactive Rows", () => {
671
693
  it("fires the row-click event", () => {
672
694
  cy.mount(
673
695
  <Table id="table1">
674
- <TableSelection id="selection" selected="1 2" slot="features"></TableSelection>
696
+ <TableSelectionMulti id="selection" selected="1 2" slot="features"></TableSelectionMulti>
675
697
  <TableHeaderRow id="headerRow" slot="headerRow">
676
698
  <TableHeaderCell>ColumnA</TableHeaderCell>
677
699
  <TableHeaderCell>ColumnB</TableHeaderCell>
@@ -715,25 +737,6 @@ describe("Table - Interactive Rows", () => {
715
737
  cy.get("@row2button").realPress("Space");
716
738
  cy.get("@buttonClickHandler").should("have.been.calledThrice");
717
739
  cy.get("@rowClickHandler").should("have.been.calledThrice");
718
-
719
- // move the following tests to the TableSelection.cy.tsx
720
- cy.get("#headerRow").shadow().find("#selection-cell").as("headerRowSelectionCell");
721
- cy.get("@headerRowSelectionCell").find("#selection-component").as("headerRowCheckBox");
722
- cy.get("@headerRowCheckBox").should("have.attr", "checked");
723
- cy.get("#table1").then($table => {
724
- $table.append(
725
- `<ui5-table-row id="row3" row-key="3">
726
- <ui5-table-cell>Cell A</ui5-table-cell>
727
- <ui5-table-cell>Cell B</ui5-table-cell>
728
- </ui5-table-row>`
729
- );
730
- });
731
- cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
732
- cy.get("#row3").invoke("remove");
733
- cy.get("@headerRowCheckBox").should("have.attr", "checked");
734
- cy.get("#row2").invoke("remove");
735
- cy.get("#row1").invoke("remove");
736
- cy.get("@headerRowCheckBox").should("not.have.attr", "checked");
737
740
  });
738
741
  });
739
742
 
@@ -0,0 +1,223 @@
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 TableGrowing from "../../src/TableGrowing.js";
7
+
8
+ describe("Table - Keyboard Navigation", () => {
9
+ beforeEach(() => {
10
+ cy.mount(
11
+ <>
12
+ <input id="before-table1" type="Number" value="0"/>
13
+ <Table id="table0">
14
+ <TableGrowing id="growing" type="Button" slot="features"></TableGrowing>
15
+ <TableHeaderRow slot="headerRow">
16
+ <TableHeaderCell><a id="row0-link" href="test.html">Link</a></TableHeaderCell>
17
+ <TableHeaderCell>Header2</TableHeaderCell>
18
+ <TableHeaderCell>Header3</TableHeaderCell>
19
+ <TableHeaderCell>Header4</TableHeaderCell>
20
+ </TableHeaderRow>
21
+ <TableRow>
22
+ <TableCell>Row1Cell0</TableCell>
23
+ <TableCell><input id="row1-input"/></TableCell>
24
+ <TableCell><button id="row1-button">Button 1</button></TableCell>
25
+ <TableCell>Row1Cell3</TableCell>
26
+ </TableRow>
27
+ <TableRow id="interactive-row" interactive>
28
+ <TableCell>Row2Cell0</TableCell>
29
+ <TableCell><input id="row2-input"/></TableCell>
30
+ <TableCell><button id="row2-button">Button 2</button></TableCell>
31
+ <TableCell>Row2Cell3</TableCell>
32
+ </TableRow>
33
+ <TableRow id="notinteractive-row"> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
34
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
35
+ <TableRow> <TableCell> Here the table structure is broken. There is only one cell in row 5. </TableCell> </TableRow>
36
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
37
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
38
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
39
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
40
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
41
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
42
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
43
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
44
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
45
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
46
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
47
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
48
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
49
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
50
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
51
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
52
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
53
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
54
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
55
+ <TableRow> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> <TableCell></TableCell> </TableRow>
56
+ </Table>
57
+ <input id="after-table1"/>
58
+ </>
59
+ );
60
+
61
+ cy.document().then(doc => {
62
+ const table = doc.getElementById("table0");
63
+ const input = doc.getElementById("before-table1");
64
+ table?.addEventListener("ui5-row-click", () => {
65
+ if (input instanceof HTMLInputElement) {
66
+ input.valueAsNumber++;
67
+ }
68
+ });
69
+ });
70
+
71
+ cy.get("#table0").children("ui5-table-row").as("rows");
72
+ cy.get("#table0").children("ui5-table-header-row").as("headerRow");
73
+ });
74
+
75
+ function getCell(row: number, cell: number, headerRow: boolean) {
76
+ if (headerRow) {
77
+ return cy.get("@headerRow").children("ui5-table-header-cell").eq(cell);
78
+ }
79
+ return cy.get("@rows").eq(row)
80
+ .children("ui5-table-cell")
81
+ .eq(cell);
82
+ }
83
+
84
+ function performActions(actions: { element: Cypress.Chainable, click?: string, condition?: string, conditionValue?:string, type?: string, press?: string | string[] }[]) {
85
+ actions.forEach(action => {
86
+ if (action.click) {
87
+ // @ts-ignore
88
+ action.element.click(action.click);
89
+ }
90
+ if (action.condition) {
91
+ if (action.conditionValue) {
92
+ // timing issue - without wait the check is failing
93
+ action.element.wait(0).should(action.condition, action.conditionValue);
94
+ } else {
95
+ action.element.wait(0).should(action.condition);
96
+ }
97
+ }
98
+ if (action.type) {
99
+ action.element.type(action.type);
100
+ }
101
+ if (action.press) {
102
+ // @ts-ignore
103
+ action.element.realPress(action.press);
104
+ }
105
+ });
106
+ }
107
+
108
+ it("should navigate on rows", () => {
109
+ performActions([
110
+ // left click is needed to focus the row
111
+ // otherwise the it would click in the center of the row where an input is
112
+ // resulting in a focus on the input instead of the row
113
+ { element: cy.get("@rows").eq(0), click: "left" },
114
+ { element: cy.get("@rows").eq(0), type: "{leftarrow}", condition: "be.focused" },
115
+ { element: cy.get("@rows").eq(0), type: "{uparrow}", condition: "be.focused" },
116
+ { element: cy.get("@headerRow"), type: "{uparrow}", condition: "be.focused" },
117
+ { element: cy.get("@headerRow"), type: "{downarrow}{downarrow}", condition: "be.focused" },
118
+ { element: cy.get("@rows").eq(1), type: "{pagedown}", condition: "be.focused" },
119
+ { element: cy.get("@rows").eq(21), type: "{pagedown}", condition: "be.focused" },
120
+ { element: cy.get("@rows").eq(24), type: "{pagedown}", condition: "be.focused" },
121
+ { element: cy.get("#growing").shadow().find("#growing-button"), type: "{pageup}", condition: "be.focused" },
122
+ { element: cy.get("@rows").eq(5), type: "{pageup}", condition: "be.focused" },
123
+ { element: cy.get("@rows").eq(0), type: "{end}", condition: "be.focused" },
124
+ { element: cy.get("@rows").eq(24), type: "{end}", condition: "be.focused" },
125
+ { element: cy.get("#growing").shadow().find("#growing-button"), type: "{home}", condition: "be.focused" },
126
+ { element: cy.get("@rows").eq(0), type: "{home}", condition: "be.focused" },
127
+ { element: cy.get("@headerRow"), condition: "be.focused" }
128
+ ]);
129
+ });
130
+
131
+ it("should navigate on cells", () => {
132
+ performActions([
133
+ { element: cy.get("@rows").eq(0), click: "left" },
134
+ { element: cy.get("@rows").eq(0), type: "{rightarrow}", condition: "be.focused" },
135
+ { element: getCell(0, 0, false), type: "{leftarrow}", condition: "be.focused" },
136
+ { element: cy.get("@rows").eq(0), type: "{rightarrow}{rightarrow}", condition: "be.focused" },
137
+ { element: getCell(0, 1, false), type: "{home}", condition: "be.focused" },
138
+ { element: getCell(0, 0, false), type: "{end}", condition: "be.focused" },
139
+ { element: getCell(0, 3, false), type: "{rightarrow}", condition: "be.focused" },
140
+ { element: getCell(0, 3, false), type: "{end}", condition: "be.focused" },
141
+ { element: cy.get("@rows").eq(0), type: "{end}", condition: "be.focused" },
142
+ { element: cy.get("@rows").eq(24), type: "{rightarrow}{rightarrow}{rightarrow}", condition: "be.focused" },
143
+ { element: getCell(24, 2, false), type: "{pageup}", condition: "be.focused" },
144
+ { element: getCell(4, 0, false), type: "{pageup}", condition: "be.focused" },
145
+ { element: getCell(0, 0, false), type: "{pageup}", condition: "be.focused" },
146
+ { element: getCell(0, 0, true), type: "{pagedown}", condition: "be.focused" },
147
+ { element: getCell(19, 0, false), type: "{pagedown}", condition: "be.focused" },
148
+ { element: getCell(24, 0, false), type: "{pagedown}", condition: "be.focused" },
149
+ { element: cy.get("#growing").shadow().find("#growing-button"), type: "{home}", condition: "be.focused" },
150
+ { element: cy.get("@rows").eq(0), type: "{home}", condition: "be.focused" },
151
+ { element: cy.get("@headerRow"), type: "{downarrow}{rightarrow}", condition: "be.focused" },
152
+ { element: getCell(0, 0, false), type: "{downarrow}{rightarrow}", condition: "be.focused" },
153
+ { element: getCell(1, 1, false), type: "{downarrow}{rightarrow}", condition: "be.focused" },
154
+ { element: getCell(2, 2, false), type: "{downarrow}{rightarrow}", condition: "be.focused" },
155
+ { element: getCell(3, 3, false), type: "{downarrow}", condition: "be.focused" },
156
+ { element: getCell(4, 0, false), condition: "be.focused" }
157
+ ]);
158
+ });
159
+
160
+ it("should handle F2/F7/Enter/Tab/Up/Down", () => {
161
+ cy.get("@rows").eq(0).get("#row1-input").as("row1Input");
162
+ cy.get("@rows").eq(1).get("#row2-input").as("row2Input");
163
+
164
+ performActions([
165
+ { element: cy.get("@rows").eq(0), click: "left" },
166
+ { element: cy.get("@rows").eq(0), press: "F2", condition: "be.focused" },
167
+ { element: cy.get("@row1Input"), press: "F2", condition: "be.focused" },
168
+ { element: getCell(0, 1, false), press: "F2", condition: "be.focused" },
169
+ { element: cy.get("@row1Input"), press: "F7", condition: "be.focused" },
170
+ { element: cy.get("@rows").eq(0), press: "F7", condition: "be.focused" },
171
+ { element: cy.get("@row1Input").eq(0), type: "{downarrow}", condition: "be.focused" },
172
+ { element: cy.get("@row1Input").eq(0), type: "{uparrow}", condition: "be.focused" },
173
+ { element: cy.get("@row1Input").eq(0), press: ["F2", "{uparrow}"], condition: "be.focused" },
174
+ { element: getCell(0, 1, true), press: "F2", condition: "be.focused" },
175
+ { element: getCell(0, 1, true), type: "{leftarrow}", condition: "be.focused" },
176
+ { element: getCell(0, 0, true), type: "{enter}", condition: "be.focused" },
177
+ { element: cy.get("@headerRow").get("#row0-link"), type: "{downarrow}", condition: "be.focused" },
178
+ { element: getCell(0, 0, false), press: "Tab", condition: "be.focused" },
179
+ { element: cy.get("#after-table1"), press: ["Shift", "Tab"], condition: "be.focused" },
180
+ { element: cy.get("@rows").eq(0), type: "{downarrow}", condition: "be.focused" },
181
+ { element: cy.get("@rows").eq(1), press: "F7", condition: "be.focused" },
182
+ { element: cy.get("@row2Input").eq(0), press: "Tab", condition: "be.focused" },
183
+ { element: cy.get("@rows").eq(1).get("#row2-button"), press: "F7", condition: "be.focused" },
184
+ { element: cy.get("@rows").eq(1), type: "{uparrow}", condition: "be.focused" },
185
+ { element: cy.get("@rows").eq(0), press: "F7", condition: "be.focused" },
186
+ { element: cy.get("@rows").eq(0).get("#row1-button"), type: "{uparrow}", condition: "be.focused" },
187
+ { element: getCell(0, 2, true), press: "F7", condition: "be.focused" },
188
+ { element: cy.get("@headerRow"), type: "{downarrow}", condition: "be.focused" },
189
+ { element: cy.get("@rows").eq(0), press: "F7", condition: "be.focused" },
190
+ { element: getCell(0, 2, false), press: "F7", condition: "be.focused" },
191
+ { element: cy.get("@rows").eq(0), type: "{downarrow}", condition: "be.focused" },
192
+ { element: cy.get("@rows").eq(1), press: "F7", condition: "be.focused" },
193
+ { element: getCell(1, 2, false), press: ["Shift", "Tab"], condition: "be.focused" },
194
+ { element: cy.get("#before-table1"), press: "Tab", condition: "be.focused" },
195
+ { element: cy.get("@rows").eq(1), press: "Tab", condition: "be.focused" }
196
+ ]);
197
+ });
198
+
199
+ it("should should work correctly for interactive rows", () => {
200
+ cy.get("@rows").eq(1).get("#row2-button").as("row2Button");
201
+ cy.get("#table0").get("#before-table1").as("input");
202
+ cy.get("@rows").get("#interactive-row").as("row");
203
+
204
+ performActions([
205
+ { element: cy.get("@row"), click: "left" },
206
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "1" },
207
+ { element: cy.get("@row"), type: "{enter}" },
208
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "2" },
209
+ { element: cy.get("@rows").get("#notinteractive-row"), click: "left" },
210
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "2" },
211
+ { element: cy.get("@row2Button"), click: "left" },
212
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "2" },
213
+ { element: cy.get("@row2Button"), type: "{enter}" },
214
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "2" },
215
+ { element: cy.get("@row2Button"), press: "F7" },
216
+ { element: cy.get("@row"), condition: "be.focused" },
217
+ { element: cy.get("@row"), press: "Space" },
218
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "2" },
219
+ { element: cy.get("@row"), type: "{enter}" },
220
+ { element: cy.get("@input"), condition: "have.value", conditionValue: "3" }
221
+ ]);
222
+ });
223
+ });