@ui5/webcomponents 2.6.0-rc.4 → 2.6.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 (636) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/README.md +10 -4
  3. package/cypress/specs/F6.cy.ts +134 -0
  4. package/cypress/specs/List.cy.ts +1 -0
  5. package/cypress/specs/Table.cy.ts +606 -0
  6. package/cypress/specs/Toast.cy.ts +1 -0
  7. package/dist/.tsbuildinfo +1 -1
  8. package/dist/Avatar.d.ts +1 -1
  9. package/dist/Avatar.js +0 -2
  10. package/dist/Avatar.js.map +1 -1
  11. package/dist/AvatarGroup.d.ts +1 -1
  12. package/dist/AvatarGroup.js +0 -2
  13. package/dist/AvatarGroup.js.map +1 -1
  14. package/dist/Breadcrumbs.d.ts +5 -4
  15. package/dist/Breadcrumbs.js +1 -18
  16. package/dist/Breadcrumbs.js.map +1 -1
  17. package/dist/BusyIndicator.js +0 -2
  18. package/dist/BusyIndicator.js.map +1 -1
  19. package/dist/Button.js +0 -2
  20. package/dist/Button.js.map +1 -1
  21. package/dist/Calendar.d.ts +3 -2
  22. package/dist/Calendar.js +1 -16
  23. package/dist/Calendar.js.map +1 -1
  24. package/dist/CalendarLegend.d.ts +2 -1
  25. package/dist/CalendarLegend.js +1 -2
  26. package/dist/CalendarLegend.js.map +1 -1
  27. package/dist/Card.js +0 -3
  28. package/dist/Card.js.map +1 -1
  29. package/dist/Carousel.js +0 -6
  30. package/dist/Carousel.js.map +1 -1
  31. package/dist/CheckBox.js +0 -6
  32. package/dist/CheckBox.js.map +1 -1
  33. package/dist/ColorPalette.d.ts +2 -2
  34. package/dist/ColorPalette.js +1 -7
  35. package/dist/ColorPalette.js.map +1 -1
  36. package/dist/ColorPalettePopover.d.ts +2 -2
  37. package/dist/ColorPalettePopover.js +0 -10
  38. package/dist/ColorPalettePopover.js.map +1 -1
  39. package/dist/ColorPaletteTemplate.js +1 -2
  40. package/dist/ColorPaletteTemplate.js.map +1 -1
  41. package/dist/ColorPicker.js +0 -8
  42. package/dist/ColorPicker.js.map +1 -1
  43. package/dist/ComboBox.d.ts +6 -4
  44. package/dist/ComboBox.js +5 -28
  45. package/dist/ComboBox.js.map +1 -1
  46. package/dist/DatePicker.d.ts +3 -3
  47. package/dist/DatePicker.js +0 -14
  48. package/dist/DatePicker.js.map +1 -1
  49. package/dist/DateRangePicker.js +0 -2
  50. package/dist/DateRangePicker.js.map +1 -1
  51. package/dist/DateTimePicker.js +0 -15
  52. package/dist/DateTimePicker.js.map +1 -1
  53. package/dist/Dialog.js +0 -5
  54. package/dist/Dialog.js.map +1 -1
  55. package/dist/DropIndicator.js +0 -1
  56. package/dist/DropIndicator.js.map +1 -1
  57. package/dist/ExpandableText.d.ts +2 -2
  58. package/dist/ExpandableText.js +2 -12
  59. package/dist/ExpandableText.js.map +1 -1
  60. package/dist/FileUploader.d.ts +2 -2
  61. package/dist/FileUploader.js +0 -8
  62. package/dist/FileUploader.js.map +1 -1
  63. package/dist/Form.js +0 -2
  64. package/dist/Form.js.map +1 -1
  65. package/dist/Input.d.ts +2 -2
  66. package/dist/Input.js +1 -8
  67. package/dist/Input.js.map +1 -1
  68. package/dist/InputPopoverTemplate.d.ts +1 -1
  69. package/dist/InputPopoverTemplate.js +1 -18
  70. package/dist/InputPopoverTemplate.js.map +1 -1
  71. package/dist/Link.js +0 -2
  72. package/dist/Link.js.map +1 -1
  73. package/dist/List.d.ts +2 -2
  74. package/dist/List.js +1 -4
  75. package/dist/List.js.map +1 -1
  76. package/dist/ListItem.js +0 -8
  77. package/dist/ListItem.js.map +1 -1
  78. package/dist/ListItemGroup.d.ts +2 -2
  79. package/dist/ListItemGroup.js +0 -4
  80. package/dist/ListItemGroup.js.map +1 -1
  81. package/dist/ListItemStandard.js +0 -7
  82. package/dist/ListItemStandard.js.map +1 -1
  83. package/dist/Menu.d.ts +4 -2
  84. package/dist/Menu.js +2 -14
  85. package/dist/Menu.js.map +1 -1
  86. package/dist/MenuItem.d.ts +1 -1
  87. package/dist/MenuItem.js +0 -5
  88. package/dist/MenuItem.js.map +1 -1
  89. package/dist/MenuSeparator.js +0 -4
  90. package/dist/MenuSeparator.js.map +1 -1
  91. package/dist/MessageStrip.js +0 -3
  92. package/dist/MessageStrip.js.map +1 -1
  93. package/dist/MultiInput.d.ts +2 -2
  94. package/dist/MultiInput.js +1 -12
  95. package/dist/MultiInput.js.map +1 -1
  96. package/dist/Option.js +0 -4
  97. package/dist/Option.js.map +1 -1
  98. package/dist/Panel.js +0 -3
  99. package/dist/Panel.js.map +1 -1
  100. package/dist/Popup.js +0 -4
  101. package/dist/Popup.js.map +1 -1
  102. package/dist/ProgressIndicator.js +0 -2
  103. package/dist/ProgressIndicator.js.map +1 -1
  104. package/dist/RadioButton.js +0 -2
  105. package/dist/RadioButton.js.map +1 -1
  106. package/dist/RangeSlider.js +0 -3
  107. package/dist/RangeSlider.js.map +1 -1
  108. package/dist/RatingIndicator.js +0 -2
  109. package/dist/RatingIndicator.js.map +1 -1
  110. package/dist/ResponsivePopover.d.ts +1 -1
  111. package/dist/ResponsivePopover.js +0 -7
  112. package/dist/ResponsivePopover.js.map +1 -1
  113. package/dist/SegmentedButton.d.ts +2 -1
  114. package/dist/SegmentedButton.js +1 -2
  115. package/dist/SegmentedButton.js.map +1 -1
  116. package/dist/SegmentedButtonItem.js +0 -2
  117. package/dist/SegmentedButtonItem.js.map +1 -1
  118. package/dist/Slider.js +0 -3
  119. package/dist/Slider.js.map +1 -1
  120. package/dist/SplitButton.d.ts +1 -1
  121. package/dist/SplitButton.js +0 -2
  122. package/dist/SplitButton.js.map +1 -1
  123. package/dist/StepInput.d.ts +1 -1
  124. package/dist/StepInput.js +0 -6
  125. package/dist/StepInput.js.map +1 -1
  126. package/dist/Switch.js +0 -2
  127. package/dist/Switch.js.map +1 -1
  128. package/dist/Tab.d.ts +1 -1
  129. package/dist/Tab.js +0 -8
  130. package/dist/Tab.js.map +1 -1
  131. package/dist/TabContainer.d.ts +3 -3
  132. package/dist/TabContainer.js +0 -14
  133. package/dist/TabContainer.js.map +1 -1
  134. package/dist/TableRow.d.ts +2 -0
  135. package/dist/TableRow.js +2 -0
  136. package/dist/TableRow.js.map +1 -1
  137. package/dist/TableVirtualizer.d.ts +1 -0
  138. package/dist/TableVirtualizer.js +1 -0
  139. package/dist/TableVirtualizer.js.map +1 -1
  140. package/dist/Tag.js +0 -4
  141. package/dist/Tag.js.map +1 -1
  142. package/dist/TextArea.d.ts +1 -1
  143. package/dist/TextArea.js +0 -3
  144. package/dist/TextArea.js.map +1 -1
  145. package/dist/TimePicker.d.ts +3 -3
  146. package/dist/TimePicker.js +0 -16
  147. package/dist/TimePicker.js.map +1 -1
  148. package/dist/TimeSelectionClocks.d.ts +2 -2
  149. package/dist/TimeSelectionClocks.js +0 -10
  150. package/dist/TimeSelectionClocks.js.map +1 -1
  151. package/dist/TimeSelectionInputs.d.ts +1 -1
  152. package/dist/TimeSelectionInputs.js +0 -8
  153. package/dist/TimeSelectionInputs.js.map +1 -1
  154. package/dist/Token.js +0 -2
  155. package/dist/Token.js.map +1 -1
  156. package/dist/Tokenizer.d.ts +4 -2
  157. package/dist/Tokenizer.js +2 -14
  158. package/dist/Tokenizer.js.map +1 -1
  159. package/dist/Toolbar.d.ts +2 -3
  160. package/dist/Toolbar.js +1 -11
  161. package/dist/Toolbar.js.map +1 -1
  162. package/dist/ToolbarButton.js +0 -2
  163. package/dist/ToolbarButton.js.map +1 -1
  164. package/dist/ToolbarRegistry.d.ts +1 -2
  165. package/dist/ToolbarRegistry.js +1 -4
  166. package/dist/ToolbarRegistry.js.map +1 -1
  167. package/dist/ToolbarSelect.js +0 -3
  168. package/dist/ToolbarSelect.js.map +1 -1
  169. package/dist/Tree.d.ts +4 -2
  170. package/dist/Tree.js +2 -10
  171. package/dist/Tree.js.map +1 -1
  172. package/dist/TreeItemBase.js +0 -5
  173. package/dist/TreeItemBase.js.map +1 -1
  174. package/dist/bundle.esm.js +1 -0
  175. package/dist/bundle.esm.js.map +1 -1
  176. package/dist/css/themes/Avatar.css +1 -1
  177. package/dist/css/themes/AvatarGroup.css +1 -1
  178. package/dist/css/themes/Bar.css +1 -1
  179. package/dist/css/themes/Breadcrumbs.css +1 -1
  180. package/dist/css/themes/BusyIndicator.css +1 -1
  181. package/dist/css/themes/Button.css +1 -1
  182. package/dist/css/themes/Calendar.css +1 -1
  183. package/dist/css/themes/CalendarHeader.css +1 -1
  184. package/dist/css/themes/CalendarLegend.css +1 -1
  185. package/dist/css/themes/CalendarLegendItem.css +1 -1
  186. package/dist/css/themes/Card.css +1 -1
  187. package/dist/css/themes/CardHeader.css +1 -1
  188. package/dist/css/themes/Carousel.css +1 -1
  189. package/dist/css/themes/CheckBox.css +1 -1
  190. package/dist/css/themes/ColorPalette.css +1 -1
  191. package/dist/css/themes/ColorPaletteItem.css +1 -1
  192. package/dist/css/themes/ColorPalettePopover.css +1 -1
  193. package/dist/css/themes/ColorPicker.css +1 -1
  194. package/dist/css/themes/ComboBox.css +1 -1
  195. package/dist/css/themes/ComboBoxItem.css +1 -1
  196. package/dist/css/themes/DatePicker.css +1 -1
  197. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  198. package/dist/css/themes/DayPicker.css +1 -1
  199. package/dist/css/themes/Dialog.css +1 -1
  200. package/dist/css/themes/FileUploader.css +1 -1
  201. package/dist/css/themes/Form.css +1 -1
  202. package/dist/css/themes/FormItem.css +1 -1
  203. package/dist/css/themes/FormItemSpan.css +1 -1
  204. package/dist/css/themes/GrowingButton.css +1 -1
  205. package/dist/css/themes/Icon.css +1 -1
  206. package/dist/css/themes/Input.css +1 -1
  207. package/dist/css/themes/InputIcon.css +1 -1
  208. package/dist/css/themes/InputSharedStyles.css +1 -1
  209. package/dist/css/themes/Link.css +1 -1
  210. package/dist/css/themes/List.css +1 -1
  211. package/dist/css/themes/ListItem.css +1 -1
  212. package/dist/css/themes/ListItemBase.css +1 -1
  213. package/dist/css/themes/ListItemCustom.css +1 -1
  214. package/dist/css/themes/ListItemGroup.css +1 -1
  215. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  216. package/dist/css/themes/ListItemIcon.css +1 -1
  217. package/dist/css/themes/Menu.css +1 -1
  218. package/dist/css/themes/MenuItem.css +1 -1
  219. package/dist/css/themes/MessageStrip.css +1 -1
  220. package/dist/css/themes/MonthPicker.css +1 -1
  221. package/dist/css/themes/MultiComboBox.css +1 -1
  222. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  223. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  224. package/dist/css/themes/MultiInput.css +1 -1
  225. package/dist/css/themes/NavigationMenu.css +1 -1
  226. package/dist/css/themes/NavigationMenuItem.css +1 -1
  227. package/dist/css/themes/OptionBase.css +1 -1
  228. package/dist/css/themes/Panel.css +1 -1
  229. package/dist/css/themes/Popover.css +1 -1
  230. package/dist/css/themes/PopupsCommon.css +1 -1
  231. package/dist/css/themes/ProgressIndicator.css +1 -1
  232. package/dist/css/themes/RadioButton.css +1 -1
  233. package/dist/css/themes/RangeSlider.css +1 -1
  234. package/dist/css/themes/RatingIndicator.css +1 -1
  235. package/dist/css/themes/ResponsivePopover.css +1 -1
  236. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  237. package/dist/css/themes/SegmentedButton.css +1 -1
  238. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  239. package/dist/css/themes/Select.css +1 -1
  240. package/dist/css/themes/SliderBase.css +1 -1
  241. package/dist/css/themes/SplitButton.css +1 -1
  242. package/dist/css/themes/StepInput.css +1 -1
  243. package/dist/css/themes/SuggestionItem.css +1 -1
  244. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  245. package/dist/css/themes/Switch.css +1 -1
  246. package/dist/css/themes/TabContainer.css +1 -1
  247. package/dist/css/themes/TabInOverflow.css +1 -1
  248. package/dist/css/themes/TabInStrip.css +1 -1
  249. package/dist/css/themes/TabSemanticIcon.css +1 -1
  250. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  251. package/dist/css/themes/Table.css +1 -1
  252. package/dist/css/themes/TableCellBase.css +1 -1
  253. package/dist/css/themes/TableHeaderRow.css +1 -1
  254. package/dist/css/themes/TableRow.css +1 -1
  255. package/dist/css/themes/TableRowBase.css +1 -1
  256. package/dist/css/themes/Tag.css +1 -1
  257. package/dist/css/themes/Text.css +1 -1
  258. package/dist/css/themes/TextArea.css +1 -1
  259. package/dist/css/themes/TimePicker.css +1 -1
  260. package/dist/css/themes/Toast.css +1 -1
  261. package/dist/css/themes/ToggleButton.css +1 -1
  262. package/dist/css/themes/Token.css +1 -1
  263. package/dist/css/themes/Tokenizer.css +1 -1
  264. package/dist/css/themes/TokenizerPopover.css +1 -1
  265. package/dist/css/themes/Toolbar.css +1 -1
  266. package/dist/css/themes/ToolbarPopover.css +1 -1
  267. package/dist/css/themes/TreeItem.css +1 -1
  268. package/dist/css/themes/ValueStateMessage.css +1 -1
  269. package/dist/css/themes/YearPicker.css +1 -1
  270. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  271. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  272. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  273. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  274. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  275. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  276. package/dist/css/themes/sap_horizon_dark_exp/parameters-bundle.css +1 -1
  277. package/dist/css/themes/sap_horizon_exp/parameters-bundle.css +1 -1
  278. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  279. package/dist/css/themes/sap_horizon_hcb_exp/parameters-bundle.css +1 -1
  280. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  281. package/dist/css/themes/sap_horizon_hcw_exp/parameters-bundle.css +1 -1
  282. package/dist/custom-elements-internal.json +13 -8
  283. package/dist/custom-elements.json +3 -3
  284. package/dist/features/ColorPaletteMoreColors.d.ts +2 -4
  285. package/dist/features/ColorPaletteMoreColors.js +3 -9
  286. package/dist/features/ColorPaletteMoreColors.js.map +1 -1
  287. package/dist/features/ColorPaletteMoreColorsTemplate.d.ts +2 -0
  288. package/dist/features/ColorPaletteMoreColorsTemplate.js +8 -0
  289. package/dist/features/ColorPaletteMoreColorsTemplate.js.map +1 -0
  290. package/dist/features/InputSuggestions.d.ts +6 -6
  291. package/dist/features/InputSuggestions.js +6 -14
  292. package/dist/features/InputSuggestions.js.map +1 -1
  293. package/dist/features/InputSuggestionsTemplate.d.ts +3 -0
  294. package/dist/features/InputSuggestionsTemplate.js +22 -0
  295. package/dist/features/InputSuggestionsTemplate.js.map +1 -0
  296. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  297. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  298. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  299. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  300. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  301. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  302. package/dist/generated/assets/themes/sap_horizon_dark_exp/parameters-bundle.css.json +1 -1
  303. package/dist/generated/assets/themes/sap_horizon_exp/parameters-bundle.css.json +1 -1
  304. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  305. package/dist/generated/assets/themes/sap_horizon_hcb_exp/parameters-bundle.css.json +1 -1
  306. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  307. package/dist/generated/assets/themes/sap_horizon_hcw_exp/parameters-bundle.css.json +1 -1
  308. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  309. package/dist/generated/themes/Avatar.css.js +1 -1
  310. package/dist/generated/themes/Avatar.css.js.map +1 -1
  311. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  312. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  313. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  314. package/dist/generated/themes/Bar.css.d.ts +1 -1
  315. package/dist/generated/themes/Bar.css.js +1 -1
  316. package/dist/generated/themes/Bar.css.js.map +1 -1
  317. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  318. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  319. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  320. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  321. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  322. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  323. package/dist/generated/themes/Button.css.d.ts +1 -1
  324. package/dist/generated/themes/Button.css.js +1 -1
  325. package/dist/generated/themes/Button.css.js.map +1 -1
  326. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  327. package/dist/generated/themes/Calendar.css.js +1 -1
  328. package/dist/generated/themes/Calendar.css.js.map +1 -1
  329. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  330. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  331. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  332. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  333. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  334. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  335. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  336. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  337. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  338. package/dist/generated/themes/Card.css.d.ts +1 -1
  339. package/dist/generated/themes/Card.css.js +1 -1
  340. package/dist/generated/themes/Card.css.js.map +1 -1
  341. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  342. package/dist/generated/themes/CardHeader.css.js +1 -1
  343. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  344. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  345. package/dist/generated/themes/Carousel.css.js +1 -1
  346. package/dist/generated/themes/Carousel.css.js.map +1 -1
  347. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  348. package/dist/generated/themes/CheckBox.css.js +1 -1
  349. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  350. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  351. package/dist/generated/themes/ColorPalette.css.js +1 -1
  352. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  353. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  354. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  355. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  356. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  357. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  358. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  359. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  360. package/dist/generated/themes/ColorPicker.css.js +1 -1
  361. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  362. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  363. package/dist/generated/themes/ComboBox.css.js +1 -1
  364. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  365. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  366. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  367. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  368. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  369. package/dist/generated/themes/DatePicker.css.js +1 -1
  370. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  371. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  372. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  373. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  374. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  375. package/dist/generated/themes/DayPicker.css.js +1 -1
  376. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  377. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  378. package/dist/generated/themes/Dialog.css.js +1 -1
  379. package/dist/generated/themes/Dialog.css.js.map +1 -1
  380. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  381. package/dist/generated/themes/FileUploader.css.js +1 -1
  382. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  383. package/dist/generated/themes/Form.css.d.ts +1 -1
  384. package/dist/generated/themes/Form.css.js +1 -1
  385. package/dist/generated/themes/Form.css.js.map +1 -1
  386. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  387. package/dist/generated/themes/FormItem.css.js +1 -1
  388. package/dist/generated/themes/FormItem.css.js.map +1 -1
  389. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  390. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  391. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  392. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  393. package/dist/generated/themes/GrowingButton.css.js +1 -1
  394. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  395. package/dist/generated/themes/Icon.css.d.ts +1 -1
  396. package/dist/generated/themes/Icon.css.js +1 -1
  397. package/dist/generated/themes/Icon.css.js.map +1 -1
  398. package/dist/generated/themes/Input.css.d.ts +1 -1
  399. package/dist/generated/themes/Input.css.js +1 -1
  400. package/dist/generated/themes/Input.css.js.map +1 -1
  401. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  402. package/dist/generated/themes/InputIcon.css.js +1 -1
  403. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  404. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  405. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  406. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  407. package/dist/generated/themes/Link.css.d.ts +1 -1
  408. package/dist/generated/themes/Link.css.js +1 -1
  409. package/dist/generated/themes/Link.css.js.map +1 -1
  410. package/dist/generated/themes/List.css.d.ts +1 -1
  411. package/dist/generated/themes/List.css.js +1 -1
  412. package/dist/generated/themes/List.css.js.map +1 -1
  413. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  414. package/dist/generated/themes/ListItem.css.js +1 -1
  415. package/dist/generated/themes/ListItem.css.js.map +1 -1
  416. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  417. package/dist/generated/themes/ListItemBase.css.js +1 -1
  418. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  419. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  420. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  421. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  422. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  423. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  424. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  425. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  426. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  427. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  428. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  429. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  430. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  431. package/dist/generated/themes/Menu.css.d.ts +1 -1
  432. package/dist/generated/themes/Menu.css.js +1 -1
  433. package/dist/generated/themes/Menu.css.js.map +1 -1
  434. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  435. package/dist/generated/themes/MenuItem.css.js +1 -1
  436. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  437. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  438. package/dist/generated/themes/MessageStrip.css.js +1 -1
  439. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  440. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  441. package/dist/generated/themes/MonthPicker.css.js +1 -1
  442. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  443. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  444. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  445. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  446. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  447. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  448. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  449. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  450. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  451. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  452. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  453. package/dist/generated/themes/MultiInput.css.js +1 -1
  454. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  455. package/dist/generated/themes/NavigationMenu.css.d.ts +1 -1
  456. package/dist/generated/themes/NavigationMenu.css.js +1 -1
  457. package/dist/generated/themes/NavigationMenu.css.js.map +1 -1
  458. package/dist/generated/themes/NavigationMenuItem.css.d.ts +1 -1
  459. package/dist/generated/themes/NavigationMenuItem.css.js +1 -1
  460. package/dist/generated/themes/NavigationMenuItem.css.js.map +1 -1
  461. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  462. package/dist/generated/themes/OptionBase.css.js +1 -1
  463. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  464. package/dist/generated/themes/Panel.css.d.ts +1 -1
  465. package/dist/generated/themes/Panel.css.js +1 -1
  466. package/dist/generated/themes/Panel.css.js.map +1 -1
  467. package/dist/generated/themes/Popover.css.d.ts +1 -1
  468. package/dist/generated/themes/Popover.css.js +1 -1
  469. package/dist/generated/themes/Popover.css.js.map +1 -1
  470. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  471. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  472. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  473. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  474. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  475. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  476. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  477. package/dist/generated/themes/RadioButton.css.js +1 -1
  478. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  479. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  480. package/dist/generated/themes/RangeSlider.css.js +1 -1
  481. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  482. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  483. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  484. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  485. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  486. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  487. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  488. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  489. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  490. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  491. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  492. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  493. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  494. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  495. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  496. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  497. package/dist/generated/themes/Select.css.d.ts +1 -1
  498. package/dist/generated/themes/Select.css.js +1 -1
  499. package/dist/generated/themes/Select.css.js.map +1 -1
  500. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  501. package/dist/generated/themes/SliderBase.css.js +1 -1
  502. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  503. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  504. package/dist/generated/themes/SplitButton.css.js +1 -1
  505. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  506. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  507. package/dist/generated/themes/StepInput.css.js +1 -1
  508. package/dist/generated/themes/StepInput.css.js.map +1 -1
  509. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  510. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  511. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  512. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  513. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  514. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  515. package/dist/generated/themes/Switch.css.d.ts +1 -1
  516. package/dist/generated/themes/Switch.css.js +1 -1
  517. package/dist/generated/themes/Switch.css.js.map +1 -1
  518. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  519. package/dist/generated/themes/TabContainer.css.js +1 -1
  520. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  521. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  522. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  523. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  524. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  525. package/dist/generated/themes/TabInStrip.css.js +1 -1
  526. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  527. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  528. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  529. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  530. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  531. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  532. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  533. package/dist/generated/themes/Table.css.d.ts +1 -1
  534. package/dist/generated/themes/Table.css.js +1 -1
  535. package/dist/generated/themes/Table.css.js.map +1 -1
  536. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  537. package/dist/generated/themes/TableCellBase.css.js +1 -1
  538. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  539. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  540. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  541. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  542. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  543. package/dist/generated/themes/TableRow.css.js +1 -1
  544. package/dist/generated/themes/TableRow.css.js.map +1 -1
  545. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  546. package/dist/generated/themes/TableRowBase.css.js +1 -1
  547. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  548. package/dist/generated/themes/Tag.css.d.ts +1 -1
  549. package/dist/generated/themes/Tag.css.js +1 -1
  550. package/dist/generated/themes/Tag.css.js.map +1 -1
  551. package/dist/generated/themes/Text.css.d.ts +1 -1
  552. package/dist/generated/themes/Text.css.js +1 -1
  553. package/dist/generated/themes/Text.css.js.map +1 -1
  554. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  555. package/dist/generated/themes/TextArea.css.js +1 -1
  556. package/dist/generated/themes/TextArea.css.js.map +1 -1
  557. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  558. package/dist/generated/themes/TimePicker.css.js +1 -1
  559. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  560. package/dist/generated/themes/Toast.css.d.ts +1 -1
  561. package/dist/generated/themes/Toast.css.js +1 -1
  562. package/dist/generated/themes/Toast.css.js.map +1 -1
  563. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  564. package/dist/generated/themes/ToggleButton.css.js +1 -1
  565. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  566. package/dist/generated/themes/Token.css.d.ts +1 -1
  567. package/dist/generated/themes/Token.css.js +1 -1
  568. package/dist/generated/themes/Token.css.js.map +1 -1
  569. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  570. package/dist/generated/themes/Tokenizer.css.js +1 -1
  571. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  572. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  573. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  574. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  575. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  576. package/dist/generated/themes/Toolbar.css.js +1 -1
  577. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  578. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  579. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  580. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  581. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  582. package/dist/generated/themes/TreeItem.css.js +1 -1
  583. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  584. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  585. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  586. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  587. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  588. package/dist/generated/themes/YearPicker.css.js +1 -1
  589. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  590. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  591. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  592. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  593. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  594. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  595. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  596. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  597. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  598. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  599. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  600. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  601. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  602. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  603. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  604. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  605. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  606. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  607. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  608. package/dist/generated/themes/sap_horizon_dark_exp/parameters-bundle.css.d.ts +1 -1
  609. package/dist/generated/themes/sap_horizon_dark_exp/parameters-bundle.css.js +1 -1
  610. package/dist/generated/themes/sap_horizon_dark_exp/parameters-bundle.css.js.map +1 -1
  611. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.d.ts +1 -1
  612. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js +1 -1
  613. package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js.map +1 -1
  614. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  615. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  616. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  617. package/dist/generated/themes/sap_horizon_hcb_exp/parameters-bundle.css.d.ts +1 -1
  618. package/dist/generated/themes/sap_horizon_hcb_exp/parameters-bundle.css.js +1 -1
  619. package/dist/generated/themes/sap_horizon_hcb_exp/parameters-bundle.css.js.map +1 -1
  620. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  621. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  622. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  623. package/dist/generated/themes/sap_horizon_hcw_exp/parameters-bundle.css.d.ts +1 -1
  624. package/dist/generated/themes/sap_horizon_hcw_exp/parameters-bundle.css.js +1 -1
  625. package/dist/generated/themes/sap_horizon_hcw_exp/parameters-bundle.css.js.map +1 -1
  626. package/dist/web-types.json +2 -2
  627. package/package.json +9 -9
  628. package/src/ColorPaletteTemplate.tsx +1 -2
  629. package/src/InputPopoverTemplate.tsx +2 -102
  630. package/src/features/ColorPaletteMoreColorsTemplate.tsx +30 -0
  631. package/src/features/InputSuggestionsTemplate.tsx +108 -0
  632. package/src/themes/TabInStrip.css +1 -5
  633. package/dist/ColorPaletteDialogTemplate.d.ts +0 -2
  634. package/dist/ColorPaletteDialogTemplate.js +0 -9
  635. package/dist/ColorPaletteDialogTemplate.js.map +0 -1
  636. package/src/ColorPaletteDialogTemplate.tsx +0 -35
