@ui5/webcomponents 2.17.0-rc.4 → 2.17.0-rc.5

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 (506) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/Calendar.d.ts +18 -1
  4. package/dist/Calendar.js +14 -0
  5. package/dist/Calendar.js.map +1 -1
  6. package/dist/CalendarTemplate.js +1 -1
  7. package/dist/CalendarTemplate.js.map +1 -1
  8. package/dist/CheckBox.d.ts +2 -0
  9. package/dist/CheckBox.js +6 -2
  10. package/dist/CheckBox.js.map +1 -1
  11. package/dist/ColorPickerTemplate.js +1 -1
  12. package/dist/ColorPickerTemplate.js.map +1 -1
  13. package/dist/ComboBox.js.map +1 -1
  14. package/dist/DayPicker.d.ts +25 -1
  15. package/dist/DayPicker.js +54 -3
  16. package/dist/DayPicker.js.map +1 -1
  17. package/dist/Input.js +7 -6
  18. package/dist/Input.js.map +1 -1
  19. package/dist/InputPopoverTemplate.d.ts +1 -0
  20. package/dist/InputPopoverTemplate.js +7 -2
  21. package/dist/InputPopoverTemplate.js.map +1 -1
  22. package/dist/InputTemplate.d.ts +1 -0
  23. package/dist/InputTemplate.js +2 -1
  24. package/dist/InputTemplate.js.map +1 -1
  25. package/dist/MultiComboBox.js.map +1 -1
  26. package/dist/MultiInput.d.ts +22 -0
  27. package/dist/MultiInput.js +52 -1
  28. package/dist/MultiInput.js.map +1 -1
  29. package/dist/MultiInputTemplate.js +29 -1
  30. package/dist/MultiInputTemplate.js.map +1 -1
  31. package/dist/Select.d.ts +10 -1
  32. package/dist/Select.js +11 -0
  33. package/dist/Select.js.map +1 -1
  34. package/dist/TextArea.js.map +1 -1
  35. package/dist/Tokenizer.js.map +1 -1
  36. package/dist/ToolbarSelect.js +1 -0
  37. package/dist/ToolbarSelect.js.map +1 -1
  38. package/dist/bundle.common.bootstrap.d.ts +2 -0
  39. package/dist/bundle.common.bootstrap.js +3 -1
  40. package/dist/bundle.common.bootstrap.js.map +1 -1
  41. package/dist/bundle.esm.d.ts +2 -0
  42. package/dist/css/themes/Avatar.css +1 -1
  43. package/dist/css/themes/AvatarGroup.css +1 -1
  44. package/dist/css/themes/Bar.css +1 -1
  45. package/dist/css/themes/Breadcrumbs.css +1 -1
  46. package/dist/css/themes/BusyIndicator.css +1 -1
  47. package/dist/css/themes/Button.css +1 -1
  48. package/dist/css/themes/ButtonBadge.css +1 -1
  49. package/dist/css/themes/Calendar.css +1 -1
  50. package/dist/css/themes/CalendarHeader.css +1 -1
  51. package/dist/css/themes/CalendarLegend.css +1 -1
  52. package/dist/css/themes/CalendarLegendItem.css +1 -1
  53. package/dist/css/themes/Card.css +1 -1
  54. package/dist/css/themes/CardHeader.css +1 -1
  55. package/dist/css/themes/Carousel.css +1 -1
  56. package/dist/css/themes/CheckBox.css +1 -1
  57. package/dist/css/themes/ColorPalette.css +1 -1
  58. package/dist/css/themes/ColorPaletteItem.css +1 -1
  59. package/dist/css/themes/ColorPalettePopover.css +1 -1
  60. package/dist/css/themes/ColorPicker.css +1 -1
  61. package/dist/css/themes/ComboBox.css +1 -1
  62. package/dist/css/themes/ComboBoxItem.css +1 -1
  63. package/dist/css/themes/DatePicker.css +1 -1
  64. package/dist/css/themes/DatePickerPopover.css +1 -1
  65. package/dist/css/themes/DateTimePickerPopover.css +1 -1
  66. package/dist/css/themes/DayPicker.css +1 -1
  67. package/dist/css/themes/Dialog.css +1 -1
  68. package/dist/css/themes/DynamicDateRange.css +1 -1
  69. package/dist/css/themes/DynamicDateRangePopover.css +1 -1
  70. package/dist/css/themes/FileUploader.css +1 -1
  71. package/dist/css/themes/Form.css +1 -1
  72. package/dist/css/themes/FormItem.css +1 -1
  73. package/dist/css/themes/FormItemSpan.css +1 -1
  74. package/dist/css/themes/GrowingButton.css +1 -1
  75. package/dist/css/themes/Icon.css +1 -1
  76. package/dist/css/themes/Input.css +1 -1
  77. package/dist/css/themes/InputIcon.css +1 -1
  78. package/dist/css/themes/InputSharedStyles.css +1 -1
  79. package/dist/css/themes/Link.css +1 -1
  80. package/dist/css/themes/List.css +1 -1
  81. package/dist/css/themes/ListItem.css +1 -1
  82. package/dist/css/themes/ListItemBase.css +1 -1
  83. package/dist/css/themes/ListItemCustom.css +1 -1
  84. package/dist/css/themes/ListItemGroup.css +1 -1
  85. package/dist/css/themes/ListItemGroupHeader.css +1 -1
  86. package/dist/css/themes/ListItemIcon.css +1 -1
  87. package/dist/css/themes/Menu.css +1 -1
  88. package/dist/css/themes/MenuItem.css +1 -1
  89. package/dist/css/themes/MessageStrip.css +1 -1
  90. package/dist/css/themes/MonthPicker.css +1 -1
  91. package/dist/css/themes/MultiComboBox.css +1 -1
  92. package/dist/css/themes/MultiComboBoxItem.css +1 -1
  93. package/dist/css/themes/MultiComboBoxPopover.css +1 -1
  94. package/dist/css/themes/MultiInput.css +1 -1
  95. package/dist/css/themes/OptionBase.css +1 -1
  96. package/dist/css/themes/Panel.css +1 -1
  97. package/dist/css/themes/Popover.css +1 -1
  98. package/dist/css/themes/PopupsCommon.css +1 -1
  99. package/dist/css/themes/ProgressIndicator.css +1 -1
  100. package/dist/css/themes/RadioButton.css +1 -1
  101. package/dist/css/themes/RangeSlider.css +1 -1
  102. package/dist/css/themes/RatingIndicator.css +1 -1
  103. package/dist/css/themes/ResponsivePopover.css +1 -1
  104. package/dist/css/themes/ResponsivePopoverCommon.css +1 -1
  105. package/dist/css/themes/SegmentedButton.css +1 -1
  106. package/dist/css/themes/SegmentedButtonItem.css +1 -1
  107. package/dist/css/themes/Select.css +1 -1
  108. package/dist/css/themes/SliderBase.css +1 -1
  109. package/dist/css/themes/SplitButton.css +1 -1
  110. package/dist/css/themes/StepInput.css +1 -1
  111. package/dist/css/themes/SuggestionItem.css +1 -1
  112. package/dist/css/themes/SuggestionItemCustom.css +1 -1
  113. package/dist/css/themes/Suggestions.css +1 -1
  114. package/dist/css/themes/Switch.css +1 -1
  115. package/dist/css/themes/TabContainer.css +1 -1
  116. package/dist/css/themes/TabInOverflow.css +1 -1
  117. package/dist/css/themes/TabInStrip.css +1 -1
  118. package/dist/css/themes/TabSemanticIcon.css +1 -1
  119. package/dist/css/themes/TabSeparatorInOverflow.css +1 -1
  120. package/dist/css/themes/TableCellBase.css +1 -1
  121. package/dist/css/themes/TableHeaderRow.css +1 -1
  122. package/dist/css/themes/TableRow.css +1 -1
  123. package/dist/css/themes/TableRowActionBase.css +1 -1
  124. package/dist/css/themes/TableRowBase.css +1 -1
  125. package/dist/css/themes/Tag.css +1 -1
  126. package/dist/css/themes/Text.css +1 -1
  127. package/dist/css/themes/TextArea.css +1 -1
  128. package/dist/css/themes/TimePicker.css +1 -1
  129. package/dist/css/themes/Toast.css +1 -1
  130. package/dist/css/themes/ToggleButton.css +1 -1
  131. package/dist/css/themes/Token.css +1 -1
  132. package/dist/css/themes/Tokenizer.css +1 -1
  133. package/dist/css/themes/TokenizerPopover.css +1 -1
  134. package/dist/css/themes/Toolbar.css +1 -1
  135. package/dist/css/themes/ToolbarButton.css +1 -1
  136. package/dist/css/themes/ToolbarPopover.css +1 -1
  137. package/dist/css/themes/ToolbarSeparator.css +1 -1
  138. package/dist/css/themes/TreeItem.css +1 -1
  139. package/dist/css/themes/ValueStateMessage.css +1 -1
  140. package/dist/css/themes/ValueStateVariables.css +1 -1
  141. package/dist/css/themes/YearPicker.css +1 -1
  142. package/dist/css/themes/YearRangePicker.css +1 -1
  143. package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -1
  144. package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -1
  145. package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -1
  146. package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -1
  147. package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -1
  148. package/dist/css/themes/sap_horizon_dark/parameters-bundle.css +1 -1
  149. package/dist/css/themes/sap_horizon_hcb/parameters-bundle.css +1 -1
  150. package/dist/css/themes/sap_horizon_hcw/parameters-bundle.css +1 -1
  151. package/dist/custom-elements-internal.json +16 -0
  152. package/dist/custom-elements.json +4 -0
  153. package/dist/features/InputSuggestions.js.map +1 -1
  154. package/dist/features/InputSuggestionsTemplate.d.ts +1 -0
  155. package/dist/features/InputSuggestionsTemplate.js +4 -2
  156. package/dist/features/InputSuggestionsTemplate.js.map +1 -1
  157. package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
  158. package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
  159. package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -1
  160. package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -1
  161. package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -1
  162. package/dist/generated/assets/themes/sap_horizon_dark/parameters-bundle.css.json +1 -1
  163. package/dist/generated/assets/themes/sap_horizon_hcb/parameters-bundle.css.json +1 -1
  164. package/dist/generated/assets/themes/sap_horizon_hcw/parameters-bundle.css.json +1 -1
  165. package/dist/generated/i18n/i18n-defaults.d.ts +5 -1
  166. package/dist/generated/i18n/i18n-defaults.js +5 -1
  167. package/dist/generated/i18n/i18n-defaults.js.map +1 -1
  168. package/dist/generated/themes/Avatar.css.d.ts +1 -1
  169. package/dist/generated/themes/Avatar.css.js +1 -1
  170. package/dist/generated/themes/Avatar.css.js.map +1 -1
  171. package/dist/generated/themes/AvatarGroup.css.d.ts +1 -1
  172. package/dist/generated/themes/AvatarGroup.css.js +1 -1
  173. package/dist/generated/themes/AvatarGroup.css.js.map +1 -1
  174. package/dist/generated/themes/Bar.css.d.ts +1 -1
  175. package/dist/generated/themes/Bar.css.js +1 -1
  176. package/dist/generated/themes/Bar.css.js.map +1 -1
  177. package/dist/generated/themes/Breadcrumbs.css.d.ts +1 -1
  178. package/dist/generated/themes/Breadcrumbs.css.js +1 -1
  179. package/dist/generated/themes/Breadcrumbs.css.js.map +1 -1
  180. package/dist/generated/themes/BusyIndicator.css.d.ts +1 -1
  181. package/dist/generated/themes/BusyIndicator.css.js +1 -1
  182. package/dist/generated/themes/BusyIndicator.css.js.map +1 -1
  183. package/dist/generated/themes/Button.css.d.ts +1 -1
  184. package/dist/generated/themes/Button.css.js +1 -1
  185. package/dist/generated/themes/Button.css.js.map +1 -1
  186. package/dist/generated/themes/ButtonBadge.css.d.ts +1 -1
  187. package/dist/generated/themes/ButtonBadge.css.js +1 -1
  188. package/dist/generated/themes/ButtonBadge.css.js.map +1 -1
  189. package/dist/generated/themes/Calendar.css.d.ts +1 -1
  190. package/dist/generated/themes/Calendar.css.js +1 -1
  191. package/dist/generated/themes/Calendar.css.js.map +1 -1
  192. package/dist/generated/themes/CalendarHeader.css.d.ts +1 -1
  193. package/dist/generated/themes/CalendarHeader.css.js +1 -1
  194. package/dist/generated/themes/CalendarHeader.css.js.map +1 -1
  195. package/dist/generated/themes/CalendarLegend.css.d.ts +1 -1
  196. package/dist/generated/themes/CalendarLegend.css.js +1 -1
  197. package/dist/generated/themes/CalendarLegend.css.js.map +1 -1
  198. package/dist/generated/themes/CalendarLegendItem.css.d.ts +1 -1
  199. package/dist/generated/themes/CalendarLegendItem.css.js +1 -1
  200. package/dist/generated/themes/CalendarLegendItem.css.js.map +1 -1
  201. package/dist/generated/themes/Card.css.d.ts +1 -1
  202. package/dist/generated/themes/Card.css.js +1 -1
  203. package/dist/generated/themes/Card.css.js.map +1 -1
  204. package/dist/generated/themes/CardHeader.css.d.ts +1 -1
  205. package/dist/generated/themes/CardHeader.css.js +1 -1
  206. package/dist/generated/themes/CardHeader.css.js.map +1 -1
  207. package/dist/generated/themes/Carousel.css.d.ts +1 -1
  208. package/dist/generated/themes/Carousel.css.js +1 -1
  209. package/dist/generated/themes/Carousel.css.js.map +1 -1
  210. package/dist/generated/themes/CheckBox.css.d.ts +1 -1
  211. package/dist/generated/themes/CheckBox.css.js +1 -1
  212. package/dist/generated/themes/CheckBox.css.js.map +1 -1
  213. package/dist/generated/themes/ColorPalette.css.d.ts +1 -1
  214. package/dist/generated/themes/ColorPalette.css.js +1 -1
  215. package/dist/generated/themes/ColorPalette.css.js.map +1 -1
  216. package/dist/generated/themes/ColorPaletteItem.css.d.ts +1 -1
  217. package/dist/generated/themes/ColorPaletteItem.css.js +1 -1
  218. package/dist/generated/themes/ColorPaletteItem.css.js.map +1 -1
  219. package/dist/generated/themes/ColorPalettePopover.css.d.ts +1 -1
  220. package/dist/generated/themes/ColorPalettePopover.css.js +1 -1
  221. package/dist/generated/themes/ColorPalettePopover.css.js.map +1 -1
  222. package/dist/generated/themes/ColorPicker.css.d.ts +1 -1
  223. package/dist/generated/themes/ColorPicker.css.js +1 -1
  224. package/dist/generated/themes/ColorPicker.css.js.map +1 -1
  225. package/dist/generated/themes/ComboBox.css.d.ts +1 -1
  226. package/dist/generated/themes/ComboBox.css.js +1 -1
  227. package/dist/generated/themes/ComboBox.css.js.map +1 -1
  228. package/dist/generated/themes/ComboBoxItem.css.d.ts +1 -1
  229. package/dist/generated/themes/ComboBoxItem.css.js +1 -1
  230. package/dist/generated/themes/ComboBoxItem.css.js.map +1 -1
  231. package/dist/generated/themes/DatePicker.css.d.ts +1 -1
  232. package/dist/generated/themes/DatePicker.css.js +1 -1
  233. package/dist/generated/themes/DatePicker.css.js.map +1 -1
  234. package/dist/generated/themes/DatePickerPopover.css.d.ts +1 -1
  235. package/dist/generated/themes/DatePickerPopover.css.js +1 -1
  236. package/dist/generated/themes/DatePickerPopover.css.js.map +1 -1
  237. package/dist/generated/themes/DateTimePickerPopover.css.d.ts +1 -1
  238. package/dist/generated/themes/DateTimePickerPopover.css.js +1 -1
  239. package/dist/generated/themes/DateTimePickerPopover.css.js.map +1 -1
  240. package/dist/generated/themes/DayPicker.css.d.ts +1 -1
  241. package/dist/generated/themes/DayPicker.css.js +1 -1
  242. package/dist/generated/themes/DayPicker.css.js.map +1 -1
  243. package/dist/generated/themes/Dialog.css.d.ts +1 -1
  244. package/dist/generated/themes/Dialog.css.js +1 -1
  245. package/dist/generated/themes/Dialog.css.js.map +1 -1
  246. package/dist/generated/themes/DynamicDateRange.css.d.ts +1 -1
  247. package/dist/generated/themes/DynamicDateRange.css.js +1 -1
  248. package/dist/generated/themes/DynamicDateRange.css.js.map +1 -1
  249. package/dist/generated/themes/DynamicDateRangePopover.css.d.ts +1 -1
  250. package/dist/generated/themes/DynamicDateRangePopover.css.js +1 -1
  251. package/dist/generated/themes/DynamicDateRangePopover.css.js.map +1 -1
  252. package/dist/generated/themes/FileUploader.css.d.ts +1 -1
  253. package/dist/generated/themes/FileUploader.css.js +1 -1
  254. package/dist/generated/themes/FileUploader.css.js.map +1 -1
  255. package/dist/generated/themes/Form.css.d.ts +1 -1
  256. package/dist/generated/themes/Form.css.js +1 -1
  257. package/dist/generated/themes/Form.css.js.map +1 -1
  258. package/dist/generated/themes/FormItem.css.d.ts +1 -1
  259. package/dist/generated/themes/FormItem.css.js +1 -1
  260. package/dist/generated/themes/FormItem.css.js.map +1 -1
  261. package/dist/generated/themes/FormItemSpan.css.d.ts +1 -1
  262. package/dist/generated/themes/FormItemSpan.css.js +1 -1
  263. package/dist/generated/themes/FormItemSpan.css.js.map +1 -1
  264. package/dist/generated/themes/GrowingButton.css.d.ts +1 -1
  265. package/dist/generated/themes/GrowingButton.css.js +1 -1
  266. package/dist/generated/themes/GrowingButton.css.js.map +1 -1
  267. package/dist/generated/themes/Icon.css.d.ts +1 -1
  268. package/dist/generated/themes/Icon.css.js +1 -1
  269. package/dist/generated/themes/Icon.css.js.map +1 -1
  270. package/dist/generated/themes/Input.css.d.ts +1 -1
  271. package/dist/generated/themes/Input.css.js +1 -1
  272. package/dist/generated/themes/Input.css.js.map +1 -1
  273. package/dist/generated/themes/InputIcon.css.d.ts +1 -1
  274. package/dist/generated/themes/InputIcon.css.js +1 -1
  275. package/dist/generated/themes/InputIcon.css.js.map +1 -1
  276. package/dist/generated/themes/InputSharedStyles.css.d.ts +1 -1
  277. package/dist/generated/themes/InputSharedStyles.css.js +1 -1
  278. package/dist/generated/themes/InputSharedStyles.css.js.map +1 -1
  279. package/dist/generated/themes/Link.css.d.ts +1 -1
  280. package/dist/generated/themes/Link.css.js +1 -1
  281. package/dist/generated/themes/Link.css.js.map +1 -1
  282. package/dist/generated/themes/List.css.d.ts +1 -1
  283. package/dist/generated/themes/List.css.js +1 -1
  284. package/dist/generated/themes/List.css.js.map +1 -1
  285. package/dist/generated/themes/ListItem.css.d.ts +1 -1
  286. package/dist/generated/themes/ListItem.css.js +1 -1
  287. package/dist/generated/themes/ListItem.css.js.map +1 -1
  288. package/dist/generated/themes/ListItemBase.css.d.ts +1 -1
  289. package/dist/generated/themes/ListItemBase.css.js +1 -1
  290. package/dist/generated/themes/ListItemBase.css.js.map +1 -1
  291. package/dist/generated/themes/ListItemCustom.css.d.ts +1 -1
  292. package/dist/generated/themes/ListItemCustom.css.js +1 -1
  293. package/dist/generated/themes/ListItemCustom.css.js.map +1 -1
  294. package/dist/generated/themes/ListItemGroup.css.d.ts +1 -1
  295. package/dist/generated/themes/ListItemGroup.css.js +1 -1
  296. package/dist/generated/themes/ListItemGroup.css.js.map +1 -1
  297. package/dist/generated/themes/ListItemGroupHeader.css.d.ts +1 -1
  298. package/dist/generated/themes/ListItemGroupHeader.css.js +1 -1
  299. package/dist/generated/themes/ListItemGroupHeader.css.js.map +1 -1
  300. package/dist/generated/themes/ListItemIcon.css.d.ts +1 -1
  301. package/dist/generated/themes/ListItemIcon.css.js +1 -1
  302. package/dist/generated/themes/ListItemIcon.css.js.map +1 -1
  303. package/dist/generated/themes/Menu.css.d.ts +1 -1
  304. package/dist/generated/themes/Menu.css.js +1 -1
  305. package/dist/generated/themes/Menu.css.js.map +1 -1
  306. package/dist/generated/themes/MenuItem.css.d.ts +1 -1
  307. package/dist/generated/themes/MenuItem.css.js +1 -1
  308. package/dist/generated/themes/MenuItem.css.js.map +1 -1
  309. package/dist/generated/themes/MessageStrip.css.d.ts +1 -1
  310. package/dist/generated/themes/MessageStrip.css.js +1 -1
  311. package/dist/generated/themes/MessageStrip.css.js.map +1 -1
  312. package/dist/generated/themes/MonthPicker.css.d.ts +1 -1
  313. package/dist/generated/themes/MonthPicker.css.js +1 -1
  314. package/dist/generated/themes/MonthPicker.css.js.map +1 -1
  315. package/dist/generated/themes/MultiComboBox.css.d.ts +1 -1
  316. package/dist/generated/themes/MultiComboBox.css.js +1 -1
  317. package/dist/generated/themes/MultiComboBox.css.js.map +1 -1
  318. package/dist/generated/themes/MultiComboBoxItem.css.d.ts +1 -1
  319. package/dist/generated/themes/MultiComboBoxItem.css.js +1 -1
  320. package/dist/generated/themes/MultiComboBoxItem.css.js.map +1 -1
  321. package/dist/generated/themes/MultiComboBoxPopover.css.d.ts +1 -1
  322. package/dist/generated/themes/MultiComboBoxPopover.css.js +1 -1
  323. package/dist/generated/themes/MultiComboBoxPopover.css.js.map +1 -1
  324. package/dist/generated/themes/MultiInput.css.d.ts +1 -1
  325. package/dist/generated/themes/MultiInput.css.js +1 -1
  326. package/dist/generated/themes/MultiInput.css.js.map +1 -1
  327. package/dist/generated/themes/OptionBase.css.d.ts +1 -1
  328. package/dist/generated/themes/OptionBase.css.js +1 -1
  329. package/dist/generated/themes/OptionBase.css.js.map +1 -1
  330. package/dist/generated/themes/Panel.css.d.ts +1 -1
  331. package/dist/generated/themes/Panel.css.js +1 -1
  332. package/dist/generated/themes/Panel.css.js.map +1 -1
  333. package/dist/generated/themes/Popover.css.d.ts +1 -1
  334. package/dist/generated/themes/Popover.css.js +1 -1
  335. package/dist/generated/themes/Popover.css.js.map +1 -1
  336. package/dist/generated/themes/PopupsCommon.css.d.ts +1 -1
  337. package/dist/generated/themes/PopupsCommon.css.js +1 -1
  338. package/dist/generated/themes/PopupsCommon.css.js.map +1 -1
  339. package/dist/generated/themes/ProgressIndicator.css.d.ts +1 -1
  340. package/dist/generated/themes/ProgressIndicator.css.js +1 -1
  341. package/dist/generated/themes/ProgressIndicator.css.js.map +1 -1
  342. package/dist/generated/themes/RadioButton.css.d.ts +1 -1
  343. package/dist/generated/themes/RadioButton.css.js +1 -1
  344. package/dist/generated/themes/RadioButton.css.js.map +1 -1
  345. package/dist/generated/themes/RangeSlider.css.d.ts +1 -1
  346. package/dist/generated/themes/RangeSlider.css.js +1 -1
  347. package/dist/generated/themes/RangeSlider.css.js.map +1 -1
  348. package/dist/generated/themes/RatingIndicator.css.d.ts +1 -1
  349. package/dist/generated/themes/RatingIndicator.css.js +1 -1
  350. package/dist/generated/themes/RatingIndicator.css.js.map +1 -1
  351. package/dist/generated/themes/ResponsivePopover.css.d.ts +1 -1
  352. package/dist/generated/themes/ResponsivePopover.css.js +1 -1
  353. package/dist/generated/themes/ResponsivePopover.css.js.map +1 -1
  354. package/dist/generated/themes/ResponsivePopoverCommon.css.d.ts +1 -1
  355. package/dist/generated/themes/ResponsivePopoverCommon.css.js +1 -1
  356. package/dist/generated/themes/ResponsivePopoverCommon.css.js.map +1 -1
  357. package/dist/generated/themes/SegmentedButton.css.d.ts +1 -1
  358. package/dist/generated/themes/SegmentedButton.css.js +1 -1
  359. package/dist/generated/themes/SegmentedButton.css.js.map +1 -1
  360. package/dist/generated/themes/SegmentedButtonItem.css.d.ts +1 -1
  361. package/dist/generated/themes/SegmentedButtonItem.css.js +1 -1
  362. package/dist/generated/themes/SegmentedButtonItem.css.js.map +1 -1
  363. package/dist/generated/themes/Select.css.d.ts +1 -1
  364. package/dist/generated/themes/Select.css.js +1 -1
  365. package/dist/generated/themes/Select.css.js.map +1 -1
  366. package/dist/generated/themes/SliderBase.css.d.ts +1 -1
  367. package/dist/generated/themes/SliderBase.css.js +1 -1
  368. package/dist/generated/themes/SliderBase.css.js.map +1 -1
  369. package/dist/generated/themes/SplitButton.css.d.ts +1 -1
  370. package/dist/generated/themes/SplitButton.css.js +1 -1
  371. package/dist/generated/themes/SplitButton.css.js.map +1 -1
  372. package/dist/generated/themes/StepInput.css.d.ts +1 -1
  373. package/dist/generated/themes/StepInput.css.js +1 -1
  374. package/dist/generated/themes/StepInput.css.js.map +1 -1
  375. package/dist/generated/themes/SuggestionItem.css.d.ts +1 -1
  376. package/dist/generated/themes/SuggestionItem.css.js +1 -1
  377. package/dist/generated/themes/SuggestionItem.css.js.map +1 -1
  378. package/dist/generated/themes/SuggestionItemCustom.css.d.ts +1 -1
  379. package/dist/generated/themes/SuggestionItemCustom.css.js +1 -1
  380. package/dist/generated/themes/SuggestionItemCustom.css.js.map +1 -1
  381. package/dist/generated/themes/Suggestions.css.d.ts +1 -1
  382. package/dist/generated/themes/Suggestions.css.js +1 -1
  383. package/dist/generated/themes/Suggestions.css.js.map +1 -1
  384. package/dist/generated/themes/Switch.css.d.ts +1 -1
  385. package/dist/generated/themes/Switch.css.js +1 -1
  386. package/dist/generated/themes/Switch.css.js.map +1 -1
  387. package/dist/generated/themes/TabContainer.css.d.ts +1 -1
  388. package/dist/generated/themes/TabContainer.css.js +1 -1
  389. package/dist/generated/themes/TabContainer.css.js.map +1 -1
  390. package/dist/generated/themes/TabInOverflow.css.d.ts +1 -1
  391. package/dist/generated/themes/TabInOverflow.css.js +1 -1
  392. package/dist/generated/themes/TabInOverflow.css.js.map +1 -1
  393. package/dist/generated/themes/TabInStrip.css.d.ts +1 -1
  394. package/dist/generated/themes/TabInStrip.css.js +1 -1
  395. package/dist/generated/themes/TabInStrip.css.js.map +1 -1
  396. package/dist/generated/themes/TabSemanticIcon.css.d.ts +1 -1
  397. package/dist/generated/themes/TabSemanticIcon.css.js +1 -1
  398. package/dist/generated/themes/TabSemanticIcon.css.js.map +1 -1
  399. package/dist/generated/themes/TabSeparatorInOverflow.css.d.ts +1 -1
  400. package/dist/generated/themes/TabSeparatorInOverflow.css.js +1 -1
  401. package/dist/generated/themes/TabSeparatorInOverflow.css.js.map +1 -1
  402. package/dist/generated/themes/TableCellBase.css.d.ts +1 -1
  403. package/dist/generated/themes/TableCellBase.css.js +1 -1
  404. package/dist/generated/themes/TableCellBase.css.js.map +1 -1
  405. package/dist/generated/themes/TableHeaderRow.css.d.ts +1 -1
  406. package/dist/generated/themes/TableHeaderRow.css.js +1 -1
  407. package/dist/generated/themes/TableHeaderRow.css.js.map +1 -1
  408. package/dist/generated/themes/TableRow.css.d.ts +1 -1
  409. package/dist/generated/themes/TableRow.css.js +1 -1
  410. package/dist/generated/themes/TableRow.css.js.map +1 -1
  411. package/dist/generated/themes/TableRowActionBase.css.d.ts +1 -1
  412. package/dist/generated/themes/TableRowActionBase.css.js +1 -1
  413. package/dist/generated/themes/TableRowActionBase.css.js.map +1 -1
  414. package/dist/generated/themes/TableRowBase.css.d.ts +1 -1
  415. package/dist/generated/themes/TableRowBase.css.js +1 -1
  416. package/dist/generated/themes/TableRowBase.css.js.map +1 -1
  417. package/dist/generated/themes/Tag.css.d.ts +1 -1
  418. package/dist/generated/themes/Tag.css.js +1 -1
  419. package/dist/generated/themes/Tag.css.js.map +1 -1
  420. package/dist/generated/themes/Text.css.d.ts +1 -1
  421. package/dist/generated/themes/Text.css.js +1 -1
  422. package/dist/generated/themes/Text.css.js.map +1 -1
  423. package/dist/generated/themes/TextArea.css.d.ts +1 -1
  424. package/dist/generated/themes/TextArea.css.js +1 -1
  425. package/dist/generated/themes/TextArea.css.js.map +1 -1
  426. package/dist/generated/themes/TimePicker.css.d.ts +1 -1
  427. package/dist/generated/themes/TimePicker.css.js +1 -1
  428. package/dist/generated/themes/TimePicker.css.js.map +1 -1
  429. package/dist/generated/themes/Toast.css.d.ts +1 -1
  430. package/dist/generated/themes/Toast.css.js +1 -1
  431. package/dist/generated/themes/Toast.css.js.map +1 -1
  432. package/dist/generated/themes/ToggleButton.css.d.ts +1 -1
  433. package/dist/generated/themes/ToggleButton.css.js +1 -1
  434. package/dist/generated/themes/ToggleButton.css.js.map +1 -1
  435. package/dist/generated/themes/Token.css.d.ts +1 -1
  436. package/dist/generated/themes/Token.css.js +1 -1
  437. package/dist/generated/themes/Token.css.js.map +1 -1
  438. package/dist/generated/themes/Tokenizer.css.d.ts +1 -1
  439. package/dist/generated/themes/Tokenizer.css.js +1 -1
  440. package/dist/generated/themes/Tokenizer.css.js.map +1 -1
  441. package/dist/generated/themes/TokenizerPopover.css.d.ts +1 -1
  442. package/dist/generated/themes/TokenizerPopover.css.js +1 -1
  443. package/dist/generated/themes/TokenizerPopover.css.js.map +1 -1
  444. package/dist/generated/themes/Toolbar.css.d.ts +1 -1
  445. package/dist/generated/themes/Toolbar.css.js +1 -1
  446. package/dist/generated/themes/Toolbar.css.js.map +1 -1
  447. package/dist/generated/themes/ToolbarButton.css.d.ts +1 -1
  448. package/dist/generated/themes/ToolbarButton.css.js +1 -1
  449. package/dist/generated/themes/ToolbarButton.css.js.map +1 -1
  450. package/dist/generated/themes/ToolbarPopover.css.d.ts +1 -1
  451. package/dist/generated/themes/ToolbarPopover.css.js +1 -1
  452. package/dist/generated/themes/ToolbarPopover.css.js.map +1 -1
  453. package/dist/generated/themes/ToolbarSeparator.css.d.ts +1 -1
  454. package/dist/generated/themes/ToolbarSeparator.css.js +1 -1
  455. package/dist/generated/themes/ToolbarSeparator.css.js.map +1 -1
  456. package/dist/generated/themes/TreeItem.css.d.ts +1 -1
  457. package/dist/generated/themes/TreeItem.css.js +1 -1
  458. package/dist/generated/themes/TreeItem.css.js.map +1 -1
  459. package/dist/generated/themes/ValueStateMessage.css.d.ts +1 -1
  460. package/dist/generated/themes/ValueStateMessage.css.js +1 -1
  461. package/dist/generated/themes/ValueStateMessage.css.js.map +1 -1
  462. package/dist/generated/themes/ValueStateVariables.css.d.ts +1 -1
  463. package/dist/generated/themes/ValueStateVariables.css.js +1 -1
  464. package/dist/generated/themes/ValueStateVariables.css.js.map +1 -1
  465. package/dist/generated/themes/YearPicker.css.d.ts +1 -1
  466. package/dist/generated/themes/YearPicker.css.js +1 -1
  467. package/dist/generated/themes/YearPicker.css.js.map +1 -1
  468. package/dist/generated/themes/YearRangePicker.css.d.ts +1 -1
  469. package/dist/generated/themes/YearRangePicker.css.js +1 -1
  470. package/dist/generated/themes/YearRangePicker.css.js.map +1 -1
  471. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.d.ts +1 -1
  472. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
  473. package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js.map +1 -1
  474. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.d.ts +1 -1
  475. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
  476. package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js.map +1 -1
  477. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.d.ts +1 -1
  478. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -1
  479. package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js.map +1 -1
  480. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.d.ts +1 -1
  481. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -1
  482. package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js.map +1 -1
  483. package/dist/generated/themes/sap_horizon/parameters-bundle.css.d.ts +1 -1
  484. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -1
  485. package/dist/generated/themes/sap_horizon/parameters-bundle.css.js.map +1 -1
  486. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.d.ts +1 -1
  487. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js +1 -1
  488. package/dist/generated/themes/sap_horizon_dark/parameters-bundle.css.js.map +1 -1
  489. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.d.ts +1 -1
  490. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js +1 -1
  491. package/dist/generated/themes/sap_horizon_hcb/parameters-bundle.css.js.map +1 -1
  492. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.d.ts +1 -1
  493. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js +1 -1
  494. package/dist/generated/themes/sap_horizon_hcw/parameters-bundle.css.js.map +1 -1
  495. package/dist/vscode.html-custom-data.json +1 -1
  496. package/dist/web-types.json +6 -2
  497. package/package.json +9 -11
  498. package/src/CalendarTemplate.tsx +1 -0
  499. package/src/ColorPickerTemplate.tsx +1 -0
  500. package/src/InputPopoverTemplate.tsx +11 -5
  501. package/src/InputTemplate.tsx +3 -2
  502. package/src/MultiInputTemplate.tsx +76 -1
  503. package/src/features/InputSuggestionsTemplate.tsx +21 -18
  504. package/src/i18n/messagebundle.properties +12 -0
  505. package/src/themes/Suggestions.css +4 -0
  506. package/src/themes/TabInStrip.css +1 -1
