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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (652) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/cypress/specs/Calendar.cy.tsx +703 -0
  3. package/cypress/specs/MultiInput.cy.tsx +1 -0
  4. package/cypress/specs/Table.cy.tsx +172 -0
  5. package/cypress/support/commands/Calendar.commands.ts +15 -0
  6. package/cypress/support/commands.ts +7 -2
  7. package/dist/.tsbuildinfo +1 -1
  8. package/dist/ComboBox.d.ts +0 -1
  9. package/dist/ComboBox.js +0 -1
  10. package/dist/ComboBox.js.map +1 -1
  11. package/dist/DateTimeInput.d.ts +1 -0
  12. package/dist/DateTimeInput.js +5 -1
  13. package/dist/DateTimeInput.js.map +1 -1
  14. package/dist/Input.js +0 -1
  15. package/dist/Input.js.map +1 -1
  16. package/dist/Link.d.ts +15 -0
  17. package/dist/Link.js +17 -0
  18. package/dist/Link.js.map +1 -1
  19. package/dist/ListItem.d.ts +0 -8
  20. package/dist/ListItem.js +0 -9
  21. package/dist/ListItem.js.map +1 -1
  22. package/dist/ListItemTemplate.js +2 -2
  23. package/dist/ListItemTemplate.js.map +1 -1
  24. package/dist/MultiComboBox.d.ts +1 -3
  25. package/dist/MultiComboBox.js +22 -19
  26. package/dist/MultiComboBox.js.map +1 -1
  27. package/dist/MultiComboBoxPopoverTemplate.d.ts +2 -0
  28. package/dist/MultiComboBoxPopoverTemplate.js +35 -0
  29. package/dist/MultiComboBoxPopoverTemplate.js.map +1 -0
  30. package/dist/MultiComboBoxTemplate.d.ts +2 -0
  31. package/dist/MultiComboBoxTemplate.js +26 -0
  32. package/dist/MultiComboBoxTemplate.js.map +1 -0
  33. package/dist/Table.d.ts +12 -7
  34. package/dist/Table.js +20 -17
  35. package/dist/Table.js.map +1 -1
  36. package/dist/TableCell.d.ts +1 -2
  37. package/dist/TableCell.js +13 -5
  38. package/dist/TableCell.js.map +1 -1
  39. package/dist/TableHeaderCell.d.ts +22 -0
  40. package/dist/TableHeaderCell.js +31 -2
  41. package/dist/TableHeaderCell.js.map +1 -1
  42. package/dist/TableHeaderCellActionAI.d.ts +27 -0
  43. package/dist/TableHeaderCellActionAI.js +44 -0
  44. package/dist/TableHeaderCellActionAI.js.map +1 -0
  45. package/dist/TableHeaderCellActionBase.d.ts +33 -0
  46. package/dist/TableHeaderCellActionBase.js +58 -0
  47. package/dist/TableHeaderCellActionBase.js.map +1 -0
  48. package/dist/TableHeaderRow.d.ts +1 -0
  49. package/dist/TableHeaderRow.js +6 -4
  50. package/dist/TableHeaderRow.js.map +1 -1
  51. package/dist/TableNavigation.js +1 -2
  52. package/dist/TableNavigation.js.map +1 -1
  53. package/dist/TableRowActionBase.d.ts +0 -2
  54. package/dist/TableRowActionBase.js +0 -4
  55. package/dist/TableRowActionBase.js.map +1 -1
  56. package/dist/TableRowActionNavigation.d.ts +11 -1
  57. package/dist/TableRowActionNavigation.js +17 -6
  58. package/dist/TableRowActionNavigation.js.map +1 -1
  59. package/dist/TimePicker.d.ts +4 -4
  60. package/dist/TimePicker.js +23 -17
  61. package/dist/TimePicker.js.map +1 -1
  62. package/dist/TimePickerPopoverTemplate.js +1 -1
  63. package/dist/TimePickerPopoverTemplate.js.map +1 -1
  64. package/dist/TimePickerTemplate.js +1 -1
  65. package/dist/TimePickerTemplate.js.map +1 -1
  66. package/dist/bundle.esm.d.ts +1 -0
  67. package/dist/bundle.esm.js +3 -0
  68. package/dist/bundle.esm.js.map +1 -1
  69. package/dist/css/themes/Avatar.css +1 -1
  70. package/dist/css/themes/AvatarGroup.css +1 -1
  71. package/dist/css/themes/Bar.css +1 -1
  72. package/dist/css/themes/Breadcrumbs.css +1 -1
  73. package/dist/css/themes/BusyIndicator.css +1 -1
  74. package/dist/css/themes/Button.css +1 -1
  75. package/dist/css/themes/ButtonBadge.css +1 -1
  76. package/dist/css/themes/Calendar.css +1 -1
  77. package/dist/css/themes/CalendarHeader.css +1 -1
  78. package/dist/css/themes/CalendarLegend.css +1 -1
  79. package/dist/css/themes/CalendarLegendItem.css +1 -1
  80. package/dist/css/themes/Card.css +1 -1
  81. package/dist/css/themes/CardHeader.css +1 -1
  82. package/dist/css/themes/Carousel.css +1 -1
  83. package/dist/css/themes/CheckBox.css +1 -1
  84. package/dist/css/themes/ColorPalette.css +1 -1
  85. package/dist/css/themes/ColorPaletteItem.css +1 -1
  86. package/dist/css/themes/ColorPalettePopover.css +1 -1
  87. package/dist/css/themes/ColorPicker.css +1 -1
  88. package/dist/css/themes/ComboBox.css +1 -1
  89. package/dist/css/themes/ComboBoxItem.css +1 -1
  90. package/dist/css/themes/DatePicker.css +1 -1
  91. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  92. package/dist/css/themes/DayPicker.css +1 -1
  93. package/dist/css/themes/Dialog.css +1 -1
  94. package/dist/css/themes/FileUploader.css +1 -1
  95. package/dist/css/themes/Form.css +1 -1
  96. package/dist/css/themes/FormItem.css +1 -1
  97. package/dist/css/themes/FormItemSpan.css +1 -1
  98. package/dist/css/themes/GrowingButton.css +1 -1
  99. package/dist/css/themes/Icon.css +1 -1
  100. package/dist/css/themes/Input.css +1 -1
  101. package/dist/css/themes/InputIcon.css +1 -1
  102. package/dist/css/themes/InputSharedStyles.css +1 -1
  103. package/dist/css/themes/Link.css +1 -1
  104. package/dist/css/themes/List.css +1 -1
  105. package/dist/css/themes/ListItem.css +1 -1
  106. package/dist/css/themes/ListItemBase.css +1 -1
  107. package/dist/css/themes/ListItemCustom.css +1 -1
  108. package/dist/css/themes/ListItemGroup.css +1 -1
  109. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  110. package/dist/css/themes/ListItemIcon.css +1 -1
  111. package/dist/css/themes/Menu.css +1 -1
  112. package/dist/css/themes/MenuItem.css +1 -1
  113. package/dist/css/themes/MessageStrip.css +1 -1
  114. package/dist/css/themes/MonthPicker.css +1 -1
  115. package/dist/css/themes/MultiComboBox.css +1 -1
  116. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  117. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  118. package/dist/css/themes/MultiInput.css +1 -1
  119. package/dist/css/themes/OptionBase.css +1 -1
  120. package/dist/css/themes/Panel.css +1 -1
  121. package/dist/css/themes/Popover.css +1 -1
  122. package/dist/css/themes/PopupsCommon.css +1 -1
  123. package/dist/css/themes/ProgressIndicator.css +1 -1
  124. package/dist/css/themes/RadioButton.css +1 -1
  125. package/dist/css/themes/RangeSlider.css +1 -1
  126. package/dist/css/themes/RatingIndicator.css +1 -1
  127. package/dist/css/themes/ResponsivePopover.css +1 -1
  128. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  129. package/dist/css/themes/SegmentedButton.css +1 -1
  130. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  131. package/dist/css/themes/Select.css +1 -1
  132. package/dist/css/themes/SliderBase.css +1 -1
  133. package/dist/css/themes/SplitButton.css +1 -1
  134. package/dist/css/themes/StepInput.css +1 -1
  135. package/dist/css/themes/SuggestionItem.css +1 -1
  136. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  137. package/dist/css/themes/Switch.css +1 -1
  138. package/dist/css/themes/TabContainer.css +1 -1
  139. package/dist/css/themes/TabInOverflow.css +1 -1
  140. package/dist/css/themes/TabInStrip.css +1 -1
  141. package/dist/css/themes/TabSemanticIcon.css +1 -1
  142. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  143. package/dist/css/themes/Table.css +1 -1
  144. package/dist/css/themes/TableCell.css +1 -1
  145. package/dist/css/themes/TableCellBase.css +1 -1
  146. package/dist/css/themes/TableHeaderCell.css +1 -1
  147. package/dist/css/themes/TableHeaderCellActionBase.css +1 -0
  148. package/dist/css/themes/TableHeaderRow.css +1 -1
  149. package/dist/css/themes/TableRow.css +1 -1
  150. package/dist/css/themes/TableRowActionBase.css +1 -1
  151. package/dist/css/themes/TableRowBase.css +1 -1
  152. package/dist/css/themes/Tag.css +1 -1
  153. package/dist/css/themes/Text.css +1 -1
  154. package/dist/css/themes/TextArea.css +1 -1
  155. package/dist/css/themes/TimePicker.css +1 -1
  156. package/dist/css/themes/Toast.css +1 -1
  157. package/dist/css/themes/ToggleButton.css +1 -1
  158. package/dist/css/themes/Token.css +1 -1
  159. package/dist/css/themes/Tokenizer.css +1 -1
  160. package/dist/css/themes/TokenizerPopover.css +1 -1
  161. package/dist/css/themes/Toolbar.css +1 -1
  162. package/dist/css/themes/ToolbarPopover.css +1 -1
  163. package/dist/css/themes/TreeItem.css +1 -1
  164. package/dist/css/themes/ValueStateMessage.css +1 -1
  165. package/dist/css/themes/YearPicker.css +1 -1
  166. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  167. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  168. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  169. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  170. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  171. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  172. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  173. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  174. package/dist/custom-elements-internal.json +265 -1
  175. package/dist/custom-elements.json +173 -1
  176. package/dist/features/InputSuggestions.d.ts +0 -2
  177. package/dist/features/InputSuggestions.js +0 -8
  178. package/dist/features/InputSuggestions.js.map +1 -1
  179. package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
  180. package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
  181. package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
  182. package/dist/generated/assets/i18n/messagebundle_cnr.json +1 -1
  183. package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
  184. package/dist/generated/assets/i18n/messagebundle_cy.json +1 -1
  185. package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
  186. package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
  187. package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
  188. package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
  189. package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -1
  190. package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -1
  191. package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -1
  192. package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
  193. package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -1
  194. package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
  195. package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
  196. package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
  197. package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -1
  198. package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
  199. package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
  200. package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
  201. package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
  202. package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
  203. package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
  204. package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
  205. package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
  206. package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
  207. package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
  208. package/dist/generated/assets/i18n/messagebundle_mk.json +1 -1
  209. package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
  210. package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
  211. package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
  212. package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
  213. package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
  214. package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -1
  215. package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
  216. package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
  217. package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
  218. package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
  219. package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
  220. package/dist/generated/assets/i18n/messagebundle_sr.json +1 -1
  221. package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
  222. package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
  223. package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
  224. package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
  225. package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
  226. package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
  227. package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
  228. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  229. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  230. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  231. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  232. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  233. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  234. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  235. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  236. package/dist/generated/i18n/i18n-defaults.d.ts +3 -1
  237. package/dist/generated/i18n/i18n-defaults.js +3 -1
  238. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  239. package/dist/generated/templates/TableCellTemplate.lit.js +3 -6
  240. package/dist/generated/templates/TableCellTemplate.lit.js.map +1 -1
  241. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.d.ts +3 -0
  242. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.js +7 -0
  243. package/dist/generated/templates/TableHeaderCellActionBaseTemplate.lit.js.map +1 -0
  244. package/dist/generated/templates/TableHeaderCellTemplate.lit.js +2 -1
  245. package/dist/generated/templates/TableHeaderCellTemplate.lit.js.map +1 -1
  246. package/dist/generated/templates/TableRowActionBaseTemplate.lit.js +2 -2
  247. package/dist/generated/templates/TableRowActionBaseTemplate.lit.js.map +1 -1
  248. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  249. package/dist/generated/themes/Avatar.css.js +1 -1
  250. package/dist/generated/themes/Avatar.css.js.map +1 -1
  251. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  252. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  253. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  254. package/dist/generated/themes/Bar.css.d.ts +1 -1
  255. package/dist/generated/themes/Bar.css.js +1 -1
  256. package/dist/generated/themes/Bar.css.js.map +1 -1
  257. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  258. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  259. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  260. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  261. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  262. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  263. package/dist/generated/themes/Button.css.d.ts +1 -1
  264. package/dist/generated/themes/Button.css.js +1 -1
  265. package/dist/generated/themes/Button.css.js.map +1 -1
  266. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  267. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  268. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  269. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  270. package/dist/generated/themes/Calendar.css.js +1 -1
  271. package/dist/generated/themes/Calendar.css.js.map +1 -1
  272. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  273. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  274. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  275. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  276. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  277. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  278. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  279. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  280. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  281. package/dist/generated/themes/Card.css.d.ts +1 -1
  282. package/dist/generated/themes/Card.css.js +1 -1
  283. package/dist/generated/themes/Card.css.js.map +1 -1
  284. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  285. package/dist/generated/themes/CardHeader.css.js +1 -1
  286. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  287. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  288. package/dist/generated/themes/Carousel.css.js +1 -1
  289. package/dist/generated/themes/Carousel.css.js.map +1 -1
  290. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  291. package/dist/generated/themes/CheckBox.css.js +1 -1
  292. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  293. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  294. package/dist/generated/themes/ColorPalette.css.js +1 -1
  295. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  296. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  297. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  298. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  299. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  300. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  301. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  302. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  303. package/dist/generated/themes/ColorPicker.css.js +1 -1
  304. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  305. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  306. package/dist/generated/themes/ComboBox.css.js +1 -1
  307. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  308. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  309. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  310. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  311. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  312. package/dist/generated/themes/DatePicker.css.js +1 -1
  313. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  314. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  315. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  316. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  317. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  318. package/dist/generated/themes/DayPicker.css.js +1 -1
  319. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  320. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  321. package/dist/generated/themes/Dialog.css.js +1 -1
  322. package/dist/generated/themes/Dialog.css.js.map +1 -1
  323. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  324. package/dist/generated/themes/FileUploader.css.js +1 -1
  325. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  326. package/dist/generated/themes/Form.css.d.ts +1 -1
  327. package/dist/generated/themes/Form.css.js +1 -1
  328. package/dist/generated/themes/Form.css.js.map +1 -1
  329. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  330. package/dist/generated/themes/FormItem.css.js +1 -1
  331. package/dist/generated/themes/FormItem.css.js.map +1 -1
  332. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  333. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  334. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  335. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  336. package/dist/generated/themes/GrowingButton.css.js +1 -1
  337. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  338. package/dist/generated/themes/Icon.css.d.ts +1 -1
  339. package/dist/generated/themes/Icon.css.js +1 -1
  340. package/dist/generated/themes/Icon.css.js.map +1 -1
  341. package/dist/generated/themes/Input.css.d.ts +1 -1
  342. package/dist/generated/themes/Input.css.js +1 -1
  343. package/dist/generated/themes/Input.css.js.map +1 -1
  344. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  345. package/dist/generated/themes/InputIcon.css.js +1 -1
  346. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  347. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  348. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  349. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  350. package/dist/generated/themes/Link.css.d.ts +1 -1
  351. package/dist/generated/themes/Link.css.js +1 -1
  352. package/dist/generated/themes/Link.css.js.map +1 -1
  353. package/dist/generated/themes/List.css.d.ts +1 -1
  354. package/dist/generated/themes/List.css.js +1 -1
  355. package/dist/generated/themes/List.css.js.map +1 -1
  356. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  357. package/dist/generated/themes/ListItem.css.js +1 -1
  358. package/dist/generated/themes/ListItem.css.js.map +1 -1
  359. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  360. package/dist/generated/themes/ListItemBase.css.js +1 -1
  361. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  362. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  363. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  364. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  365. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  366. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  367. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  368. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  369. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  370. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  371. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  372. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  373. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  374. package/dist/generated/themes/Menu.css.d.ts +1 -1
  375. package/dist/generated/themes/Menu.css.js +1 -1
  376. package/dist/generated/themes/Menu.css.js.map +1 -1
  377. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  378. package/dist/generated/themes/MenuItem.css.js +1 -1
  379. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  380. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  381. package/dist/generated/themes/MessageStrip.css.js +1 -1
  382. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  383. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  384. package/dist/generated/themes/MonthPicker.css.js +1 -1
  385. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  386. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  387. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  388. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  389. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  390. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  391. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  392. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  393. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  394. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  395. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  396. package/dist/generated/themes/MultiInput.css.js +1 -1
  397. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  398. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  399. package/dist/generated/themes/OptionBase.css.js +1 -1
  400. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  401. package/dist/generated/themes/Panel.css.d.ts +1 -1
  402. package/dist/generated/themes/Panel.css.js +1 -1
  403. package/dist/generated/themes/Panel.css.js.map +1 -1
  404. package/dist/generated/themes/Popover.css.d.ts +1 -1
  405. package/dist/generated/themes/Popover.css.js +1 -1
  406. package/dist/generated/themes/Popover.css.js.map +1 -1
  407. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  408. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  409. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  410. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  411. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  412. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  413. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  414. package/dist/generated/themes/RadioButton.css.js +1 -1
  415. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  416. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  417. package/dist/generated/themes/RangeSlider.css.js +1 -1
  418. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  419. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  420. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  421. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  422. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  423. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  424. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  425. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  426. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  427. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  428. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  429. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  430. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  431. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  432. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  433. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  434. package/dist/generated/themes/Select.css.d.ts +1 -1
  435. package/dist/generated/themes/Select.css.js +1 -1
  436. package/dist/generated/themes/Select.css.js.map +1 -1
  437. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  438. package/dist/generated/themes/SliderBase.css.js +1 -1
  439. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  440. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  441. package/dist/generated/themes/SplitButton.css.js +1 -1
  442. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  443. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  444. package/dist/generated/themes/StepInput.css.js +1 -1
  445. package/dist/generated/themes/StepInput.css.js.map +1 -1
  446. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  447. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  448. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  449. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  450. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  451. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  452. package/dist/generated/themes/Switch.css.d.ts +1 -1
  453. package/dist/generated/themes/Switch.css.js +1 -1
  454. package/dist/generated/themes/Switch.css.js.map +1 -1
  455. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  456. package/dist/generated/themes/TabContainer.css.js +1 -1
  457. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  458. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  459. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  460. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  461. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  462. package/dist/generated/themes/TabInStrip.css.js +1 -1
  463. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  464. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  465. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  466. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  467. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  468. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  469. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  470. package/dist/generated/themes/Table.css.d.ts +1 -1
  471. package/dist/generated/themes/Table.css.js +1 -1
  472. package/dist/generated/themes/Table.css.js.map +1 -1
  473. package/dist/generated/themes/TableCell.css.d.ts +1 -1
  474. package/dist/generated/themes/TableCell.css.js +1 -1
  475. package/dist/generated/themes/TableCell.css.js.map +1 -1
  476. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  477. package/dist/generated/themes/TableCellBase.css.js +1 -1
  478. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  479. package/dist/generated/themes/TableHeaderCell.css.d.ts +1 -1
  480. package/dist/generated/themes/TableHeaderCell.css.js +1 -1
  481. package/dist/generated/themes/TableHeaderCell.css.js.map +1 -1
  482. package/dist/generated/themes/TableHeaderCellActionBase.css.d.ts +2 -0
  483. package/dist/generated/themes/TableHeaderCellActionBase.css.js +8 -0
  484. package/dist/generated/themes/TableHeaderCellActionBase.css.js.map +1 -0
  485. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  486. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  487. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  488. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  489. package/dist/generated/themes/TableRow.css.js +1 -1
  490. package/dist/generated/themes/TableRow.css.js.map +1 -1
  491. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  492. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  493. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  494. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  495. package/dist/generated/themes/TableRowBase.css.js +1 -1
  496. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  497. package/dist/generated/themes/Tag.css.d.ts +1 -1
  498. package/dist/generated/themes/Tag.css.js +1 -1
  499. package/dist/generated/themes/Tag.css.js.map +1 -1
  500. package/dist/generated/themes/Text.css.d.ts +1 -1
  501. package/dist/generated/themes/Text.css.js +1 -1
  502. package/dist/generated/themes/Text.css.js.map +1 -1
  503. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  504. package/dist/generated/themes/TextArea.css.js +1 -1
  505. package/dist/generated/themes/TextArea.css.js.map +1 -1
  506. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  507. package/dist/generated/themes/TimePicker.css.js +1 -1
  508. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  509. package/dist/generated/themes/Toast.css.d.ts +1 -1
  510. package/dist/generated/themes/Toast.css.js +1 -1
  511. package/dist/generated/themes/Toast.css.js.map +1 -1
  512. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  513. package/dist/generated/themes/ToggleButton.css.js +1 -1
  514. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  515. package/dist/generated/themes/Token.css.d.ts +1 -1
  516. package/dist/generated/themes/Token.css.js +1 -1
  517. package/dist/generated/themes/Token.css.js.map +1 -1
  518. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  519. package/dist/generated/themes/Tokenizer.css.js +1 -1
  520. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  521. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  522. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  523. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  524. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  525. package/dist/generated/themes/Toolbar.css.js +1 -1
  526. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  527. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  528. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  529. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  530. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  531. package/dist/generated/themes/TreeItem.css.js +1 -1
  532. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  533. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  534. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  535. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  536. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  537. package/dist/generated/themes/YearPicker.css.js +1 -1
  538. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  539. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  540. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  541. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  542. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  543. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  544. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  545. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  546. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  547. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  548. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  549. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  550. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  551. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  552. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  553. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  554. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  555. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  556. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  557. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  558. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  559. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  560. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  561. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  562. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  563. package/dist/types/InteractiveAreaSize.d.ts +19 -0
  564. package/dist/types/InteractiveAreaSize.js +21 -0
  565. package/dist/types/InteractiveAreaSize.js.map +1 -0
  566. package/dist/vscode.html-custom-data.json +28 -2
  567. package/dist/web-types.json +56 -3
  568. package/package.json +11 -10
  569. package/src/ListItemTemplate.tsx +1 -2
  570. package/src/MultiComboBoxPopoverTemplate.tsx +150 -0
  571. package/src/MultiComboBoxTemplate.tsx +121 -0
  572. package/src/TableCell.hbs +6 -11
  573. package/src/TableHeaderCell.hbs +5 -1
  574. package/src/TableHeaderCellActionBase.hbs +6 -0
  575. package/src/TableRowActionBase.hbs +1 -2
  576. package/src/TimePickerPopoverTemplate.tsx +1 -1
  577. package/src/TimePickerTemplate.tsx +1 -1
  578. package/src/i18n/messagebundle.properties +4 -0
  579. package/src/i18n/messagebundle_ar.properties +0 -2
  580. package/src/i18n/messagebundle_bg.properties +0 -2
  581. package/src/i18n/messagebundle_ca.properties +0 -2
  582. package/src/i18n/messagebundle_cnr.properties +0 -2
  583. package/src/i18n/messagebundle_cs.properties +0 -2
  584. package/src/i18n/messagebundle_cy.properties +0 -2
  585. package/src/i18n/messagebundle_da.properties +0 -2
  586. package/src/i18n/messagebundle_de.properties +0 -2
  587. package/src/i18n/messagebundle_el.properties +0 -2
  588. package/src/i18n/messagebundle_en.properties +0 -2
  589. package/src/i18n/messagebundle_en_GB.properties +0 -2
  590. package/src/i18n/messagebundle_en_US_sappsd.properties +0 -2
  591. package/src/i18n/messagebundle_en_US_saptrc.properties +0 -2
  592. package/src/i18n/messagebundle_es.properties +0 -2
  593. package/src/i18n/messagebundle_es_MX.properties +0 -2
  594. package/src/i18n/messagebundle_et.properties +0 -2
  595. package/src/i18n/messagebundle_fi.properties +0 -2
  596. package/src/i18n/messagebundle_fr.properties +0 -2
  597. package/src/i18n/messagebundle_fr_CA.properties +9 -11
  598. package/src/i18n/messagebundle_hi.properties +0 -2
  599. package/src/i18n/messagebundle_hr.properties +0 -2
  600. package/src/i18n/messagebundle_hu.properties +0 -2
  601. package/src/i18n/messagebundle_id.properties +1 -3
  602. package/src/i18n/messagebundle_it.properties +0 -2
  603. package/src/i18n/messagebundle_iw.properties +0 -2
  604. package/src/i18n/messagebundle_ja.properties +0 -2
  605. package/src/i18n/messagebundle_kk.properties +0 -2
  606. package/src/i18n/messagebundle_ko.properties +0 -2
  607. package/src/i18n/messagebundle_lt.properties +0 -2
  608. package/src/i18n/messagebundle_lv.properties +0 -2
  609. package/src/i18n/messagebundle_mk.properties +0 -2
  610. package/src/i18n/messagebundle_ms.properties +0 -2
  611. package/src/i18n/messagebundle_nl.properties +5 -7
  612. package/src/i18n/messagebundle_no.properties +1 -3
  613. package/src/i18n/messagebundle_pl.properties +0 -2
  614. package/src/i18n/messagebundle_pt.properties +0 -2
  615. package/src/i18n/messagebundle_pt_PT.properties +0 -2
  616. package/src/i18n/messagebundle_ro.properties +0 -2
  617. package/src/i18n/messagebundle_ru.properties +0 -2
  618. package/src/i18n/messagebundle_sh.properties +0 -2
  619. package/src/i18n/messagebundle_sk.properties +0 -2
  620. package/src/i18n/messagebundle_sl.properties +0 -2
  621. package/src/i18n/messagebundle_sr.properties +0 -2
  622. package/src/i18n/messagebundle_sv.properties +1 -3
  623. package/src/i18n/messagebundle_th.properties +1 -3
  624. package/src/i18n/messagebundle_tr.properties +0 -2
  625. package/src/i18n/messagebundle_uk.properties +0 -2
  626. package/src/i18n/messagebundle_vi.properties +0 -2
  627. package/src/i18n/messagebundle_zh_CN.properties +0 -2
  628. package/src/i18n/messagebundle_zh_TW.properties +0 -2
  629. package/src/themes/Button.css +1 -0
  630. package/src/themes/Link.css +9 -0
  631. package/src/themes/TableCell.css +1 -0
  632. package/src/themes/TableHeaderCell.css +20 -3
  633. package/src/themes/TableHeaderCellActionBase.css +23 -0
  634. package/src/themes/TableRowActionBase.css +1 -0
  635. package/src/themes/base/Link-parameters.css +1 -1
  636. package/src/themes/base/Select-parameters.css +0 -5
  637. package/src/themes/sap_fiori_3_hcb/Select-parameters.css +0 -5
  638. package/src/themes/sap_fiori_3_hcw/Select-parameters.css +0 -5
  639. package/src/themes/sap_horizon/Link-parameters.css +1 -0
  640. package/src/themes/sap_horizon_dark/Link-parameters.css +1 -0
  641. package/src/themes/sap_horizon_hcb/Link-parameters.css +1 -0
  642. package/src/themes/sap_horizon_hcb/Select-parameters.css +0 -5
  643. package/src/themes/sap_horizon_hcw/Link-parameters.css +1 -0
  644. package/src/themes/sap_horizon_hcw/Select-parameters.css +0 -5
  645. package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.d.ts +0 -3
  646. package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.js +0 -29
  647. package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.js.map +0 -1
  648. package/dist/generated/templates/MultiComboBoxTemplate.lit.d.ts +0 -3
  649. package/dist/generated/templates/MultiComboBoxTemplate.lit.js +0 -39
  650. package/dist/generated/templates/MultiComboBoxTemplate.lit.js.map +0 -1
  651. package/src/MultiComboBox.hbs +0 -106
  652. package/src/MultiComboBoxPopover.hbs +0 -144