@@ -0,0 +1,606 @@
1
+ import { html } from "lit";
2
+
3
+ import "../../src/Table.js";
4
+ import "../../src/TableHeaderRow.js";
5
+ import "../../src/TableCell.js";
6
+ import "../../src/TableRow.js";
7
+ import "../../src/TableSelection.js";
8
+
9
+ // Porting Table.spec.js (wdio tests) to cypress tests
10
+ const ROLE_COLUMN_HEADER = "columnheader";
11
+
12
+ describe("Table - Rendering", () => {
13
+ it("tests if table is rendered", () => {
14
+ cy.mount(html`
15
+ <ui5-table id="table">
16
+ <ui5-table-header-row slot="headerRow">
17
+ <ui5-table-header-cell><span>ColumnA</span></ui5-table-header-cell>
18
+ <ui5-table-header-cell><span>ColumnB</span></ui5-table-header-cell>
19
+ </ui5-table-header-row>
20
+ <ui5-table-row>
21
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
22
+ <ui5-table-cell><ui5-label>Cell B</ui5-label></ui5-table-cell>
23
+ </ui5-table-row>
24
+ </ui5-table>
25
+ `);
26
+
27
+ cy.get("ui5-table").should("exist");
28
+ cy.get("ui5-table-header-row").should("exist");
29
+ cy.get("ui5-table-row").should("exist");
30
+ cy.get("ui5-table-header-cell").should("have.length", 2);
31
+ });
32
+
33
+ it("tests if initial empty table renders without errors", () => {
34
+ cy.window().then(window => {
35
+ window.addEventListener("unhandledrejection", cy.stub().as("rejection"));
36
+
37
+ const table = window.document.createElement("ui5-table");
38
+ window.document.body.appendChild(table);
39
+
40
+ setTimeout(() => {
41
+ const row = window.document.createElement("ui5-table-row");
42
+ table.appendChild(row);
43
+
44
+ cy.get("@rejection").should("not.be.called");
45
+
46
+ table.remove();
47
+ }, 100);
48
+ });
49
+
50
+ // eslint-disable-next-line cypress/no-unnecessary-waiting
51
+ cy.wait(500);
52
+ });
53
+ });
54
+
55
+ describe("Table - Popin Mode", () => {
56
+ beforeEach(() => {
57
+ cy.mount(html`
58
+ <ui5-table id="table" overflow-mode="Popin">
59
+ <ui5-table-header-row slot="headerRow">
60
+ <ui5-table-header-cell id="colA" min-width="300px"><span>ColumnA</span></ui5-table-header-cell>
61
+ <ui5-table-header-cell id="colB" min-width="200px">Column B</ui5-table-header-cell>
62
+ <ui5-table-header-cell id="colC" min-width="200px">Column C</ui5-table-header-cell>
63
+ <ui5-table-header-cell id="colD" min-width="150px">Column D</ui5-table-header-cell>
64
+ </ui5-table-header-row>
65
+ <ui5-table-row>
66
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
67
+ <ui5-table-cell><ui5-label>Cell B</ui5-label></ui5-table-cell>
68
+ <ui5-table-cell><ui5-label>Cell C</ui5-label></ui5-table-cell>
69
+ <ui5-table-cell><ui5-label>Cell D</ui5-label></ui5-table-cell>
70
+ </ui5-table-row>
71
+ <ui5-table-row>
72
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
73
+ <ui5-table-cell><ui5-label>Cell B</ui5-label></ui5-table-cell>
74
+ <ui5-table-cell><ui5-label>Cell C</ui5-label></ui5-table-cell>
75
+ <ui5-table-cell><ui5-label>Cell D</ui5-label></ui5-table-cell>
76
+ </ui5-table-row>
77
+ <ui5-table-row>
78
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
79
+ <ui5-table-cell><ui5-label>Cell B</ui5-label></ui5-table-cell>
80
+ <ui5-table-cell><ui5-label>Cell C</ui5-label></ui5-table-cell>
81
+ <ui5-table-cell><ui5-label>Cell D</ui5-label></ui5-table-cell>
82
+ </ui5-table-row>
83
+ </ui5-table>
84
+ `);
85
+ });
86
+
87
+ it("no pop-in width 'optimal' table width", () => {
88
+ cy.get("ui5-table").then($table => {
89
+ $table.css("width", "850px");
90
+ });
91
+
92
+ cy.get("ui5-table")
93
+ .should("exist")
94
+ .should("have.attr", "overflow-mode", "Popin")
95
+ .should("have.css", "width", "850px");
96
+ cy.get("ui5-table-header-cell")
97
+ .should("have.length", 4);
98
+
99
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
100
+ cy.wrap($cell)
101
+ .should("have.attr", "role", ROLE_COLUMN_HEADER);
102
+ cy.get("ui5-table-header-row")
103
+ .shadow()
104
+ .find(`slot[name=default-${index + 1}]`)
105
+ .should("exist");
106
+ });
107
+ });
108
+
109
+ it("test with one by one popping in", () => {
110
+ const testWidths = [
111
+ { width: 850, poppedIn: [] },
112
+ { width: 700, poppedIn: ["colD"] },
113
+ { width: 500, poppedIn: ["colD", "colC"] },
114
+ { width: 300, poppedIn: ["colD", "colC", "colB"] },
115
+ { width: 150, poppedIn: ["colD", "colC", "colB"] },
116
+ ];
117
+
118
+ testWidths.forEach(({ width, poppedIn }) => {
119
+ cy.get("ui5-table").then($table => {
120
+ $table.css("width", `${width}px`);
121
+ });
122
+
123
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
124
+ const id = $cell.attr("id") ?? "";
125
+ const shouldBePoppedIn = poppedIn.includes(id);
126
+ const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
127
+
128
+ cy.wrap($cell)
129
+ .should(roleCondition, "role", ROLE_COLUMN_HEADER);
130
+ cy.get("ui5-table-header-row")
131
+ .shadow()
132
+ .find(`slot[name=default-${index + 1}]`)
133
+ .should(shouldBePoppedIn ? "not.exist" : "exist");
134
+ });
135
+ });
136
+ });
137
+
138
+ it("test with one by one popping out", () => {
139
+ const testWidths = [
140
+ { width: 150, poppedIn: ["colD", "colC", "colB"] },
141
+ { width: 300, poppedIn: ["colD", "colC", "colB"] },
142
+ { width: 500, poppedIn: ["colD", "colC"] },
143
+ { width: 700, poppedIn: ["colD"] },
144
+ { width: 850, poppedIn: [] },
145
+ ];
146
+
147
+ testWidths.forEach(({ width, poppedIn }) => {
148
+ cy.get("ui5-table").then($table => {
149
+ $table.css("width", `${width}px`);
150
+ });
151
+
152
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
153
+ const id = $cell.attr("id") ?? "";
154
+ const shouldBePoppedIn = poppedIn.includes(id);
155
+ const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
156
+
157
+ cy.wrap($cell)
158
+ .should(roleCondition, "role", ROLE_COLUMN_HEADER);
159
+ cy.get("ui5-table-header-row")
160
+ .shadow()
161
+ .find(`slot[name=default-${index + 1}]`)
162
+ .should(shouldBePoppedIn ? "not.exist" : "exist");
163
+ });
164
+ });
165
+ });
166
+
167
+ it("test with random widths", () => {
168
+ const expectedStates = [
169
+ { width: 500, poppedIn: ["colD", "colC", "colB"] },
170
+ { width: 700, poppedIn: ["colD", "colC"] },
171
+ { width: 850, poppedIn: ["colD"] },
172
+ { width: Infinity, poppedIn: [] },
173
+ ];
174
+
175
+ const runs = 10;
176
+ for (let i = 0; i < runs; i++) {
177
+ const randomWidth = Math.floor(Math.random() * 1000) + 1;
178
+ cy.get("ui5-table").then($table => {
179
+ $table.css("width", `${randomWidth}px`);
180
+ });
181
+
182
+ const expectedState = expectedStates.find(state => state.width >= randomWidth);
183
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
184
+ const id = $cell.attr("id") ?? "";
185
+ const shouldBePoppedIn = expectedState?.poppedIn.includes(id);
186
+ const roleCondition = shouldBePoppedIn ? "not.have.attr" : "have.attr";
187
+
188
+ cy.wrap($cell)
189
+ .should(roleCondition, "role", ROLE_COLUMN_HEADER);
190
+ cy.get("ui5-table-header-row")
191
+ .shadow()
192
+ .find(`slot[name=default-${index + 1}]`)
193
+ .should(shouldBePoppedIn ? "not.exist" : "exist");
194
+ });
195
+ }
196
+ });
197
+ });
198
+
199
+ describe("Table - Horizontal alignment of cells", () => {
200
+ function check(id: string, index: number, alignment: string) {
201
+ cy.get(id)
202
+ .should("have.css", "justify-content", alignment)
203
+ .invoke("attr", "style")
204
+ .then(style => {
205
+ const variable = style?.match(/justify-content: ([^;]+)/)?.[1] ?? "";
206
+ expect(variable).to.equal(`var(--horizontal-align-default-${index})`);
207
+ });
208
+ cy.get("ui5-table-row")
209
+ .get(`ui5-table-cell:nth-of-type(${index})`)
210
+ .should("have.css", "justify-content", alignment);
211
+ }
212
+
213
+ beforeEach(() => {
214
+ cy.mount(html`
215
+ <ui5-table id="table" overflow-mode="Popin" style="width: 1120px;">
216
+ <ui5-table-header-row slot="headerRow">
217
+ <ui5-table-header-cell id="productCol" width="300px"><span>Product</span></ui5-table-header-cell>
218
+ <ui5-table-header-cell id="supplierCol" horizontal-align="Center" width="200px">Supplier</ui5-table-header-cell>
219
+ <ui5-table-header-cell id="dimensionsCol" horizontal-align="Right" width="300px">Dimensions</ui5-table-header-cell>
220
+ <ui5-table-header-cell id="weightCol" width="100px">Weight</ui5-table-header-cell>
221
+ <ui5-table-header-cell id="priceCol" width="220px">Price</ui5-table-header-cell>
222
+ </ui5-table-header-row>
223
+ <ui5-table-row>
224
+ <ui5-table-cell><ui5-label><b>Notebook Basic 15</b><br>HT-1000</ui5-label></ui5-table-cell>
225
+ <ui5-table-cell><ui5-label>Very Best Screens</ui5-label></ui5-table-cell>
226
+ <ui5-table-cell><ui5-label>30 x 18 x 3 cm</ui5-label></ui5-table-cell>
227
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>4.2</b> KG</ui5-label></ui5-table-cell>
228
+ <ui5-table-cell><ui5-label><b>956</b> EUR</ui5-label></ui5-table-cell>
229
+ </ui5-table-row>
230
+ <ui5-table-row>
231
+ <ui5-table-cell><ui5-label><b>Notebook Basic 17</b><br>HT-1001</ui5-label></ui5-table-cell>
232
+ <ui5-table-cell><ui5-label>Smartcards</ui5-label></ui5-table-cell>
233
+ <ui5-table-cell><ui5-label>29 x 17 x 3.1 cm</ui5-label></ui5-table-cell>
234
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>4.5</b> KG</ui5-label></ui5-table-cell>
235
+ <ui5-table-cell><ui5-label><b>1249</b> EUR</ui5-label></ui5-table-cell>
236
+ </ui5-table-row>
237
+ <ui5-table-row>
238
+ <ui5-table-cell><ui5-label><b>Notebook Basic 18</b><br>HT-1002</ui5-label></ui5-table-cell>
239
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
240
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
241
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
242
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
243
+ </ui5-table-row>
244
+ </ui5-table>
245
+ `);
246
+ });
247
+
248
+ it("default alignment when horizotal align is not set", () => {
249
+ check("#productCol", 1, "normal");
250
+ });
251
+
252
+ it("alignment is set correctly during runtime", () => {
253
+ const alignments = ["Left", "Start", "Right", "End", "Center"];
254
+
255
+ alignments.forEach(alignment => {
256
+ cy.get("#productCol")
257
+ .invoke("attr", "horizontal-align", alignment)
258
+ .should("have.attr", "horizontal-align", alignment);
259
+ check("#productCol", 1, alignment.toLowerCase());
260
+ });
261
+ });
262
+
263
+ it("alignment is normal if set to unknown value", () => {
264
+ cy.get("#productCol")
265
+ .invoke("attr", "horizontal-align", "UnknownValue")
266
+ .should("have.attr", "horizontal-align", "UnknownValue");
267
+ check("#productCol", 1, "normal");
268
+ });
269
+
270
+ it("alignment cells have same alignment as header cell on init time", () => {
271
+ check("#supplierCol", 2, "center");
272
+ check("#dimensionsCol", 3, "right");
273
+ });
274
+
275
+ it("cells should change alignment when changing headerCell alignment", () => {
276
+ check("#supplierCol", 2, "center");
277
+
278
+ cy.get("#supplierCol")
279
+ .invoke("attr", "horizontal-align", "End")
280
+ .should("have.attr", "horizontal-align", "End");
281
+
282
+ check("#supplierCol", 2, "end");
283
+ });
284
+
285
+ it("single cell alignment does not affect other cells and is not affected by header cell alignment", () => {
286
+ check("#supplierCol", 2, "center");
287
+
288
+ cy.get("ui5-table-row:nth-of-type(2) > ui5-table-cell:nth-child(2)")
289
+ .invoke("attr", "horizontal-align", "Start")
290
+ .should("have.attr", "horizontal-align", "Start")
291
+ .should("have.css", "justify-content", "start");
292
+
293
+ cy.get("#supplierCol")
294
+ .should("have.css", "justify-content", "center");
295
+
296
+ cy.get("ui5-table-row:nth-of-type(3) > ui5-table-cell:nth-child(2)")
297
+ .should("have.css", "justify-content", "center");
298
+
299
+ cy.get("ui5-table-row:nth-of-type(1) > ui5-table-cell:nth-child(2)")
300
+ .should("have.css", "justify-content", "center");
301
+
302
+ // Change alignment of header cell => should not affect custom cell alignment
303
+ cy.get("#supplierCol")
304
+ .invoke("attr", "horizontal-align", "End")
305
+ .should("have.attr", "horizontal-align", "End");
306
+
307
+ cy.get("ui5-table-row:nth-of-type(2) > ui5-table-cell:nth-child(2)")
308
+ .should("have.attr", "horizontal-align", "Start")
309
+ .should("have.css", "justify-content", "start");
310
+
311
+ cy.get("ui5-table-row:nth-of-type(3) > ui5-table-cell:nth-child(2)")
312
+ .should("have.css", "justify-content", "end");
313
+
314
+ cy.get("ui5-table-row:nth-of-type(1) > ui5-table-cell:nth-child(2)")
315
+ .should("have.css", "justify-content", "end");
316
+ });
317
+
318
+ it("alignment with popin", () => {
319
+ const testWidths = [
320
+ { width: 1120, poppedIn: [] },
321
+ { width: 900, poppedIn: ["priceCol"] },
322
+ { width: 800, poppedIn: ["priceCol", "weightCol"] },
323
+ { width: 500, poppedIn: ["priceCol", "weightCol", "dimensionsCol"] },
324
+ { width: 300, poppedIn: ["priceCol", "weightCol", "dimensionsCol", "supplierCol"] },
325
+ ];
326
+ const alignments = {
327
+ "productCol": "normal",
328
+ "supplierCol": "center",
329
+ "dimensionsCol": "right",
330
+ "weightCol": "normal",
331
+ "priceCol": "normal",
332
+ "none": "",
333
+ };
334
+
335
+ testWidths.forEach(({ width, poppedIn }) => {
336
+ cy.get("ui5-table").then($table => {
337
+ $table.css("width", `${width}px`);
338
+ });
339
+
340
+ cy.get("ui5-table-header-cell").each(($cell, index) => {
341
+ const id = $cell.attr("id") as keyof typeof alignments ?? "none";
342
+ const shouldBePoppedIn = poppedIn.includes(id);
343
+
344
+ if (shouldBePoppedIn) {
345
+ check(`#${id}`, index + 1, "normal");
346
+ } else {
347
+ check(`#${id}`, index + 1, alignments[id]);
348
+ }
349
+ });
350
+ });
351
+ });
352
+ });
353
+
354
+ describe("Table - Fixed Header", () => {
355
+ function check(topOffset: number, lastRow: string) {
356
+ cy.get("ui5-table-header-row")
357
+ .should("have.css", "position", "sticky")
358
+ .should("have.css", "top", `${topOffset}px`);
359
+
360
+ cy.get(lastRow)
361
+ .scrollIntoView();
362
+
363
+ cy.get("ui5-table-header-row")
364
+ .then($header => {
365
+ const headerRect = $header[0].getBoundingClientRect();
366
+ expect(headerRect.top).to.be.eq(topOffset);
367
+ });
368
+ }
369
+
370
+ beforeEach(() => {
371
+ cy.window().then(window => {
372
+ window.document.body.style.margin = "0";
373
+ window.document.body.style.padding = "0";
374
+ });
375
+ });
376
+
377
+ it("fixed header with scrollable wrapping container", () => {
378
+ cy.mount(html`
379
+ <div style="height:300px; overflow:auto;">
380
+ <ui5-bar id="toolbar" design="Header" accessible-name-ref="title" style="position: sticky; top: 0; z-index: 2; height: 50px;">
381
+ <ui5-title tabindsex="0" level="H3" id="title" slot="startContent">My Selectable Products (3)</ui5-title>
382
+ <ui5-slider id="slider" min="0" max="100" step="1" value="100"
383
+ label-interval="0"></ui5-slider>
384
+ </ui5-bar>
385
+ <ui5-table id="table0" overflow-mode="Popin" sticky-top="50px" accessible-name-ref="title" no-data-text="No data found">
386
+ <ui5-table-header-row sticky slot="headerRow">
387
+ <ui5-table-header-cell id="colA" min-width="300px"><span>ColumnA</span></ui5-table-header-cell>
388
+ <ui5-table-header-cell id="colB" min-width="200px">Column B</ui5-table-header-cell>
389
+ <ui5-table-header-cell id="colC" min-width="200px">Column C</ui5-table-header-cell>
390
+ <ui5-table-header-cell id="colD" min-width="150px">Column D</ui5-table-header-cell>
391
+ </ui5-table-header-row>
392
+ ${Array.from({ length: 20 }).map((val, index) => html`
393
+ <ui5-table-row id=row-${index + 1}><ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> </ui5-table-row>
394
+ `)}
395
+ </ui5-table>
396
+ </div>
397
+ `);
398
+
399
+ check(50, "#row-20");
400
+ });
401
+
402
+ it("fixed header with table being scrollable", () => {
403
+ cy.mount(html`
404
+ <ui5-table id="table" overflow-mode="Popin" sticky-top="0" accessible-name-ref="title" no-data-text="No data found" style="height: 300px; overflow: auto;">
405
+ <ui5-table-header-row sticky slot="headerRow">
406
+ <ui5-table-header-cell id="colA" min-width="300px"><span>ColumnA</span></ui5-table-header-cell>
407
+ <ui5-table-header-cell id="colB" min-width="200px">Column B</ui5-table-header-cell>
408
+ <ui5-table-header-cell id="colC" min-width="200px">Column C</ui5-table-header-cell>
409
+ <ui5-table-header-cell id="colD" min-width="150px">Column D</ui5-table-header-cell>
410
+ </ui5-table-header-row>
411
+ ${Array.from({ length: 20 }).map((val, index) => html`
412
+ <ui5-table-row id=row-${index + 1}><ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> </ui5-table-row>
413
+ `)}
414
+ </ui5-table>
415
+ `);
416
+
417
+ check(0, "#row-20");
418
+ });
419
+
420
+ it("fixed header with body being scroll container", () => {
421
+ cy.mount(html`
422
+ <ui5-bar id="toolbar2" design="Header" accessible-name-ref="title" style="position: sticky; top: 0; z-index: 2; height: 50px;">
423
+ <ui5-title tabindsex="0" level="H3" id="title" slot="startContent">My Selectable Products (3)</ui5-title>
424
+ <ui5-slider id="slider" min="0" max="100" step="1" value="100"
425
+ label-interval="0"></ui5-slider>
426
+ </ui5-bar>
427
+ <ui5-table id="table" overflow-mode="Popin" sticky-top="50px" accessible-name-ref="title" no-data-text="No data found">
428
+ <ui5-table-header-row sticky slot="headerRow">
429
+ <ui5-table-header-cell id="colA" min-width="300px"><span>ColumnA</span></ui5-table-header-cell>
430
+ <ui5-table-header-cell id="colB" min-width="200px">Column B</ui5-table-header-cell>
431
+ <ui5-table-header-cell id="colC" min-width="200px">Column C</ui5-table-header-cell>
432
+ <ui5-table-header-cell id="colD" min-width="150px">Column D</ui5-table-header-cell>
433
+ </ui5-table-header-row>
434
+ ${Array.from({ length: 100 }).map((val, index) => html`
435
+ <ui5-table-row id=row-${index + 1}><ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> <ui5-table-cell></ui5-table-cell> </ui5-table-row>
436
+ `)}
437
+ </ui5-table>
438
+ `);
439
+
440
+ check(50, "#row-100");
441
+ });
442
+ });
443
+
444
+ describe("Table - Horizontal Scrolling", () => {
445
+ beforeEach(() => {
446
+ cy.window().then(window => {
447
+ window.document.body.style.margin = "0";
448
+ window.document.body.style.padding = "0";
449
+ });
450
+
451
+ cy.mount(html`
452
+ <ui5-table id="table" overflow-mode="Scroll" height="300px" sticky-top="0px" style="width: 300px; overflow: auto;" accessible-name-ref="title">
453
+ <ui5-table-selection id="selection" selected="0 2" slot="features"></ui5-table-selection>
454
+ <ui5-table-header-row slot="headerRow" sticky>
455
+ <ui5-table-header-cell id="produtCol" width="200px"><span>Product</span></ui5-table-header-cell>
456
+ <ui5-table-header-cell id="supplierCol" width="200px">Supplier</ui5-table-header-cell>
457
+ <ui5-table-header-cell id="dimensionsCol" width="200px">Dimensions</ui5-table-header-cell>
458
+ <ui5-table-header-cell id="weightCol" width="200px">Weight</ui5-table-header-cell>
459
+ <ui5-table-header-cell id="priceCol" width="200px">Price</ui5-table-header-cell>
460
+ </ui5-table-header-row>
461
+ <ui5-table-row id="firstRow" navigated key="0">
462
+ <ui5-table-cell><ui5-label><b>Notebook Basic 15</b><br><a href="#">HT-1000</a></ui5-label></ui5-table-cell>
463
+ <ui5-table-cell><ui5-label>Very Best Screens</ui5-label></ui5-table-cell>
464
+ <ui5-table-cell><ui5-label>30 x 18 x 3 cm</ui5-label></ui5-table-cell>
465
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>4.2</b> KG</ui5-label></ui5-table-cell>
466
+ <ui5-table-cell id="lastCell"><ui5-label><b>956</b> EUR</ui5-label></ui5-table-cell>
467
+ </ui5-table-row>
468
+ <ui5-table-row key="1">
469
+ <ui5-table-cell><ui5-label><b>Notebook Basic 16</b><br><a href="#">HT-1001</a></ui5-label></ui5-table-cell>
470
+ <ui5-table-cell><ui5-label>Smartcards</ui5-label></ui5-table-cell>
471
+ <ui5-table-cell><ui5-input value="29 x 17 x 3.1 cm" accessible-name-ref="dimensionsCol"></ui5-input></ui5-table-cell>
472
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>4.5</b> KG</ui5-label></ui5-table-cell>
473
+ <ui5-table-cell><ui5-label><b>1249</b> EUR</ui5-label></ui5-table-cell>
474
+ </ui5-table-row>
475
+ <ui5-table-row key="2" interactive>
476
+ <ui5-table-cell><ui5-label><b>Notebook Basic 17</b><br><a href="#">HT-1002</a></ui5-label></ui5-table-cell>
477
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
478
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
479
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
480
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
481
+ </ui5-table-row>
482
+ <ui5-table-row key="3">
483
+ <ui5-table-cell><ui5-label><b>Notebook Basic 18</b><br><a href="#">HT-1003</a></ui5-label></ui5-table-cell>
484
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
485
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
486
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
487
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
488
+ </ui5-table-row>
489
+ <ui5-table-row key="4">
490
+ <ui5-table-cell><ui5-label><b>Notebook Basic 19</b><br><a href="#">HT-1004</a></ui5-label></ui5-table-cell>
491
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
492
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
493
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
494
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
495
+ </ui5-table-row>
496
+ <ui5-table-row key="5">
497
+ <ui5-table-cell><ui5-label><b>Notebook Basic 20</b><br><a href="#">HT-1005</a></ui5-label></ui5-table-cell>
498
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
499
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
500
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
501
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
502
+ </ui5-table-row>
503
+ <ui5-table-row key="6" interactive>
504
+ <ui5-table-cell><ui5-label><b>Notebook Basic 21</b><br><a href="#">HT-1006</a></ui5-label></ui5-table-cell>
505
+ <ui5-table-cell><ui5-label>Technocom</ui5-label></ui5-table-cell>
506
+ <ui5-table-cell><ui5-label>32 x 21 x 4 cm</ui5-label></ui5-table-cell>
507
+ <ui5-table-cell><ui5-label style="color: #2b7c2b"><b>3.7</b> KG</ui5-label></ui5-table-cell>
508
+ <ui5-table-cell><ui5-label><b>29</b> EUR</ui5-label></ui5-table-cell>
509
+ </ui5-table-row>
510
+ </ui5-table>
511
+ `);
512
+ });
513
+
514
+ it("navigated indidcator is fixed to the right", () => {
515
+ cy.get("#lastCell")
516
+ .then($lastCell => {
517
+ $lastCell[0].scrollIntoView();
518
+ });
519
+
520
+ cy.get("#firstRow")
521
+ .shadow()
522
+ .find("#navigated-cell")
523
+ .should("have.css", "position", "sticky")
524
+ .should("have.css", "right", "0px");
525
+ });
526
+
527
+ it("selection column should be fixed to the left", () => {
528
+ cy.get("#lastCell")
529
+ .then($lastCell => {
530
+ $lastCell[0].scrollIntoView();
531
+ });
532
+
533
+ cy.get("#firstRow")
534
+ .shadow()
535
+ .find("#selection-cell")
536
+ .should("have.css", "position", "sticky")
537
+ .then($selectionCell => {
538
+ const selectionRect = $selectionCell[0].getBoundingClientRect();
539
+ expect(selectionRect.left).to.be.eq(0);
540
+ });
541
+
542
+ cy.get("#table")
543
+ .shadow()
544
+ .find("#table")
545
+ .then($table => {
546
+ const leftOffset = $table[0].scrollLeft;
547
+ expect(leftOffset).to.be.greaterThan(0);
548
+ });
549
+ });
550
+ });
551
+
552
+ describe("Table - Navigated Rows", () => {
553
+ it("Navigated cell is rendered", () => {
554
+ cy.mount(html`
555
+ <ui5-table id="table1">
556
+ <ui5-table-header-row slot="headerRow">
557
+ <ui5-table-header-cell id="colA"><span>ColumnA</span></ui5-table-header-cell>
558
+ </ui5-table-header-row>
559
+ <ui5-table-row id="row1" navigated>
560
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
561
+ </ui5-table-row>
562
+ <ui5-table-row id="row2">
563
+ <ui5-table-cell><ui5-label>Cell A</ui5-label></ui5-table-cell>
564
+ </ui5-table-row>
565
+ </ui5-table>
566
+ `);
567
+
568
+ cy.get("#row1")
569
+ .shadow()
570
+ .find("#navigated-cell")
571
+ .should("exist")
572
+ .should("have.attr", "excluded-from-navigation", "");
573
+
574
+ cy.get("#row2")
575
+ .shadow()
576
+ .find("#navigated-cell")
577
+ .should("exist")
578
+ .should("have.attr", "excluded-from-navigation", "");
579
+
580
+ cy.get("#row1")
581
+ .shadow()
582
+ .find("#navigated")
583
+ .as("navigated1");
584
+
585
+ cy.get("#row2")
586
+ .shadow()
587
+ .find("#navigated")
588
+ .then($navigated2 => {
589
+ cy.get("@navigated1")
590
+ .then($navigated1 => {
591
+ const nav1BG = getComputedStyle($navigated1[0]).backgroundColor;
592
+ const nav2BG = getComputedStyle($navigated2[0]).backgroundColor;
593
+ expect(nav1BG).to.not.be.eq(nav2BG);
594
+ });
595
+ });
596
+
597
+ cy.get("#table1")
598
+ .shadow()
599
+ .find("#table")
600
+ .then($table => {
601
+ const gridTemplateColumns = $table[0].style.gridTemplateColumns;
602
+ // eslint-disable-next-line no-unused-expressions
603
+ expect(gridTemplateColumns.endsWith("table_navigated_cell_width)")).to.be.true;
604
+ });
605
+ });
606
+ });
@@ -2,6 +2,7 @@ import { html } from "lit";
2
2
  import "../../src/Toast.js";
3
3
  import "../../src/Button.js";
4
4
  import "../../src/List.js";
5
+ import "../../src/ListItemStandard.js";
5
6
  import type Toast from "../../src/Toast.js";
6
7
 
7
8
  describe("Toast - test popover API", () => {