@ui5/webcomponents 0.0.0-0fcda382e → 0.0.0-1929d08ff
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.
- package/CHANGELOG.md +884 -1
- package/README.md +145 -52
- package/customI18n.js +50 -0
- package/dist/Assets-static.js +6 -0
- package/dist/Assets.js +2 -1
- package/dist/Avatar.js +197 -46
- package/dist/AvatarGroup.js +603 -0
- package/dist/Badge.js +44 -22
- package/dist/Breadcrumbs.js +580 -0
- package/dist/BreadcrumbsItem.js +103 -0
- package/dist/BusyIndicator.js +145 -37
- package/dist/Button.js +177 -80
- package/dist/Calendar.js +349 -546
- package/dist/CalendarDate.js +45 -0
- package/dist/CalendarHeader.js +133 -62
- package/dist/CalendarPart.js +111 -0
- package/dist/Card.js +42 -156
- package/dist/CardHeader.js +288 -0
- package/dist/Carousel.js +281 -76
- package/dist/CheckBox.js +183 -50
- package/dist/ColorPalette.js +494 -0
- package/dist/ColorPaletteItem.js +137 -0
- package/dist/ColorPalettePopover.js +244 -0
- package/dist/ColorPicker.js +562 -0
- package/dist/ComboBox.js +675 -98
- package/dist/ComboBoxFilters.js +8 -1
- package/dist/ComboBoxGroupItem.js +70 -0
- package/dist/ComboBoxItem.js +12 -24
- package/dist/CustomListItem.js +38 -4
- package/dist/DateComponentBase.js +168 -0
- package/dist/DatePicker.js +404 -411
- package/dist/DateRangePicker.js +356 -0
- package/dist/DateTimePicker.js +111 -384
- package/dist/DayPicker.js +509 -431
- package/dist/Dialog.js +508 -43
- package/dist/DurationPicker.js +135 -390
- package/dist/FileUploader.js +215 -29
- package/dist/GroupHeaderListItem.js +24 -14
- package/dist/Icon.js +153 -50
- package/dist/Input.js +774 -177
- package/dist/Interfaces.js +192 -0
- package/dist/Label.js +34 -18
- package/dist/Link.js +154 -31
- package/dist/List.js +462 -118
- package/dist/ListItem.js +96 -26
- package/dist/ListItemBase.js +31 -8
- package/dist/MessageStrip.js +86 -71
- package/dist/MonthPicker.js +180 -182
- package/dist/MultiComboBox.js +701 -163
- package/dist/MultiComboBoxItem.js +8 -2
- package/dist/MultiInput.js +348 -0
- package/dist/Option.js +59 -5
- package/dist/Panel.js +110 -40
- package/dist/Popover.js +355 -190
- package/dist/Popup.js +415 -87
- package/dist/ProgressIndicator.js +235 -0
- package/dist/RadioButton.js +143 -51
- package/dist/RadioButtonGroup.js +53 -29
- package/dist/RangeSlider.js +769 -0
- package/dist/RatingIndicator.js +321 -0
- package/dist/ResponsivePopover.js +80 -61
- package/dist/SegmentedButton.js +132 -70
- package/dist/SegmentedButtonItem.js +109 -0
- package/dist/Select.js +448 -110
- package/dist/Slider.js +320 -0
- package/dist/SliderBase.js +847 -0
- package/dist/SplitButton.js +426 -0
- package/dist/StandardListItem.js +44 -13
- package/dist/StepInput.js +684 -0
- package/dist/SuggestionGroupItem.js +64 -0
- package/dist/SuggestionItem.js +37 -31
- package/dist/SuggestionListItem.js +76 -0
- package/dist/Switch.js +85 -37
- package/dist/Tab.js +64 -29
- package/dist/TabContainer.js +616 -128
- package/dist/TabSeparator.js +43 -3
- package/dist/Table.js +730 -36
- package/dist/TableCell.js +11 -13
- package/dist/TableColumn.js +13 -10
- package/dist/TableGroupRow.js +164 -0
- package/dist/TableRow.js +318 -18
- package/dist/TextArea.js +152 -44
- package/dist/TimePicker.js +55 -675
- package/dist/TimePickerBase.js +463 -0
- package/dist/TimeSelection.js +493 -0
- package/dist/Title.js +16 -9
- package/dist/Toast.js +24 -13
- package/dist/ToggleButton.js +26 -8
- package/dist/Token.js +84 -47
- package/dist/Tokenizer.js +398 -64
- package/dist/Tree.js +154 -63
- package/dist/TreeItem.js +67 -11
- package/dist/TreeListItem.js +148 -15
- package/dist/WheelSlider.js +79 -59
- package/dist/YearPicker.js +199 -255
- package/dist/api.json +7203 -1
- package/dist/css/themes/Avatar.css +1 -0
- package/dist/css/themes/AvatarGroup.css +1 -0
- package/dist/css/themes/Badge.css +1 -0
- package/dist/css/themes/Breadcrumbs.css +1 -0
- package/dist/css/themes/BreadcrumbsPopover.css +1 -0
- package/dist/css/themes/BrowserScrollbar.css +1 -0
- package/dist/css/themes/BusyIndicator.css +1 -0
- package/dist/css/themes/Button.css +1 -0
- package/dist/css/themes/Button.ie11.css +1 -0
- package/dist/css/themes/Calendar.css +1 -0
- package/dist/css/themes/CalendarHeader.css +1 -0
- package/dist/css/themes/Card.css +1 -0
- package/dist/css/themes/CardHeader.css +1 -0
- package/dist/css/themes/Carousel.css +1 -0
- package/dist/css/themes/CheckBox.css +1 -0
- package/dist/css/themes/ColorPalette.css +1 -0
- package/dist/css/themes/ColorPaletteItem.css +1 -0
- package/dist/css/themes/ColorPalettePopover.css +1 -0
- package/dist/css/themes/ColorPaletteStaticArea.css +1 -0
- package/dist/css/themes/ColorPicker.css +1 -0
- package/dist/css/themes/ComboBox.css +1 -0
- package/dist/css/themes/ComboBoxPopover.css +1 -0
- package/dist/css/themes/CustomListItem.css +1 -0
- package/dist/css/themes/DatePicker.css +1 -0
- package/dist/css/themes/DatePickerPopover.css +1 -0
- package/dist/css/themes/DateRangePicker.css +1 -0
- package/dist/css/themes/DateTimePicker.css +1 -0
- package/dist/css/themes/DateTimePickerPopover.css +1 -0
- package/dist/css/themes/DayPicker.css +1 -0
- package/dist/css/themes/Dialog.css +1 -0
- package/dist/css/themes/FileUploader.css +1 -0
- package/dist/css/themes/GroupHeaderListItem.css +1 -0
- package/dist/css/themes/GrowingButton.css +1 -0
- package/dist/css/themes/Icon.css +1 -0
- package/dist/css/themes/Input.css +1 -0
- package/dist/css/themes/InputIcon.css +1 -0
- package/dist/css/themes/InvisibleTextStyles.css +1 -0
- package/dist/css/themes/Label.css +1 -0
- package/dist/css/themes/Link.css +1 -0
- package/dist/css/themes/List.css +1 -0
- package/dist/css/themes/ListItem.css +1 -0
- package/dist/css/themes/ListItemBase.css +1 -0
- package/dist/css/themes/MessageStrip.css +1 -0
- package/dist/css/themes/MonthPicker.css +1 -0
- package/dist/css/themes/MultiComboBox.css +1 -0
- package/dist/css/themes/MultiInput.css +1 -0
- package/dist/css/themes/Panel.css +1 -0
- package/dist/css/themes/Popover.css +1 -0
- package/dist/css/themes/Popup.css +1 -0
- package/dist/css/themes/PopupGlobal.css +1 -0
- package/dist/css/themes/PopupStaticAreaStyles.css +1 -0
- package/dist/css/themes/PopupsCommon.css +1 -0
- package/dist/css/themes/ProgressIndicator.css +1 -0
- package/dist/css/themes/RadioButton.css +1 -0
- package/dist/css/themes/RatingIndicator.css +1 -0
- package/dist/css/themes/ResponsivePopover.css +1 -0
- package/dist/css/themes/ResponsivePopoverCommon.css +1 -0
- package/dist/css/themes/SegmentedButton.css +1 -0
- package/dist/css/themes/Select.css +1 -0
- package/dist/css/themes/SelectPopover.css +1 -0
- package/dist/css/themes/SliderBase.css +1 -0
- package/dist/css/themes/SplitButton.css +1 -0
- package/dist/css/themes/StepInput.css +1 -0
- package/dist/css/themes/Suggestions.css +1 -0
- package/dist/css/themes/Switch.css +1 -0
- package/dist/css/themes/Tab.css +1 -0
- package/dist/css/themes/TabContainer.css +1 -0
- package/dist/css/themes/TabInOverflow.css +1 -0
- package/dist/css/themes/TabInStrip.css +1 -0
- package/dist/css/themes/TabSeparatorInOverflow.css +1 -0
- package/dist/css/themes/TabSeparatorInStrip.css +1 -0
- package/dist/css/themes/Table.css +1 -0
- package/dist/css/themes/TableCell.css +1 -0
- package/dist/css/themes/TableColumn.css +1 -0
- package/dist/css/themes/TableGroupRow.css +1 -0
- package/dist/css/themes/TableRow.css +1 -0
- package/dist/css/themes/TapHighlightColor.css +1 -0
- package/dist/css/themes/TextArea.css +1 -0
- package/dist/css/themes/TimePicker.css +1 -0
- package/dist/css/themes/TimePickerPopover.css +1 -0
- package/dist/css/themes/TimeSelection.css +1 -0
- package/dist/css/themes/Title.css +1 -0
- package/dist/css/themes/Toast.css +1 -0
- package/dist/css/themes/ToggleButton.css +1 -0
- package/dist/css/themes/ToggleButton.ie11.css +1 -0
- package/dist/css/themes/Token.css +1 -0
- package/dist/css/themes/Tokenizer.css +1 -0
- package/dist/css/themes/TokenizerPopover.css +1 -0
- package/dist/css/themes/Tree.css +1 -0
- package/dist/css/themes/TreeListItem.css +1 -0
- package/dist/css/themes/ValueStateMessage.css +1 -0
- package/dist/css/themes/WheelSlider.css +1 -0
- package/dist/css/themes/YearPicker.css +1 -0
- package/dist/css/themes/sap_belize/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_belize_hcb/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_belize_hcw/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_fiori_3/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_fiori_3_dark/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_fiori_3_hcb/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_fiori_3_hcw/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_horizon/parameters-bundle.css +1 -0
- package/dist/css/themes/sap_horizon_exp/parameters-bundle.css +1 -0
- package/dist/features/ColorPaletteMoreColors.js +42 -0
- package/dist/features/InputElementsFormSupport.js +0 -1
- package/dist/features/InputSuggestions.js +341 -54
- package/dist/generated/assets/i18n/messagebundle_ar.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_bg.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_ca.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_cs.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_cy.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_da.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_de.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_el.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_en.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_en_GB.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_en_US_sappsd.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_en_US_saprigi.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_en_US_saptrc.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_es.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_es_MX.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_et.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_fi.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_fr.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_fr_CA.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_hi.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_hr.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_hu.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_in.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_it.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_iw.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_ja.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_kk.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_ko.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_lt.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_lv.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_ms.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_nl.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_no.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_pl.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_pt.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_pt_PT.json +1 -0
- package/dist/generated/assets/i18n/messagebundle_ro.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_ru.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_sh.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_sk.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_sl.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_sv.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_th.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_tr.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_uk.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_vi.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_zh_CN.json +1 -1
- package/dist/generated/assets/i18n/messagebundle_zh_TW.json +1 -1
- package/dist/generated/assets/themes/sap_belize/parameters-bundle.css.json +1 -1
- package/dist/generated/assets/themes/sap_belize_hcb/parameters-bundle.css.json +1 -1
- package/dist/generated/assets/themes/sap_belize_hcw/parameters-bundle.css.json +1 -1
- package/dist/generated/assets/themes/sap_fiori_3/parameters-bundle.css.json +1 -1
- package/dist/generated/assets/themes/sap_fiori_3_dark/parameters-bundle.css.json +1 -1
- package/dist/generated/assets/themes/sap_fiori_3_hcb/parameters-bundle.css.json +1 -0
- package/dist/generated/assets/themes/sap_fiori_3_hcw/parameters-bundle.css.json +1 -0
- package/dist/generated/assets/themes/sap_horizon/parameters-bundle.css.json +1 -0
- package/dist/generated/assets/themes/sap_horizon_exp/parameters-bundle.css.json +1 -0
- package/dist/generated/i18n/i18n-defaults.js +2 -2
- package/dist/generated/json-imports/Themes-static.js +35 -0
- package/dist/generated/json-imports/Themes.js +23 -15
- package/dist/generated/json-imports/i18n-static.js +162 -0
- package/dist/generated/json-imports/i18n.js +113 -89
- package/dist/generated/templates/AvatarGroupTemplate.lit.js +9 -0
- package/dist/generated/templates/AvatarTemplate.lit.js +9 -9
- package/dist/generated/templates/BadgeTemplate.lit.js +5 -6
- package/dist/generated/templates/BreadcrumbsPopoverTemplate.lit.js +8 -0
- package/dist/generated/templates/BreadcrumbsTemplate.lit.js +9 -0
- package/dist/generated/templates/BusyIndicatorTemplate.lit.js +7 -6
- package/dist/generated/templates/ButtonTemplate.lit.js +6 -6
- package/dist/generated/templates/CalendarHeaderTemplate.lit.js +6 -4
- package/dist/generated/templates/CalendarTemplate.lit.js +4 -4
- package/dist/generated/templates/CardHeaderTemplate.lit.js +12 -0
- package/dist/generated/templates/CardTemplate.lit.js +5 -8
- package/dist/generated/templates/CarouselTemplate.lit.js +13 -12
- package/dist/generated/templates/CheckBoxTemplate.lit.js +7 -7
- package/dist/generated/templates/ColorPaletteDialogTemplate.lit.js +7 -0
- package/dist/generated/templates/ColorPaletteItemTemplate.lit.js +7 -0
- package/dist/generated/templates/ColorPalettePopoverTemplate.lit.js +8 -0
- package/dist/generated/templates/ColorPaletteTemplate.lit.js +12 -0
- package/dist/generated/templates/ColorPickerTemplate.lit.js +7 -0
- package/dist/generated/templates/ComboBoxPopoverTemplate.lit.js +20 -5
- package/dist/generated/templates/ComboBoxTemplate.lit.js +8 -6
- package/dist/generated/templates/CustomListItemTemplate.lit.js +13 -13
- package/dist/generated/templates/DatePickerPopoverTemplate.lit.js +7 -6
- package/dist/generated/templates/DatePickerTemplate.lit.js +6 -6
- package/dist/generated/templates/DateTimePickerPopoverTemplate.lit.js +9 -12
- package/dist/generated/templates/DayPickerTemplate.lit.js +13 -11
- package/dist/generated/templates/DialogTemplate.lit.js +9 -9
- package/dist/generated/templates/FileUploaderPopoverTemplate.lit.js +11 -0
- package/dist/generated/templates/FileUploaderTemplate.lit.js +7 -7
- package/dist/generated/templates/GroupHeaderListItemTemplate.lit.js +4 -4
- package/dist/generated/templates/IconTemplate.lit.js +6 -6
- package/dist/generated/templates/InputPopoverTemplate.lit.js +24 -23
- package/dist/generated/templates/InputTemplate.lit.js +10 -8
- package/dist/generated/templates/LabelTemplate.lit.js +4 -4
- package/dist/generated/templates/LinkTemplate.lit.js +5 -5
- package/dist/generated/templates/ListItemTemplate.lit.js +13 -13
- package/dist/generated/templates/ListTemplate.lit.js +12 -9
- package/dist/generated/templates/MessageStripTemplate.lit.js +8 -17
- package/dist/generated/templates/MonthPickerTemplate.lit.js +6 -6
- package/dist/generated/templates/MultiComboBoxPopoverTemplate.lit.js +23 -5
- package/dist/generated/templates/MultiComboBoxTemplate.lit.js +10 -8
- package/dist/generated/templates/MultiInputTemplate.lit.js +17 -0
- package/dist/generated/templates/PanelTemplate.lit.js +9 -6
- package/dist/generated/templates/PopoverTemplate.lit.js +9 -9
- package/dist/generated/templates/PopupBlockLayerTemplate.lit.js +4 -4
- package/dist/generated/templates/PopupTemplate.lit.js +4 -9
- package/dist/generated/templates/ProgressIndicatorTemplate.lit.js +17 -0
- package/dist/generated/templates/RadioButtonTemplate.lit.js +7 -7
- package/dist/generated/templates/RangeSliderTemplate.lit.js +13 -0
- package/dist/generated/templates/RatingIndicatorTemplate.lit.js +14 -0
- package/dist/generated/templates/ResponsivePopoverTemplate.lit.js +16 -14
- package/dist/generated/templates/SegmentedButtonItemTemplate.lit.js +8 -0
- package/dist/generated/templates/SegmentedButtonTemplate.lit.js +4 -9
- package/dist/generated/templates/SelectPopoverTemplate.lit.js +20 -6
- package/dist/generated/templates/SelectTemplate.lit.js +6 -5
- package/dist/generated/templates/SliderBaseTemplate.lit.js +11 -0
- package/dist/generated/templates/SliderTemplate.lit.js +12 -0
- package/dist/generated/templates/SplitButtonTemplate.lit.js +7 -0
- package/dist/generated/templates/StandardListItemTemplate.lit.js +21 -20
- package/dist/generated/templates/StepInputTemplate.lit.js +10 -0
- package/dist/generated/templates/SuggestionListItemTemplate.lit.js +27 -0
- package/dist/generated/templates/SwitchTemplate.lit.js +8 -6
- package/dist/generated/templates/TabContainerPopoverTemplate.lit.js +8 -6
- package/dist/generated/templates/TabContainerTemplate.lit.js +15 -14
- package/dist/generated/templates/TabInOverflowTemplate.lit.js +6 -13
- package/dist/generated/templates/TabInStripTemplate.lit.js +8 -21
- package/dist/generated/templates/TabSeparatorInOverflowTemplate.lit.js +7 -0
- package/dist/generated/templates/TabSeparatorInStripTemplate.lit.js +7 -0
- package/dist/generated/templates/TabTemplate.lit.js +4 -4
- package/dist/generated/templates/TableCellTemplate.lit.js +4 -4
- package/dist/generated/templates/TableColumnTemplate.lit.js +4 -4
- package/dist/generated/templates/TableGroupRowTemplate.lit.js +7 -0
- package/dist/generated/templates/TableRowTemplate.lit.js +12 -11
- package/dist/generated/templates/TableTemplate.lit.js +13 -8
- package/dist/generated/templates/TextAreaPopoverTemplate.lit.js +8 -8
- package/dist/generated/templates/TextAreaTemplate.lit.js +8 -7
- package/dist/generated/templates/TimePickerPopoverTemplate.lit.js +4 -8
- package/dist/generated/templates/TimePickerTemplate.lit.js +6 -6
- package/dist/generated/templates/TimeSelectionTemplate.lit.js +11 -0
- package/dist/generated/templates/TitleTemplate.lit.js +10 -10
- package/dist/generated/templates/ToastTemplate.lit.js +5 -4
- package/dist/generated/templates/ToggleButtonTemplate.lit.js +6 -6
- package/dist/generated/templates/TokenTemplate.lit.js +7 -5
- package/dist/generated/templates/TokenizerPopoverTemplate.lit.js +12 -0
- package/dist/generated/templates/TokenizerTemplate.lit.js +6 -6
- package/dist/generated/templates/TreeListItemTemplate.lit.js +18 -16
- package/dist/generated/templates/TreeTemplate.lit.js +5 -5
- package/dist/generated/templates/WheelSliderTemplate.lit.js +7 -7
- package/dist/generated/templates/YearPickerTemplate.lit.js +6 -6
- package/dist/generated/themes/Avatar.css.js +5 -5
- package/dist/generated/themes/AvatarGroup.css.js +8 -0
- package/dist/generated/themes/Badge.css.js +5 -5
- package/dist/generated/themes/Breadcrumbs.css.js +8 -0
- package/dist/generated/themes/BreadcrumbsPopover.css.js +8 -0
- package/dist/generated/themes/BrowserScrollbar.css.js +8 -0
- package/dist/generated/themes/BusyIndicator.css.js +5 -5
- package/dist/generated/themes/Button.css.js +5 -5
- package/dist/generated/themes/Button.ie11.css.js +8 -0
- package/dist/generated/themes/Calendar.css.js +5 -5
- package/dist/generated/themes/CalendarHeader.css.js +5 -5
- package/dist/generated/themes/Card.css.js +5 -5
- package/dist/generated/themes/CardHeader.css.js +8 -0
- package/dist/generated/themes/Carousel.css.js +5 -5
- package/dist/generated/themes/CheckBox.css.js +5 -5
- package/dist/generated/themes/ColorPalette.css.js +8 -0
- package/dist/generated/themes/ColorPaletteItem.css.js +8 -0
- package/dist/generated/themes/ColorPalettePopover.css.js +8 -0
- package/dist/generated/themes/ColorPaletteStaticArea.css.js +8 -0
- package/dist/generated/themes/ColorPicker.css.js +8 -0
- package/dist/generated/themes/ComboBox.css.js +5 -5
- package/dist/generated/themes/ComboBoxPopover.css.js +5 -5
- package/dist/generated/themes/CustomListItem.css.js +5 -5
- package/dist/generated/themes/DatePicker.css.js +5 -5
- package/dist/generated/themes/DatePickerPopover.css.js +5 -5
- package/dist/generated/themes/DateRangePicker.css.js +8 -0
- package/dist/generated/themes/DateTimePicker.css.js +8 -0
- package/dist/generated/themes/DateTimePickerPopover.css.js +5 -5
- package/dist/generated/themes/DayPicker.css.js +5 -5
- package/dist/generated/themes/Dialog.css.js +5 -5
- package/dist/generated/themes/FileUploader.css.js +5 -5
- package/dist/generated/themes/GroupHeaderListItem.css.js +5 -5
- package/dist/generated/themes/GrowingButton.css.js +8 -0
- package/dist/generated/themes/Icon.css.js +5 -5
- package/dist/generated/themes/Input.css.js +5 -5
- package/dist/generated/themes/InputIcon.css.js +5 -5
- package/dist/generated/themes/InvisibleTextStyles.css.js +5 -5
- package/dist/generated/themes/Label.css.js +5 -5
- package/dist/generated/themes/Link.css.js +5 -5
- package/dist/generated/themes/List.css.js +5 -5
- package/dist/generated/themes/ListItem.css.js +5 -5
- package/dist/generated/themes/ListItemBase.css.js +5 -5
- package/dist/generated/themes/MessageStrip.css.js +5 -5
- package/dist/generated/themes/MonthPicker.css.js +5 -5
- package/dist/generated/themes/MultiComboBox.css.js +5 -5
- package/dist/generated/themes/MultiInput.css.js +8 -0
- package/dist/generated/themes/Panel.css.js +5 -5
- package/dist/generated/themes/Popover.css.js +5 -5
- package/dist/generated/themes/Popup.css.js +5 -5
- package/dist/generated/themes/PopupGlobal.css.js +8 -0
- package/dist/generated/themes/PopupStaticAreaStyles.css.js +5 -5
- package/dist/generated/themes/PopupsCommon.css.js +8 -0
- package/dist/generated/themes/ProgressIndicator.css.js +8 -0
- package/dist/generated/themes/RadioButton.css.js +5 -5
- package/dist/generated/themes/RatingIndicator.css.js +8 -0
- package/dist/generated/themes/ResponsivePopover.css.js +5 -5
- package/dist/generated/themes/ResponsivePopoverCommon.css.js +5 -5
- package/dist/generated/themes/SegmentedButton.css.js +5 -5
- package/dist/generated/themes/Select.css.js +5 -5
- package/dist/generated/themes/SelectPopover.css.js +8 -0
- package/dist/generated/themes/SliderBase.css.js +8 -0
- package/dist/generated/themes/SplitButton.css.js +8 -0
- package/dist/generated/themes/StepInput.css.js +8 -0
- package/dist/generated/themes/Suggestions.css.js +8 -0
- package/dist/generated/themes/Switch.css.js +5 -5
- package/dist/generated/themes/Tab.css.js +5 -5
- package/dist/generated/themes/TabContainer.css.js +5 -5
- package/dist/generated/themes/TabInOverflow.css.js +5 -5
- package/dist/generated/themes/TabInStrip.css.js +5 -5
- package/dist/generated/themes/TabSeparatorInOverflow.css.js +8 -0
- package/dist/generated/themes/TabSeparatorInStrip.css.js +8 -0
- package/dist/generated/themes/Table.css.js +5 -5
- package/dist/generated/themes/TableCell.css.js +5 -5
- package/dist/generated/themes/TableColumn.css.js +5 -5
- package/dist/generated/themes/TableGroupRow.css.js +8 -0
- package/dist/generated/themes/TableRow.css.js +5 -5
- package/dist/generated/themes/TapHighlightColor.css.js +8 -0
- package/dist/generated/themes/TextArea.css.js +5 -5
- package/dist/generated/themes/TimePicker.css.js +5 -5
- package/dist/generated/themes/TimePickerPopover.css.js +5 -5
- package/dist/generated/themes/TimeSelection.css.js +8 -0
- package/dist/generated/themes/Title.css.js +5 -5
- package/dist/generated/themes/Toast.css.js +5 -5
- package/dist/generated/themes/ToggleButton.css.js +5 -5
- package/dist/generated/themes/ToggleButton.ie11.css.js +8 -0
- package/dist/generated/themes/Token.css.js +5 -5
- package/dist/generated/themes/Tokenizer.css.js +5 -5
- package/dist/generated/themes/TokenizerPopover.css.js +8 -0
- package/dist/generated/themes/Tree.css.js +5 -5
- package/dist/generated/themes/TreeListItem.css.js +5 -5
- package/dist/generated/themes/ValueStateMessage.css.js +5 -5
- package/dist/generated/themes/WheelSlider.css.js +5 -5
- package/dist/generated/themes/YearPicker.css.js +5 -5
- package/dist/generated/themes/sap_belize/parameters-bundle.css.js +1 -1
- package/dist/generated/themes/sap_belize_hcb/parameters-bundle.css.js +1 -1
- package/dist/generated/themes/sap_belize_hcw/parameters-bundle.css.js +1 -1
- package/dist/generated/themes/sap_fiori_3/parameters-bundle.css.js +1 -1
- package/dist/generated/themes/sap_fiori_3_dark/parameters-bundle.css.js +1 -1
- package/dist/generated/themes/sap_fiori_3_hcb/parameters-bundle.css.js +1 -0
- package/dist/generated/themes/sap_fiori_3_hcw/parameters-bundle.css.js +1 -0
- package/dist/generated/themes/sap_horizon/parameters-bundle.css.js +1 -0
- package/dist/generated/themes/sap_horizon_exp/parameters-bundle.css.js +1 -0
- package/dist/i18n/messagebundle.properties +360 -0
- package/dist/i18n/messagebundle_ar.properties +241 -0
- package/dist/i18n/messagebundle_bg.properties +241 -0
- package/dist/i18n/messagebundle_ca.properties +241 -0
- package/dist/i18n/messagebundle_cs.properties +241 -0
- package/dist/i18n/messagebundle_cy.properties +241 -0
- package/dist/i18n/messagebundle_da.properties +241 -0
- package/dist/i18n/messagebundle_de.properties +241 -0
- package/dist/i18n/messagebundle_el.properties +241 -0
- package/dist/i18n/messagebundle_en.properties +241 -0
- package/dist/i18n/messagebundle_en_GB.properties +241 -0
- package/dist/i18n/messagebundle_en_US_sappsd.properties +241 -0
- package/dist/i18n/messagebundle_en_US_saprigi.properties +241 -0
- package/dist/i18n/messagebundle_en_US_saptrc.properties +241 -0
- package/dist/i18n/messagebundle_es.properties +241 -0
- package/dist/i18n/messagebundle_es_MX.properties +241 -0
- package/dist/i18n/messagebundle_et.properties +241 -0
- package/dist/i18n/messagebundle_fi.properties +241 -0
- package/dist/i18n/messagebundle_fr.properties +241 -0
- package/dist/i18n/messagebundle_fr_CA.properties +241 -0
- package/dist/i18n/messagebundle_hi.properties +241 -0
- package/dist/i18n/messagebundle_hr.properties +241 -0
- package/dist/i18n/messagebundle_hu.properties +241 -0
- package/dist/i18n/messagebundle_id.properties +241 -0
- package/dist/i18n/messagebundle_in.properties +172 -0
- package/dist/i18n/messagebundle_it.properties +241 -0
- package/dist/i18n/messagebundle_iw.properties +241 -0
- package/dist/i18n/messagebundle_ja.properties +241 -0
- package/dist/i18n/messagebundle_kk.properties +241 -0
- package/dist/i18n/messagebundle_ko.properties +241 -0
- package/dist/i18n/messagebundle_lt.properties +241 -0
- package/dist/i18n/messagebundle_lv.properties +241 -0
- package/dist/i18n/messagebundle_ms.properties +241 -0
- package/dist/i18n/messagebundle_nl.properties +241 -0
- package/dist/i18n/messagebundle_no.properties +241 -0
- package/dist/i18n/messagebundle_pl.properties +241 -0
- package/dist/i18n/messagebundle_pt.properties +241 -0
- package/dist/i18n/messagebundle_pt_PT.properties +241 -0
- package/dist/i18n/messagebundle_ro.properties +241 -0
- package/dist/i18n/messagebundle_ru.properties +241 -0
- package/dist/i18n/messagebundle_sh.properties +241 -0
- package/dist/i18n/messagebundle_sk.properties +241 -0
- package/dist/i18n/messagebundle_sl.properties +241 -0
- package/dist/i18n/messagebundle_sv.properties +241 -0
- package/dist/i18n/messagebundle_th.properties +241 -0
- package/dist/i18n/messagebundle_tr.properties +241 -0
- package/dist/i18n/messagebundle_uk.properties +241 -0
- package/dist/i18n/messagebundle_vi.properties +241 -0
- package/dist/i18n/messagebundle_zh_CN.properties +241 -0
- package/dist/i18n/messagebundle_zh_TW.properties +241 -0
- package/dist/popup-utils/OpenedPopupsRegistry.js +18 -13
- package/dist/popup-utils/PopoverRegistry.js +49 -15
- package/dist/timepicker-utils/TimeSlider.js +15 -13
- package/dist/types/{AvatarBackgroundColor.js → AvatarColorScheme.js} +9 -9
- package/dist/types/AvatarGroupType.js +43 -0
- package/dist/types/AvatarShape.js +1 -1
- package/dist/types/AvatarSize.js +1 -1
- package/dist/types/BreadcrumbsDesign.js +42 -0
- package/dist/types/BreadcrumbsSeparatorStyle.js +69 -0
- package/dist/types/BusyIndicatorSize.js +1 -1
- package/dist/types/ButtonDesign.js +8 -1
- package/dist/types/CalendarSelectionMode.js +47 -0
- package/dist/types/CarouselArrowsPlacement.js +3 -3
- package/dist/types/GrowingMode.js +48 -0
- package/dist/types/HasPopup.js +62 -0
- package/dist/types/InputType.js +7 -7
- package/dist/types/LinkDesign.js +1 -1
- package/dist/types/ListGrowingMode.js +15 -0
- package/dist/types/ListItemType.js +2 -2
- package/dist/types/ListMode.js +9 -1
- package/dist/types/ListSeparators.js +1 -1
- package/dist/types/{MessageStripType.js → MessageStripDesign.js} +7 -7
- package/dist/types/PanelAccessibleRole.js +1 -1
- package/dist/types/PopoverHorizontalAlign.js +1 -1
- package/dist/types/PopoverPlacementType.js +2 -2
- package/dist/types/PopoverVerticalAlign.js +1 -2
- package/dist/types/Priority.js +1 -1
- package/dist/types/SemanticColor.js +1 -1
- package/dist/types/SwitchDesign.js +40 -0
- package/dist/types/TabContainerTabsPlacement.js +5 -5
- package/dist/types/TabLayout.js +1 -1
- package/dist/types/TableGrowingMode.js +15 -0
- package/dist/types/TableMode.js +47 -0
- package/dist/types/TableRowType.js +40 -0
- package/dist/types/TabsOverflowMode.js +40 -0
- package/dist/types/TitleLevel.js +1 -1
- package/dist/types/ToastPlacement.js +1 -2
- package/dist/types/WrappingType.js +41 -0
- package/dist/webcomponentsjs/CHANGELOG.md +61 -0
- package/dist/webcomponentsjs/README.md +64 -47
- package/dist/webcomponentsjs/bundles/webcomponents-ce.js +38 -38
- package/dist/webcomponentsjs/bundles/webcomponents-ce.js.map +1 -1
- package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js +60 -0
- package/dist/webcomponentsjs/bundles/webcomponents-pf_dom.js.map +1 -0
- package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js +95 -0
- package/dist/webcomponentsjs/bundles/webcomponents-pf_js.js.map +1 -0
- package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js +292 -229
- package/dist/webcomponentsjs/bundles/webcomponents-sd-ce-pf.js.map +1 -1
- package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js +190 -170
- package/dist/webcomponentsjs/bundles/webcomponents-sd-ce.js.map +1 -1
- package/dist/webcomponentsjs/bundles/webcomponents-sd.js +151 -132
- package/dist/webcomponentsjs/bundles/webcomponents-sd.js.map +1 -1
- package/dist/webcomponentsjs/custom-elements-es5-adapter.js +2 -2
- package/dist/webcomponentsjs/webcomponents-bundle.js +302 -230
- package/dist/webcomponentsjs/webcomponents-bundle.js.map +1 -1
- package/dist/webcomponentsjs/webcomponents-loader.js +49 -28
- package/package-scripts.js +1 -0
- package/package.json +25 -6
- package/src/Assets-static.js +6 -0
- package/src/Assets.js +7 -0
- package/src/Avatar.hbs +20 -0
- package/src/Avatar.js +392 -0
- package/src/AvatarGroup.hbs +30 -0
- package/src/AvatarGroup.js +603 -0
- package/src/Badge.hbs +14 -0
- package/src/Badge.js +165 -0
- package/src/Breadcrumbs.hbs +43 -0
- package/src/Breadcrumbs.js +580 -0
- package/src/BreadcrumbsItem.js +103 -0
- package/src/BreadcrumbsPopover.hbs +27 -0
- package/src/BusyIndicator.hbs +32 -0
- package/src/BusyIndicator.js +268 -0
- package/src/Button.hbs +45 -0
- package/src/Button.js +504 -0
- package/src/Calendar.hbs +69 -0
- package/src/Calendar.js +496 -0
- package/src/CalendarDate.js +45 -0
- package/src/CalendarHeader.hbs +54 -0
- package/src/CalendarHeader.js +209 -0
- package/src/CalendarPart.js +111 -0
- package/src/Card.hbs +14 -0
- package/src/Card.js +160 -0
- package/src/CardHeader.hbs +42 -0
- package/src/CardHeader.js +288 -0
- package/src/Carousel.hbs +86 -0
- package/src/Carousel.js +690 -0
- package/src/CheckBox.hbs +45 -0
- package/src/CheckBox.js +457 -0
- package/src/ColorPalette.hbs +52 -0
- package/src/ColorPalette.js +494 -0
- package/src/ColorPaletteDialog.hbs +18 -0
- package/src/ColorPaletteItem.hbs +11 -0
- package/src/ColorPaletteItem.js +137 -0
- package/src/ColorPalettePopover.hbs +31 -0
- package/src/ColorPalettePopover.js +244 -0
- package/src/ColorPicker.hbs +99 -0
- package/src/ColorPicker.js +562 -0
- package/src/ComboBox.hbs +50 -0
- package/src/ComboBox.js +1113 -0
- package/src/ComboBoxFilters.js +40 -0
- package/src/ComboBoxGroupItem.js +70 -0
- package/src/ComboBoxItem.js +49 -0
- package/src/ComboBoxPopover.hbs +125 -0
- package/src/CustomListItem.hbs +5 -0
- package/src/CustomListItem.js +99 -0
- package/src/DateComponentBase.js +168 -0
- package/src/DatePicker.hbs +44 -0
- package/src/DatePicker.js +833 -0
- package/src/DatePickerPopover.hbs +61 -0
- package/src/DateRangePicker.js +356 -0
- package/src/DateTimePicker.js +430 -0
- package/src/DateTimePickerPopover.hbs +74 -0
- package/src/DayPicker.hbs +66 -0
- package/src/DayPicker.js +754 -0
- package/src/Dialog.hbs +36 -0
- package/src/Dialog.js +614 -0
- package/src/DurationPicker.js +312 -0
- package/src/FileUploader.hbs +40 -0
- package/src/FileUploader.js +530 -0
- package/src/FileUploaderPopover.hbs +26 -0
- package/src/GroupHeaderListItem.hbs +15 -0
- package/src/GroupHeaderListItem.js +94 -0
- package/src/Icon.hbs +25 -0
- package/src/Icon.js +376 -0
- package/src/Input.hbs +82 -0
- package/src/Input.js +1522 -0
- package/src/InputPopover.hbs +116 -0
- package/src/Interfaces.js +192 -0
- package/src/Label.hbs +13 -0
- package/src/Label.js +158 -0
- package/src/Link.hbs +21 -0
- package/src/Link.js +378 -0
- package/src/List.hbs +89 -0
- package/src/List.js +1066 -0
- package/src/ListItem.hbs +103 -0
- package/src/ListItem.js +371 -0
- package/src/ListItemBase.js +179 -0
- package/src/MessageStrip.hbs +34 -0
- package/src/MessageStrip.js +256 -0
- package/src/MonthPicker.hbs +29 -0
- package/src/MonthPicker.js +299 -0
- package/src/MultiComboBox.hbs +78 -0
- package/src/MultiComboBox.js +1216 -0
- package/src/MultiComboBoxItem.js +43 -0
- package/src/MultiComboBoxPopover.hbs +132 -0
- package/src/MultiInput.hbs +41 -0
- package/src/MultiInput.js +348 -0
- package/src/Option.js +126 -0
- package/src/Panel.hbs +64 -0
- package/src/Panel.js +469 -0
- package/src/Popover.hbs +25 -0
- package/src/Popover.js +865 -0
- package/src/Popup.hbs +34 -0
- package/src/Popup.js +621 -0
- package/src/PopupBlockLayer.hbs +7 -0
- package/src/ProgressIndicator.hbs +35 -0
- package/src/ProgressIndicator.js +235 -0
- package/src/RadioButton.hbs +33 -0
- package/src/RadioButton.js +506 -0
- package/src/RadioButtonGroup.js +205 -0
- package/src/RangeSlider.hbs +70 -0
- package/src/RangeSlider.js +769 -0
- package/src/RatingIndicator.hbs +35 -0
- package/src/RatingIndicator.js +321 -0
- package/src/ResponsivePopover.hbs +41 -0
- package/src/ResponsivePopover.js +211 -0
- package/src/SegmentedButton.hbs +18 -0
- package/src/SegmentedButton.js +303 -0
- package/src/SegmentedButtonItem.hbs +42 -0
- package/src/SegmentedButtonItem.js +109 -0
- package/src/Select.hbs +45 -0
- package/src/Select.js +839 -0
- package/src/SelectPopover.hbs +89 -0
- package/src/Slider.hbs +42 -0
- package/src/Slider.js +320 -0
- package/src/SliderBase.hbs +38 -0
- package/src/SliderBase.js +847 -0
- package/src/SplitButton.hbs +53 -0
- package/src/SplitButton.js +426 -0
- package/src/StandardListItem.hbs +44 -0
- package/src/StandardListItem.js +191 -0
- package/src/StepInput.hbs +81 -0
- package/src/StepInput.js +684 -0
- package/src/SuggestionGroupItem.js +64 -0
- package/src/SuggestionItem.js +146 -0
- package/src/SuggestionListItem.hbs +33 -0
- package/src/SuggestionListItem.js +76 -0
- package/src/Switch.hbs +51 -0
- package/src/Switch.js +292 -0
- package/src/Tab.hbs +3 -0
- package/src/Tab.js +338 -0
- package/src/TabContainer.hbs +83 -0
- package/src/TabContainer.js +1087 -0
- package/src/TabContainerPopover.hbs +27 -0
- package/src/TabInOverflow.hbs +21 -0
- package/src/TabInStrip.hbs +38 -0
- package/src/TabSeparator.js +83 -0
- package/src/TabSeparatorInOverflow.hbs +8 -0
- package/src/TabSeparatorInStrip.hbs +6 -0
- package/src/Table.hbs +109 -0
- package/src/Table.js +1010 -0
- package/src/TableCell.hbs +7 -0
- package/src/TableCell.js +88 -0
- package/src/TableColumn.hbs +8 -0
- package/src/TableColumn.js +129 -0
- package/src/TableGroupRow.hbs +13 -0
- package/src/TableGroupRow.js +164 -0
- package/src/TableRow.hbs +63 -0
- package/src/TableRow.js +462 -0
- package/src/TextArea.hbs +50 -0
- package/src/TextArea.js +701 -0
- package/src/TextAreaPopover.hbs +27 -0
- package/src/TimePicker.hbs +35 -0
- package/src/TimePicker.js +166 -0
- package/src/TimePickerBase.js +463 -0
- package/src/TimePickerPopover.hbs +33 -0
- package/src/TimeSelection.hbs +60 -0
- package/src/TimeSelection.js +493 -0
- package/src/Title.hbs +47 -0
- package/src/Title.js +132 -0
- package/src/Toast.hbs +13 -0
- package/src/Toast.js +243 -0
- package/src/ToggleButton.hbs +5 -0
- package/src/ToggleButton.js +89 -0
- package/src/Token.hbs +30 -0
- package/src/Token.js +219 -0
- package/src/Tokenizer.hbs +28 -0
- package/src/Tokenizer.js +566 -0
- package/src/TokenizerPopover.hbs +50 -0
- package/src/Tree.hbs +43 -0
- package/src/Tree.js +447 -0
- package/src/TreeItem.js +189 -0
- package/src/TreeListItem.hbs +48 -0
- package/src/TreeListItem.js +343 -0
- package/src/WheelSlider.hbs +48 -0
- package/src/WheelSlider.js +435 -0
- package/src/YearPicker.hbs +27 -0
- package/src/YearPicker.js +324 -0
- package/src/features/ColorPaletteMoreColors.js +42 -0
- package/src/features/InputElementsFormSupport.js +88 -0
- package/src/features/InputSuggestions.js +594 -0
- package/src/i18n/messagebundle.properties +360 -0
- package/src/i18n/messagebundle_ar.properties +241 -0
- package/src/i18n/messagebundle_bg.properties +241 -0
- package/src/i18n/messagebundle_ca.properties +241 -0
- package/src/i18n/messagebundle_cs.properties +241 -0
- package/src/i18n/messagebundle_cy.properties +241 -0
- package/src/i18n/messagebundle_da.properties +241 -0
- package/src/i18n/messagebundle_de.properties +241 -0
- package/src/i18n/messagebundle_el.properties +241 -0
- package/src/i18n/messagebundle_en.properties +241 -0
- package/src/i18n/messagebundle_en_GB.properties +241 -0
- package/src/i18n/messagebundle_en_US_sappsd.properties +241 -0
- package/src/i18n/messagebundle_en_US_saprigi.properties +241 -0
- package/src/i18n/messagebundle_en_US_saptrc.properties +241 -0
- package/src/i18n/messagebundle_es.properties +241 -0
- package/src/i18n/messagebundle_es_MX.properties +241 -0
- package/src/i18n/messagebundle_et.properties +241 -0
- package/src/i18n/messagebundle_fi.properties +241 -0
- package/src/i18n/messagebundle_fr.properties +241 -0
- package/src/i18n/messagebundle_fr_CA.properties +241 -0
- package/src/i18n/messagebundle_hi.properties +241 -0
- package/src/i18n/messagebundle_hr.properties +241 -0
- package/src/i18n/messagebundle_hu.properties +241 -0
- package/src/i18n/messagebundle_id.properties +241 -0
- package/src/i18n/messagebundle_in.properties +172 -0
- package/src/i18n/messagebundle_it.properties +241 -0
- package/src/i18n/messagebundle_iw.properties +241 -0
- package/src/i18n/messagebundle_ja.properties +241 -0
- package/src/i18n/messagebundle_kk.properties +241 -0
- package/src/i18n/messagebundle_ko.properties +241 -0
- package/src/i18n/messagebundle_lt.properties +241 -0
- package/src/i18n/messagebundle_lv.properties +241 -0
- package/src/i18n/messagebundle_ms.properties +241 -0
- package/src/i18n/messagebundle_nl.properties +241 -0
- package/src/i18n/messagebundle_no.properties +241 -0
- package/src/i18n/messagebundle_pl.properties +241 -0
- package/src/i18n/messagebundle_pt.properties +241 -0
- package/src/i18n/messagebundle_pt_PT.properties +241 -0
- package/src/i18n/messagebundle_ro.properties +241 -0
- package/src/i18n/messagebundle_ru.properties +241 -0
- package/src/i18n/messagebundle_sh.properties +241 -0
- package/src/i18n/messagebundle_sk.properties +241 -0
- package/src/i18n/messagebundle_sl.properties +241 -0
- package/src/i18n/messagebundle_sv.properties +241 -0
- package/src/i18n/messagebundle_th.properties +241 -0
- package/src/i18n/messagebundle_tr.properties +241 -0
- package/src/i18n/messagebundle_uk.properties +241 -0
- package/src/i18n/messagebundle_vi.properties +241 -0
- package/src/i18n/messagebundle_zh_CN.properties +241 -0
- package/src/i18n/messagebundle_zh_TW.properties +241 -0
- package/src/popup-utils/OpenedPopupsRegistry.js +50 -0
- package/src/popup-utils/PopoverRegistry.js +145 -0
- package/src/themes/Avatar.css +227 -0
- package/src/themes/AvatarGroup.css +82 -0
- package/src/themes/Badge.css +247 -0
- package/src/themes/Breadcrumbs.css +100 -0
- package/src/themes/BreadcrumbsPopover.css +6 -0
- package/src/themes/BrowserScrollbar.css +25 -0
- package/src/themes/BusyIndicator.css +143 -0
- package/src/themes/Button.css +306 -0
- package/src/themes/Button.ie11.css +48 -0
- package/src/themes/Calendar.css +23 -0
- package/src/themes/CalendarHeader.css +137 -0
- package/src/themes/Card.css +42 -0
- package/src/themes/CardHeader.css +133 -0
- package/src/themes/Carousel.css +140 -0
- package/src/themes/CheckBox.css +289 -0
- package/src/themes/ColorPalette.css +70 -0
- package/src/themes/ColorPaletteItem.css +70 -0
- package/src/themes/ColorPalettePopover.css +17 -0
- package/src/themes/ColorPaletteStaticArea.css +17 -0
- package/src/themes/ColorPicker.css +190 -0
- package/src/themes/ComboBox.css +9 -0
- package/src/themes/ComboBoxPopover.css +17 -0
- package/src/themes/CustomListItem.css +31 -0
- package/src/themes/DatePicker.css +46 -0
- package/src/themes/DatePickerPopover.css +9 -0
- package/src/themes/DateRangePicker.css +16 -0
- package/src/themes/DateTimePicker.css +11 -0
- package/src/themes/DateTimePickerPopover.css +78 -0
- package/src/themes/DayPicker.css +269 -0
- package/src/themes/Dialog.css +66 -0
- package/src/themes/FileUploader.css +40 -0
- package/src/themes/GroupHeaderListItem.css +24 -0
- package/src/themes/GrowingButton.css +67 -0
- package/src/themes/Icon.css +38 -0
- package/src/themes/Input.css +407 -0
- package/src/themes/InputIcon.css +53 -0
- package/src/themes/InvisibleTextStyles.css +9 -0
- package/src/themes/Label.css +85 -0
- package/src/themes/Link.css +77 -0
- package/src/themes/List.css +116 -0
- package/src/themes/ListItem.css +231 -0
- package/src/themes/ListItemBase.css +79 -0
- package/src/themes/MessageStrip.css +123 -0
- package/src/themes/MonthPicker.css +86 -0
- package/src/themes/MultiComboBox.css +36 -0
- package/src/themes/MultiInput.css +14 -0
- package/src/themes/Panel.css +100 -0
- package/src/themes/Popover.css +102 -0
- package/src/themes/Popup.css +5 -0
- package/src/themes/PopupGlobal.css +6 -0
- package/src/themes/PopupStaticAreaStyles.css +17 -0
- package/src/themes/PopupsCommon.css +127 -0
- package/src/themes/ProgressIndicator.css +158 -0
- package/src/themes/RadioButton.css +249 -0
- package/src/themes/RatingIndicator.css +52 -0
- package/src/themes/ResponsivePopover.css +29 -0
- package/src/themes/ResponsivePopoverCommon.css +208 -0
- package/src/themes/SegmentedButton.css +88 -0
- package/src/themes/Select.css +53 -0
- package/src/themes/SelectPopover.css +19 -0
- package/src/themes/SliderBase.css +253 -0
- package/src/themes/SplitButton.css +98 -0
- package/src/themes/StepInput.css +269 -0
- package/src/themes/Suggestions.css +28 -0
- package/src/themes/Switch.css +370 -0
- package/src/themes/Tab.css +9 -0
- package/src/themes/TabContainer.css +128 -0
- package/src/themes/TabInOverflow.css +65 -0
- package/src/themes/TabInStrip.css +374 -0
- package/src/themes/TabSeparatorInOverflow.css +8 -0
- package/src/themes/TabSeparatorInStrip.css +5 -0
- package/src/themes/Table.css +91 -0
- package/src/themes/TableCell.css +28 -0
- package/src/themes/TableColumn.css +29 -0
- package/src/themes/TableGroupRow.css +34 -0
- package/src/themes/TableRow.css +85 -0
- package/src/themes/TapHighlightColor.css +3 -0
- package/src/themes/TextArea.css +309 -0
- package/src/themes/TimePicker.css +50 -0
- package/src/themes/TimePickerPopover.css +15 -0
- package/src/themes/TimeSelection.css +27 -0
- package/src/themes/Title.css +65 -0
- package/src/themes/Toast.css +93 -0
- package/src/themes/ToggleButton.css +88 -0
- package/src/themes/ToggleButton.ie11.css +48 -0
- package/src/themes/Token.css +117 -0
- package/src/themes/Tokenizer.css +85 -0
- package/src/themes/TokenizerPopover.css +4 -0
- package/src/themes/Tree.css +11 -0
- package/src/themes/TreeListItem.css +107 -0
- package/src/themes/ValueStateMessage.css +86 -0
- package/src/themes/WheelSlider.css +203 -0
- package/src/themes/YearPicker.css +86 -0
- package/src/themes/base/Avatar-parameters.css +38 -0
- package/src/themes/base/AvatarGroup-parameter.css +6 -0
- package/src/themes/base/Badge-parameters.css +61 -0
- package/src/themes/base/BrowserScrollbar-parameters.css +4 -0
- package/src/themes/base/BusyIndicator-parameters.css +5 -0
- package/src/themes/base/Button-parameters.css +30 -0
- package/src/themes/base/CalendarHeader-parameters.css +20 -0
- package/src/themes/base/Card-parameters.css +17 -0
- package/src/themes/base/Carousel-parameters.css +9 -0
- package/src/themes/base/CheckBox-parameters.css +53 -0
- package/src/themes/base/ColorPalette-parameters.css +14 -0
- package/src/themes/base/ColorPicker-parameters.css +8 -0
- package/src/themes/base/DatePicker-parameters.css +6 -0
- package/src/themes/base/DayPicker-parameters.css +41 -0
- package/src/themes/base/Dialog-parameters.css +9 -0
- package/src/themes/base/GroupHeaderListItem-parameters.css +3 -0
- package/src/themes/base/GrowingButton-parameters.css +6 -0
- package/src/themes/base/Input-parameters.css +63 -0
- package/src/themes/base/InputIcon-parameters.css +11 -0
- package/src/themes/base/Link-parameters.css +8 -0
- package/src/themes/base/List-parameters.css +3 -0
- package/src/themes/base/ListItemBase-parameters.css +9 -0
- package/src/themes/base/MessageStrip-parameters.css +21 -0
- package/src/themes/base/MonthPicker-parameters.css +16 -0
- package/src/themes/base/MultiComboBox-parameters.css +3 -0
- package/src/themes/base/Panel-parameters.css +11 -0
- package/src/themes/base/PopupsCommon-parameters.css +13 -0
- package/src/themes/base/ProgressIndicator-parameters.css +21 -0
- package/src/themes/base/RadioButton-parameters.css +32 -0
- package/src/themes/base/RatingIndicator-parameters.css +3 -0
- package/src/themes/base/SegmentedButtton-parameters.css +8 -0
- package/src/themes/base/Select-parameters.css +11 -0
- package/src/themes/base/SelectPopover-parameters.css +4 -0
- package/src/themes/base/SliderBase-parameters.css +64 -0
- package/src/themes/base/StepInput-parameters.css +23 -0
- package/src/themes/base/Suggestions-parameters.css +3 -0
- package/src/themes/base/Switch-parameters.css +96 -0
- package/src/themes/base/TabContainer-parameters.css +84 -0
- package/src/themes/base/Table-parameters.css +6 -0
- package/src/themes/base/TableColumn-parameters.css +3 -0
- package/src/themes/base/TableRow-parameters.css +3 -0
- package/src/themes/base/TextArea-parameters.css +22 -0
- package/src/themes/base/TimePicker-parameters.css +4 -0
- package/src/themes/base/TimelineItem-parameters.css +10 -0
- package/src/themes/base/Title-parameters.css +8 -0
- package/src/themes/base/Toast-parameters.css +6 -0
- package/src/themes/base/ToggleButton-parameters.css +8 -0
- package/src/themes/base/Token-parameters.css +19 -0
- package/src/themes/base/Tokenizer-parameters.css +4 -0
- package/src/themes/base/ValueStateMessage-parameters.css +7 -0
- package/src/themes/base/WheelSlider-parameters.css +15 -0
- package/src/themes/base/YearPicker-parameters.css +16 -0
- package/src/themes/base/sizes-parameters.css +302 -0
- package/src/themes/sap_belize/BrowserScrollbar-parameters.css +4 -0
- package/src/themes/sap_belize/Carousel-parameters.css +9 -0
- package/src/themes/sap_belize/Dialog-parameters.css +5 -0
- package/src/themes/sap_belize/Input-parameters.css +6 -0
- package/src/themes/sap_belize/InputIcon-parameters.css +5 -0
- package/src/themes/sap_belize/ProgressIndicator-parameters.css +8 -0
- package/src/themes/sap_belize/SliderBase-parameters.css +22 -0
- package/src/themes/sap_belize/TabContainer-parameters.css +6 -0
- package/src/themes/sap_belize/Table-parameters.css +7 -0
- package/src/themes/sap_belize/TimePicker-parameters.css +5 -0
- package/src/themes/sap_belize/WheelSlider-parameters.css +17 -0
- package/src/themes/sap_belize/parameters-bundle.css +48 -0
- package/src/themes/sap_belize_hcb/Avatar-parameters.css +18 -0
- package/src/themes/sap_belize_hcb/Badge-parameters.css +43 -0
- package/src/themes/sap_belize_hcb/BrowserScrollbar-parameters.css +4 -0
- package/src/themes/sap_belize_hcb/Button-parameters.css +12 -0
- package/src/themes/sap_belize_hcb/CalendarHeader-parameters.css +11 -0
- package/src/themes/sap_belize_hcb/Card-parameters.css +6 -0
- package/src/themes/sap_belize_hcb/Carousel-parameters.css +9 -0
- package/src/themes/sap_belize_hcb/CheckBox-parameters.css +12 -0
- package/src/themes/sap_belize_hcb/DatePicker-parameters.css +6 -0
- package/src/themes/sap_belize_hcb/DayPicker-parameters.css +13 -0
- package/src/themes/sap_belize_hcb/Dialog-parameters.css +7 -0
- package/src/themes/sap_belize_hcb/GrowingButton-parameters.css +8 -0
- package/src/themes/sap_belize_hcb/Input-parameters.css +14 -0
- package/src/themes/sap_belize_hcb/InputIcon-parameters.css +5 -0
- package/src/themes/sap_belize_hcb/Link-parameters.css +7 -0
- package/src/themes/sap_belize_hcb/MessageStrip-parameters.css +10 -0
- package/src/themes/sap_belize_hcb/MonthPicker-parameters.css +10 -0
- package/src/themes/sap_belize_hcb/Panel-parameters.css +5 -0
- package/src/themes/sap_belize_hcb/ProgressIndicator-parameters.css +11 -0
- package/src/themes/sap_belize_hcb/RadioButton-parameters.css +10 -0
- package/src/themes/sap_belize_hcb/Select-parameters.css +12 -0
- package/src/themes/sap_belize_hcb/SliderBase-parameters.css +17 -0
- package/src/themes/sap_belize_hcb/Switch-parameters.css +44 -0
- package/src/themes/sap_belize_hcb/TabContainer-parameters.css +44 -0
- package/src/themes/sap_belize_hcb/Table-parameters.css +7 -0
- package/src/themes/sap_belize_hcb/TableRow-parameters.css +5 -0
- package/src/themes/sap_belize_hcb/TextArea-parameters.css +6 -0
- package/src/themes/sap_belize_hcb/ToggleButton-parameters.css +7 -0
- package/src/themes/sap_belize_hcb/Token-parameters.css +6 -0
- package/src/themes/sap_belize_hcb/ValueStateMessage-parameters.css +5 -0
- package/src/themes/sap_belize_hcb/WheelSlider-parameters.css +17 -0
- package/src/themes/sap_belize_hcb/YearPicker-parameters.css +10 -0
- package/src/themes/sap_belize_hcb/parameters-bundle.css +47 -0
- package/src/themes/sap_belize_hcw/Avatar-parameters.css +18 -0
- package/src/themes/sap_belize_hcw/Badge-parameters.css +43 -0
- package/src/themes/sap_belize_hcw/BrowserScrollbar-parameters.css +4 -0
- package/src/themes/sap_belize_hcw/Button-parameters.css +12 -0
- package/src/themes/sap_belize_hcw/CalendarHeader-parameters.css +11 -0
- package/src/themes/sap_belize_hcw/Card-parameters.css +6 -0
- package/src/themes/sap_belize_hcw/Carousel-parameters.css +9 -0
- package/src/themes/sap_belize_hcw/CheckBox-parameters.css +12 -0
- package/src/themes/sap_belize_hcw/DatePicker-parameters.css +5 -0
- package/src/themes/sap_belize_hcw/DayPicker-parameters.css +14 -0
- package/src/themes/sap_belize_hcw/Dialog-parameters.css +7 -0
- package/src/themes/sap_belize_hcw/GrowingButton-parameters.css +8 -0
- package/src/themes/sap_belize_hcw/Input-parameters.css +14 -0
- package/src/themes/sap_belize_hcw/InputIcon-parameters.css +5 -0
- package/src/themes/sap_belize_hcw/Link-parameters.css +7 -0
- package/src/themes/sap_belize_hcw/MessageStrip-parameters.css +10 -0
- package/src/themes/sap_belize_hcw/MonthPicker-parameters.css +10 -0
- package/src/themes/sap_belize_hcw/Panel-parameters.css +5 -0
- package/src/themes/sap_belize_hcw/ProgressIndicator-parameters.css +11 -0
- package/src/themes/sap_belize_hcw/RadioButton-parameters.css +10 -0
- package/src/themes/sap_belize_hcw/Select-parameters.css +12 -0
- package/src/themes/sap_belize_hcw/SliderBase-parameters.css +17 -0
- package/src/themes/sap_belize_hcw/Switch-parameters.css +43 -0
- package/src/themes/sap_belize_hcw/TabContainer-parameters.css +44 -0
- package/src/themes/sap_belize_hcw/Table-parameters.css +7 -0
- package/src/themes/sap_belize_hcw/TableRow-parameters.css +5 -0
- package/src/themes/sap_belize_hcw/TextArea-parameters.css +6 -0
- package/src/themes/sap_belize_hcw/ToggleButton-parameters.css +6 -0
- package/src/themes/sap_belize_hcw/Token-parameters.css +6 -0
- package/src/themes/sap_belize_hcw/ValueStateMessage-parameters.css +5 -0
- package/src/themes/sap_belize_hcw/WheelSlider-parameters.css +17 -0
- package/src/themes/sap_belize_hcw/YearPicker-parameters.css +10 -0
- package/src/themes/sap_belize_hcw/parameters-bundle.css +47 -0
- package/src/themes/sap_fiori_3/Avatar-parameters.css +9 -0
- package/src/themes/sap_fiori_3/Button-parameters.css +14 -0
- package/src/themes/sap_fiori_3/CalendarHeader-parameters.css +8 -0
- package/src/themes/sap_fiori_3/CheckBox-parameters.css +13 -0
- package/src/themes/sap_fiori_3/DayPicker-parameters.css +6 -0
- package/src/themes/sap_fiori_3/Input-parameters.css +7 -0
- package/src/themes/sap_fiori_3/Link-parameters.css +7 -0
- package/src/themes/sap_fiori_3/List-parameters.css +5 -0
- package/src/themes/sap_fiori_3/MonthPicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3/MultiComboBox-parameters.css +5 -0
- package/src/themes/sap_fiori_3/Panel-parameters.css +6 -0
- package/src/themes/sap_fiori_3/SliderBase-parameters.css +5 -0
- package/src/themes/sap_fiori_3/TabContainer-parameters.css +12 -0
- package/src/themes/sap_fiori_3/TimePicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3/Token-parameters.css +9 -0
- package/src/themes/sap_fiori_3/WheelSlider-parameters.css +16 -0
- package/src/themes/sap_fiori_3/YearPicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3/parameters-bundle.css +48 -0
- package/src/themes/sap_fiori_3_dark/Avatar-parameters.css +9 -0
- package/src/themes/sap_fiori_3_dark/Button-parameters.css +14 -0
- package/src/themes/sap_fiori_3_dark/CalendarHeader-parameters.css +8 -0
- package/src/themes/sap_fiori_3_dark/CheckBox-parameters.css +13 -0
- package/src/themes/sap_fiori_3_dark/DayPicker-parameters.css +6 -0
- package/src/themes/sap_fiori_3_dark/Input-parameters.css +7 -0
- package/src/themes/sap_fiori_3_dark/Link-parameters.css +7 -0
- package/src/themes/sap_fiori_3_dark/List-parameters.css +5 -0
- package/src/themes/sap_fiori_3_dark/MonthPicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_dark/MultiComboBox-parameters.css +5 -0
- package/src/themes/sap_fiori_3_dark/Panel-parameters.css +6 -0
- package/src/themes/sap_fiori_3_dark/SliderBase-parameters.css +5 -0
- package/src/themes/sap_fiori_3_dark/TabContainer-parameters.css +12 -0
- package/src/themes/sap_fiori_3_dark/Token-parameters.css +8 -0
- package/src/themes/sap_fiori_3_dark/WheelSlider-parameters.css +15 -0
- package/src/themes/sap_fiori_3_dark/YearPicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_dark/parameters-bundle.css +47 -0
- package/src/themes/sap_fiori_3_hcb/Avatar-parameters.css +24 -0
- package/src/themes/sap_fiori_3_hcb/Badge-parameters.css +43 -0
- package/src/themes/sap_fiori_3_hcb/Button-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcb/CalendarHeader-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcb/Card-parameters.css +6 -0
- package/src/themes/sap_fiori_3_hcb/Carousel-parameters.css +9 -0
- package/src/themes/sap_fiori_3_hcb/CheckBox-parameters.css +13 -0
- package/src/themes/sap_fiori_3_hcb/DatePicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/DayPicker-parameters.css +17 -0
- package/src/themes/sap_fiori_3_hcb/Dialog-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcb/GrowingButton-parameters.css +8 -0
- package/src/themes/sap_fiori_3_hcb/Input-parameters.css +21 -0
- package/src/themes/sap_fiori_3_hcb/InputIcon-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/Link-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcb/MessageStrip-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcb/MonthPicker-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcb/Panel-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/ProgressIndicator-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcb/RadioButton-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcb/Select-parameters.css +12 -0
- package/src/themes/sap_fiori_3_hcb/SliderBase-parameters.css +14 -0
- package/src/themes/sap_fiori_3_hcb/Switch-parameters.css +43 -0
- package/src/themes/sap_fiori_3_hcb/TabContainer-parameters.css +44 -0
- package/src/themes/sap_fiori_3_hcb/Table-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/TableRow-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/TextArea-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcb/TimePicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/ToggleButton-parameters.css +6 -0
- package/src/themes/sap_fiori_3_hcb/Token-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcb/ValueStateMessage-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcb/WheelSlider-parameters.css +17 -0
- package/src/themes/sap_fiori_3_hcb/YearPicker-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcb/parameters-bundle.css +48 -0
- package/src/themes/sap_fiori_3_hcw/Avatar-parameters.css +24 -0
- package/src/themes/sap_fiori_3_hcw/Badge-parameters.css +43 -0
- package/src/themes/sap_fiori_3_hcw/Button-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcw/CalendarHeader-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcw/Card-parameters.css +6 -0
- package/src/themes/sap_fiori_3_hcw/Carousel-parameters.css +9 -0
- package/src/themes/sap_fiori_3_hcw/CheckBox-parameters.css +13 -0
- package/src/themes/sap_fiori_3_hcw/DatePicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/DayPicker-parameters.css +17 -0
- package/src/themes/sap_fiori_3_hcw/Dialog-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcw/GrowingButton-parameters.css +8 -0
- package/src/themes/sap_fiori_3_hcw/Input-parameters.css +21 -0
- package/src/themes/sap_fiori_3_hcw/InputIcon-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/Link-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcw/MessageStrip-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcw/MonthPicker-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcw/Panel-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/ProgressIndicator-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcw/RadioButton-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcw/Select-parameters.css +12 -0
- package/src/themes/sap_fiori_3_hcw/SliderBase-parameters.css +13 -0
- package/src/themes/sap_fiori_3_hcw/Switch-parameters.css +43 -0
- package/src/themes/sap_fiori_3_hcw/TabContainer-parameters.css +44 -0
- package/src/themes/sap_fiori_3_hcw/Table-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/TableRow-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/TextArea-parameters.css +10 -0
- package/src/themes/sap_fiori_3_hcw/TimePicker-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/ToggleButton-parameters.css +6 -0
- package/src/themes/sap_fiori_3_hcw/Token-parameters.css +7 -0
- package/src/themes/sap_fiori_3_hcw/ValueStateMessage-parameters.css +5 -0
- package/src/themes/sap_fiori_3_hcw/WheelSlider-parameters.css +17 -0
- package/src/themes/sap_fiori_3_hcw/YearPicker-parameters.css +11 -0
- package/src/themes/sap_fiori_3_hcw/parameters-bundle.css +48 -0
- package/src/themes/sap_horizon/Avatar-parameters.css +33 -0
- package/src/themes/sap_horizon/BusyIndicator-parameters.css +7 -0
- package/src/themes/sap_horizon/Button-parameters.css +20 -0
- package/src/themes/sap_horizon/CalendarHeader-parameters.css +19 -0
- package/src/themes/sap_horizon/Card-parameters.css +10 -0
- package/src/themes/sap_horizon/CheckBox-parameters.css +34 -0
- package/src/themes/sap_horizon/ColorPalette-parameters.css +16 -0
- package/src/themes/sap_horizon/ColorPicker-parameters.css +10 -0
- package/src/themes/sap_horizon/DatePicker-parameters.css +6 -0
- package/src/themes/sap_horizon/DayPicker-parameters.css +31 -0
- package/src/themes/sap_horizon/Dialog-parameters.css +11 -0
- package/src/themes/sap_horizon/GrowingButton-parameters.css +5 -0
- package/src/themes/sap_horizon/Input-parameters.css +35 -0
- package/src/themes/sap_horizon/InputIcon-parameters.css +17 -0
- package/src/themes/sap_horizon/Link-parameters.css +10 -0
- package/src/themes/sap_horizon/List-parameters.css +5 -0
- package/src/themes/sap_horizon/ListItemBase-parameters.css +7 -0
- package/src/themes/sap_horizon/MessageStrip-parameters.css +9 -0
- package/src/themes/sap_horizon/MonthPicker-parameters.css +17 -0
- package/src/themes/sap_horizon/MultiComboBox-parameters.css +5 -0
- package/src/themes/sap_horizon/Panel-parameters.css +12 -0
- package/src/themes/sap_horizon/PopupsCommon-parameters.css +9 -0
- package/src/themes/sap_horizon/ProgressIndicator-parameters.css +23 -0
- package/src/themes/sap_horizon/RadioButton-parameters.css +9 -0
- package/src/themes/sap_horizon/RatingIndicator-parameters.css +3 -0
- package/src/themes/sap_horizon/SegmentedButtton-parameters.css +10 -0
- package/src/themes/sap_horizon/Select-parameters.css +5 -0
- package/src/themes/sap_horizon/SelectPopover-parameters.css +4 -0
- package/src/themes/sap_horizon/SliderBase-parameters.css +44 -0
- package/src/themes/sap_horizon/StepInput-parameters.css +25 -0
- package/src/themes/sap_horizon/Suggestions-parameters.css +5 -0
- package/src/themes/sap_horizon/Switch-parameters.css +31 -0
- package/src/themes/sap_horizon/TabContainer-parameters.css +25 -0
- package/src/themes/sap_horizon/Table-parameters.css +8 -0
- package/src/themes/sap_horizon/TableColumn-parameters.css +5 -0
- package/src/themes/sap_horizon/TableRow-parameters.css +5 -0
- package/src/themes/sap_horizon/TextArea-parameters.css +22 -0
- package/src/themes/sap_horizon/TimePicker-parameters.css +6 -0
- package/src/themes/sap_horizon/ToggleButton-parameters.css +11 -0
- package/src/themes/sap_horizon/Token-parameters.css +28 -0
- package/src/themes/sap_horizon/Tokenizer-parameters.css +6 -0
- package/src/themes/sap_horizon/ValueStateMessage-parameters.css +8 -0
- package/src/themes/sap_horizon/WheelSlider-parameters.css +19 -0
- package/src/themes/sap_horizon/YearPicker-parameters.css +16 -0
- package/src/themes/sap_horizon/parameters-bundle.css +57 -0
- package/src/themes/sap_horizon/sizes-parameters.css +8 -0
- package/src/themes/sap_horizon_exp/Badge-parameters.css +91 -0
- package/src/themes/sap_horizon_exp/Button-parameters.css +12 -0
- package/src/themes/sap_horizon_exp/CalendarHeader-parameters.css +8 -0
- package/src/themes/sap_horizon_exp/CheckBox-parameters.css +35 -0
- package/src/themes/sap_horizon_exp/DatePicker-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/DayPicker-parameters.css +6 -0
- package/src/themes/sap_horizon_exp/Input-parameters.css +46 -0
- package/src/themes/sap_horizon_exp/InputIcon-parameters.css +9 -0
- package/src/themes/sap_horizon_exp/Link-parameters.css +7 -0
- package/src/themes/sap_horizon_exp/List-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/MonthPicker-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/MultiComboBox-parameters.css +7 -0
- package/src/themes/sap_horizon_exp/Panel-parameters.css +6 -0
- package/src/themes/sap_horizon_exp/Popover-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/RadioButton-parameters.css +30 -0
- package/src/themes/sap_horizon_exp/Select-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/SliderBase-parameters.css +30 -0
- package/src/themes/sap_horizon_exp/Switch-parameters.css +46 -0
- package/src/themes/sap_horizon_exp/TabContainer-parameters.css +40 -0
- package/src/themes/sap_horizon_exp/TimePicker-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/Token-parameters.css +9 -0
- package/src/themes/sap_horizon_exp/WheelSlider-parameters.css +16 -0
- package/src/themes/sap_horizon_exp/YearPicker-parameters.css +5 -0
- package/src/themes/sap_horizon_exp/parameters-bundle.css +46 -0
- package/src/timepicker-utils/TimeSlider.js +103 -0
- package/src/types/AvatarColorScheme.js +104 -0
- package/src/types/AvatarGroupType.js +43 -0
- package/src/types/AvatarShape.js +41 -0
- package/src/types/AvatarSize.js +67 -0
- package/src/types/BreadcrumbsDesign.js +42 -0
- package/src/types/BreadcrumbsSeparatorStyle.js +69 -0
- package/src/types/BusyIndicatorSize.js +47 -0
- package/src/types/ButtonDesign.js +68 -0
- package/src/types/CalendarSelectionMode.js +47 -0
- package/src/types/CarouselArrowsPlacement.js +40 -0
- package/src/types/GrowingMode.js +48 -0
- package/src/types/HasPopup.js +62 -0
- package/src/types/InputType.js +68 -0
- package/src/types/LinkDesign.js +47 -0
- package/src/types/ListGrowingMode.js +15 -0
- package/src/types/ListItemType.js +47 -0
- package/src/types/ListMode.js +77 -0
- package/src/types/ListSeparators.js +46 -0
- package/src/types/MessageStripDesign.js +54 -0
- package/src/types/PanelAccessibleRole.js +48 -0
- package/src/types/PopoverHorizontalAlign.js +54 -0
- package/src/types/PopoverPlacementType.js +54 -0
- package/src/types/PopoverVerticalAlign.js +54 -0
- package/src/types/Priority.js +55 -0
- package/src/types/SemanticColor.js +61 -0
- package/src/types/SwitchDesign.js +40 -0
- package/src/types/TabContainerTabsPlacement.js +40 -0
- package/src/types/TabLayout.js +40 -0
- package/src/types/TableGrowingMode.js +15 -0
- package/src/types/TableMode.js +47 -0
- package/src/types/TableRowType.js +40 -0
- package/src/types/TabsOverflowMode.js +40 -0
- package/src/types/TitleLevel.js +68 -0
- package/src/types/ToastPlacement.js +91 -0
- package/src/types/WrappingType.js +41 -0
- package/dist/Timeline.js +0 -97
- package/dist/TimelineItem.js +0 -161
- package/dist/generated/templates/ComboBoxItemTemplate.lit.js +0 -7
- package/dist/generated/templates/DurationPickerPopoverTemplate.lit.js +0 -10
- package/dist/generated/templates/DurationPickerTemplate.lit.js +0 -8
- package/dist/generated/templates/TabSeparatorTemplate.lit.js +0 -7
- package/dist/generated/templates/TimelineItemTemplate.lit.js +0 -12
- package/dist/generated/templates/TimelineTemplate.lit.js +0 -8
- package/dist/generated/themes/ComboBoxItem.css.js +0 -8
- package/dist/generated/themes/DurationPicker.css.js +0 -8
- package/dist/generated/themes/DurationPickerPopover.css.js +0 -8
- package/dist/generated/themes/Timeline.css.js +0 -8
- package/dist/generated/themes/TimelineItem.css.js +0 -8
- package/dist/popup-utils/PopupUtils.js +0 -55
- package/dist/types/AvatarFitType.js +0 -40
- package/dist/webcomponentsjs/package.json +0 -46
package/src/Input.js
ADDED
|
@@ -0,0 +1,1522 @@
|
|
|
1
|
+
import UI5Element from "@ui5/webcomponents-base/dist/UI5Element.js";
|
|
2
|
+
import litRender from "@ui5/webcomponents-base/dist/renderer/LitRenderer.js";
|
|
3
|
+
import ResizeHandler from "@ui5/webcomponents-base/dist/delegate/ResizeHandler.js";
|
|
4
|
+
import { isIE, isPhone, isSafari } from "@ui5/webcomponents-base/dist/Device.js";
|
|
5
|
+
import ValueState from "@ui5/webcomponents-base/dist/types/ValueState.js";
|
|
6
|
+
import { getFeature } from "@ui5/webcomponents-base/dist/FeaturesRegistry.js";
|
|
7
|
+
import {
|
|
8
|
+
isUp,
|
|
9
|
+
isDown,
|
|
10
|
+
isSpace,
|
|
11
|
+
isEnter,
|
|
12
|
+
isBackSpace,
|
|
13
|
+
isDelete,
|
|
14
|
+
isEscape,
|
|
15
|
+
isTabNext,
|
|
16
|
+
isPageUp,
|
|
17
|
+
isPageDown,
|
|
18
|
+
isHome,
|
|
19
|
+
isEnd,
|
|
20
|
+
} from "@ui5/webcomponents-base/dist/Keys.js";
|
|
21
|
+
import Integer from "@ui5/webcomponents-base/dist/types/Integer.js";
|
|
22
|
+
import { getI18nBundle } from "@ui5/webcomponents-base/dist/i18nBundle.js";
|
|
23
|
+
import { getEffectiveAriaLabelText } from "@ui5/webcomponents-base/dist/util/AriaLabelHelper.js";
|
|
24
|
+
import { getCaretPosition, setCaretPosition } from "@ui5/webcomponents-base/dist/util/Caret.js";
|
|
25
|
+
import "@ui5/webcomponents-icons/dist/decline.js";
|
|
26
|
+
import "@ui5/webcomponents-icons/dist/not-editable.js";
|
|
27
|
+
import "@ui5/webcomponents-icons/dist/error.js";
|
|
28
|
+
import "@ui5/webcomponents-icons/dist/alert.js";
|
|
29
|
+
import "@ui5/webcomponents-icons/dist/sys-enter-2.js";
|
|
30
|
+
import "@ui5/webcomponents-icons/dist/information.js";
|
|
31
|
+
import InputType from "./types/InputType.js";
|
|
32
|
+
import Popover from "./Popover.js";
|
|
33
|
+
// Templates
|
|
34
|
+
import InputTemplate from "./generated/templates/InputTemplate.lit.js";
|
|
35
|
+
import InputPopoverTemplate from "./generated/templates/InputPopoverTemplate.lit.js";
|
|
36
|
+
|
|
37
|
+
import {
|
|
38
|
+
VALUE_STATE_SUCCESS,
|
|
39
|
+
VALUE_STATE_INFORMATION,
|
|
40
|
+
VALUE_STATE_ERROR,
|
|
41
|
+
VALUE_STATE_WARNING,
|
|
42
|
+
INPUT_SUGGESTIONS,
|
|
43
|
+
INPUT_SUGGESTIONS_TITLE,
|
|
44
|
+
INPUT_SUGGESTIONS_ONE_HIT,
|
|
45
|
+
INPUT_SUGGESTIONS_MORE_HITS,
|
|
46
|
+
INPUT_SUGGESTIONS_NO_HIT,
|
|
47
|
+
} from "./generated/i18n/i18n-defaults.js";
|
|
48
|
+
|
|
49
|
+
// Styles
|
|
50
|
+
import styles from "./generated/themes/Input.css.js";
|
|
51
|
+
import ResponsivePopoverCommonCss from "./generated/themes/ResponsivePopoverCommon.css.js";
|
|
52
|
+
import ValueStateMessageCss from "./generated/themes/ValueStateMessage.css.js";
|
|
53
|
+
import SuggestionsCss from "./generated/themes/Suggestions.css.js";
|
|
54
|
+
|
|
55
|
+
const rgxFloat = new RegExp(/(\+|-)?\d+(\.|,)\d+/);
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* @public
|
|
59
|
+
*/
|
|
60
|
+
const metadata = {
|
|
61
|
+
tag: "ui5-input",
|
|
62
|
+
languageAware: true,
|
|
63
|
+
managedSlots: true,
|
|
64
|
+
slots: /** @lends sap.ui.webcomponents.main.Input.prototype */ {
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Defines the icon to be displayed in the component.
|
|
68
|
+
*
|
|
69
|
+
* @type {sap.ui.webcomponents.main.IIcon[]}
|
|
70
|
+
* @slot
|
|
71
|
+
* @public
|
|
72
|
+
*/
|
|
73
|
+
icon: {
|
|
74
|
+
type: HTMLElement,
|
|
75
|
+
},
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Defines the suggestion items.
|
|
79
|
+
* <br><br>
|
|
80
|
+
* Example:
|
|
81
|
+
* <br><br>
|
|
82
|
+
* <ui5-input show-suggestions><br>
|
|
83
|
+
* <ui5-suggestion-item text="Item #1"></ui5-suggestion-item><br>
|
|
84
|
+
* <ui5-suggestion-item text="Item #2"></ui5-suggestion-item><br>
|
|
85
|
+
* </ui5-input>
|
|
86
|
+
* <br>
|
|
87
|
+
* <ui5-input show-suggestions>
|
|
88
|
+
* <ui5-suggestion-group-item text="Group #1"></ui5-suggestion-group-item>
|
|
89
|
+
* <ui5-suggestion-item text="Item #1"></ui5-suggestion-item>
|
|
90
|
+
* <ui5-suggestion-item text="Item #2"></ui5-suggestion-item>
|
|
91
|
+
* <ui5-suggestion-group-item text="Group #2"></ui5-suggestion-group-item>
|
|
92
|
+
* <ui5-suggestion-item text="Item #3"></ui5-suggestion-item>
|
|
93
|
+
* <ui5-suggestion-item text="Item #4"></ui5-suggestion-item>
|
|
94
|
+
* </ui5-input>
|
|
95
|
+
* <br><br>
|
|
96
|
+
* <b>Note:</b> The suggestions would be displayed only if the <code>showSuggestions</code>
|
|
97
|
+
* property is set to <code>true</code>.
|
|
98
|
+
* <br><br>
|
|
99
|
+
* <b>Note:</b> The <code><ui5-suggestion-item></code> and <code><ui5-suggestion-group-item></code> are recommended to be used as suggestion items.
|
|
100
|
+
* <br><br>
|
|
101
|
+
* <b>Note:</b> Importing the Input Suggestions Support feature:
|
|
102
|
+
* <br>
|
|
103
|
+
* <code>import "@ui5/webcomponents/dist/features/InputSuggestions.js";</code>
|
|
104
|
+
* <br>
|
|
105
|
+
* automatically imports the <code><ui5-suggestion-item></code> and <code><ui5-suggestion-group-item></code> for your convenience.
|
|
106
|
+
*
|
|
107
|
+
* @type {sap.ui.webcomponents.main.IInputSuggestionItem[]}
|
|
108
|
+
* @slot suggestionItems
|
|
109
|
+
* @public
|
|
110
|
+
*/
|
|
111
|
+
"default": {
|
|
112
|
+
propertyName: "suggestionItems",
|
|
113
|
+
type: HTMLElement,
|
|
114
|
+
},
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* The slot is used for native <code>input</code> HTML element to enable form submit,
|
|
118
|
+
* when <code>name</code> property is set.
|
|
119
|
+
* @type {HTMLElement[]}
|
|
120
|
+
* @private
|
|
121
|
+
*/
|
|
122
|
+
formSupport: {
|
|
123
|
+
type: HTMLElement,
|
|
124
|
+
},
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* Defines the value state message that will be displayed as pop up under the component.
|
|
128
|
+
* <br><br>
|
|
129
|
+
*
|
|
130
|
+
* <b>Note:</b> If not specified, a default text (in the respective language) will be displayed.
|
|
131
|
+
* <br><br>
|
|
132
|
+
* <b>Note:</b> The <code>valueStateMessage</code> would be displayed,
|
|
133
|
+
* when the component is in <code>Information</code>, <code>Warning</code> or <code>Error</code> value state.
|
|
134
|
+
* <br><br>
|
|
135
|
+
* <b>Note:</b> If the component has <code>suggestionItems</code>,
|
|
136
|
+
* the <code>valueStateMessage</code> would be displayed as part of the same popover, if used on desktop, or dialog - on phone.
|
|
137
|
+
* @type {HTMLElement[]}
|
|
138
|
+
* @since 1.0.0-rc.6
|
|
139
|
+
* @slot
|
|
140
|
+
* @public
|
|
141
|
+
*/
|
|
142
|
+
valueStateMessage: {
|
|
143
|
+
type: HTMLElement,
|
|
144
|
+
},
|
|
145
|
+
},
|
|
146
|
+
properties: /** @lends sap.ui.webcomponents.main.Input.prototype */ {
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* Defines whether the component is in disabled state.
|
|
150
|
+
* <br><br>
|
|
151
|
+
* <b>Note:</b> A disabled component is completely noninteractive.
|
|
152
|
+
*
|
|
153
|
+
* @type {boolean}
|
|
154
|
+
* @defaultvalue false
|
|
155
|
+
* @public
|
|
156
|
+
*/
|
|
157
|
+
disabled: {
|
|
158
|
+
type: Boolean,
|
|
159
|
+
},
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Defines if characters within the suggestions are to be highlighted
|
|
163
|
+
* in case the input value matches parts of the suggestions text.
|
|
164
|
+
* <br><br>
|
|
165
|
+
* <b>Note:</b> takes effect when <code>showSuggestions</code> is set to <code>true</code>
|
|
166
|
+
*
|
|
167
|
+
* @type {boolean}
|
|
168
|
+
* @defaultvalue false
|
|
169
|
+
* @private
|
|
170
|
+
* @sicne 1.0.0-rc.8
|
|
171
|
+
*/
|
|
172
|
+
highlight: {
|
|
173
|
+
type: Boolean,
|
|
174
|
+
},
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* Defines a short hint intended to aid the user with data entry when the
|
|
178
|
+
* component has no value.
|
|
179
|
+
* @type {string}
|
|
180
|
+
* @defaultvalue ""
|
|
181
|
+
* @public
|
|
182
|
+
*/
|
|
183
|
+
placeholder: {
|
|
184
|
+
type: String,
|
|
185
|
+
},
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
* Defines whether the component is read-only.
|
|
189
|
+
* <br><br>
|
|
190
|
+
* <b>Note:</b> A read-only component is not editable,
|
|
191
|
+
* but still provides visual feedback upon user interaction.
|
|
192
|
+
*
|
|
193
|
+
* @type {boolean}
|
|
194
|
+
* @defaultvalue false
|
|
195
|
+
* @public
|
|
196
|
+
*/
|
|
197
|
+
readonly: {
|
|
198
|
+
type: Boolean,
|
|
199
|
+
},
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* Defines whether the component is required.
|
|
203
|
+
*
|
|
204
|
+
* @type {boolean}
|
|
205
|
+
* @defaultvalue false
|
|
206
|
+
* @public
|
|
207
|
+
* @since 1.0.0-rc.3
|
|
208
|
+
*/
|
|
209
|
+
required: {
|
|
210
|
+
type: Boolean,
|
|
211
|
+
},
|
|
212
|
+
|
|
213
|
+
/**
|
|
214
|
+
* Defines the HTML type of the component.
|
|
215
|
+
* Available options are: <code>Text</code>, <code>Email</code>,
|
|
216
|
+
* <code>Number</code>, <code>Password</code>, <code>Tel</code>, and <code>URL</code>.
|
|
217
|
+
* <br><br>
|
|
218
|
+
* <b>Notes:</b>
|
|
219
|
+
* <ul>
|
|
220
|
+
* <li>The particular effect of this property differs depending on the browser
|
|
221
|
+
* and the current language settings, especially for type <code>Number</code>.</li>
|
|
222
|
+
* <li>The property is mostly intended to be used with touch devices
|
|
223
|
+
* that use different soft keyboard layouts depending on the given input type.</li>
|
|
224
|
+
* </ul>
|
|
225
|
+
*
|
|
226
|
+
* @type {InputType}
|
|
227
|
+
* @defaultvalue "Text"
|
|
228
|
+
* @public
|
|
229
|
+
*/
|
|
230
|
+
type: {
|
|
231
|
+
type: InputType,
|
|
232
|
+
defaultValue: InputType.Text,
|
|
233
|
+
},
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Defines the value of the component.
|
|
237
|
+
* <br><br>
|
|
238
|
+
* <b>Note:</b> The property is updated upon typing.
|
|
239
|
+
*
|
|
240
|
+
* @type {string}
|
|
241
|
+
* @defaultvalue ""
|
|
242
|
+
* @public
|
|
243
|
+
*/
|
|
244
|
+
value: {
|
|
245
|
+
type: String,
|
|
246
|
+
},
|
|
247
|
+
|
|
248
|
+
/**
|
|
249
|
+
* Defines the value state of the component.
|
|
250
|
+
* <br><br>
|
|
251
|
+
* Available options are:
|
|
252
|
+
* <ul>
|
|
253
|
+
* <li><code>None</code></li>
|
|
254
|
+
* <li><code>Error</code></li>
|
|
255
|
+
* <li><code>Warning</code></li>
|
|
256
|
+
* <li><code>Success</code></li>
|
|
257
|
+
* <li><code>Information</code></li>
|
|
258
|
+
* </ul>
|
|
259
|
+
*
|
|
260
|
+
* @type {ValueState}
|
|
261
|
+
* @defaultvalue "None"
|
|
262
|
+
* @public
|
|
263
|
+
*/
|
|
264
|
+
valueState: {
|
|
265
|
+
type: ValueState,
|
|
266
|
+
defaultValue: ValueState.None,
|
|
267
|
+
},
|
|
268
|
+
|
|
269
|
+
/**
|
|
270
|
+
* Determines the name with which the component will be submitted in an HTML form.
|
|
271
|
+
*
|
|
272
|
+
* <br><br>
|
|
273
|
+
* <b>Important:</b> For the <code>name</code> property to have effect, you must add the following import to your project:
|
|
274
|
+
* <code>import "@ui5/webcomponents/dist/features/InputElementsFormSupport.js";</code>
|
|
275
|
+
*
|
|
276
|
+
* <br><br>
|
|
277
|
+
* <b>Note:</b> When set, a native <code>input</code> HTML element
|
|
278
|
+
* will be created inside the component so that it can be submitted as
|
|
279
|
+
* part of an HTML form. Do not use this property unless you need to submit a form.
|
|
280
|
+
*
|
|
281
|
+
* @type {string}
|
|
282
|
+
* @defaultvalue ""
|
|
283
|
+
* @public
|
|
284
|
+
*/
|
|
285
|
+
name: {
|
|
286
|
+
type: String,
|
|
287
|
+
},
|
|
288
|
+
|
|
289
|
+
/**
|
|
290
|
+
* Defines whether the component should show suggestions, if such are present.
|
|
291
|
+
* <br><br>
|
|
292
|
+
* <b>Note:</b> You need to import the <code>InputSuggestions</code> module
|
|
293
|
+
* from <code>"@ui5/webcomponents/dist/features/InputSuggestions.js"</code> to enable this functionality.
|
|
294
|
+
* @type {boolean}
|
|
295
|
+
* @defaultvalue false
|
|
296
|
+
* @public
|
|
297
|
+
*/
|
|
298
|
+
showSuggestions: {
|
|
299
|
+
type: Boolean,
|
|
300
|
+
},
|
|
301
|
+
|
|
302
|
+
/**
|
|
303
|
+
* Sets the maximum number of characters available in the input field.
|
|
304
|
+
*
|
|
305
|
+
* @type {Integer}
|
|
306
|
+
* @since 1.0.0-rc.5
|
|
307
|
+
* @public
|
|
308
|
+
*/
|
|
309
|
+
maxlength: {
|
|
310
|
+
type: Integer,
|
|
311
|
+
},
|
|
312
|
+
|
|
313
|
+
/**
|
|
314
|
+
* Defines the accessible aria name of the component.
|
|
315
|
+
*
|
|
316
|
+
* @type {string}
|
|
317
|
+
* @public
|
|
318
|
+
* @since 1.0.0-rc.15
|
|
319
|
+
*/
|
|
320
|
+
accessibleName: {
|
|
321
|
+
type: String,
|
|
322
|
+
},
|
|
323
|
+
|
|
324
|
+
/**
|
|
325
|
+
* Receives id(or many ids) of the elements that label the input.
|
|
326
|
+
*
|
|
327
|
+
* @type {string}
|
|
328
|
+
* @defaultvalue ""
|
|
329
|
+
* @public
|
|
330
|
+
* @since 1.0.0-rc.15
|
|
331
|
+
*/
|
|
332
|
+
accessibleNameRef: {
|
|
333
|
+
type: String,
|
|
334
|
+
defaultValue: "",
|
|
335
|
+
},
|
|
336
|
+
|
|
337
|
+
/**
|
|
338
|
+
* Defines whether the clear icon of the input will be shown.
|
|
339
|
+
*
|
|
340
|
+
* @type {boolean}
|
|
341
|
+
* @defaultvalue false
|
|
342
|
+
* @public
|
|
343
|
+
* @since 1.2.0
|
|
344
|
+
*/
|
|
345
|
+
showClearIcon: {
|
|
346
|
+
type: Boolean,
|
|
347
|
+
},
|
|
348
|
+
|
|
349
|
+
/**
|
|
350
|
+
* Defines whether the clear icon is visible.
|
|
351
|
+
*
|
|
352
|
+
* @type {boolean}
|
|
353
|
+
* @defaultvalue false
|
|
354
|
+
* @private
|
|
355
|
+
* @since 1.2.0
|
|
356
|
+
*/
|
|
357
|
+
effectiveShowClearIcon: {
|
|
358
|
+
type: Boolean,
|
|
359
|
+
},
|
|
360
|
+
|
|
361
|
+
/**
|
|
362
|
+
* @private
|
|
363
|
+
*/
|
|
364
|
+
focused: {
|
|
365
|
+
type: Boolean,
|
|
366
|
+
},
|
|
367
|
+
|
|
368
|
+
/**
|
|
369
|
+
* Indicates whether the visual focus is on the value state header
|
|
370
|
+
* @private
|
|
371
|
+
*/
|
|
372
|
+
_isValueStateFocused: {
|
|
373
|
+
type: Boolean,
|
|
374
|
+
},
|
|
375
|
+
|
|
376
|
+
open: {
|
|
377
|
+
type: Boolean,
|
|
378
|
+
},
|
|
379
|
+
|
|
380
|
+
_input: {
|
|
381
|
+
type: Object,
|
|
382
|
+
},
|
|
383
|
+
|
|
384
|
+
_inputAccInfo: {
|
|
385
|
+
type: Object,
|
|
386
|
+
},
|
|
387
|
+
|
|
388
|
+
_nativeInputAttributes: {
|
|
389
|
+
type: Object,
|
|
390
|
+
},
|
|
391
|
+
|
|
392
|
+
_inputWidth: {
|
|
393
|
+
type: Integer,
|
|
394
|
+
},
|
|
395
|
+
|
|
396
|
+
_listWidth: {
|
|
397
|
+
type: Integer,
|
|
398
|
+
},
|
|
399
|
+
|
|
400
|
+
_isPopoverOpen: {
|
|
401
|
+
type: Boolean,
|
|
402
|
+
noAttribute: true,
|
|
403
|
+
},
|
|
404
|
+
|
|
405
|
+
_inputIconFocused: {
|
|
406
|
+
type: Boolean,
|
|
407
|
+
noAttribute: true,
|
|
408
|
+
},
|
|
409
|
+
},
|
|
410
|
+
events: /** @lends sap.ui.webcomponents.main.Input.prototype */ {
|
|
411
|
+
/**
|
|
412
|
+
* Fired when the input operation has finished by pressing Enter or on focusout.
|
|
413
|
+
*
|
|
414
|
+
* @event
|
|
415
|
+
* @public
|
|
416
|
+
*/
|
|
417
|
+
change: {},
|
|
418
|
+
|
|
419
|
+
/**
|
|
420
|
+
* Fired when the value of the component changes at each keystroke,
|
|
421
|
+
* and when a suggestion item has been selected.
|
|
422
|
+
*
|
|
423
|
+
* @event
|
|
424
|
+
* @public
|
|
425
|
+
*/
|
|
426
|
+
input: {},
|
|
427
|
+
|
|
428
|
+
/**
|
|
429
|
+
* Fired when a suggestion item, that is displayed in the suggestion popup, is selected.
|
|
430
|
+
*
|
|
431
|
+
* @event sap.ui.webcomponents.main.Input#suggestion-item-select
|
|
432
|
+
* @param {HTMLElement} item The selected item.
|
|
433
|
+
* @public
|
|
434
|
+
*/
|
|
435
|
+
"suggestion-item-select": {
|
|
436
|
+
detail: {
|
|
437
|
+
item: { type: HTMLElement },
|
|
438
|
+
},
|
|
439
|
+
},
|
|
440
|
+
|
|
441
|
+
/**
|
|
442
|
+
* Fired when the user navigates to a suggestion item via the ARROW keys,
|
|
443
|
+
* as a preview, before the final selection.
|
|
444
|
+
*
|
|
445
|
+
* @event sap.ui.webcomponents.main.Input#suggestion-item-preview
|
|
446
|
+
* @param {HTMLElement} item The previewed suggestion item.
|
|
447
|
+
* @param {HTMLElement} targetRef The DOM ref of the suggestion item.
|
|
448
|
+
* @public
|
|
449
|
+
* @since 1.0.0-rc.8
|
|
450
|
+
*/
|
|
451
|
+
"suggestion-item-preview": {
|
|
452
|
+
detail: {
|
|
453
|
+
item: { type: HTMLElement },
|
|
454
|
+
targetRef: { type: HTMLElement },
|
|
455
|
+
},
|
|
456
|
+
},
|
|
457
|
+
|
|
458
|
+
/**
|
|
459
|
+
* Fired when the user scrolls the suggestion popover.
|
|
460
|
+
*
|
|
461
|
+
* @event sap.ui.webcomponents.main.Input#suggestion-scroll
|
|
462
|
+
* @param {Integer} scrollTop The current scroll position.
|
|
463
|
+
* @param {HTMLElement} scrollContainer The scroll container.
|
|
464
|
+
* @protected
|
|
465
|
+
* @since 1.0.0-rc.8
|
|
466
|
+
*/
|
|
467
|
+
"suggestion-scroll": {
|
|
468
|
+
detail: {
|
|
469
|
+
scrollTop: { type: Integer },
|
|
470
|
+
scrollContainer: { type: HTMLElement },
|
|
471
|
+
},
|
|
472
|
+
},
|
|
473
|
+
},
|
|
474
|
+
};
|
|
475
|
+
|
|
476
|
+
/**
|
|
477
|
+
* @class
|
|
478
|
+
* <h3 class="comment-api-title">Overview</h3>
|
|
479
|
+
*
|
|
480
|
+
* The <code>ui5-input</code> component allows the user to enter and edit text or numeric values in one line.
|
|
481
|
+
* <br>
|
|
482
|
+
* Additionally, you can provide <code>suggestionItems</code>,
|
|
483
|
+
* that are displayed in a popover right under the input.
|
|
484
|
+
* <br><br>
|
|
485
|
+
* The text field can be editable or read-only (<code>readonly</code> property),
|
|
486
|
+
* and it can be enabled or disabled (<code>disabled</code> property).
|
|
487
|
+
* To visualize semantic states, such as "error" or "warning", the <code>valueState</code> property is provided.
|
|
488
|
+
* When the user makes changes to the text, the change event is fired,
|
|
489
|
+
* which enables you to react on any text change.
|
|
490
|
+
* <br><br>
|
|
491
|
+
* <b>Note:</b> If you are using the <code>ui5-input</code> as a single npm module,
|
|
492
|
+
* don't forget to import the <code>InputSuggestions</code> module from
|
|
493
|
+
* "@ui5/webcomponents/dist/features/InputSuggestions.js"
|
|
494
|
+
* to enable the suggestions functionality.
|
|
495
|
+
*
|
|
496
|
+
* <h3>Keyboard Handling</h3>
|
|
497
|
+
* The <code>ui5-input</code> provides the following keyboard shortcuts:
|
|
498
|
+
* <br>
|
|
499
|
+
*
|
|
500
|
+
* <ul>
|
|
501
|
+
* <li>[ESC] - Closes the suggestion list, if open. If closed or not enabled, cancels changes and reverts to the value which the Input field had when it got the focus.</li>
|
|
502
|
+
* <li>[ENTER] or [RETURN] - If suggestion list is open takes over the current matching item and closes it. If value state or group header is focused, does nothing.</li>
|
|
503
|
+
* <li>[DOWN] - Focuses the next matching item in the suggestion list.</li>
|
|
504
|
+
* <li>[UP] - Focuses the previous matching item in the suggestion list.</li>
|
|
505
|
+
* <li>[HOME] - If focus is in the text input, moves caret before the first character. If focus is in the list, highlights the first item and updates the input accordingly.</li>
|
|
506
|
+
* <li>[END] - If focus is in the text input, moves caret after the last character. If focus is in the list, highlights the last item and updates the input accordingly.</li>
|
|
507
|
+
* <li>[PAGEUP] - If focus is in the list, moves highlight up by page size (10 items by default). If focus is in the input, does nothing.</li>
|
|
508
|
+
* <li>[PAGEDOWN] - If focus is in the list, moves highlight down by page size (10 items by default). If focus is in the input, does nothing.</li>
|
|
509
|
+
* </ul>
|
|
510
|
+
*
|
|
511
|
+
* <h3>ES6 Module Import</h3>
|
|
512
|
+
*
|
|
513
|
+
* <code>import "@ui5/webcomponents/dist/Input.js";</code>
|
|
514
|
+
* <br>
|
|
515
|
+
* <code>import "@ui5/webcomponents/dist/features/InputSuggestions.js";</code> (optional - for input suggestions support)
|
|
516
|
+
*
|
|
517
|
+
* @constructor
|
|
518
|
+
* @author SAP SE
|
|
519
|
+
* @alias sap.ui.webcomponents.main.Input
|
|
520
|
+
* @extends sap.ui.webcomponents.base.UI5Element
|
|
521
|
+
* @tagname ui5-input
|
|
522
|
+
* @appenddocs SuggestionItem SuggestionGroupItem
|
|
523
|
+
* @implements sap.ui.webcomponents.main.IInput
|
|
524
|
+
* @public
|
|
525
|
+
*/
|
|
526
|
+
class Input extends UI5Element {
|
|
527
|
+
static get metadata() {
|
|
528
|
+
return metadata;
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
static get render() {
|
|
532
|
+
return litRender;
|
|
533
|
+
}
|
|
534
|
+
|
|
535
|
+
static get template() {
|
|
536
|
+
return InputTemplate;
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
static get staticAreaTemplate() {
|
|
540
|
+
return InputPopoverTemplate;
|
|
541
|
+
}
|
|
542
|
+
|
|
543
|
+
static get styles() {
|
|
544
|
+
return styles;
|
|
545
|
+
}
|
|
546
|
+
|
|
547
|
+
static get staticAreaStyles() {
|
|
548
|
+
return [ResponsivePopoverCommonCss, ValueStateMessageCss, SuggestionsCss];
|
|
549
|
+
}
|
|
550
|
+
|
|
551
|
+
constructor() {
|
|
552
|
+
super();
|
|
553
|
+
// Indicates if there is selected suggestionItem.
|
|
554
|
+
this.hasSuggestionItemSelected = false;
|
|
555
|
+
|
|
556
|
+
// Represents the value before user moves selection from suggestion item to another
|
|
557
|
+
// and its value is updated after each move.
|
|
558
|
+
// Note: Used to register and fire "input" event upon [SPACE] or [ENTER].
|
|
559
|
+
// Note: The property "value" is updated upon selection move and can`t be used.
|
|
560
|
+
this.valueBeforeItemSelection = "";
|
|
561
|
+
|
|
562
|
+
// Represents the value before user moves selection between the suggestion items
|
|
563
|
+
// and its value remains the same when the user navigates up or down the list.
|
|
564
|
+
// Note: Used to cancel selection upon [ESC].
|
|
565
|
+
this.valueBeforeItemPreview = "";
|
|
566
|
+
|
|
567
|
+
// Indicates if the user selection has been canceled with [ESC].
|
|
568
|
+
this.suggestionSelectionCanceled = false;
|
|
569
|
+
|
|
570
|
+
// Indicates if the change event has already been fired
|
|
571
|
+
this._changeFiredValue = null;
|
|
572
|
+
|
|
573
|
+
// tracks the value between focus in and focus out to detect that change event should be fired.
|
|
574
|
+
this.previousValue = undefined;
|
|
575
|
+
|
|
576
|
+
// Indicates, if the component is rendering for first time.
|
|
577
|
+
this.firstRendering = true;
|
|
578
|
+
|
|
579
|
+
// The value that should be highlited.
|
|
580
|
+
this.highlightValue = "";
|
|
581
|
+
|
|
582
|
+
// The last value confirmed by the user with "ENTER"
|
|
583
|
+
this.lastConfirmedValue = "";
|
|
584
|
+
|
|
585
|
+
// Indicates, if the user pressed the BACKSPACE key.
|
|
586
|
+
this._backspaceKeyDown = false;
|
|
587
|
+
|
|
588
|
+
// all sementic events
|
|
589
|
+
this.EVENT_CHANGE = "change";
|
|
590
|
+
this.EVENT_INPUT = "input";
|
|
591
|
+
this.EVENT_SUGGESTION_ITEM_SELECT = "suggestion-item-select";
|
|
592
|
+
|
|
593
|
+
// all user interactions
|
|
594
|
+
this.ACTION_ENTER = "enter";
|
|
595
|
+
this.ACTION_USER_INPUT = "input";
|
|
596
|
+
|
|
597
|
+
// Suggestions array initialization
|
|
598
|
+
this.suggestionsTexts = [];
|
|
599
|
+
|
|
600
|
+
this._handleResizeBound = this._handleResize.bind(this);
|
|
601
|
+
}
|
|
602
|
+
|
|
603
|
+
onEnterDOM() {
|
|
604
|
+
ResizeHandler.register(this, this._handleResizeBound);
|
|
605
|
+
}
|
|
606
|
+
|
|
607
|
+
onExitDOM() {
|
|
608
|
+
ResizeHandler.deregister(this, this._handleResizeBound);
|
|
609
|
+
}
|
|
610
|
+
|
|
611
|
+
onBeforeRendering() {
|
|
612
|
+
if (this.showSuggestions) {
|
|
613
|
+
this.enableSuggestions();
|
|
614
|
+
this.suggestionsTexts = this.Suggestions.defaultSlotProperties(this.highlightValue);
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
this.effectiveShowClearIcon = (this.showClearIcon && !!this.value && !this.readonly && !this.disabled);
|
|
618
|
+
this.open = this.open && (!!this.suggestionItems.length || this._isPhone);
|
|
619
|
+
|
|
620
|
+
const FormSupport = getFeature("FormSupport");
|
|
621
|
+
|
|
622
|
+
if (FormSupport) {
|
|
623
|
+
FormSupport.syncNativeHiddenInput(this);
|
|
624
|
+
} else if (this.name) {
|
|
625
|
+
console.warn(`In order for the "name" property to have effect, you should also: import "@ui5/webcomponents/dist/features/InputElementsFormSupport.js";`); // eslint-disable-line
|
|
626
|
+
}
|
|
627
|
+
}
|
|
628
|
+
|
|
629
|
+
async onAfterRendering() {
|
|
630
|
+
if (this.Suggestions) {
|
|
631
|
+
this.Suggestions.toggle(this.open, {
|
|
632
|
+
preventFocusRestore: true,
|
|
633
|
+
});
|
|
634
|
+
|
|
635
|
+
this._listWidth = await this.Suggestions._getListWidth();
|
|
636
|
+
}
|
|
637
|
+
|
|
638
|
+
if (this.shouldDisplayOnlyValueStateMessage) {
|
|
639
|
+
this.openPopover();
|
|
640
|
+
} else {
|
|
641
|
+
this.closePopover();
|
|
642
|
+
}
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
_onkeydown(event) {
|
|
646
|
+
if (isUp(event)) {
|
|
647
|
+
return this._handleUp(event);
|
|
648
|
+
}
|
|
649
|
+
|
|
650
|
+
if (isDown(event)) {
|
|
651
|
+
return this._handleDown(event);
|
|
652
|
+
}
|
|
653
|
+
|
|
654
|
+
if (isSpace(event)) {
|
|
655
|
+
return this._handleSpace(event);
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
if (isTabNext(event)) {
|
|
659
|
+
return this._handleTab(event);
|
|
660
|
+
}
|
|
661
|
+
|
|
662
|
+
if (isEnter(event)) {
|
|
663
|
+
return this._handleEnter(event);
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
if (isPageUp(event)) {
|
|
667
|
+
return this._handlePageUp(event);
|
|
668
|
+
}
|
|
669
|
+
|
|
670
|
+
if (isPageDown(event)) {
|
|
671
|
+
return this._handlePageDown(event);
|
|
672
|
+
}
|
|
673
|
+
|
|
674
|
+
if (isHome(event)) {
|
|
675
|
+
return this._handleHome(event);
|
|
676
|
+
}
|
|
677
|
+
|
|
678
|
+
if (isEnd(event)) {
|
|
679
|
+
return this._handleEnd(event);
|
|
680
|
+
}
|
|
681
|
+
|
|
682
|
+
if (isEscape(event)) {
|
|
683
|
+
return this._handleEscape(event);
|
|
684
|
+
}
|
|
685
|
+
|
|
686
|
+
if (isBackSpace(event)) {
|
|
687
|
+
this._backspaceKeyDown = true;
|
|
688
|
+
this._selectedText = window.getSelection().toString();
|
|
689
|
+
}
|
|
690
|
+
|
|
691
|
+
if (this.showSuggestions) {
|
|
692
|
+
this._clearPopoverFocusAndSelection();
|
|
693
|
+
}
|
|
694
|
+
|
|
695
|
+
this._keyDown = true;
|
|
696
|
+
}
|
|
697
|
+
|
|
698
|
+
_onkeyup(event) {
|
|
699
|
+
// The native Delete event does not update the value property "on time". So, the (native) change event is always fired with the old value
|
|
700
|
+
if (isDelete(event)) {
|
|
701
|
+
this.value = event.target.value;
|
|
702
|
+
}
|
|
703
|
+
|
|
704
|
+
this._keyDown = false;
|
|
705
|
+
this._backspaceKeyDown = false;
|
|
706
|
+
}
|
|
707
|
+
|
|
708
|
+
/* Event handling */
|
|
709
|
+
_handleUp(event) {
|
|
710
|
+
if (this.Suggestions && this.Suggestions.isOpened()) {
|
|
711
|
+
this.Suggestions.onUp(event);
|
|
712
|
+
}
|
|
713
|
+
}
|
|
714
|
+
|
|
715
|
+
_handleDown(event) {
|
|
716
|
+
if (this.Suggestions && this.Suggestions.isOpened()) {
|
|
717
|
+
this.Suggestions.onDown(event);
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
_handleSpace(event) {
|
|
722
|
+
if (this.Suggestions) {
|
|
723
|
+
this.Suggestions.onSpace(event);
|
|
724
|
+
}
|
|
725
|
+
}
|
|
726
|
+
|
|
727
|
+
_handleTab(event) {
|
|
728
|
+
if (this.Suggestions && (this.previousValue !== this.value)) {
|
|
729
|
+
this.Suggestions.onTab(event);
|
|
730
|
+
}
|
|
731
|
+
}
|
|
732
|
+
|
|
733
|
+
_handleEnter(event) {
|
|
734
|
+
const itemPressed = !!(this.Suggestions && this.Suggestions.onEnter(event));
|
|
735
|
+
|
|
736
|
+
if (!itemPressed) {
|
|
737
|
+
this.fireEventByAction(this.ACTION_ENTER);
|
|
738
|
+
this.lastConfirmedValue = this.value;
|
|
739
|
+
return;
|
|
740
|
+
}
|
|
741
|
+
|
|
742
|
+
this.focused = true;
|
|
743
|
+
}
|
|
744
|
+
|
|
745
|
+
_handlePageUp(event) {
|
|
746
|
+
if (this._isSuggestionsFocused) {
|
|
747
|
+
this.Suggestions.onPageUp(event);
|
|
748
|
+
} else {
|
|
749
|
+
event.preventDefault();
|
|
750
|
+
}
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
_handlePageDown(event) {
|
|
754
|
+
if (this._isSuggestionsFocused) {
|
|
755
|
+
this.Suggestions.onPageDown(event);
|
|
756
|
+
} else {
|
|
757
|
+
event.preventDefault();
|
|
758
|
+
}
|
|
759
|
+
}
|
|
760
|
+
|
|
761
|
+
_handleHome(event) {
|
|
762
|
+
if (this._isSuggestionsFocused) {
|
|
763
|
+
this.Suggestions.onHome(event);
|
|
764
|
+
}
|
|
765
|
+
}
|
|
766
|
+
|
|
767
|
+
_handleEnd(event) {
|
|
768
|
+
if (this._isSuggestionsFocused) {
|
|
769
|
+
this.Suggestions.onEnd(event);
|
|
770
|
+
}
|
|
771
|
+
}
|
|
772
|
+
|
|
773
|
+
_handleEscape() {
|
|
774
|
+
const hasSuggestions = this.showSuggestions && !!this.Suggestions;
|
|
775
|
+
const isOpen = hasSuggestions && this.open;
|
|
776
|
+
|
|
777
|
+
if (!isOpen) {
|
|
778
|
+
this.value = this.lastConfirmedValue ? this.lastConfirmedValue : this.previousValue;
|
|
779
|
+
return;
|
|
780
|
+
}
|
|
781
|
+
|
|
782
|
+
if (hasSuggestions && isOpen && this.Suggestions._isItemOnTarget()) {
|
|
783
|
+
// Restore the value.
|
|
784
|
+
this.value = this.valueBeforeItemPreview;
|
|
785
|
+
|
|
786
|
+
// Mark that the selection has been canceled, so the popover can close
|
|
787
|
+
// and not reopen, due to receiving focus.
|
|
788
|
+
this.suggestionSelectionCanceled = true;
|
|
789
|
+
this.focused = true;
|
|
790
|
+
}
|
|
791
|
+
|
|
792
|
+
if (this._isValueStateFocused) {
|
|
793
|
+
this._isValueStateFocused = false;
|
|
794
|
+
this.focused = true;
|
|
795
|
+
}
|
|
796
|
+
|
|
797
|
+
this.open = false;
|
|
798
|
+
}
|
|
799
|
+
|
|
800
|
+
async _onfocusin(event) {
|
|
801
|
+
await this.getInputDOMRef();
|
|
802
|
+
|
|
803
|
+
this.focused = true; // invalidating property
|
|
804
|
+
this.previousValue = this.value;
|
|
805
|
+
this.valueBeforeItemPreview = this.value;
|
|
806
|
+
|
|
807
|
+
this._inputIconFocused = event.target && event.target === this.querySelector("[ui5-icon]");
|
|
808
|
+
}
|
|
809
|
+
|
|
810
|
+
_onfocusout(event) {
|
|
811
|
+
const focusedOutToSuggestions = this.Suggestions && event.relatedTarget && event.relatedTarget.shadowRoot && event.relatedTarget.shadowRoot.contains(this.Suggestions.responsivePopover);
|
|
812
|
+
const focusedOutToValueStateMessage = event.relatedTarget && event.relatedTarget.shadowRoot && event.relatedTarget.shadowRoot.querySelector(".ui5-valuestatemessage-root");
|
|
813
|
+
|
|
814
|
+
this._preventNextChange = this.effectiveShowClearIcon && this.shadowRoot.contains(event.relatedTarget);
|
|
815
|
+
|
|
816
|
+
// if focusout is triggered by pressing on suggestion item or value state message popover, skip invalidation, because re-rendering
|
|
817
|
+
// will happen before "itemPress" event, which will make item "active" state not visualized
|
|
818
|
+
if (focusedOutToSuggestions || focusedOutToValueStateMessage) {
|
|
819
|
+
event.stopImmediatePropagation();
|
|
820
|
+
return;
|
|
821
|
+
}
|
|
822
|
+
|
|
823
|
+
const toBeFocused = event.relatedTarget;
|
|
824
|
+
|
|
825
|
+
if (toBeFocused && toBeFocused.classList.contains(this._id)) {
|
|
826
|
+
return;
|
|
827
|
+
}
|
|
828
|
+
|
|
829
|
+
this.closePopover();
|
|
830
|
+
this._clearPopoverFocusAndSelection();
|
|
831
|
+
|
|
832
|
+
this.previousValue = "";
|
|
833
|
+
this.lastConfirmedValue = "";
|
|
834
|
+
this.focused = false; // invalidating property
|
|
835
|
+
this.open = false;
|
|
836
|
+
}
|
|
837
|
+
|
|
838
|
+
_clearPopoverFocusAndSelection() {
|
|
839
|
+
if (!this.showSuggestions || !this.Suggestions) {
|
|
840
|
+
return;
|
|
841
|
+
}
|
|
842
|
+
|
|
843
|
+
this._isValueStateFocused = false;
|
|
844
|
+
this.hasSuggestionItemSelected = false;
|
|
845
|
+
|
|
846
|
+
this.Suggestions._deselectItems();
|
|
847
|
+
this.Suggestions._clearItemFocus();
|
|
848
|
+
}
|
|
849
|
+
|
|
850
|
+
_click(event) {
|
|
851
|
+
if (isPhone() && !this.readonly && this.Suggestions) {
|
|
852
|
+
this.blur();
|
|
853
|
+
this.open = true;
|
|
854
|
+
}
|
|
855
|
+
}
|
|
856
|
+
|
|
857
|
+
_handleNativeInputChange() {
|
|
858
|
+
// The native change sometimes fires too early and getting input's value in the listener would return
|
|
859
|
+
// the previous value instead of the most recent one. This would make things consistent.
|
|
860
|
+
clearTimeout(this._nativeChangeDebounce);
|
|
861
|
+
this._nativeChangeDebounce = setTimeout(() => this._handleChange(), 100);
|
|
862
|
+
}
|
|
863
|
+
|
|
864
|
+
_handleChange() {
|
|
865
|
+
if (this._preventNextChange) {
|
|
866
|
+
this._preventNextChange = false;
|
|
867
|
+
return;
|
|
868
|
+
}
|
|
869
|
+
|
|
870
|
+
if (this._changeFiredValue !== this.value) {
|
|
871
|
+
this._changeFiredValue = this.value;
|
|
872
|
+
this.fireEvent(this.EVENT_CHANGE);
|
|
873
|
+
}
|
|
874
|
+
}
|
|
875
|
+
|
|
876
|
+
_clear() {
|
|
877
|
+
this.value = "";
|
|
878
|
+
this.fireEvent(this.EVENT_INPUT);
|
|
879
|
+
this._handleChange();
|
|
880
|
+
|
|
881
|
+
if (!this._isPhone) {
|
|
882
|
+
this.focus();
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
|
|
886
|
+
_scroll(event) {
|
|
887
|
+
const detail = event.detail;
|
|
888
|
+
this.fireEvent("suggestion-scroll", {
|
|
889
|
+
scrollTop: detail.scrollTop,
|
|
890
|
+
scrollContainer: detail.targetRef,
|
|
891
|
+
});
|
|
892
|
+
}
|
|
893
|
+
|
|
894
|
+
_handleInput(event) {
|
|
895
|
+
const inputDomRef = this.getInputDOMRefSync();
|
|
896
|
+
const emptyValueFiredOnNumberInput = this.value && this.isTypeNumber && !inputDomRef.value;
|
|
897
|
+
|
|
898
|
+
this.suggestionSelectionCanceled = false;
|
|
899
|
+
|
|
900
|
+
if (emptyValueFiredOnNumberInput && !this._backspaceKeyDown) {
|
|
901
|
+
// For input with type="Number", if the delimiter is entered second time,
|
|
902
|
+
// the inner input is firing event with empty value
|
|
903
|
+
return;
|
|
904
|
+
}
|
|
905
|
+
|
|
906
|
+
if (emptyValueFiredOnNumberInput && this._backspaceKeyDown) {
|
|
907
|
+
// Issue: when the user removes the character(s) after the delimeter of numeric Input,
|
|
908
|
+
// the native input is firing event with an empty value and we have to manually handle this case,
|
|
909
|
+
// otherwise the entire input will be cleared as we sync the "value".
|
|
910
|
+
|
|
911
|
+
// There are tree scenarios:
|
|
912
|
+
// Example: type "123.4" and press BACKSPACE - the native input is firing event with empty value.
|
|
913
|
+
// Example: type "123.456", select/mark "456" and press BACKSPACE - the native input is firing event with empty value.
|
|
914
|
+
// Example: type "123.456", select/mark "123.456" and press BACKSPACE - the native input is firing event with empty value,
|
|
915
|
+
// but this time that's really the case.
|
|
916
|
+
|
|
917
|
+
// Perform manual handling in case of floating number
|
|
918
|
+
// and if the user did not select the entire input value
|
|
919
|
+
if (this._selectedText.indexOf(",") > -1) {
|
|
920
|
+
this._selectedText = this._selectedText.replace(",", ".");
|
|
921
|
+
}
|
|
922
|
+
|
|
923
|
+
if (rgxFloat.test(this.value) && this._selectedText !== this.value) {
|
|
924
|
+
const newValue = this.removeFractionalPart(this.value);
|
|
925
|
+
|
|
926
|
+
// update state
|
|
927
|
+
this.value = newValue;
|
|
928
|
+
this.highlightValue = newValue;
|
|
929
|
+
this.valueBeforeItemPreview = newValue;
|
|
930
|
+
|
|
931
|
+
// fire events
|
|
932
|
+
this.fireEvent(this.EVENT_INPUT);
|
|
933
|
+
this.fireEvent("value-changed");
|
|
934
|
+
return;
|
|
935
|
+
}
|
|
936
|
+
}
|
|
937
|
+
|
|
938
|
+
if (event.target === inputDomRef) {
|
|
939
|
+
this.focused = true;
|
|
940
|
+
|
|
941
|
+
// stop the native event, as the semantic "input" would be fired.
|
|
942
|
+
event.stopImmediatePropagation();
|
|
943
|
+
}
|
|
944
|
+
|
|
945
|
+
/* skip calling change event when an input with a placeholder is focused on IE
|
|
946
|
+
- value of the host and the internal input should be differnt in case of actual input
|
|
947
|
+
- input is called when a key is pressed => keyup should not be called yet
|
|
948
|
+
*/
|
|
949
|
+
const skipFiring = (inputDomRef.value === this.value) && isIE() && !this._keyDown && !!this.placeholder;
|
|
950
|
+
|
|
951
|
+
!skipFiring && this.fireEventByAction(this.ACTION_USER_INPUT);
|
|
952
|
+
|
|
953
|
+
this.hasSuggestionItemSelected = false;
|
|
954
|
+
this._isValueStateFocused = false;
|
|
955
|
+
|
|
956
|
+
if (this.Suggestions) {
|
|
957
|
+
this.Suggestions.updateSelectedItemPosition(null);
|
|
958
|
+
|
|
959
|
+
if (!this._isPhone) {
|
|
960
|
+
this.open = !!inputDomRef.value;
|
|
961
|
+
}
|
|
962
|
+
}
|
|
963
|
+
}
|
|
964
|
+
|
|
965
|
+
_handleResize() {
|
|
966
|
+
this._inputWidth = this.offsetWidth;
|
|
967
|
+
}
|
|
968
|
+
|
|
969
|
+
_closeRespPopover(preventFocusRestore) {
|
|
970
|
+
this.Suggestions.close(preventFocusRestore);
|
|
971
|
+
}
|
|
972
|
+
|
|
973
|
+
async _afterOpenPopover() {
|
|
974
|
+
// Set initial focus to the native input
|
|
975
|
+
if (isPhone()) {
|
|
976
|
+
(await this.getInputDOMRef()).focus();
|
|
977
|
+
}
|
|
978
|
+
}
|
|
979
|
+
|
|
980
|
+
_afterClosePopover() {
|
|
981
|
+
this.announceSelectedItem();
|
|
982
|
+
|
|
983
|
+
// close device's keyboard and prevent further typing
|
|
984
|
+
if (isPhone()) {
|
|
985
|
+
this.blur();
|
|
986
|
+
this.focused = false;
|
|
987
|
+
}
|
|
988
|
+
}
|
|
989
|
+
|
|
990
|
+
/**
|
|
991
|
+
* Checks if the value state popover is open.
|
|
992
|
+
* @returns {boolean} true if the value state popover is open, false otherwise
|
|
993
|
+
*/
|
|
994
|
+
isValueStateOpened() {
|
|
995
|
+
return !!this._isPopoverOpen;
|
|
996
|
+
}
|
|
997
|
+
|
|
998
|
+
async openPopover() {
|
|
999
|
+
const popover = await this._getPopover();
|
|
1000
|
+
|
|
1001
|
+
if (popover) {
|
|
1002
|
+
this._isPopoverOpen = true;
|
|
1003
|
+
popover.showAt(this);
|
|
1004
|
+
}
|
|
1005
|
+
}
|
|
1006
|
+
|
|
1007
|
+
async closePopover() {
|
|
1008
|
+
const popover = await this._getPopover();
|
|
1009
|
+
|
|
1010
|
+
popover && popover.close();
|
|
1011
|
+
}
|
|
1012
|
+
|
|
1013
|
+
async _getPopover() {
|
|
1014
|
+
const staticAreaItem = await this.getStaticAreaItemDomRef();
|
|
1015
|
+
return staticAreaItem && staticAreaItem.querySelector("[ui5-popover]");
|
|
1016
|
+
}
|
|
1017
|
+
|
|
1018
|
+
enableSuggestions() {
|
|
1019
|
+
if (this.Suggestions) {
|
|
1020
|
+
return;
|
|
1021
|
+
}
|
|
1022
|
+
|
|
1023
|
+
const Suggestions = getFeature("InputSuggestions");
|
|
1024
|
+
|
|
1025
|
+
if (Suggestions) {
|
|
1026
|
+
this.Suggestions = new Suggestions(this, "suggestionItems", true);
|
|
1027
|
+
} else {
|
|
1028
|
+
throw new Error(`You have to import "@ui5/webcomponents/dist/features/InputSuggestions.js" module to use ui5-input suggestions`);
|
|
1029
|
+
}
|
|
1030
|
+
}
|
|
1031
|
+
|
|
1032
|
+
selectSuggestion(item, keyboardUsed) {
|
|
1033
|
+
if (item.group) {
|
|
1034
|
+
return;
|
|
1035
|
+
}
|
|
1036
|
+
|
|
1037
|
+
const itemText = item.text || item.textContent; // keep textContent for compatibility
|
|
1038
|
+
const fireInput = keyboardUsed
|
|
1039
|
+
? this.valueBeforeItemSelection !== itemText : this.value !== itemText;
|
|
1040
|
+
|
|
1041
|
+
this.hasSuggestionItemSelected = true;
|
|
1042
|
+
|
|
1043
|
+
if (fireInput) {
|
|
1044
|
+
this.value = itemText;
|
|
1045
|
+
this.valueBeforeItemSelection = itemText;
|
|
1046
|
+
this.lastConfirmedValue = itemText;
|
|
1047
|
+
this.fireEvent(this.EVENT_INPUT);
|
|
1048
|
+
this._handleChange();
|
|
1049
|
+
}
|
|
1050
|
+
|
|
1051
|
+
this.valueBeforeItemPreview = "";
|
|
1052
|
+
this.suggestionSelectionCanceled = false;
|
|
1053
|
+
|
|
1054
|
+
this.fireEvent(this.EVENT_SUGGESTION_ITEM_SELECT, { item });
|
|
1055
|
+
}
|
|
1056
|
+
|
|
1057
|
+
previewSuggestion(item) {
|
|
1058
|
+
this.valueBeforeItemSelection = this.value;
|
|
1059
|
+
this.updateValueOnPreview(item);
|
|
1060
|
+
this.announceSelectedItem();
|
|
1061
|
+
this._previewItem = item;
|
|
1062
|
+
}
|
|
1063
|
+
|
|
1064
|
+
/**
|
|
1065
|
+
* Updates the input value on item preview.
|
|
1066
|
+
* @param {Object} item The item that is on preview
|
|
1067
|
+
*/
|
|
1068
|
+
updateValueOnPreview(item) {
|
|
1069
|
+
const noPreview = item.type === "Inactive" || item.group;
|
|
1070
|
+
const itemValue = noPreview ? this.valueBeforeItemPreview : (item.effectiveTitle || item.textContent);
|
|
1071
|
+
this.value = itemValue;
|
|
1072
|
+
}
|
|
1073
|
+
|
|
1074
|
+
/**
|
|
1075
|
+
* The suggestion item on preview.
|
|
1076
|
+
* @type { sap.ui.webcomponents.main.IInputSuggestionItem }
|
|
1077
|
+
* @readonly
|
|
1078
|
+
* @public
|
|
1079
|
+
*/
|
|
1080
|
+
get previewItem() {
|
|
1081
|
+
if (!this._previewItem) {
|
|
1082
|
+
return null;
|
|
1083
|
+
}
|
|
1084
|
+
|
|
1085
|
+
return this.getSuggestionByListItem(this._previewItem);
|
|
1086
|
+
}
|
|
1087
|
+
|
|
1088
|
+
async fireEventByAction(action) {
|
|
1089
|
+
await this.getInputDOMRef();
|
|
1090
|
+
|
|
1091
|
+
if (this.disabled || this.readonly) {
|
|
1092
|
+
return;
|
|
1093
|
+
}
|
|
1094
|
+
|
|
1095
|
+
const inputValue = await this.getInputValue();
|
|
1096
|
+
const isUserInput = action === this.ACTION_USER_INPUT;
|
|
1097
|
+
|
|
1098
|
+
const input = await this.getInputDOMRef();
|
|
1099
|
+
const cursorPosition = input.selectionStart;
|
|
1100
|
+
|
|
1101
|
+
this.value = inputValue;
|
|
1102
|
+
this.highlightValue = inputValue;
|
|
1103
|
+
this.valueBeforeItemPreview = inputValue;
|
|
1104
|
+
|
|
1105
|
+
if (isSafari()) {
|
|
1106
|
+
// When setting the value by hand, Safari moves the cursor when typing in the middle of the text (See #1761)
|
|
1107
|
+
setTimeout(() => {
|
|
1108
|
+
input.selectionStart = cursorPosition;
|
|
1109
|
+
input.selectionEnd = cursorPosition;
|
|
1110
|
+
}, 0);
|
|
1111
|
+
}
|
|
1112
|
+
|
|
1113
|
+
if (isUserInput) { // input
|
|
1114
|
+
this.fireEvent(this.EVENT_INPUT);
|
|
1115
|
+
// Angular two way data binding
|
|
1116
|
+
this.fireEvent("value-changed");
|
|
1117
|
+
return;
|
|
1118
|
+
}
|
|
1119
|
+
|
|
1120
|
+
// In IE, pressing the ENTER does not fire change
|
|
1121
|
+
const valueChanged = (this.previousValue !== undefined) && (this.previousValue !== this.value);
|
|
1122
|
+
if (isIE() && action === this.ACTION_ENTER && valueChanged) {
|
|
1123
|
+
this._handleChange();
|
|
1124
|
+
}
|
|
1125
|
+
}
|
|
1126
|
+
|
|
1127
|
+
async getInputValue() {
|
|
1128
|
+
const domRef = this.getDomRef();
|
|
1129
|
+
|
|
1130
|
+
if (domRef) {
|
|
1131
|
+
return (await this.getInputDOMRef()).value;
|
|
1132
|
+
}
|
|
1133
|
+
return "";
|
|
1134
|
+
}
|
|
1135
|
+
|
|
1136
|
+
async getInputDOMRef() {
|
|
1137
|
+
if (isPhone() && this.Suggestions) {
|
|
1138
|
+
await this.Suggestions._getSuggestionPopover();
|
|
1139
|
+
return this.Suggestions && this.Suggestions.responsivePopover.querySelector(".ui5-input-inner-phone");
|
|
1140
|
+
}
|
|
1141
|
+
|
|
1142
|
+
return this.nativeInput;
|
|
1143
|
+
}
|
|
1144
|
+
|
|
1145
|
+
getInputDOMRefSync() {
|
|
1146
|
+
if (isPhone() && this.Suggestions) {
|
|
1147
|
+
return this.Suggestions && this.Suggestions.responsivePopover.querySelector(".ui5-input-inner-phone");
|
|
1148
|
+
}
|
|
1149
|
+
|
|
1150
|
+
return this.nativeInput;
|
|
1151
|
+
}
|
|
1152
|
+
|
|
1153
|
+
/**
|
|
1154
|
+
* Returns a reference to the native input element
|
|
1155
|
+
* @protected
|
|
1156
|
+
*/
|
|
1157
|
+
get nativeInput() {
|
|
1158
|
+
return this.getDomRef() && this.getDomRef().querySelector(`input`);
|
|
1159
|
+
}
|
|
1160
|
+
|
|
1161
|
+
get nativeInputWidth() {
|
|
1162
|
+
return this.nativeInput && this.nativeInput.offsetWidth;
|
|
1163
|
+
}
|
|
1164
|
+
|
|
1165
|
+
getLabelableElementId() {
|
|
1166
|
+
return this.getInputId();
|
|
1167
|
+
}
|
|
1168
|
+
|
|
1169
|
+
getSuggestionByListItem(item) {
|
|
1170
|
+
const key = parseInt(item.getAttribute("data-ui5-key"));
|
|
1171
|
+
return this.suggestionItems[key];
|
|
1172
|
+
}
|
|
1173
|
+
|
|
1174
|
+
/**
|
|
1175
|
+
* Returns if the suggestions popover is scrollable.
|
|
1176
|
+
* The method returns <code>Promise</code> that resolves to true,
|
|
1177
|
+
* if the popup is scrollable and false otherwise.
|
|
1178
|
+
* @returns {Promise}
|
|
1179
|
+
*/
|
|
1180
|
+
isSuggestionsScrollable() {
|
|
1181
|
+
if (!this.Suggestions) {
|
|
1182
|
+
return Promise.resolve(false);
|
|
1183
|
+
}
|
|
1184
|
+
|
|
1185
|
+
return this.Suggestions._isScrollable();
|
|
1186
|
+
}
|
|
1187
|
+
|
|
1188
|
+
getInputId() {
|
|
1189
|
+
return `${this._id}-inner`;
|
|
1190
|
+
}
|
|
1191
|
+
|
|
1192
|
+
/* Suggestions interface */
|
|
1193
|
+
onItemFocused() {}
|
|
1194
|
+
|
|
1195
|
+
onItemMouseOver(event) {
|
|
1196
|
+
const item = event.target;
|
|
1197
|
+
const suggestion = this.getSuggestionByListItem(item);
|
|
1198
|
+
suggestion && suggestion.fireEvent("mouseover", {
|
|
1199
|
+
item: suggestion,
|
|
1200
|
+
targetRef: item,
|
|
1201
|
+
});
|
|
1202
|
+
}
|
|
1203
|
+
|
|
1204
|
+
onItemMouseOut(event) {
|
|
1205
|
+
const item = event.target;
|
|
1206
|
+
const suggestion = this.getSuggestionByListItem(item);
|
|
1207
|
+
suggestion && suggestion.fireEvent("mouseout", {
|
|
1208
|
+
item: suggestion,
|
|
1209
|
+
targetRef: item,
|
|
1210
|
+
});
|
|
1211
|
+
}
|
|
1212
|
+
|
|
1213
|
+
onItemMouseDown(event) {
|
|
1214
|
+
event.preventDefault();
|
|
1215
|
+
}
|
|
1216
|
+
|
|
1217
|
+
onItemSelected(item, keyboardUsed) {
|
|
1218
|
+
this.selectSuggestion(item, keyboardUsed);
|
|
1219
|
+
}
|
|
1220
|
+
|
|
1221
|
+
onItemPreviewed(item) {
|
|
1222
|
+
this.previewSuggestion(item);
|
|
1223
|
+
this.fireEvent("suggestion-item-preview", {
|
|
1224
|
+
item: this.getSuggestionByListItem(item),
|
|
1225
|
+
targetRef: item,
|
|
1226
|
+
});
|
|
1227
|
+
}
|
|
1228
|
+
|
|
1229
|
+
onOpen() {}
|
|
1230
|
+
|
|
1231
|
+
onClose() {}
|
|
1232
|
+
|
|
1233
|
+
valueStateTextMappings() {
|
|
1234
|
+
return {
|
|
1235
|
+
"Success": Input.i18nBundle.getText(VALUE_STATE_SUCCESS),
|
|
1236
|
+
"Information": Input.i18nBundle.getText(VALUE_STATE_INFORMATION),
|
|
1237
|
+
"Error": Input.i18nBundle.getText(VALUE_STATE_ERROR),
|
|
1238
|
+
"Warning": Input.i18nBundle.getText(VALUE_STATE_WARNING),
|
|
1239
|
+
};
|
|
1240
|
+
}
|
|
1241
|
+
|
|
1242
|
+
announceSelectedItem() {
|
|
1243
|
+
const invisibleText = this.shadowRoot.querySelector(`#${this._id}-selectionText`);
|
|
1244
|
+
|
|
1245
|
+
if (this.Suggestions && this.Suggestions._isItemOnTarget()) {
|
|
1246
|
+
invisibleText.textContent = this.itemSelectionAnnounce;
|
|
1247
|
+
} else {
|
|
1248
|
+
invisibleText.textContent = "";
|
|
1249
|
+
}
|
|
1250
|
+
}
|
|
1251
|
+
|
|
1252
|
+
get _readonly() {
|
|
1253
|
+
return this.readonly && !this.disabled;
|
|
1254
|
+
}
|
|
1255
|
+
|
|
1256
|
+
get _headerTitleText() {
|
|
1257
|
+
return Input.i18nBundle.getText(INPUT_SUGGESTIONS_TITLE);
|
|
1258
|
+
}
|
|
1259
|
+
|
|
1260
|
+
get inputType() {
|
|
1261
|
+
return this.type.toLowerCase();
|
|
1262
|
+
}
|
|
1263
|
+
|
|
1264
|
+
get isTypeNumber() {
|
|
1265
|
+
return this.type === InputType.Number;
|
|
1266
|
+
}
|
|
1267
|
+
|
|
1268
|
+
get suggestionsTextId() {
|
|
1269
|
+
return this.showSuggestions ? `${this._id}-suggestionsText` : "";
|
|
1270
|
+
}
|
|
1271
|
+
|
|
1272
|
+
get valueStateTextId() {
|
|
1273
|
+
return this.hasValueState ? `${this._id}-valueStateDesc` : "";
|
|
1274
|
+
}
|
|
1275
|
+
|
|
1276
|
+
get accInfo() {
|
|
1277
|
+
const ariaHasPopupDefault = this.showSuggestions ? "true" : undefined;
|
|
1278
|
+
const ariaAutoCompleteDefault = this.showSuggestions ? "list" : undefined;
|
|
1279
|
+
const ariaDescribedBy = this._inputAccInfo.ariaDescribedBy ? `${this.suggestionsTextId} ${this.valueStateTextId} ${this._inputAccInfo.ariaDescribedBy}`.trim() : `${this.suggestionsTextId} ${this.valueStateTextId}`.trim();
|
|
1280
|
+
|
|
1281
|
+
return {
|
|
1282
|
+
"input": {
|
|
1283
|
+
"ariaRoledescription": this._inputAccInfo && (this._inputAccInfo.ariaRoledescription || undefined),
|
|
1284
|
+
"ariaDescribedBy": ariaDescribedBy || undefined,
|
|
1285
|
+
"ariaInvalid": this.valueState === ValueState.Error ? "true" : undefined,
|
|
1286
|
+
"ariaHasPopup": this._inputAccInfo.ariaHasPopup ? this._inputAccInfo.ariaHasPopup : ariaHasPopupDefault,
|
|
1287
|
+
"ariaAutoComplete": this._inputAccInfo.ariaAutoComplete ? this._inputAccInfo.ariaAutoComplete : ariaAutoCompleteDefault,
|
|
1288
|
+
"role": this._inputAccInfo && this._inputAccInfo.role,
|
|
1289
|
+
"ariaControls": this._inputAccInfo && this._inputAccInfo.ariaControls,
|
|
1290
|
+
"ariaExpanded": this._inputAccInfo && this._inputAccInfo.ariaExpanded,
|
|
1291
|
+
"ariaDescription": this._inputAccInfo && this._inputAccInfo.ariaDescription,
|
|
1292
|
+
"ariaLabel": (this._inputAccInfo && this._inputAccInfo.ariaLabel) || getEffectiveAriaLabelText(this),
|
|
1293
|
+
},
|
|
1294
|
+
};
|
|
1295
|
+
}
|
|
1296
|
+
|
|
1297
|
+
get nativeInputAttributes() {
|
|
1298
|
+
return {
|
|
1299
|
+
"min": this.isTypeNumber ? this._nativeInputAttributes.min : undefined,
|
|
1300
|
+
"max": this.isTypeNumber ? this._nativeInputAttributes.max : undefined,
|
|
1301
|
+
"step": this.isTypeNumber ? (this._nativeInputAttributes.step || "any") : undefined,
|
|
1302
|
+
};
|
|
1303
|
+
}
|
|
1304
|
+
|
|
1305
|
+
get ariaValueStateHiddenText() {
|
|
1306
|
+
if (!this.hasValueStateMessage) {
|
|
1307
|
+
return;
|
|
1308
|
+
}
|
|
1309
|
+
|
|
1310
|
+
if (this.shouldDisplayDefaultValueStateMessage) {
|
|
1311
|
+
return this.valueStateText;
|
|
1312
|
+
}
|
|
1313
|
+
|
|
1314
|
+
return this.valueStateMessageText.map(el => el.textContent).join(" ");
|
|
1315
|
+
}
|
|
1316
|
+
|
|
1317
|
+
get itemSelectionAnnounce() {
|
|
1318
|
+
return this.Suggestions ? this.Suggestions.itemSelectionAnnounce : undefined;
|
|
1319
|
+
}
|
|
1320
|
+
|
|
1321
|
+
get classes() {
|
|
1322
|
+
return {
|
|
1323
|
+
popover: {
|
|
1324
|
+
"ui5-suggestions-popover": !this.isPhone && this.showSuggestions,
|
|
1325
|
+
"ui5-suggestions-popover-with-value-state-header": !this.isPhone && this.showSuggestions && this.hasValueStateMessage,
|
|
1326
|
+
},
|
|
1327
|
+
popoverValueState: {
|
|
1328
|
+
"ui5-valuestatemessage-root": true,
|
|
1329
|
+
"ui5-valuestatemessage-header": true,
|
|
1330
|
+
"ui5-valuestatemessage--success": this.valueState === ValueState.Success,
|
|
1331
|
+
"ui5-valuestatemessage--error": this.valueState === ValueState.Error,
|
|
1332
|
+
"ui5-valuestatemessage--warning": this.valueState === ValueState.Warning,
|
|
1333
|
+
"ui5-valuestatemessage--information": this.valueState === ValueState.Information,
|
|
1334
|
+
},
|
|
1335
|
+
};
|
|
1336
|
+
}
|
|
1337
|
+
|
|
1338
|
+
get styles() {
|
|
1339
|
+
const remSizeIxPx = parseInt(getComputedStyle(document.documentElement).fontSize);
|
|
1340
|
+
|
|
1341
|
+
const stylesObject = {
|
|
1342
|
+
popoverHeader: {
|
|
1343
|
+
"max-width": `${this._inputWidth}px`,
|
|
1344
|
+
},
|
|
1345
|
+
suggestionPopoverHeader: {
|
|
1346
|
+
"display": this._listWidth === 0 ? "none" : "inline-block",
|
|
1347
|
+
"width": `${this._listWidth}px`,
|
|
1348
|
+
},
|
|
1349
|
+
suggestionsPopover: {
|
|
1350
|
+
"min-width": `${this._inputWidth}px`,
|
|
1351
|
+
"max-width": (this._inputWidth / remSizeIxPx) > 40 ? `${this._inputWidth}px` : "40rem",
|
|
1352
|
+
},
|
|
1353
|
+
innerInput: {},
|
|
1354
|
+
};
|
|
1355
|
+
|
|
1356
|
+
if (this.nativeInputWidth < 48) {
|
|
1357
|
+
stylesObject.innerInput.padding = "0";
|
|
1358
|
+
}
|
|
1359
|
+
|
|
1360
|
+
return stylesObject;
|
|
1361
|
+
}
|
|
1362
|
+
|
|
1363
|
+
get suggestionSeparators() {
|
|
1364
|
+
return "None";
|
|
1365
|
+
}
|
|
1366
|
+
|
|
1367
|
+
get valueStateMessageText() {
|
|
1368
|
+
return this.getSlottedNodes("valueStateMessage").map(el => el.cloneNode(true));
|
|
1369
|
+
}
|
|
1370
|
+
|
|
1371
|
+
get shouldDisplayOnlyValueStateMessage() {
|
|
1372
|
+
return this.hasValueStateMessage && !this.readonly && !this.open && this.focused;
|
|
1373
|
+
}
|
|
1374
|
+
|
|
1375
|
+
get shouldDisplayDefaultValueStateMessage() {
|
|
1376
|
+
return !this.valueStateMessage.length && this.hasValueStateMessage;
|
|
1377
|
+
}
|
|
1378
|
+
|
|
1379
|
+
get hasValueState() {
|
|
1380
|
+
return this.valueState !== ValueState.None;
|
|
1381
|
+
}
|
|
1382
|
+
|
|
1383
|
+
get hasValueStateMessage() {
|
|
1384
|
+
return this.hasValueState && this.valueState !== ValueState.Success
|
|
1385
|
+
&& (!this._inputIconFocused // Handles the cases when valueStateMessage is forwarded (from datepicker e.g.)
|
|
1386
|
+
|| (this._isPhone && this.Suggestions)); // Handles Input with suggestions on mobile
|
|
1387
|
+
}
|
|
1388
|
+
|
|
1389
|
+
get valueStateText() {
|
|
1390
|
+
return this.valueStateTextMappings()[this.valueState];
|
|
1391
|
+
}
|
|
1392
|
+
|
|
1393
|
+
get suggestionsText() {
|
|
1394
|
+
return Input.i18nBundle.getText(INPUT_SUGGESTIONS);
|
|
1395
|
+
}
|
|
1396
|
+
|
|
1397
|
+
get availableSuggestionsCount() {
|
|
1398
|
+
if (this.showSuggestions && (this.value || this.Suggestions.isOpened())) {
|
|
1399
|
+
switch (this.suggestionsTexts.length) {
|
|
1400
|
+
case 0:
|
|
1401
|
+
return Input.i18nBundle.getText(INPUT_SUGGESTIONS_NO_HIT);
|
|
1402
|
+
|
|
1403
|
+
case 1:
|
|
1404
|
+
return Input.i18nBundle.getText(INPUT_SUGGESTIONS_ONE_HIT);
|
|
1405
|
+
|
|
1406
|
+
default:
|
|
1407
|
+
return Input.i18nBundle.getText(INPUT_SUGGESTIONS_MORE_HITS, this.suggestionsTexts.length);
|
|
1408
|
+
}
|
|
1409
|
+
}
|
|
1410
|
+
|
|
1411
|
+
return undefined;
|
|
1412
|
+
}
|
|
1413
|
+
|
|
1414
|
+
get step() {
|
|
1415
|
+
return this.isTypeNumber ? "any" : undefined;
|
|
1416
|
+
}
|
|
1417
|
+
|
|
1418
|
+
get _isPhone() {
|
|
1419
|
+
return isPhone();
|
|
1420
|
+
}
|
|
1421
|
+
|
|
1422
|
+
get _isSuggestionsFocused() {
|
|
1423
|
+
return !this.focused && this.Suggestions && this.Suggestions.isOpened();
|
|
1424
|
+
}
|
|
1425
|
+
|
|
1426
|
+
/**
|
|
1427
|
+
* Returns the placeholder value.
|
|
1428
|
+
* @protected
|
|
1429
|
+
*/
|
|
1430
|
+
get _placeholder() {
|
|
1431
|
+
return this.placeholder;
|
|
1432
|
+
}
|
|
1433
|
+
|
|
1434
|
+
/**
|
|
1435
|
+
* This method is relevant for sap_horizon theme only
|
|
1436
|
+
*/
|
|
1437
|
+
get _valueStateInputIcon() {
|
|
1438
|
+
const iconPerValueState = {
|
|
1439
|
+
Error: `<path xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" d="M10 20C4.47715 20 0 15.5228 0 10C0 4.47715 4.47715 0 10 0C15.5228 0 20 4.47715 20 10C20 15.5228 15.5228 20 10 20ZM7.70711 13.7071C7.31658 14.0976 6.68342 14.0976 6.29289 13.7071C5.90237 13.3166 5.90237 12.6834 6.29289 12.2929L8.58579 10L6.29289 7.70711C5.90237 7.31658 5.90237 6.68342 6.29289 6.29289C6.68342 5.90237 7.31658 5.90237 7.70711 6.29289L10 8.58579L12.2929 6.29289C12.6834 5.90237 13.3166 5.90237 13.7071 6.29289C14.0976 6.68342 14.0976 7.31658 13.7071 7.70711L11.4142 10L13.7071 12.2929C14.0976 12.6834 14.0976 13.3166 13.7071 13.7071C13.3166 14.0976 12.6834 14.0976 12.2929 13.7071L10 11.4142L7.70711 13.7071Z" fill="#EE3939"/>`,
|
|
1440
|
+
Warning: `<path xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" d="M11.8619 0.49298C11.6823 0.187541 11.3544 0 11 0C10.6456 0 10.3177 0.187541 10.1381 0.49298L0.138066 17.493C-0.0438112 17.8022 -0.0461447 18.1851 0.13195 18.4965C0.310046 18.8079 0.641283 19 1 19H21C21.3587 19 21.69 18.8079 21.868 18.4965C22.0461 18.1851 22.0438 17.8022 21.8619 17.493L11.8619 0.49298ZM11 6C11.5523 6 12 6.44772 12 7V10C12 10.5523 11.5523 11 11 11C10.4477 11 10 10.5523 10 10V7C10 6.44772 10.4477 6 11 6ZM11 16C11.8284 16 12.5 15.3284 12.5 14.5C12.5 13.6716 11.8284 13 11 13C10.1716 13 9.5 13.6716 9.5 14.5C9.5 15.3284 10.1716 16 11 16Z" fill="#F58B00"/>`,
|
|
1441
|
+
Success: `<path xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" d="M0 10C0 15.5228 4.47715 20 10 20C15.5228 20 20 15.5228 20 10C20 4.47715 15.5228 0 10 0C4.47715 0 0 4.47715 0 10ZM14.7071 6.29289C14.3166 5.90237 13.6834 5.90237 13.2929 6.29289L8 11.5858L6.70711 10.2929C6.31658 9.90237 5.68342 9.90237 5.29289 10.2929C4.90237 10.6834 4.90237 11.3166 5.29289 11.7071L7.29289 13.7071C7.68342 14.0976 8.31658 14.0976 8.70711 13.7071L14.7071 7.70711C15.0976 7.31658 15.0976 6.68342 14.7071 6.29289Z" fill="#36A41D"/>`,
|
|
1442
|
+
Information: `<path xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" d="M3 0C1.34315 0 0 1.34315 0 3V15C0 16.6569 1.34315 18 3 18H15C16.6569 18 18 16.6569 18 15V3C18 1.34315 16.6569 0 15 0H3ZM9 6.5C9.82843 6.5 10.5 5.82843 10.5 5C10.5 4.17157 9.82843 3.5 9 3.5C8.17157 3.5 7.5 4.17157 7.5 5C7.5 5.82843 8.17157 6.5 9 6.5ZM9 8.5C9.55228 8.5 10 8.94772 10 9.5V13.5C10 14.0523 9.55228 14.5 9 14.5C8.44771 14.5 8 14.0523 8 13.5V9.5C8 8.94772 8.44771 8.5 9 8.5Z" fill="#1B90FF"/>`,
|
|
1443
|
+
};
|
|
1444
|
+
|
|
1445
|
+
const result = `
|
|
1446
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="20" viewBox="0 0 20 20" fill="none">
|
|
1447
|
+
${iconPerValueState[this.valueState]};
|
|
1448
|
+
</svg>
|
|
1449
|
+
`;
|
|
1450
|
+
|
|
1451
|
+
return this.valueState !== ValueState.None ? result : "";
|
|
1452
|
+
}
|
|
1453
|
+
|
|
1454
|
+
get _valueStatePopoverHorizontalAlign() {
|
|
1455
|
+
return this.effectiveDir !== "rtl" ? "Left" : "Right";
|
|
1456
|
+
}
|
|
1457
|
+
|
|
1458
|
+
/**
|
|
1459
|
+
* This method is relevant for sap_horizon theme only
|
|
1460
|
+
*/
|
|
1461
|
+
get _valueStateMessageInputIcon() {
|
|
1462
|
+
const iconPerValueState = {
|
|
1463
|
+
Error: "error",
|
|
1464
|
+
Warning: "alert",
|
|
1465
|
+
Success: "sys-enter-2",
|
|
1466
|
+
Information: "information",
|
|
1467
|
+
};
|
|
1468
|
+
|
|
1469
|
+
return this.valueState !== ValueState.None ? iconPerValueState[this.valueState] : "";
|
|
1470
|
+
}
|
|
1471
|
+
|
|
1472
|
+
/**
|
|
1473
|
+
* Returns the caret position inside the native input
|
|
1474
|
+
* @protected
|
|
1475
|
+
*/
|
|
1476
|
+
getCaretPosition() {
|
|
1477
|
+
return getCaretPosition(this.nativeInput);
|
|
1478
|
+
}
|
|
1479
|
+
|
|
1480
|
+
/**
|
|
1481
|
+
* Sets the caret to a certain position inside the native input
|
|
1482
|
+
* @protected
|
|
1483
|
+
* @param pos
|
|
1484
|
+
*/
|
|
1485
|
+
setCaretPosition(pos) {
|
|
1486
|
+
setCaretPosition(this.nativeInput, pos);
|
|
1487
|
+
}
|
|
1488
|
+
|
|
1489
|
+
/**
|
|
1490
|
+
* Removes the fractional part of floating-point number.
|
|
1491
|
+
* @param {string} value the numeric value of Input of type "Number"
|
|
1492
|
+
*/
|
|
1493
|
+
removeFractionalPart(value) {
|
|
1494
|
+
if (value.includes(".")) {
|
|
1495
|
+
return value.slice(0, value.indexOf("."));
|
|
1496
|
+
}
|
|
1497
|
+
if (value.includes(",")) {
|
|
1498
|
+
return value.slice(0, value.indexOf(","));
|
|
1499
|
+
}
|
|
1500
|
+
|
|
1501
|
+
return value;
|
|
1502
|
+
}
|
|
1503
|
+
|
|
1504
|
+
static get dependencies() {
|
|
1505
|
+
const Suggestions = getFeature("InputSuggestions");
|
|
1506
|
+
|
|
1507
|
+
return [Popover].concat(Suggestions ? Suggestions.dependencies : []);
|
|
1508
|
+
}
|
|
1509
|
+
|
|
1510
|
+
static async onDefine() {
|
|
1511
|
+
const Suggestions = getFeature("InputSuggestions");
|
|
1512
|
+
|
|
1513
|
+
[Input.i18nBundle] = await Promise.all([
|
|
1514
|
+
getI18nBundle("@ui5/webcomponents"),
|
|
1515
|
+
Suggestions ? Suggestions.init() : Promise.resolve(),
|
|
1516
|
+
]);
|
|
1517
|
+
}
|
|
1518
|
+
}
|
|
1519
|
+
|
|
1520
|
+
Input.define();
|
|
1521
|
+
|
|
1522
|
+
export default Input;
|