@@ -0,0 +1,703 @@
1
+ import Calendar from "../../src/Calendar.js";
2
+ import CalendarDate from "../../src/CalendarDate.js";
3
+ import CalendarDateRange from "../../src/CalendarDateRange.js";
4
+ import SpecialCalendarDate from "../../src/SpecialCalendarDate.js";
5
+ import "@ui5/webcomponents-localization/dist/features/calendar/Islamic.js";
6
+ import "@ui5/webcomponents-localization/dist/features/calendar/Gregorian.js";
7
+
8
+ const getDefaultCalendar = (date: Date) => {
9
+ const calDate = new Date(date);
10
+ const formattedDate = calDate.toLocaleDateString("default", {
11
+ year: "numeric",
12
+ month: "short",
13
+ day: "numeric",
14
+ });
15
+
16
+ return (<Calendar id="calendar1" timestamp={calDate.valueOf() / 1000}>
17
+ <CalendarDate value={formattedDate}></CalendarDate>
18
+ </Calendar>);
19
+ };
20
+
21
+ const getCalendarsWithWeekNumbers = () => (<>
22
+ <Calendar id="calendar1" calendarWeekNumbering="ISO_8601">
23
+ <CalendarDate value="Jan 1, 2023"></CalendarDate>
24
+ </Calendar>
25
+
26
+ <Calendar id="calendar2" calendarWeekNumbering="MiddleEastern">
27
+ <CalendarDate value="Jan 1, 2023"></CalendarDate>
28
+ </Calendar>
29
+
30
+ <Calendar id="calendar3" calendarWeekNumbering="WesternTraditional">
31
+ <CalendarDate value="Jan 1, 2023"></CalendarDate>
32
+ </Calendar>
33
+ </>);
34
+
35
+ describe("Calendar general interaction", () => {
36
+ it("Focus goes into the current day item of the day picker", () => {
37
+ const date = new Date(Date.UTC(2000, 10, 22, 0, 0, 0));
38
+ cy.mount(getDefaultCalendar(date));
39
+
40
+ cy.ui5CalendarGetDay("#calendar1", "974851200")
41
+ .should("have.focus");
42
+
43
+ cy.focused().realPress("Tab");
44
+
45
+ cy.get<Calendar>("#calendar1")
46
+ .shadow()
47
+ .find(".ui5-calheader")
48
+ .find("[data-ui5-cal-header-btn-month]")
49
+ .should("have.focus");
50
+
51
+ cy.focused().realPress("Tab");
52
+
53
+ cy.get<Calendar>("#calendar1")
54
+ .shadow()
55
+ .find(".ui5-calheader")
56
+ .find("[data-ui5-cal-header-btn-year]")
57
+ .should("have.focus");
58
+
59
+ cy.focused().realPress(["Shift", "Tab"]);
60
+
61
+ cy.get<Calendar>("#calendar1")
62
+ .shadow()
63
+ .find(".ui5-calheader")
64
+ .find("[data-ui5-cal-header-btn-month]")
65
+ .should("have.focus");
66
+
67
+ cy.focused().realPress(["Shift", "Tab"]);
68
+
69
+ cy.ui5CalendarGetDay("#calendar1", "974851200")
70
+ .should("have.focus");
71
+ });
72
+
73
+ it("Calendar focuses the selected year when yearpicker is opened", () => {
74
+ const YEAR = 1997;
75
+ const date = Date.UTC(YEAR);
76
+ cy.mount(getDefaultCalendar(new Date(date)));
77
+
78
+ cy.get<Calendar>("#calendar1")
79
+ .shadow()
80
+ .find(".ui5-calheader")
81
+ .find("[data-ui5-cal-header-btn-year]")
82
+ .click();
83
+
84
+ cy.get<Calendar>("#calendar1")
85
+ .shadow()
86
+ .find("[ui5-yearpicker]")
87
+ .shadow()
88
+ .find("[tabindex='0']")
89
+ .invoke("attr", "data-sap-timestamp")
90
+ .then(_timestamp => {
91
+ const focusedYear = new Date(parseInt(_timestamp!) * 1000).getUTCFullYear();
92
+ expect(focusedYear).to.equal(1997);
93
+ });
94
+ });
95
+
96
+ it("Calendar focuses the selected month when monthpicker is opened with space", () => {
97
+ const date = new Date(Date.UTC(2000, 10, 22, 0, 0, 0));
98
+ cy.mount(getDefaultCalendar(date));
99
+
100
+ cy.ui5CalendarGetDay("#calendar1", "974851200")
101
+ .click();
102
+
103
+ cy.focused().realPress("Tab");
104
+ cy.focused().realPress("Space");
105
+
106
+ cy.get<Calendar>("#calendar1")
107
+ .shadow()
108
+ .find("[ui5-monthpicker]")
109
+ .should("not.have.attr", "hidden");
110
+
111
+ cy.get<Calendar>("#calendar1")
112
+ .shadow()
113
+ .find("[ui5-monthpicker]")
114
+ .shadow()
115
+ .find("[tabindex='0']")
116
+ .invoke("attr", "data-sap-timestamp")
117
+ .then(_timestamp => {
118
+ const focusedMonth = new Date(parseInt(_timestamp!) * 1000).getUTCMonth();
119
+ expect(focusedMonth).to.equal(10);
120
+ });
121
+ });
122
+
123
+ it("Calendar focuses the selected year when yearpicker is opened with space", () => {
124
+ const date = new Date(Date.UTC(2000, 10, 22, 0, 0, 0));
125
+ cy.mount(getDefaultCalendar(date));
126
+
127
+ cy.ui5CalendarGetDay("#calendar1", "974851200")
128
+ .click();
129
+
130
+ cy.focused().realPress("Tab");
131
+ cy.focused().realPress("Tab");
132
+ cy.focused().realPress("Space");
133
+
134
+ cy.get<Calendar>("#calendar1")
135
+ .shadow()
136
+ .find("[ui5-yearpicker]")
137
+ .should("not.have.attr", "hidden");
138
+
139
+ cy.get<Calendar>("#calendar1")
140
+ .shadow()
141
+ .find("[ui5-yearpicker]")
142
+ .shadow()
143
+ .find("[tabindex='0']")
144
+ .invoke("attr", "data-sap-timestamp")
145
+ .then(_timestamp => {
146
+ const focusedYear = new Date(parseInt(_timestamp!) * 1000).getUTCFullYear();
147
+ expect(focusedYear).to.equal(2000);
148
+ });
149
+ });
150
+
151
+ it("Calendar doesn't mark year as selected when there are no selected dates", () => {
152
+ const todayDate = new Date();
153
+ const todayTimestamp = Date.UTC(todayDate.getFullYear(), todayDate.getMonth(), todayDate.getDate(), 0, 0, 0, 0) / 1000;
154
+
155
+ cy.mount(<Calendar id="calendar2"></Calendar>);
156
+
157
+ cy.get<Calendar>("#calendar2")
158
+ .shadow()
159
+ .find(".ui5-calheader")
160
+ .find("[data-ui5-cal-header-btn-year]")
161
+ .click();
162
+
163
+ cy.get<Calendar>("#calendar2")
164
+ .shadow()
165
+ .find("[ui5-yearpicker]")
166
+ .shadow()
167
+ .find(`[data-sap-timestamp=${todayTimestamp}]`)
168
+ .should("have.focus")
169
+ .should("not.have.class", "ui5-yp-item--selected");
170
+ });
171
+
172
+ it("Calendar doesn't mark month as selected when there are no selected dates", () => {
173
+ const todayDate = new Date();
174
+ const todayTimestamp = Date.UTC(todayDate.getFullYear(), todayDate.getMonth(), todayDate.getDate(), 0, 0, 0, 0) / 1000;
175
+
176
+ cy.mount(<Calendar id="calendar2"></Calendar>);
177
+
178
+ cy.get<Calendar>("#calendar2")
179
+ .shadow()
180
+ .find(".ui5-calheader")
181
+ .find("[data-ui5-cal-header-btn-month]")
182
+ .click();
183
+
184
+ cy.ui5CalendarGetMonth("#calendar2", todayTimestamp.toString())
185
+ .should("have.focus")
186
+ .should("not.have.class", "ui5-mp-item--selected");
187
+ });
188
+
189
+ it("Page up/down increments/decrements the month value", () => {
190
+ const date = new Date(Date.UTC(2000, 10, 1, 0, 0, 0));
191
+ cy.mount(getDefaultCalendar(date));
192
+
193
+ cy.get<Calendar>("#calendar1")
194
+ .shadow()
195
+ .find("[ui5-daypicker]")
196
+ .shadow()
197
+ .find("[tabindex='0']")
198
+ .click();
199
+
200
+ cy.focused().realPress("PageUp");
201
+
202
+ cy.get<Calendar>("#calendar1")
203
+ .invoke("prop", "timestamp")
204
+ .then(_timestamp => {
205
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 9, 1, 0, 0, 0)));
206
+ });
207
+
208
+ cy.focused().realPress("PageDown");
209
+
210
+ cy.get<Calendar>("#calendar1")
211
+ .invoke("prop", "timestamp")
212
+ .then(_timestamp => {
213
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 10, 1, 0, 0, 0)));
214
+ });
215
+ });
216
+
217
+ it("Shift + Page up/down increments/decrements the year value by one", () => {
218
+ const date = new Date(Date.UTC(2000, 10, 1, 0, 0, 0));
219
+ cy.mount(getDefaultCalendar(date));
220
+
221
+ cy.get<Calendar>("#calendar1")
222
+ .shadow()
223
+ .find("[ui5-daypicker]")
224
+ .shadow()
225
+ .find("[tabindex='0']")
226
+ .click();
227
+
228
+ cy.focused().realPress(["Shift", "PageUp"]);
229
+
230
+ cy.get<Calendar>("#calendar1")
231
+ .invoke("prop", "timestamp")
232
+ .then(_timestamp => {
233
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(1999, 10, 1, 0, 0, 0)));
234
+ });
235
+
236
+ cy.focused().realPress(["Shift", "PageDown"]);
237
+
238
+ cy.get<Calendar>("#calendar1")
239
+ .invoke("prop", "timestamp")
240
+ .then(_timestamp => {
241
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 10, 1, 0, 0, 0)));
242
+ });
243
+ });
244
+
245
+ it("Ctrl + Shift + Page up/down increments/decrements the year value by ten", () => {
246
+ const date = new Date(Date.UTC(2000, 10, 1, 0, 0, 0));
247
+ cy.mount(getDefaultCalendar(date));
248
+
249
+ cy.get<Calendar>("#calendar1")
250
+ .shadow()
251
+ .find("[ui5-daypicker]")
252
+ .shadow()
253
+ .find("[tabindex='0']")
254
+ .click();
255
+
256
+ cy.focused().realPress(["Control", "Shift", "PageUp"]);
257
+
258
+ cy.get<Calendar>("#calendar1")
259
+ .invoke("prop", "timestamp")
260
+ .then(_timestamp => {
261
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(1990, 10, 1, 0, 0, 0)));
262
+ });
263
+
264
+ cy.focused().realPress(["Control", "Shift", "PageDown"]);
265
+
266
+ cy.get<Calendar>("#calendar1")
267
+ .invoke("prop", "timestamp")
268
+ .then(_timestamp => {
269
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 10, 1, 0, 0, 0)));
270
+ });
271
+ });
272
+
273
+ it("Page up/down increments/decrements the year value in the month picker", () => {
274
+ const date = new Date(Date.UTC(2000, 9, 1, 0, 0, 0));
275
+ cy.mount(getDefaultCalendar(date));
276
+
277
+ cy.get<Calendar>("#calendar1")
278
+ .shadow()
279
+ .find("[ui5-daypicker]")
280
+ .shadow()
281
+ .find("[tabindex='0']")
282
+ .click();
283
+
284
+ cy.focused().realPress("F4");
285
+ cy.focused().realPress("PageUp");
286
+
287
+ cy.get<Calendar>("#calendar1")
288
+ .invoke("prop", "timestamp")
289
+ .then(_timestamp => {
290
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(1999, 9, 1, 0, 0, 0)));
291
+ });
292
+
293
+ cy.focused().realPress("PageDown");
294
+
295
+ cy.get<Calendar>("#calendar1")
296
+ .invoke("prop", "timestamp")
297
+ .then(_timestamp => {
298
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 9, 1, 0, 0, 0)));
299
+ });
300
+ });
301
+
302
+ it("Page up/down increments/decrements the year range in the year picker", () => {
303
+ const date = new Date(Date.UTC(2000, 9, 1, 0, 0, 0));
304
+ cy.mount(getDefaultCalendar(date));
305
+
306
+ cy.get<Calendar>("#calendar1")
307
+ .shadow()
308
+ .find("[ui5-daypicker]")
309
+ .shadow()
310
+ .find("[tabindex='0']")
311
+ .click();
312
+
313
+ cy.focused().realPress(["Shift", "F4"]);
314
+ cy.focused().realPress("PageUp");
315
+
316
+ cy.get<Calendar>("#calendar1")
317
+ .invoke("prop", "timestamp")
318
+ .then(_timestamp => {
319
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(1980, 9, 1, 0, 0, 0)));
320
+ });
321
+
322
+ cy.focused().realPress("PageDown");
323
+
324
+ cy.get<Calendar>("#calendar1")
325
+ .invoke("prop", "timestamp")
326
+ .then(_timestamp => {
327
+ expect(new Date(_timestamp * 1000)).to.deep.equal(new Date(Date.UTC(2000, 9, 1, 0, 0, 0)));
328
+ });
329
+ });
330
+
331
+ it("Calendar with 'Multiple' selection type", () => {
332
+ cy.mount(<Calendar id="calendar1" selectionMode="Multiple"></Calendar>);
333
+ const timestamp = new Date(Date.UTC(2000, 9, 10, 0, 0, 0)).valueOf() / 1000;
334
+
335
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
336
+
337
+ const timestamps = [971136000, 971222400, 971308800];
338
+
339
+ timestamps.forEach(_timestamp => {
340
+ cy.ui5CalendarGetDay("#calendar1", _timestamp.toString())
341
+ .as("date");
342
+
343
+ cy.get("@date").click();
344
+ cy.get("@date").should("have.class", "ui5-dp-item--selected");
345
+ });
346
+
347
+ cy.get<Calendar>("#calendar1")
348
+ .invoke("prop", "selectedDates")
349
+ .then(selectedDates => {
350
+ expect(selectedDates.sort()).to.deep.equal(timestamps.sort());
351
+ });
352
+ });
353
+
354
+ it("Keyboard navigation works properly, when calendar selection type is set to 'Multiple'", () => {
355
+ cy.mount(<Calendar id="calendar1" selectionMode="Multiple"></Calendar>);
356
+
357
+ const timestamp = new Date(Date.UTC(2000, 9, 10, 0, 0, 0)).valueOf() / 1000;
358
+
359
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
360
+
361
+ cy.ui5CalendarGetDay("#calendar1", timestamp.toString())
362
+ .focus();
363
+
364
+ // Select the focused date
365
+ cy.focused().realPress("Space");
366
+
367
+ // Deselect the focused date
368
+ cy.focused().realPress("Space");
369
+ cy.focused().realPress("ArrowRight");
370
+
371
+ cy.ui5CalendarGetDay("#calendar1", "971222400")
372
+ .should("have.focus");
373
+ });
374
+
375
+ it("Calendar with 'Range' selection type", () => {
376
+ cy.mount(<Calendar id="calendar1" selectionMode="Range"></Calendar>);
377
+ const timestamp = new Date(Date.UTC(2000, 9, 10, 0, 0, 0)).valueOf() / 1000;
378
+
379
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
380
+
381
+ const timestamps = [971740800, 971827200, 971913600];
382
+
383
+ cy.ui5CalendarGetDay("#calendar1", timestamps[0].toString())
384
+ .click();
385
+
386
+ cy.ui5CalendarGetDay("#calendar1", timestamps[2].toString())
387
+ .click();
388
+
389
+ cy.ui5CalendarGetDay("#calendar1", timestamps[0].toString())
390
+ .should("have.class", "ui5-dp-item--selected");
391
+
392
+ cy.ui5CalendarGetDay("#calendar1", timestamps[1].toString())
393
+ .should("have.class", "ui5-dp-item--selected-between");
394
+
395
+ cy.ui5CalendarGetDay("#calendar1", timestamps[2].toString())
396
+ .should("have.class", "ui5-dp-item--selected");
397
+
398
+ cy.get<Calendar>("#calendar1")
399
+ .invoke("prop", "selectedDates")
400
+ .then(selectedDates => {
401
+ expect(selectedDates.sort()).to.deep.equal([timestamps[0], timestamps[2]].sort());
402
+ });
403
+ });
404
+
405
+ it("Previous and next buttons are disabled when necessary", () => {
406
+ cy.mount(<>
407
+ <Calendar id="calendar1" formatPattern="dd/MM/yyyy" minDate="7/7/2020" maxDate="20/10/2020">
408
+ <CalendarDate value="08/07/2020"></CalendarDate>
409
+ </Calendar>
410
+ </>);
411
+ const timestamp = 1594166400;
412
+
413
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
414
+
415
+ cy.get<Calendar>("#calendar1")
416
+ .shadow()
417
+ .find(".ui5-calheader")
418
+ .find("[data-ui5-cal-header-btn-prev]")
419
+ .should("have.class", "ui5-calheader-arrowbtn-disabled");
420
+
421
+ cy.get<Calendar>("#calendar1")
422
+ .shadow()
423
+ .find(".ui5-calheader")
424
+ .find("[data-ui5-cal-header-btn-next]")
425
+ .should("not.have.class", "ui5-calheader-arrowbtn-disabled")
426
+ .click();
427
+
428
+ cy.get<Calendar>("#calendar1")
429
+ .shadow()
430
+ .find(".ui5-calheader")
431
+ .find("[data-ui5-cal-header-btn-prev]")
432
+ .should("not.have.class", "ui5-calheader-arrowbtn-disabled");
433
+
434
+ cy.get<Calendar>("#calendar1")
435
+ .shadow()
436
+ .find(".ui5-calheader")
437
+ .find("[data-ui5-cal-header-btn-next]")
438
+ .should("not.have.class", "ui5-calheader-arrowbtn-disabled");
439
+
440
+ cy.get<Calendar>("#calendar1")
441
+ .shadow()
442
+ .find(".ui5-calheader")
443
+ .find("[data-ui5-cal-header-btn-next]")
444
+ .click();
445
+
446
+ cy.get<Calendar>("#calendar1")
447
+ .shadow()
448
+ .find(".ui5-calheader")
449
+ .find("[data-ui5-cal-header-btn-next]")
450
+ .click();
451
+
452
+ cy.get<Calendar>("#calendar1")
453
+ .shadow()
454
+ .find(".ui5-calheader")
455
+ .find("[data-ui5-cal-header-btn-prev]")
456
+ .should("not.have.class", "ui5-calheader-arrowbtn-disabled");
457
+
458
+ cy.get<Calendar>("#calendar1")
459
+ .shadow()
460
+ .find(".ui5-calheader")
461
+ .find("[data-ui5-cal-header-btn-next]")
462
+ .should("have.class", "ui5-calheader-arrowbtn-disabled");
463
+ });
464
+
465
+ it("Second month and year are rendered in the header", () => {
466
+ cy.mount(<Calendar id="calendar1" primaryCalendarType="Islamic" secondaryCalendarType="Gregorian"></Calendar>);
467
+ const timestamp = new Date(Date.UTC(2000, 9, 10, 0, 0, 0)).valueOf() / 1000;
468
+
469
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
470
+
471
+ cy.get<Calendar>("#calendar1")
472
+ .shadow()
473
+ .find(".ui5-calheader")
474
+ .find("[data-ui5-cal-header-btn-month] > span")
475
+ .should("have.length", 2);
476
+
477
+ cy.get<Calendar>("#calendar1")
478
+ .shadow()
479
+ .find(".ui5-calheader")
480
+ .find("[data-ui5-cal-header-btn-year] > span")
481
+ .should("have.length", 2);
482
+ });
483
+
484
+ it("Buttons for month and year in header are rendered with correct value", () => {
485
+ cy.mount(<Calendar id="calendar1" primary-calendar-type="Islamic" secondary-calendar-type="Gregorian"></Calendar>);
486
+ const timestamp = new Date(Date.UTC(2000, 9, 10, 0, 0, 0)).valueOf() / 1000;
487
+
488
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
489
+
490
+ cy.get<Calendar>("#calendar1")
491
+ .shadow()
492
+ .find(".ui5-calheader")
493
+ .find("[data-ui5-cal-header-btn-month]")
494
+ .find("span")
495
+ .should(spans => {
496
+ expect(spans[0].textContent).to.equal("Rajab");
497
+ expect(spans[1].textContent).to.equal("Sep – Oct");
498
+ });
499
+
500
+ cy.get<Calendar>("#calendar1")
501
+ .shadow()
502
+ .find(".ui5-calheader")
503
+ .find("[data-ui5-cal-header-btn-year]")
504
+ .find("span")
505
+ .then(spans => {
506
+ expect(spans[0].textContent).to.equal("1421 AH");
507
+ expect(spans[1].textContent).to.equal("2000");
508
+ });
509
+ });
510
+
511
+ it("Calendar render two type for Month when MonthPicker is opened", () => {
512
+ cy.mount(<Calendar id="calendar1" primary-calendar-type='Islamic' secondary-calendar-type='Gregorian'></Calendar>);
513
+ const timestamp = new Date(Date.UTC(2000, 0, 1, 0, 0, 0)).valueOf() / 1000;
514
+
515
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
516
+
517
+ cy.get<Calendar>("#calendar1")
518
+ .shadow()
519
+ .find(".ui5-calheader")
520
+ .find("[data-ui5-cal-header-btn-month]")
521
+ .click();
522
+
523
+ cy.get<Calendar>("#calendar1")
524
+ .shadow()
525
+ .find("[ui5-monthpicker]")
526
+ .shadow()
527
+ .find(".ui5-mp-item")
528
+ .first()
529
+ .find("span")
530
+ .should("have.length", 2)
531
+ .then(spans => {
532
+ expect(spans[0]).to.have.text("Muharram");
533
+ expect(spans[1]).to.have.text("Apr – May");
534
+ });
535
+ });
536
+
537
+ it("Calendar render two type for Year when Year Picker is opened", () => {
538
+ cy.mount(<Calendar id="calendar1" primary-calendar-type='Islamic' secondary-calendar-type='Gregorian'></Calendar>);
539
+ const timestamp = new Date(Date.UTC(2000, 0, 1, 0, 0, 0)).valueOf() / 1000;
540
+
541
+ cy.get<Calendar>("#calendar1").invoke("prop", "timestamp", timestamp);
542
+
543
+ cy.get<Calendar>("#calendar1")
544
+ .shadow()
545
+ .find(".ui5-calheader")
546
+ .find("[data-ui5-cal-header-btn-year]")
547
+ .click();
548
+
549
+ cy.get<Calendar>("#calendar1")
550
+ .shadow()
551
+ .find("[ui5-yearpicker]")
552
+ .shadow()
553
+ .find(".ui5-yp-item")
554
+ .should("have.length", 8)
555
+ .first()
556
+ .find("span")
557
+ .should("have.length", 2)
558
+ .then(spans => {
559
+ expect(spans[0]).to.have.text("1416 AH");
560
+ expect(spans[1]).to.have.text("1995 - 1996");
561
+ });
562
+ });
563
+
564
+ it("Min and max dates are set without format-pattern by using ISO (YYYY-MM-dd) format", () => {
565
+ const maxDate = new Date(Date.UTC(2024, 9, 4, 0, 0, 0)).toISOString().split("T")[0];
566
+ cy.mount(<Calendar id="calendar1" maxDate={maxDate}></Calendar>);
567
+
568
+ cy.get<Calendar>("#calendar1")
569
+ .shadow()
570
+ .find(".ui5-calheader")
571
+ .find("[data-ui5-cal-header-btn-year]")
572
+ .click();
573
+
574
+ cy.get<Calendar>("#calendar1")
575
+ .shadow()
576
+ .find("[ui5-yearpicker]")
577
+ .shadow()
578
+ .find(".ui5-yp-root .ui5-yp-item")
579
+ .eq(11) // year 2025
580
+ .should("have.class", "ui5-yp-item--disabled");
581
+ });
582
+
583
+ it("Min and max dates are NOT set without format-pattern, because are not in ISO format (YYYY-MM-dd)", () => {
584
+ const maxDate = new Date(Date.UTC(2024, 9, 4, 0, 0, 0)).toString();
585
+ cy.mount(<Calendar id="calendar1" maxDate={maxDate} minDate="25.10.2018"></Calendar>);
586
+
587
+ cy.get<Calendar>("#calendar1")
588
+ .shadow()
589
+ .find(".ui5-calheader")
590
+ .find("[data-ui5-cal-header-btn-year]")
591
+ .click();
592
+
593
+ cy.get<Calendar>("#calendar1")
594
+ .shadow()
595
+ .find("[ui5-yearpicker]")
596
+ .shadow()
597
+ .find(".ui5-yp-root .ui5-yp-item")
598
+ .eq(3) // year 2016
599
+ .should("not.have.class", "ui5-yp-item--disabled");
600
+
601
+ cy.get<Calendar>("#calendar1")
602
+ .shadow()
603
+ .find("[ui5-yearpicker]")
604
+ .shadow()
605
+ .find(".ui5-yp-root .ui5-yp-item")
606
+ .eq(10) // year 2024
607
+ .should("not.have.class", "ui5-yp-item--disabled");
608
+ });
609
+
610
+ it("Focus goes into first selected day of the range selection", () => {
611
+ cy.mount(
612
+ <Calendar id="calendar1" primaryCalendarType="Gregorian" secondaryCalendarType="Gregorian" selectionMode="Range">
613
+ <CalendarDateRange startValue="Jan 20, 2021" endValue="Jan 30, 2021"></CalendarDateRange>
614
+ </Calendar>);
615
+
616
+ const timestamp = new Date(Date.UTC(2021, 0, 20, 0, 0, 0)).valueOf() / 1000; // 1611100800
617
+
618
+ cy.get<Calendar>("#calendar1")
619
+ .shadow()
620
+ .find(".ui5-calheader")
621
+ .find("[data-ui5-cal-header-btn-month]")
622
+ .click();
623
+
624
+ cy.ui5CalendarGetMonth("#calendar1", timestamp.toString())
625
+ .click();
626
+
627
+ cy.ui5CalendarGetDay("#calendar1", timestamp.toString())
628
+ .should("have.focus");
629
+ });
630
+
631
+ it("Special date respects format-pattern given to the calendar", () => {
632
+ cy.mount(
633
+ <Calendar id="calendar1" formatPattern="ddMMyyyy" minDate="01072020" maxDate="21102020">
634
+ <SpecialCalendarDate slot="specialDates" type="Type01" value="07102020"></SpecialCalendarDate>
635
+ </Calendar>);
636
+
637
+ cy.get<Calendar>("#calendar1")
638
+ .shadow()
639
+ .find("[ui5-daypicker]")
640
+ .shadow()
641
+ .find(".ui5-dp-root")
642
+ .find("div[data-ui5-special-day]")
643
+ .should("have.length", 1);
644
+ });
645
+
646
+ it("Check calendar week numbers with specific CalendarWeekNumbering configuration", () => {
647
+ cy.mount(getCalendarsWithWeekNumbers());
648
+
649
+ // Check first week number in ISO_8601 calendar
650
+ cy.get<Calendar>("#calendar1")
651
+ .shadow()
652
+ .find("[ui5-daypicker]")
653
+ .shadow()
654
+ .find(".ui5-dp-weekname")
655
+ .first()
656
+ .should("have.text", "52");
657
+
658
+ // Check first week number in MiddleEastern calendar
659
+ cy.get<Calendar>("#calendar2")
660
+ .shadow()
661
+ .find("[ui5-daypicker]")
662
+ .shadow()
663
+ .find(".ui5-dp-weekname")
664
+ .first()
665
+ .should("have.text", "1");
666
+
667
+ // Check first week number in WesternTraditional calendar
668
+ cy.get<Calendar>("#calendar3")
669
+ .shadow()
670
+ .find("[ui5-daypicker]")
671
+ .shadow()
672
+ .find(".ui5-dp-weekname")
673
+ .first()
674
+ .should("have.text", "1");
675
+ });
676
+
677
+ it("Check calendar week day names with specific CalendarWeekNumbering configuration", () => {
678
+ cy.mount(getCalendarsWithWeekNumbers());
679
+ cy.get<Calendar>("#calendar1")
680
+ .shadow()
681
+ .find("[ui5-daypicker]")
682
+ .shadow()
683
+ .find(".ui5-dp-firstday")
684
+ .first()
685
+ .should("have.text", "Mon");
686
+
687
+ cy.get<Calendar>("#calendar2")
688
+ .shadow()
689
+ .find("[ui5-daypicker]")
690
+ .shadow()
691
+ .find(".ui5-dp-firstday")
692
+ .first()
693
+ .should("have.text", "Sat");
694
+
695
+ cy.get<Calendar>("#calendar3")
696
+ .shadow()
697
+ .find("[ui5-daypicker]")
698
+ .shadow()
699
+ .find(".ui5-dp-firstday")
700
+ .first()
701
+ .should("have.text", "Sun");
702
+ });
703
+ });
@@ -1,5 +1,6 @@
1
1
  import SuggestionItem from "../../src/SuggestionItem.js";
2
2
  import MultiInput from "../../src/MultiInput.js";
3
+ import "../../src/Token.js";
3
4
 
4
5
  describe("MultiInput Web Component", () => {
5
6
  it("creates only one token when typing 'ad' and pressing Enter", () => {