@@ -63,6 +63,18 @@ declare class MultiInput extends Input implements IFormInputElement {
63
63
  * @public
64
64
  */
65
65
  name?: string;
66
+ /**
67
+ * Indicates whether to show tokens in suggestions popover
68
+ * @default false
69
+ * @private
70
+ */
71
+ _showTokensInSuggestions: boolean;
72
+ /**
73
+ * Tracks whether user has explicitly toggled the show tokens state
74
+ * @default false
75
+ * @private
76
+ */
77
+ _userToggledShowTokens: boolean;
66
78
  /**
67
79
  * Defines the component tokens.
68
80
  * @public
@@ -91,12 +103,17 @@ declare class MultiInput extends Input implements IFormInputElement {
91
103
  */
92
104
  _onfocusin(e: FocusEvent): void;
93
105
  onBeforeRendering(): void;
106
+ /**
107
+ * Override the _handlePickerAfterOpen method to reset toggle state when dialog opens with tokens
108
+ */
109
+ _handlePickerAfterOpen(): void;
94
110
  onAfterRendering(): void;
95
111
  get iconsCount(): number;
96
112
  get tokenizer(): Tokenizer;
97
113
  get tokenizerExpanded(): boolean;
98
114
  get _tokensCountText(): string;
99
115
  get _valueHelpText(): string;
116
+ get _filterButtonAccessibleName(): string;
100
117
  get _tokensCountTextId(): string;
101
118
  get _valueHelpTextId(): "" | "hiddenText-value-help";
102
119
  /**
@@ -121,6 +138,11 @@ declare class MultiInput extends Input implements IFormInputElement {
121
138
  get ariaRoleDescription(): string;
122
139
  get morePopoverOpener(): HTMLElement;
123
140
  get shouldDisplayOnlyValueStateMessage(): boolean;
141
+ /**
142
+ * Computes the effective state for showing tokens in suggestions.
143
+ * Defaults to true when tokens exist, but respects explicit user toggle.
144
+ */
145
+ get _effectiveShowTokensInSuggestions(): boolean;
124
146
  }
