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