125
147
  export default MultiInput;
126
148
  export type { IToken, MultiInputTokenDeleteEventDetail, MultiInputSelectionChangeEventDetail, };
@@ -12,7 +12,7 @@ import customElement from "@ui5/webcomponents-base/dist/decorators/customElement
12
12
  import jsxRenderer from "@ui5/webcomponents-base/dist/renderer/JsxRenderer.js";
13
13
  import { isShow, isBackSpace, isLeft, isRight, isRightCtrl, isHome, isEnd, isDown, isEnter, } from "@ui5/webcomponents-base/dist/Keys.js";
14
14
  import { getScopedVarName } from "@ui5/webcomponents-base/dist/CustomElementsScope.js";
15
- import { MULTIINPUT_ROLEDESCRIPTION_TEXT, MULTIINPUT_VALUE_HELP_LABEL, MULTIINPUT_VALUE_HELP } from "./generated/i18n/i18n-defaults.js";
15
+ import { MULTIINPUT_ROLEDESCRIPTION_TEXT, MULTIINPUT_VALUE_HELP_LABEL, MULTIINPUT_VALUE_HELP, MULTIINPUT_FILTER_BUTTON_LABEL, } from "./generated/i18n/i18n-defaults.js";
16
16
  import Input from "./Input.js";
17
17
  import MultiInputTemplate from "./MultiInputTemplate.js";
18
18
  import styles from "./generated/themes/MultiInput.css.js";
@@ -69,6 +69,18 @@ let MultiInput = MultiInput_1 = class MultiInput extends Input {
69
69
  * @private
70
70
  */
71
71
  this.tokenizerAvailable = false;
72
+ /**
73
+ * Indicates whether to show tokens in suggestions popover
74
+ * @default false
75
+ * @private
76
+ */
77
+ this._showTokensInSuggestions = false;
78
+ /**
79
+ * Tracks whether user has explicitly toggled the show tokens state
80
+ * @default false
81
+ * @private
82
+ */
83
+ this._userToggledShowTokens = false;
72
84
  // Prevent suggestions' opening.
73
85
  this._skipOpenSuggestions = false;
74
86
  this._valueHelpIconPressed = false;
@@ -216,6 +228,20 @@ let MultiInput = MultiInput_1 = class MultiInput extends Input {
216
228
  if (this.tokenizer) {
217
229
  this.tokenizer.readonly = this.readonly;
218
230
  }
231
+ // Reset toggle state if there are tokens and dialog is about to open
232
+ if (this.tokens.length > 0 && !this._userToggledShowTokens) {
233
+ this._showTokensInSuggestions = true;
234
+ }
235
+ }
236
+ /**
237
+ * Override the _handlePickerAfterOpen method to reset toggle state when dialog opens with tokens
238
+ */
239
+ _handlePickerAfterOpen() {
240
+ if (this.tokens.length > 0) {
241
+ this._showTokensInSuggestions = true;
242
+ this._userToggledShowTokens = false;
243
+ }
244
+ super._handlePickerAfterOpen();
219
245
  }
220
246
  onAfterRendering() {
221
247
  super.onAfterRendering();
@@ -236,6 +262,9 @@ let MultiInput = MultiInput_1 = class MultiInput extends Input {
236
262
  get _valueHelpText() {
237
263
  return MultiInput_1.i18nBundle.getText(MULTIINPUT_VALUE_HELP);
238
264
  }
265
+ get _filterButtonAccessibleName() {
266
+ return MultiInput_1.i18nBundle.getText(MULTIINPUT_FILTER_BUTTON_LABEL);
267
+ }
239
268
  get _tokensCountTextId() {
240
269
  return `hiddenText-nMore`;
241
270
  }
@@ -275,6 +304,22 @@ let MultiInput = MultiInput_1 = class MultiInput extends Input {
275
304
  get shouldDisplayOnlyValueStateMessage() {
276
305
  return this.hasValueStateMessage && !this.readonly && !this.open && this.focused && !this.tokenizer.open;
277
306
  }
307
+ /**
308
+ * Computes the effective state for showing tokens in suggestions.
309
+ * Defaults to true when tokens exist, but respects explicit user toggle.
310
+ */
311
+ get _effectiveShowTokensInSuggestions() {
312
+ // If no tokens exist, always false
313
+ if (this.tokens.length === 0) {
314
+ return false;
315
+ }
316
+ // If user has never interacted with the toggle, default to true when tokens exist
317
+ if (!this._userToggledShowTokens) {
318
+ return true;
319
+ }
320
+ // If user has interacted, respect their choice
321
+ return this._showTokensInSuggestions;
322
+ }
278
323
  };
279
324
  __decorate([
280
325
  property({ type: Boolean })
@@ -285,6 +330,12 @@ __decorate([
285
330
  __decorate([
286
331
  property()
287
332
  ], MultiInput.prototype, "name", void 0);
333
+ __decorate([
334
+ property({ type: Boolean })
335
+ ], MultiInput.prototype, "_showTokensInSuggestions", void 0);
336
+ __decorate([
337
+ property({ type: Boolean })
338
+ ], MultiInput.prototype, "_userToggledShowTokens", void 0);
288
339
  __decorate([
289
340
  slot({ type: HTMLElement, individualSlots: true })
290
341
  ], MultiInput.prototype, "tokens", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"MultiInput.js","sourceRoot":"","sources":["../src/MultiInput.ts"],"names":[],"mappings":"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","sourcesContent":["import type UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event-strict.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport jsxRenderer from \"@ui5/webcomponents-base/dist/renderer/JsxRenderer.js\";\nimport {\n\tisShow,\n\tisBackSpace,\n\tisLeft,\n\tisRight,\n\tisRightCtrl,\n\tisHome,\n\tisEnd,\n\tisDown,\n\tisEnter,\n\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport type { ITabbable } from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport { getScopedVarName } from \"@ui5/webcomponents-base/dist/CustomElementsScope.js\";\nimport type { IFormInputElement } from \"@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js\";\nimport { MULTIINPUT_ROLEDESCRIPTION_TEXT, MULTIINPUT_VALUE_HELP_LABEL, MULTIINPUT_VALUE_HELP } from \"./generated/i18n/i18n-defaults.js\";\nimport Input from \"./Input.js\";\nimport MultiInputTemplate from \"./MultiInputTemplate.js\";\nimport styles from \"./generated/themes/MultiInput.css.js\";\nimport type Token from \"./Token.js\";\nimport type Tokenizer from \"./Tokenizer.js\";\nimport { getTokensCountText } from \"./Tokenizer.js\";\nimport type { TokenizerTokenDeleteEventDetail } from \"./Tokenizer.js\";\nimport type Icon from \"./Icon.js\";\n\nimport type {\n\tInputSelectionChangeEventDetail as MultiInputSelectionChangeEventDetail,\n} from \"./Input.js\";\n\ninterface IToken extends UI5Element, ITabbable {\n\ttext?: string;\n\treadonly: boolean,\n\tselected: boolean,\n\tisTruncatable: boolean,\n}\n\ntype MultiInputTokenDeleteEventDetail = {\n\ttokens: Token[];\n}\n\n/**\n * @class\n * ### Overview\n * A `ui5-multi-input` field allows the user to enter multiple values, which are displayed as `ui5-token`.\n *\n * User can choose interaction for creating tokens.\n * Fiori Guidelines say that user should create tokens when:\n *\n * - Type a value in the input and press enter or focus out the input field (`change` event is fired)\n * - Move between suggestion items (`selection-change` event is fired)\n * - Clicking on a suggestion item (`selection-change` event is fired if the clicked item is different than the current value. Also `change` event is fired )\n *\n * ### ES6 Module Import\n *\n * `import \"@ui5/webcomponents/dist/MultiInput.js\";`\n * @constructor\n * @extends Input\n * @since 1.0.0-rc.9\n * @public\n */\n@customElement({\n\ttag: \"ui5-multi-input\",\n\trenderer: jsxRenderer,\n\tformAssociated: true,\n\ttemplate: MultiInputTemplate,\n\tstyles: [Input.styles, styles],\n})\n/**\n * Fired when the value help icon is pressed\n * and F4 or ALT/OPTION + ARROW_UP/ARROW_DOWN keyboard keys are used.\n * @public\n */\n@event(\"value-help-trigger\", {\n\tbubbles: true,\n})\n\n/**\n * Fired when tokens are being deleted.\n * @param {Array} tokens An array containing the deleted tokens.\n * @public\n */\n@event(\"token-delete\", {\n\tbubbles: true,\n})\n\nclass MultiInput extends Input implements IFormInputElement {\n\teventDetails!: Input[\"eventDetails\"] & {\n\t\t\"value-help-trigger\": void,\n\t\t\"token-delete\": MultiInputTokenDeleteEventDetail,\n\t}\n\t/**\n\t * Determines whether a value help icon will be visualized in the end of the input.\n\t * Pressing the icon will fire `value-help-trigger` event.\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tshowValueHelpIcon = false;\n\n\t/**\n\t * Indicates whether the tokenizer has tokens\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\ttokenizerAvailable = false;\n\n\t/**\n\t * Determines the name by which the component will be identified upon submission in an HTML form.\n\t *\n\t * **Note:** This property is only applicable within the context of an HTML Form element.\n\t * **Note:** When the component is used inside a form element,\n\t * the value is sent as the first element in the form data, even if it's empty.\n\t * @default undefined\n\t * @public\n\t */\n\t@property()\n\tdeclare name?: string;\n\n\t/**\n\t * Defines the component tokens.\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, individualSlots: true })\n\ttokens!: Array<IToken>;\n\n\t_skipOpenSuggestions: boolean;\n\t_valueHelpIconPressed: boolean;\n\n\tget formValidity(): ValidityStateFlags {\n\t\tconst tokens = (this.tokens || []);\n\n\t\treturn { valueMissing: this.required && !this.value && !tokens.length };\n\t}\n\n\tget formFormattedValue(): FormData | string | null {\n\t\tconst tokens = (this.tokens || []);\n\n\t\tif (tokens.length && this.name) {\n\t\t\tconst formData = new FormData();\n\n\t\t\tformData.append(this.name, this.value);\n\n\t\t\tfor (let i = 0; i < tokens.length; i++) {\n\t\t\t\tformData.append(this.name, (tokens[i].text || \"\"));\n\t\t\t}\n\n\t\t\treturn formData;\n\t\t}\n\n\t\treturn this.value;\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\t// Prevent suggestions' opening.\n\t\tthis._skipOpenSuggestions = false;\n\t\tthis._valueHelpIconPressed = false;\n\t}\n\n\tvalueHelpPress() {\n\t\tthis.closeValueStatePopover();\n\t\tthis.fireDecoratorEvent(\"value-help-trigger\");\n\t}\n\n\ttokenDelete(e: CustomEvent<TokenizerTokenDeleteEventDetail>) {\n\t\tconst deletedTokens = e.detail.tokens;\n\t\tconst selectedTokens = this.tokens.filter(token => token.selected);\n\t\tconst shouldFocusInput = this.tokens.length - 1 === 0 || this.tokens.length === selectedTokens.length;\n\n\t\tif (this._readonly) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (deletedTokens) {\n\t\t\tthis.fireDecoratorEvent(\"token-delete\", { tokens: deletedTokens });\n\n\t\t\tif (shouldFocusInput) {\n\t\t\t\tthis.focus();\n\t\t\t}\n\t\t}\n\t}\n\n\tvalueHelpMouseDown(e: MouseEvent) {\n\t\tconst target = e.target as Icon;\n\t\tthis.closeValueStatePopover();\n\t\tthis.tokenizer.open = false;\n\t\tthis._valueHelpIconPressed = true;\n\t\ttarget.focus();\n\t}\n\n\t_tokenizerFocusOut(e: FocusEvent) {\n\t\tif (!this.contains(e.relatedTarget as HTMLElement) && !this.shadowRoot!.contains(e.relatedTarget as HTMLElement)) {\n\t\t\tthis.tokenizer._tokens.forEach(token => { token.selected = false; });\n\t\t}\n\t}\n\n\tvalueHelpMouseUp() {\n\t\tsetTimeout(() => {\n\t\t\tthis._valueHelpIconPressed = false;\n\t\t}, 0);\n\t}\n\n\tinnerFocusIn() {\n\t\tthis.tokenizer._scrollToEndOnExpand = true;\n\t\tthis.tokenizer.expanded = true;\n\t\tthis.focused = true;\n\n\t\tthis.tokens.forEach(token => {\n\t\t\ttoken.selected = false;\n\t\t});\n\t}\n\n\t_showMoreItemsPress() {\n\t\tthis.tokenizer._scrollToEndOnExpand = true;\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\t!this._isComposing && super._onkeydown(e);\n\n\t\tconst target = e.target as HTMLInputElement;\n\t\tconst isHomeInBeginning = isHome(e) && target.selectionStart === 0;\n\n\t\tif (isHomeInBeginning) {\n\t\t\tthis._skipOpenSuggestions = true; // Prevent input focus when navigating through the tokens\n\t\t\treturn this._focusFirstToken(e);\n\t\t}\n\n\t\tif (isEnter(e) && !!this._internals.form) {\n\t\t\te.preventDefault();\n\t\t}\n\n\t\tif (isLeft(e)) {\n\t\t\tthis._skipOpenSuggestions = true;\n\t\t\treturn this._handleLeft(e);\n\t\t}\n\n\t\tif (isBackSpace(e)) {\n\t\t\tthis._skipOpenSuggestions = true;\n\t\t\treturn this._handleBackspace(e);\n\t\t}\n\n\t\tthis._skipOpenSuggestions = false;\n\n\t\tif (isShow(e)) {\n\t\t\tthis.valueHelpPress();\n\t\t}\n\t}\n\n\t_onTokenizerKeydown(e: KeyboardEvent) {\n\t\tconst rightCtrl = isRightCtrl(e);\n\t\tif (isRight(e) || isDown(e) || isEnd(e) || rightCtrl) {\n\t\t\te.preventDefault();\n\t\t\tconst lastTokenIndex = this.tokens.length - 1;\n\n\t\t\tif (e.target === this.tokens[lastTokenIndex] && this.tokens[lastTokenIndex] === document.activeElement) {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis.focus();\n\t\t\t\t}, 0);\n\t\t\t}\n\t\t}\n\t}\n\n\t_handleLeft(e: KeyboardEvent) {\n\t\tconst cursorPosition = this.getDomRef()!.querySelector(`input`)!.selectionStart;\n\t\tconst tokens = this.tokens;\n\t\tconst lastToken = tokens.length && tokens[tokens.length - 1];\n\n\t\t// selectionStart property applies only to inputs of types text, search, URL, tel, and password\n\t\tif (((cursorPosition === null && !this.value) || cursorPosition === 0) && lastToken) {\n\t\t\te.preventDefault();\n\t\t\tlastToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(lastToken);\n\t\t}\n\t}\n\n\t_handleBackspace(e: KeyboardEvent) {\n\t\tconst cursorPosition = this.getDomRef()!.querySelector(`input`)!.selectionStart;\n\t\tconst selectionEnd = this.getDomRef()!.querySelector(`input`)!.selectionEnd;\n\t\tconst isValueSelected = cursorPosition === 0 && selectionEnd === this.value.length;\n\t\tconst tokens = this.tokens;\n\t\tconst lastToken = tokens.length && tokens[tokens.length - 1];\n\n\t\t// selectionStart property applies only to inputs of types text, search, URL, tel, and password\n\t\tif ((!this.value || (this.value && cursorPosition === 0 && !isValueSelected)) && lastToken) {\n\t\t\te.preventDefault();\n\t\t\tlastToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(lastToken);\n\t\t}\n\t}\n\n\t_focusFirstToken(e: KeyboardEvent) {\n\t\tconst tokens = this.tokens;\n\t\tconst firstToken = tokens.length && tokens[0];\n\n\t\tif (firstToken) {\n\t\t\te.preventDefault();\n\n\t\t\tfirstToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(firstToken);\n\t\t}\n\t}\n\n\t_onfocusout(e: FocusEvent) {\n\t\tsuper._onfocusout(e);\n\t\tconst relatedTarget = e.relatedTarget as HTMLElement;\n\t\tconst insideDOM = this.contains(relatedTarget);\n\t\tconst insideShadowDom = this.shadowRoot!.contains(relatedTarget);\n\n\t\tif (!insideDOM && !insideShadowDom) {\n\t\t\tthis.tokenizer.expanded = false;\n\t\t}\n\n\t\tif (this.contains(relatedTarget) && relatedTarget.hasAttribute(\"ui5-token\")) {\n\t\t\tthis.focused = false;\n\t\t}\n\t}\n\n\t/**\n\t * @override\n\t */\n\t_onfocusin(e: FocusEvent) {\n\t\tconst inputDomRef = this.getInputDOMRef();\n\n\t\tif (e.target === inputDomRef) {\n\t\t\tsuper._onfocusin(e);\n\t\t}\n\t}\n\n\tonBeforeRendering() {\n\t\tsuper.onBeforeRendering();\n\n\t\tthis.style.setProperty(getScopedVarName(\"--_ui5-input-icons-count\"), `${this.iconsCount}`);\n\t\tthis.tokenizerAvailable = this.tokens && this.tokens.length > 0;\n\n\t\tif (this.tokenizer) {\n\t\t\tthis.tokenizer.readonly = this.readonly;\n\t\t}\n\t}\n\n\tonAfterRendering() {\n\t\tsuper.onAfterRendering();\n\n\t\tthis.tokenizer.preventInitialFocus = true;\n\t}\n\n\tget iconsCount() {\n\t\treturn super.iconsCount + (this.showValueHelpIcon ? 1 : 0);\n\t}\n\n\tget tokenizer() {\n\t\treturn this.shadowRoot!.querySelector<Tokenizer>(\"[ui5-tokenizer]\")!;\n\t}\n\n\tget tokenizerExpanded() {\n\t\treturn this.tokenizer && this.tokenizer.expanded;\n\t}\n\n\tget _tokensCountText() {\n\t\treturn getTokensCountText(this.tokens.length);\n\t}\n\n\tget _valueHelpText() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_VALUE_HELP);\n\t}\n\n\tget _tokensCountTextId() {\n\t\treturn `hiddenText-nMore`;\n\t}\n\n\tget _valueHelpTextId() {\n\t\treturn this.showValueHelpIcon ? `hiddenText-value-help` : \"\";\n\t}\n\n\t/**\n\t * Returns the placeholder value when there are no tokens.\n\t * @protected\n\t */\n\tget _placeholder() {\n\t\tif (this.tokens.length) {\n\t\t\treturn \"\";\n\t\t}\n\n\t\treturn this.placeholder;\n\t}\n\n\tget accInfo() {\n\t\tconst ariaDescribedBy = `${this._tokensCountTextId} ${this.suggestionsTextId} ${this.valueStateTextId} ${this._valueStateLinksShortcutsTextAccId} ${this._valueHelpTextId}`.trim();\n\t\treturn {\n\t\t\t...super.accInfo,\n\t\t\t\"ariaRoledescription\": this.ariaRoleDescription,\n\t\t\t\"ariaDescribedBy\": ariaDescribedBy,\n\t\t};\n\t}\n\n\tget valueHelpLabel() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_VALUE_HELP_LABEL);\n\t}\n\n\tget ariaRoleDescription() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_ROLEDESCRIPTION_TEXT);\n\t}\n\n\tget morePopoverOpener(): HTMLElement {\n\t\tif (this.tokens.length === 1 && this.tokens[0].isTruncatable) {\n\t\t\treturn this.tokens[0];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tget shouldDisplayOnlyValueStateMessage() {\n\t\treturn this.hasValueStateMessage && !this.readonly && !this.open && this.focused && !this.tokenizer.open;\n\t}\n}\n\nMultiInput.define();\n\nexport default MultiInput;\nexport type {\n\tIToken,\n\tMultiInputTokenDeleteEventDetail,\n\tMultiInputSelectionChangeEventDetail,\n};\n"]}
1
+ {"version":3,"file":"MultiInput.js","sourceRoot":"","sources":["../src/MultiInput.ts"],"names":[],"mappings":"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","sourcesContent":["import type UI5Element from \"@ui5/webcomponents-base/dist/UI5Element.js\";\nimport property from \"@ui5/webcomponents-base/dist/decorators/property.js\";\nimport slot from \"@ui5/webcomponents-base/dist/decorators/slot.js\";\nimport event from \"@ui5/webcomponents-base/dist/decorators/event-strict.js\";\nimport customElement from \"@ui5/webcomponents-base/dist/decorators/customElement.js\";\nimport jsxRenderer from \"@ui5/webcomponents-base/dist/renderer/JsxRenderer.js\";\nimport {\n\tisShow,\n\tisBackSpace,\n\tisLeft,\n\tisRight,\n\tisRightCtrl,\n\tisHome,\n\tisEnd,\n\tisDown,\n\tisEnter,\n\n} from \"@ui5/webcomponents-base/dist/Keys.js\";\nimport type { ITabbable } from \"@ui5/webcomponents-base/dist/delegate/ItemNavigation.js\";\nimport { getScopedVarName } from \"@ui5/webcomponents-base/dist/CustomElementsScope.js\";\nimport type { IFormInputElement } from \"@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js\";\nimport {\n\tMULTIINPUT_ROLEDESCRIPTION_TEXT,\n\tMULTIINPUT_VALUE_HELP_LABEL,\n\tMULTIINPUT_VALUE_HELP,\n\tMULTIINPUT_FILTER_BUTTON_LABEL,\n} from \"./generated/i18n/i18n-defaults.js\";\nimport Input from \"./Input.js\";\nimport MultiInputTemplate from \"./MultiInputTemplate.js\";\nimport styles from \"./generated/themes/MultiInput.css.js\";\nimport type Token from \"./Token.js\";\nimport type Tokenizer from \"./Tokenizer.js\";\nimport { getTokensCountText } from \"./Tokenizer.js\";\nimport type { TokenizerTokenDeleteEventDetail } from \"./Tokenizer.js\";\nimport type Icon from \"./Icon.js\";\n\nimport type {\n\tInputSelectionChangeEventDetail as MultiInputSelectionChangeEventDetail,\n} from \"./Input.js\";\n\ninterface IToken extends UI5Element, ITabbable {\n\ttext?: string;\n\treadonly: boolean,\n\tselected: boolean,\n\tisTruncatable: boolean,\n}\n\ntype MultiInputTokenDeleteEventDetail = {\n\ttokens: Token[];\n}\n\n/**\n * @class\n * ### Overview\n * A `ui5-multi-input` field allows the user to enter multiple values, which are displayed as `ui5-token`.\n *\n * User can choose interaction for creating tokens.\n * Fiori Guidelines say that user should create tokens when:\n *\n * - Type a value in the input and press enter or focus out the input field (`change` event is fired)\n * - Move between suggestion items (`selection-change` event is fired)\n * - Clicking on a suggestion item (`selection-change` event is fired if the clicked item is different than the current value. Also `change` event is fired )\n *\n * ### ES6 Module Import\n *\n * `import \"@ui5/webcomponents/dist/MultiInput.js\";`\n * @constructor\n * @extends Input\n * @since 1.0.0-rc.9\n * @public\n */\n@customElement({\n\ttag: \"ui5-multi-input\",\n\trenderer: jsxRenderer,\n\tformAssociated: true,\n\ttemplate: MultiInputTemplate,\n\tstyles: [Input.styles, styles],\n})\n/**\n * Fired when the value help icon is pressed\n * and F4 or ALT/OPTION + ARROW_UP/ARROW_DOWN keyboard keys are used.\n * @public\n */\n@event(\"value-help-trigger\", {\n\tbubbles: true,\n})\n\n/**\n * Fired when tokens are being deleted.\n * @param {Array} tokens An array containing the deleted tokens.\n * @public\n */\n@event(\"token-delete\", {\n\tbubbles: true,\n})\n\nclass MultiInput extends Input implements IFormInputElement {\n\teventDetails!: Input[\"eventDetails\"] & {\n\t\t\"value-help-trigger\": void,\n\t\t\"token-delete\": MultiInputTokenDeleteEventDetail,\n\t}\n\t/**\n\t * Determines whether a value help icon will be visualized in the end of the input.\n\t * Pressing the icon will fire `value-help-trigger` event.\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tshowValueHelpIcon = false;\n\n\t/**\n\t * Indicates whether the tokenizer has tokens\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\ttokenizerAvailable = false;\n\n\t/**\n\t * Determines the name by which the component will be identified upon submission in an HTML form.\n\t *\n\t * **Note:** This property is only applicable within the context of an HTML Form element.\n\t * **Note:** When the component is used inside a form element,\n\t * the value is sent as the first element in the form data, even if it's empty.\n\t * @default undefined\n\t * @public\n\t */\n\t@property()\n\tdeclare name?: string;\n\n\t/**\n\t * Indicates whether to show tokens in suggestions popover\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_showTokensInSuggestions = false;\n\n\t/**\n\t * Tracks whether user has explicitly toggled the show tokens state\n\t * @default false\n\t * @private\n\t */\n\t@property({ type: Boolean })\n\t_userToggledShowTokens = false;\n\n\t/**\n\t * Defines the component tokens.\n\t * @public\n\t */\n\t@slot({ type: HTMLElement, individualSlots: true })\n\ttokens!: Array<IToken>;\n\n\t_skipOpenSuggestions: boolean;\n\t_valueHelpIconPressed: boolean;\n\n\tget formValidity(): ValidityStateFlags {\n\t\tconst tokens = (this.tokens || []);\n\n\t\treturn { valueMissing: this.required && !this.value && !tokens.length };\n\t}\n\n\tget formFormattedValue(): FormData | string | null {\n\t\tconst tokens = (this.tokens || []);\n\n\t\tif (tokens.length && this.name) {\n\t\t\tconst formData = new FormData();\n\n\t\t\tformData.append(this.name, this.value);\n\n\t\t\tfor (let i = 0; i < tokens.length; i++) {\n\t\t\t\tformData.append(this.name, (tokens[i].text || \"\"));\n\t\t\t}\n\n\t\t\treturn formData;\n\t\t}\n\n\t\treturn this.value;\n\t}\n\n\tconstructor() {\n\t\tsuper();\n\n\t\t// Prevent suggestions' opening.\n\t\tthis._skipOpenSuggestions = false;\n\t\tthis._valueHelpIconPressed = false;\n\t}\n\n\tvalueHelpPress() {\n\t\tthis.closeValueStatePopover();\n\t\tthis.fireDecoratorEvent(\"value-help-trigger\");\n\t}\n\n\ttokenDelete(e: CustomEvent<TokenizerTokenDeleteEventDetail>) {\n\t\tconst deletedTokens = e.detail.tokens;\n\t\tconst selectedTokens = this.tokens.filter(token => token.selected);\n\t\tconst shouldFocusInput = this.tokens.length - 1 === 0 || this.tokens.length === selectedTokens.length;\n\n\t\tif (this._readonly) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (deletedTokens) {\n\t\t\tthis.fireDecoratorEvent(\"token-delete\", { tokens: deletedTokens });\n\n\t\t\tif (shouldFocusInput) {\n\t\t\t\tthis.focus();\n\t\t\t}\n\t\t}\n\t}\n\n\tvalueHelpMouseDown(e: MouseEvent) {\n\t\tconst target = e.target as Icon;\n\t\tthis.closeValueStatePopover();\n\t\tthis.tokenizer.open = false;\n\t\tthis._valueHelpIconPressed = true;\n\t\ttarget.focus();\n\t}\n\n\t_tokenizerFocusOut(e: FocusEvent) {\n\t\tif (!this.contains(e.relatedTarget as HTMLElement) && !this.shadowRoot!.contains(e.relatedTarget as HTMLElement)) {\n\t\t\tthis.tokenizer._tokens.forEach(token => { token.selected = false; });\n\t\t}\n\t}\n\n\tvalueHelpMouseUp() {\n\t\tsetTimeout(() => {\n\t\t\tthis._valueHelpIconPressed = false;\n\t\t}, 0);\n\t}\n\n\tinnerFocusIn() {\n\t\tthis.tokenizer._scrollToEndOnExpand = true;\n\t\tthis.tokenizer.expanded = true;\n\t\tthis.focused = true;\n\n\t\tthis.tokens.forEach(token => {\n\t\t\ttoken.selected = false;\n\t\t});\n\t}\n\n\t_showMoreItemsPress() {\n\t\tthis.tokenizer._scrollToEndOnExpand = true;\n\t}\n\n\t_onkeydown(e: KeyboardEvent) {\n\t\t!this._isComposing && super._onkeydown(e);\n\n\t\tconst target = e.target as HTMLInputElement;\n\t\tconst isHomeInBeginning = isHome(e) && target.selectionStart === 0;\n\n\t\tif (isHomeInBeginning) {\n\t\t\tthis._skipOpenSuggestions = true; // Prevent input focus when navigating through the tokens\n\t\t\treturn this._focusFirstToken(e);\n\t\t}\n\n\t\tif (isEnter(e) && !!this._internals.form) {\n\t\t\te.preventDefault();\n\t\t}\n\n\t\tif (isLeft(e)) {\n\t\t\tthis._skipOpenSuggestions = true;\n\t\t\treturn this._handleLeft(e);\n\t\t}\n\n\t\tif (isBackSpace(e)) {\n\t\t\tthis._skipOpenSuggestions = true;\n\t\t\treturn this._handleBackspace(e);\n\t\t}\n\n\t\tthis._skipOpenSuggestions = false;\n\n\t\tif (isShow(e)) {\n\t\t\tthis.valueHelpPress();\n\t\t}\n\t}\n\n\t_onTokenizerKeydown(e: KeyboardEvent) {\n\t\tconst rightCtrl = isRightCtrl(e);\n\t\tif (isRight(e) || isDown(e) || isEnd(e) || rightCtrl) {\n\t\t\te.preventDefault();\n\t\t\tconst lastTokenIndex = this.tokens.length - 1;\n\n\t\t\tif (e.target === this.tokens[lastTokenIndex] && this.tokens[lastTokenIndex] === document.activeElement) {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis.focus();\n\t\t\t\t}, 0);\n\t\t\t}\n\t\t}\n\t}\n\n\t_handleLeft(e: KeyboardEvent) {\n\t\tconst cursorPosition = this.getDomRef()!.querySelector(`input`)!.selectionStart;\n\t\tconst tokens = this.tokens;\n\t\tconst lastToken = tokens.length && tokens[tokens.length - 1];\n\n\t\t// selectionStart property applies only to inputs of types text, search, URL, tel, and password\n\t\tif (((cursorPosition === null && !this.value) || cursorPosition === 0) && lastToken) {\n\t\t\te.preventDefault();\n\t\t\tlastToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(lastToken);\n\t\t}\n\t}\n\n\t_handleBackspace(e: KeyboardEvent) {\n\t\tconst cursorPosition = this.getDomRef()!.querySelector(`input`)!.selectionStart;\n\t\tconst selectionEnd = this.getDomRef()!.querySelector(`input`)!.selectionEnd;\n\t\tconst isValueSelected = cursorPosition === 0 && selectionEnd === this.value.length;\n\t\tconst tokens = this.tokens;\n\t\tconst lastToken = tokens.length && tokens[tokens.length - 1];\n\n\t\t// selectionStart property applies only to inputs of types text, search, URL, tel, and password\n\t\tif ((!this.value || (this.value && cursorPosition === 0 && !isValueSelected)) && lastToken) {\n\t\t\te.preventDefault();\n\t\t\tlastToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(lastToken);\n\t\t}\n\t}\n\n\t_focusFirstToken(e: KeyboardEvent) {\n\t\tconst tokens = this.tokens;\n\t\tconst firstToken = tokens.length && tokens[0];\n\n\t\tif (firstToken) {\n\t\t\te.preventDefault();\n\n\t\t\tfirstToken.focus();\n\t\t\tthis.tokenizer._itemNav.setCurrentItem(firstToken);\n\t\t}\n\t}\n\n\t_onfocusout(e: FocusEvent) {\n\t\tsuper._onfocusout(e);\n\t\tconst relatedTarget = e.relatedTarget as HTMLElement;\n\t\tconst insideDOM = this.contains(relatedTarget);\n\t\tconst insideShadowDom = this.shadowRoot!.contains(relatedTarget);\n\n\t\tif (!insideDOM && !insideShadowDom) {\n\t\t\tthis.tokenizer.expanded = false;\n\t\t}\n\n\t\tif (this.contains(relatedTarget) && relatedTarget.hasAttribute(\"ui5-token\")) {\n\t\t\tthis.focused = false;\n\t\t}\n\t}\n\n\t/**\n\t * @override\n\t */\n\t_onfocusin(e: FocusEvent) {\n\t\tconst inputDomRef = this.getInputDOMRef();\n\n\t\tif (e.target === inputDomRef) {\n\t\t\tsuper._onfocusin(e);\n\t\t}\n\t}\n\n\tonBeforeRendering() {\n\t\tsuper.onBeforeRendering();\n\n\t\tthis.style.setProperty(getScopedVarName(\"--_ui5-input-icons-count\"), `${this.iconsCount}`);\n\t\tthis.tokenizerAvailable = this.tokens && this.tokens.length > 0;\n\n\t\tif (this.tokenizer) {\n\t\t\tthis.tokenizer.readonly = this.readonly;\n\t\t}\n\n\t\t// Reset toggle state if there are tokens and dialog is about to open\n\t\tif (this.tokens.length > 0 && !this._userToggledShowTokens) {\n\t\t\tthis._showTokensInSuggestions = true;\n\t\t}\n\t}\n\n\t/**\n\t * Override the _handlePickerAfterOpen method to reset toggle state when dialog opens with tokens\n\t */\n\t_handlePickerAfterOpen() {\n\t\tif (this.tokens.length > 0) {\n\t\t\tthis._showTokensInSuggestions = true;\n\t\t\tthis._userToggledShowTokens = false;\n\t\t}\n\n\t\tsuper._handlePickerAfterOpen();\n\t}\n\n\tonAfterRendering() {\n\t\tsuper.onAfterRendering();\n\n\t\tthis.tokenizer.preventInitialFocus = true;\n\t}\n\n\tget iconsCount() {\n\t\treturn super.iconsCount + (this.showValueHelpIcon ? 1 : 0);\n\t}\n\n\tget tokenizer() {\n\t\treturn this.shadowRoot!.querySelector<Tokenizer>(\"[ui5-tokenizer]\")!;\n\t}\n\n\tget tokenizerExpanded() {\n\t\treturn this.tokenizer && this.tokenizer.expanded;\n\t}\n\n\tget _tokensCountText() {\n\t\treturn getTokensCountText(this.tokens.length);\n\t}\n\n\tget _valueHelpText() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_VALUE_HELP);\n\t}\n\n\tget _filterButtonAccessibleName() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_FILTER_BUTTON_LABEL);\n\t}\n\n\tget _tokensCountTextId() {\n\t\treturn `hiddenText-nMore`;\n\t}\n\n\tget _valueHelpTextId() {\n\t\treturn this.showValueHelpIcon ? `hiddenText-value-help` : \"\";\n\t}\n\n\t/**\n\t * Returns the placeholder value when there are no tokens.\n\t * @protected\n\t */\n\tget _placeholder() {\n\t\tif (this.tokens.length) {\n\t\t\treturn \"\";\n\t\t}\n\n\t\treturn this.placeholder;\n\t}\n\n\tget accInfo() {\n\t\tconst ariaDescribedBy = `${this._tokensCountTextId} ${this.suggestionsTextId} ${this.valueStateTextId} ${this._valueStateLinksShortcutsTextAccId} ${this._valueHelpTextId}`.trim();\n\t\treturn {\n\t\t\t...super.accInfo,\n\t\t\t\"ariaRoledescription\": this.ariaRoleDescription,\n\t\t\t\"ariaDescribedBy\": ariaDescribedBy,\n\t\t};\n\t}\n\n\tget valueHelpLabel() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_VALUE_HELP_LABEL);\n\t}\n\n\tget ariaRoleDescription() {\n\t\treturn MultiInput.i18nBundle.getText(MULTIINPUT_ROLEDESCRIPTION_TEXT);\n\t}\n\n\tget morePopoverOpener(): HTMLElement {\n\t\tif (this.tokens.length === 1 && this.tokens[0].isTruncatable) {\n\t\t\treturn this.tokens[0];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tget shouldDisplayOnlyValueStateMessage() {\n\t\treturn this.hasValueStateMessage && !this.readonly && !this.open && this.focused && !this.tokenizer.open;\n\t}\n\n\t/**\n\t * Computes the effective state for showing tokens in suggestions.\n\t * Defaults to true when tokens exist, but respects explicit user toggle.\n\t */\n\tget _effectiveShowTokensInSuggestions() {\n\t\t// If no tokens exist, always false\n\t\tif (this.tokens.length === 0) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// If user has never interacted with the toggle, default to true when tokens exist\n\t\tif (!this._userToggledShowTokens) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// If user has interacted, respect their choice\n\t\treturn this._showTokensInSuggestions;\n\t}\n}\n\nMultiInput.define();\n\nexport default MultiInput;\nexport type {\n\tIToken,\n\tMultiInputTokenDeleteEventDetail,\n\tMultiInputSelectionChangeEventDetail,\n};\n"]}
@@ -2,10 +2,19 @@ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "@ui5/webcompo
2
2
  import Icon from "./Icon.js";
3
3
  import InputTemplate from "./InputTemplate.js";
4
4
  import Tokenizer from "./Tokenizer.js";
5
+ import ToggleButton from "./ToggleButton.js";
6
+ import List from "./List.js";
7
+ import ListItemStandard from "./ListItemStandard.js";
8
+ import ListAccessibleRole from "./types/ListAccessibleRole.js";
5
9
  import valueHelp from "@ui5/webcomponents-icons/dist/value-help.js";
6
10
  export default function MultiInputTemplate() {
7
11
  return [
8
- InputTemplate.call(this, { preContent, postContent }),
12
+ InputTemplate.call(this, {
13
+ preContent,
14
+ postContent,
15
+ suggestionsList: multiInputSuggestionsList,
16
+ mobileHeader: multiInputMobileHeader,
17
+ }),
9
18
  ];
10
19
  }
11
20
  function preContent() {
@@ -16,4 +25,23 @@ function postContent() {
16
25
  return (_jsx(_Fragment, { children: this.showValueHelpIcon &&
17
26
  _jsx(Icon, { class: "inputIcon", name: valueHelp, accessibleName: this.valueHelpLabel, onMouseUp: this.valueHelpMouseUp, onMouseDown: this.valueHelpMouseDown, onClick: this.valueHelpPress }) }));
18
27
  }
28
+ function multiInputSuggestionsList() {
29
+ if (this._effectiveShowTokensInSuggestions) {
30
+ return (_jsx(List, { class: "ui5-tokenizer-list", accessibleRole: ListAccessibleRole.ListBox, separators: this.suggestionSeparators, selectionMode: "Delete", onMouseDown: this.onItemMouseDown, onItemClick: this._handleSuggestionItemPress, onSelectionChange: this._handleSelectionChange, onItemDelete: (e) => {
31
+ const listItem = e.detail.item;
32
+ const tokenId = listItem.getAttribute("data-ui5-token-ref-id");
33
+ const token = this.tokens.find((t) => t._id === tokenId);
34
+ if (token) {
35
+ this.tokenDelete({ detail: { tokens: [token] } });
36
+ }
37
+ }, children: this.tokens?.map((token, index) => (_jsx(ListItemStandard, { class: "ui5-suggestion-token-item", "data-ui5-token-ref-id": token._id, wrappingType: "Normal", text: token.text }, index))) }));
38
+ }
39
+ return (_jsx(List, { accessibleRole: ListAccessibleRole.ListBox, separators: this.suggestionSeparators, selectionMode: "Single", onMouseDown: this.onItemMouseDown, onItemClick: this._handleSuggestionItemPress, onSelectionChange: this._handleSelectionChange, children: _jsx("slot", {}) }));
40
+ }
41
+ function multiInputMobileHeader() {
42
+ return (_jsx(ToggleButton, { class: "ui5-multi-input-mobile-dialog-button", design: "Transparent", icon: "multiselect-all", accessibleName: this._filterButtonAccessibleName, disabled: !this.tokens?.length, pressed: this._effectiveShowTokensInSuggestions, onClick: () => {
43
+ this._userToggledShowTokens = true;
44
+ this._showTokensInSuggestions = !this._effectiveShowTokensInSuggestions;
45
+ } }));
46
+ }
19
47
  //# sourceMappingURL=MultiInputTemplate.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"MultiInputTemplate.js","sourceRoot":"","sources":["../src/MultiInputTemplate.tsx"],"names":[],"mappings":";AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,aAAa,MAAM,oBAAoB,CAAC;AAE/C,OAAO,SAAS,MAAM,gBAAgB,CAAC;AACvC,OAAO,SAAS,MAAM,6CAA6C,CAAC;AAEpE,MAAM,CAAC,OAAO,UAAU,kBAAkB;IACzC,OAAO;QACN,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC;KACrD,CAAC;AACH,CAAC;AAED,SAAS,UAAU;IAClB,OAAO,CACN,8BACC,eAAM,EAAE,EAAC,kBAAkB,EAAC,KAAK,EAAC,iBAAiB,YAAE,IAAI,CAAC,gBAAgB,GAAQ,EAEjF,IAAI,CAAC,iBAAiB;gBACtB,eAAM,EAAE,EAAC,uBAAuB,EAAC,KAAK,EAAC,iBAAiB,YAAE,IAAI,CAAC,cAAc,GAAQ,EAEtF,KAAC,SAAS,IACT,KAAK,EAAC,2BAA2B,EACjC,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAC9B,eAAe,EAAE,IAAI,CAAC,WAAW,EACjC,gBAAgB,EAAE,IAAI,EACtB,QAAQ,EAAE,IAAI,CAAC,iBAAiB,EAChC,SAAS,EAAE,IAAI,CAAC,mBAAmB,EACnC,aAAa,EAAE,IAAI,CAAC,WAAW,EAC/B,UAAU,EAAE,IAAI,CAAC,kBAAkB,EACnC,oBAAoB,EAAE,IAAI,CAAC,mBAAmB,YAE5C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,eAAM,IAAI,EAAE,KAAK,CAAC,eAAe,GAAS,CAAC,GAC3D,IACV,CACH,CAAC;AACH,CAAC;AAED,SAAS,WAAW;IACnB,OAAO,CACN,4BACE,IAAI,CAAC,iBAAiB;YACtB,KAAC,IAAI,IACJ,KAAK,EAAC,WAAW,EACjB,IAAI,EAAE,SAAS,EACf,cAAc,EAAE,IAAI,CAAC,cAAc,EACnC,SAAS,EAAE,IAAI,CAAC,gBAAgB,EAChC,WAAW,EAAE,IAAI,CAAC,kBAAkB,EACpC,OAAO,EAAE,IAAI,CAAC,cAAc,GAC3B,GAED,CACH,CAAC;AACH,CAAC","sourcesContent":["import Icon from \"./Icon.js\";\nimport InputTemplate from \"./InputTemplate.js\";\nimport type MultiInput from \"./MultiInput.js\";\nimport Tokenizer from \"./Tokenizer.js\";\nimport valueHelp from \"@ui5/webcomponents-icons/dist/value-help.js\";\n\nexport default function MultiInputTemplate(this: MultiInput) {\n\treturn [\n\t\tInputTemplate.call(this, { preContent, postContent }),\n\t];\n}\n\nfunction preContent(this: MultiInput) {\n\treturn (\n\t\t<>\n\t\t\t<span id=\"hiddenText-nMore\" class=\"ui5-hidden-text\">{this._tokensCountText}</span>\n\n\t\t\t{this.showValueHelpIcon &&\n\t\t\t\t<span id=\"hiddenText-value-help\" class=\"ui5-hidden-text\">{this._valueHelpText}</span>\n\t\t\t}\n\t\t\t<Tokenizer\n\t\t\t\tclass=\"ui5-multi-input-tokenizer\"\n\t\t\t\topener={this.morePopoverOpener}\n\t\t\t\tpopoverMinWidth={this._inputWidth}\n\t\t\t\thidePopoverArrow={true}\n\t\t\t\texpanded={this.tokenizerExpanded}\n\t\t\t\tonKeyDown={this._onTokenizerKeydown}\n\t\t\t\tonTokenDelete={this.tokenDelete}\n\t\t\t\tonFocusOut={this._tokenizerFocusOut}\n\t\t\t\tonShowMoreItemsPress={this._showMoreItemsPress}\n\t\t\t>\n\t\t\t\t{ this.tokens.map(token => <slot name={token._individualSlot}></slot>)}\n\t\t\t</Tokenizer>\n\t\t</>\n\t);\n}\n\nfunction postContent(this: MultiInput) {\n\treturn (\n\t\t<>\n\t\t\t{this.showValueHelpIcon &&\n\t\t\t\t<Icon\n\t\t\t\t\tclass=\"inputIcon\"\n\t\t\t\t\tname={valueHelp}\n\t\t\t\t\taccessibleName={this.valueHelpLabel}\n\t\t\t\t\tonMouseUp={this.valueHelpMouseUp}\n\t\t\t\t\tonMouseDown={this.valueHelpMouseDown}\n\t\t\t\t\tonClick={this.valueHelpPress}\n\t\t\t\t/>\n\t\t\t}\n\t\t</>\n\t);\n}\n"]}
1
+ {"version":3,"file":"MultiInputTemplate.js","sourceRoot":"","sources":["../src/MultiInputTemplate.tsx"],"names":[],"mappings":"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","sourcesContent":["import Icon from \"./Icon.js\";\nimport InputTemplate from \"./InputTemplate.js\";\nimport type MultiInput from \"./MultiInput.js\";\nimport type { MultiInputTokenDeleteEventDetail } from \"./MultiInput.js\";\nimport Tokenizer from \"./Tokenizer.js\";\nimport ToggleButton from \"./ToggleButton.js\";\nimport List from \"./List.js\";\nimport ListItemStandard from \"./ListItemStandard.js\";\nimport ListAccessibleRole from \"./types/ListAccessibleRole.js\";\nimport valueHelp from \"@ui5/webcomponents-icons/dist/value-help.js\";\n\nexport default function MultiInputTemplate(this: MultiInput) {\n\treturn [\n\t\tInputTemplate.call(this, {\n\t\t\tpreContent,\n\t\t\tpostContent,\n\t\t\tsuggestionsList: multiInputSuggestionsList,\n\t\t\tmobileHeader: multiInputMobileHeader,\n\t\t}),\n\t];\n}\n\nfunction preContent(this: MultiInput) {\n\treturn (\n\t\t<>\n\t\t\t<span id=\"hiddenText-nMore\" class=\"ui5-hidden-text\">{this._tokensCountText}</span>\n\n\t\t\t{this.showValueHelpIcon &&\n\t\t\t\t<span id=\"hiddenText-value-help\" class=\"ui5-hidden-text\">{this._valueHelpText}</span>\n\t\t\t}\n\t\t\t<Tokenizer\n\t\t\t\tclass=\"ui5-multi-input-tokenizer\"\n\t\t\t\topener={this.morePopoverOpener}\n\t\t\t\tpopoverMinWidth={this._inputWidth}\n\t\t\t\thidePopoverArrow={true}\n\t\t\t\texpanded={this.tokenizerExpanded}\n\t\t\t\tonKeyDown={this._onTokenizerKeydown}\n\t\t\t\tonTokenDelete={this.tokenDelete}\n\t\t\t\tonFocusOut={this._tokenizerFocusOut}\n\t\t\t\tonShowMoreItemsPress={this._showMoreItemsPress}\n\t\t\t>\n\t\t\t\t{ this.tokens.map(token => <slot name={token._individualSlot}></slot>)}\n\t\t\t</Tokenizer>\n\t\t</>\n\t);\n}\n\nfunction postContent(this: MultiInput) {\n\treturn (\n\t\t<>\n\t\t\t{this.showValueHelpIcon &&\n\t\t\t\t<Icon\n\t\t\t\t\tclass=\"inputIcon\"\n\t\t\t\t\tname={valueHelp}\n\t\t\t\t\taccessibleName={this.valueHelpLabel}\n\t\t\t\t\tonMouseUp={this.valueHelpMouseUp}\n\t\t\t\t\tonMouseDown={this.valueHelpMouseDown}\n\t\t\t\t\tonClick={this.valueHelpPress}\n\t\t\t\t/>\n\t\t\t}\n\t\t</>\n\t);\n}\n\nfunction multiInputSuggestionsList(this: MultiInput) {\n\tif (this._effectiveShowTokensInSuggestions) {\n\t\treturn (\n\t\t\t<List\n\t\t\t\tclass=\"ui5-tokenizer-list\"\n\t\t\t\taccessibleRole={ListAccessibleRole.ListBox}\n\t\t\t\tseparators={this.suggestionSeparators}\n\t\t\t\tselectionMode=\"Delete\"\n\t\t\t\tonMouseDown={this.onItemMouseDown}\n\t\t\t\tonItemClick={this._handleSuggestionItemPress}\n\t\t\t\tonSelectionChange={this._handleSelectionChange}\n\t\t\t\tonItemDelete={(e: any) => {\n\t\t\t\t\tconst listItem = e.detail.item;\n\t\t\t\t\tconst tokenId = listItem.getAttribute(\"data-ui5-token-ref-id\");\n\t\t\t\t\tconst token = this.tokens.find((t: any) => t._id === tokenId);\n\n\t\t\t\t\tif (token) {\n\t\t\t\t\t\tthis.tokenDelete({ detail: { tokens: [token] } } as CustomEvent<MultiInputTokenDeleteEventDetail>);\n\t\t\t\t\t}\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t{this.tokens?.map((token: any, index: number) => (\n\t\t\t\t\t<ListItemStandard\n\t\t\t\t\t\tkey={index}\n\t\t\t\t\t\tclass=\"ui5-suggestion-token-item\"\n\t\t\t\t\t\tdata-ui5-token-ref-id={token._id}\n\t\t\t\t\t\twrappingType=\"Normal\"\n\t\t\t\t\t\ttext={token.text}\n\t\t\t\t\t/>\n\t\t\t\t))}\n\t\t\t</List>\n\t\t);\n\t}\n\n\treturn (\n\t\t<List\n\t\t\taccessibleRole={ListAccessibleRole.ListBox}\n\t\t\tseparators={this.suggestionSeparators}\n\t\t\tselectionMode=\"Single\"\n\t\t\tonMouseDown={this.onItemMouseDown}\n\t\t\tonItemClick={this._handleSuggestionItemPress}\n\t\t\tonSelectionChange={this._handleSelectionChange}\n\t\t>\n\t\t\t<slot></slot>\n\t\t</List>\n\t);\n}\n\nfunction multiInputMobileHeader(this: MultiInput) {\n\treturn (\n\t\t<ToggleButton\n\t\t\tclass=\"ui5-multi-input-mobile-dialog-button\"\n\t\t\tdesign=\"Transparent\"\n\t\t\ticon=\"multiselect-all\"\n\t\t\taccessibleName={this._filterButtonAccessibleName}\n\t\t\tdisabled={!this.tokens?.length}\n\t\t\tpressed={this._effectiveShowTokensInSuggestions}\n\t\t\tonClick={() => {\n\t\t\t\tthis._userToggledShowTokens = true;\n\t\t\t\tthis._showTokensInSuggestions = !this._effectiveShowTokensInSuggestions;\n\t\t\t}}\n\t\t/>\n\t);\n}\n"]}
package/dist/Select.d.ts CHANGED
@@ -6,7 +6,7 @@ import "@ui5/webcomponents-icons/dist/alert.js";
6
6
  import "@ui5/webcomponents-icons/dist/sys-enter-2.js";
7
7
  import "@ui5/webcomponents-icons/dist/information.js";
8
8
  import type I18nBundle from "@ui5/webcomponents-base/dist/i18nBundle.js";
9
- import type { Timeout } from "@ui5/webcomponents-base/dist/types.js";
9
+ import type { Timeout, AriaRole } from "@ui5/webcomponents-base/dist/types.js";
10
10
  import type { IFormInputElement } from "@ui5/webcomponents-base/dist/features/InputElementsFormSupport.js";
11
11
  import type { ListItemClickEventDetail } from "./List.js";
12
12
  import ResponsivePopover from "./ResponsivePopover.js";
@@ -427,6 +427,15 @@ declare class Select extends UI5Element implements IFormInputElement {
427
427
  get ariaDescriptionText(): string | undefined;
428
428
  get ariaDescriptionTextId(): "" | "accessibleDescription";
429
429
  get ariaDescribedByIds(): string | undefined;
430
+ get accessibilityInfo(): {
431
+ role: AriaRole;
432
+ type: string;
433
+ description: string;
434
+ label: string | undefined;
435
+ readonly: boolean;
436
+ required: boolean;
437
+ disabled: boolean;
438
+ };
430
439
  _updateAssociatedLabelsTexts(): void;
431
440
  _getPopover(): Popover | null;
432
441
  }
package/dist/Select.js CHANGED
@@ -774,6 +774,17 @@ let Select = Select_1 = class Select extends UI5Element {
774
774
  const ids = [this.valueStateTextId, this.ariaDescriptionTextId].filter(Boolean);
775
775
  return ids.length ? ids.join(" ") : undefined;
776
776
  }
777
+ get accessibilityInfo() {
778
+ return {
779
+ role: "combobox",
780
+ type: this._ariaRoleDescription,
781
+ description: this.text,
782
+ label: this.ariaLabelText,
783
+ readonly: this.readonly,
784
+ required: this.required,
785
+ disabled: this.disabled,
786
+ };
787
+ }
777
788
  _updateAssociatedLabelsTexts() {
778
789
  this._associatedDescriptionRefTexts = getAllAccessibleDescriptionRefTexts(this);
779
790
  }