@react-spectrum/s2 0.5.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Accordion.cjs +5 -8
- package/dist/Accordion.cjs.map +1 -1
- package/dist/Accordion.css +3 -7
- package/dist/Accordion.css.map +1 -1
- package/dist/Accordion.mjs +5 -8
- package/dist/Accordion.mjs.map +1 -1
- package/dist/ActionBar.cjs +264 -0
- package/dist/ActionBar.cjs.map +1 -0
- package/dist/ActionBar.css +261 -0
- package/dist/ActionBar.css.map +1 -0
- package/dist/ActionBar.mjs +257 -0
- package/dist/ActionBar.mjs.map +1 -0
- package/dist/ActionButton.cjs +121 -147
- package/dist/ActionButton.cjs.map +1 -1
- package/dist/ActionButton.css +133 -159
- package/dist/ActionButton.css.map +1 -1
- package/dist/ActionButton.mjs +122 -148
- package/dist/ActionButton.mjs.map +1 -1
- package/dist/ActionButtonGroup.cjs +6 -9
- package/dist/ActionButtonGroup.cjs.map +1 -1
- package/dist/ActionButtonGroup.css +4 -8
- package/dist/ActionButtonGroup.css.map +1 -1
- package/dist/ActionButtonGroup.mjs +6 -9
- package/dist/ActionButtonGroup.mjs.map +1 -1
- package/dist/ActionMenu.cjs +2 -5
- package/dist/ActionMenu.cjs.map +1 -1
- package/dist/ActionMenu.mjs +2 -5
- package/dist/ActionMenu.mjs.map +1 -1
- package/dist/AlertDialog.cjs +2 -5
- package/dist/AlertDialog.cjs.map +1 -1
- package/dist/AlertDialog.css +1 -5
- package/dist/AlertDialog.css.map +1 -1
- package/dist/AlertDialog.mjs +2 -5
- package/dist/AlertDialog.mjs.map +1 -1
- package/dist/Avatar.cjs +12 -15
- package/dist/Avatar.cjs.map +1 -1
- package/dist/Avatar.css +12 -16
- package/dist/Avatar.css.map +1 -1
- package/dist/Avatar.mjs +12 -15
- package/dist/Avatar.mjs.map +1 -1
- package/dist/AvatarGroup.cjs +100 -103
- package/dist/AvatarGroup.cjs.map +1 -1
- package/dist/AvatarGroup.css +31 -37
- package/dist/AvatarGroup.css.map +1 -1
- package/dist/AvatarGroup.mjs +100 -103
- package/dist/AvatarGroup.mjs.map +1 -1
- package/dist/Badge.cjs +123 -108
- package/dist/Badge.cjs.map +1 -1
- package/dist/Badge.css +101 -83
- package/dist/Badge.css.map +1 -1
- package/dist/Badge.mjs +124 -109
- package/dist/Badge.mjs.map +1 -1
- package/dist/Breadcrumbs.cjs +98 -99
- package/dist/Breadcrumbs.cjs.map +1 -1
- package/dist/Breadcrumbs.css +70 -70
- package/dist/Breadcrumbs.css.map +1 -1
- package/dist/Breadcrumbs.mjs +100 -101
- package/dist/Breadcrumbs.mjs.map +1 -1
- package/dist/Button.cjs +305 -278
- package/dist/Button.cjs.map +1 -1
- package/dist/Button.css +253 -186
- package/dist/Button.css.map +1 -1
- package/dist/Button.mjs +307 -280
- package/dist/Button.mjs.map +1 -1
- package/dist/ButtonGroup.cjs +17 -20
- package/dist/ButtonGroup.cjs.map +1 -1
- package/dist/ButtonGroup.css +12 -16
- package/dist/ButtonGroup.css.map +1 -1
- package/dist/ButtonGroup.mjs +18 -21
- package/dist/ButtonGroup.mjs.map +1 -1
- package/dist/Card.cjs +169 -169
- package/dist/Card.cjs.map +1 -1
- package/dist/Card.css +121 -127
- package/dist/Card.css.map +1 -1
- package/dist/Card.mjs +170 -170
- package/dist/Card.mjs.map +1 -1
- package/dist/CardView.cjs +115 -327
- package/dist/CardView.cjs.map +1 -1
- package/dist/CardView.css +36 -16
- package/dist/CardView.css.map +1 -1
- package/dist/CardView.mjs +73 -285
- package/dist/CardView.mjs.map +1 -1
- package/dist/CenterBaseline.cjs +1 -1
- package/dist/CenterBaseline.css +3 -7
- package/dist/CenterBaseline.css.map +1 -1
- package/dist/CenterBaseline.mjs +1 -1
- package/dist/Checkbox.cjs +58 -62
- package/dist/Checkbox.cjs.map +1 -1
- package/dist/Checkbox.css +54 -60
- package/dist/Checkbox.css.map +1 -1
- package/dist/Checkbox.mjs +59 -63
- package/dist/Checkbox.mjs.map +1 -1
- package/dist/CheckboxGroup.cjs +43 -45
- package/dist/CheckboxGroup.cjs.map +1 -1
- package/dist/CheckboxGroup.css +32 -38
- package/dist/CheckboxGroup.css.map +1 -1
- package/dist/CheckboxGroup.mjs +44 -46
- package/dist/CheckboxGroup.mjs.map +1 -1
- package/dist/ClearButton.cjs +7 -8
- package/dist/ClearButton.cjs.map +1 -1
- package/dist/ClearButton.css +6 -10
- package/dist/ClearButton.css.map +1 -1
- package/dist/ClearButton.mjs +7 -8
- package/dist/ClearButton.mjs.map +1 -1
- package/dist/CloseButton.cjs +40 -53
- package/dist/CloseButton.cjs.map +1 -1
- package/dist/CloseButton.css +46 -54
- package/dist/CloseButton.css.map +1 -1
- package/dist/CloseButton.mjs +40 -53
- package/dist/CloseButton.mjs.map +1 -1
- package/dist/ColorArea.cjs +12 -15
- package/dist/ColorArea.cjs.map +1 -1
- package/dist/ColorArea.css +11 -15
- package/dist/ColorArea.css.map +1 -1
- package/dist/ColorArea.mjs +12 -15
- package/dist/ColorArea.mjs.map +1 -1
- package/dist/ColorField.cjs +31 -34
- package/dist/ColorField.cjs.map +1 -1
- package/dist/ColorField.css +24 -30
- package/dist/ColorField.css.map +1 -1
- package/dist/ColorField.mjs +32 -35
- package/dist/ColorField.mjs.map +1 -1
- package/dist/ColorHandle.cjs +11 -11
- package/dist/ColorHandle.css +20 -24
- package/dist/ColorHandle.css.map +1 -1
- package/dist/ColorHandle.mjs +11 -11
- package/dist/ColorSlider.cjs +43 -46
- package/dist/ColorSlider.cjs.map +1 -1
- package/dist/ColorSlider.css +43 -49
- package/dist/ColorSlider.css.map +1 -1
- package/dist/ColorSlider.mjs +44 -47
- package/dist/ColorSlider.mjs.map +1 -1
- package/dist/ColorSwatch.cjs +8 -11
- package/dist/ColorSwatch.cjs.map +1 -1
- package/dist/ColorSwatch.css +15 -19
- package/dist/ColorSwatch.css.map +1 -1
- package/dist/ColorSwatch.mjs +9 -12
- package/dist/ColorSwatch.mjs.map +1 -1
- package/dist/ColorSwatchPicker.cjs +15 -18
- package/dist/ColorSwatchPicker.cjs.map +1 -1
- package/dist/ColorSwatchPicker.css +34 -38
- package/dist/ColorSwatchPicker.css.map +1 -1
- package/dist/ColorSwatchPicker.mjs +15 -18
- package/dist/ColorSwatchPicker.mjs.map +1 -1
- package/dist/ColorWheel.cjs +18 -21
- package/dist/ColorWheel.cjs.map +1 -1
- package/dist/ColorWheel.css +16 -20
- package/dist/ColorWheel.css.map +1 -1
- package/dist/ColorWheel.mjs +18 -21
- package/dist/ColorWheel.mjs.map +1 -1
- package/dist/ComboBox.cjs +62 -62
- package/dist/ComboBox.cjs.map +1 -1
- package/dist/ComboBox.css +52 -58
- package/dist/ComboBox.css.map +1 -1
- package/dist/ComboBox.mjs +63 -63
- package/dist/ComboBox.mjs.map +1 -1
- package/dist/Content.cjs +15 -20
- package/dist/Content.cjs.map +1 -1
- package/dist/Content.mjs +15 -20
- package/dist/Content.mjs.map +1 -1
- package/dist/ContextualHelp.cjs +7 -10
- package/dist/ContextualHelp.cjs.map +1 -1
- package/dist/ContextualHelp.css +23 -29
- package/dist/ContextualHelp.css.map +1 -1
- package/dist/ContextualHelp.mjs +7 -10
- package/dist/ContextualHelp.mjs.map +1 -1
- package/dist/CustomDialog.cjs +10 -13
- package/dist/CustomDialog.cjs.map +1 -1
- package/dist/CustomDialog.css +10 -14
- package/dist/CustomDialog.css.map +1 -1
- package/dist/CustomDialog.mjs +10 -13
- package/dist/CustomDialog.mjs.map +1 -1
- package/dist/Dialog.cjs +14 -18
- package/dist/Dialog.cjs.map +1 -1
- package/dist/Dialog.css +39 -45
- package/dist/Dialog.css.map +1 -1
- package/dist/Dialog.mjs +14 -18
- package/dist/Dialog.mjs.map +1 -1
- package/dist/Disclosure.cjs +60 -69
- package/dist/Disclosure.cjs.map +1 -1
- package/dist/Disclosure.css +49 -55
- package/dist/Disclosure.css.map +1 -1
- package/dist/Disclosure.mjs +61 -70
- package/dist/Disclosure.mjs.map +1 -1
- package/dist/Divider.cjs +15 -19
- package/dist/Divider.cjs.map +1 -1
- package/dist/Divider.css +19 -23
- package/dist/Divider.css.map +1 -1
- package/dist/Divider.mjs +15 -19
- package/dist/Divider.mjs.map +1 -1
- package/dist/DropZone.cjs +30 -33
- package/dist/DropZone.cjs.map +1 -1
- package/dist/DropZone.css +26 -32
- package/dist/DropZone.css.map +1 -1
- package/dist/DropZone.mjs +30 -33
- package/dist/DropZone.mjs.map +1 -1
- package/dist/Field.cjs +134 -132
- package/dist/Field.cjs.map +1 -1
- package/dist/Field.css +76 -90
- package/dist/Field.css.map +1 -1
- package/dist/Field.mjs +134 -132
- package/dist/Field.mjs.map +1 -1
- package/dist/Form.cjs +6 -9
- package/dist/Form.cjs.map +1 -1
- package/dist/Form.css +4 -8
- package/dist/Form.css.map +1 -1
- package/dist/Form.mjs +6 -9
- package/dist/Form.mjs.map +1 -1
- package/dist/FullscreenDialog.cjs +7 -10
- package/dist/FullscreenDialog.cjs.map +1 -1
- package/dist/FullscreenDialog.css +54 -60
- package/dist/FullscreenDialog.css.map +1 -1
- package/dist/FullscreenDialog.mjs +7 -10
- package/dist/FullscreenDialog.mjs.map +1 -1
- package/dist/IllustratedMessage.cjs +128 -132
- package/dist/IllustratedMessage.cjs.map +1 -1
- package/dist/IllustratedMessage.css +58 -64
- package/dist/IllustratedMessage.css.map +1 -1
- package/dist/IllustratedMessage.mjs +128 -132
- package/dist/IllustratedMessage.mjs.map +1 -1
- package/dist/Image.cjs +24 -13
- package/dist/Image.cjs.map +1 -1
- package/dist/Image.css +12 -16
- package/dist/Image.css.map +1 -1
- package/dist/Image.mjs +25 -14
- package/dist/Image.mjs.map +1 -1
- package/dist/InlineAlert.cjs +75 -84
- package/dist/InlineAlert.cjs.map +1 -1
- package/dist/InlineAlert.css +59 -69
- package/dist/InlineAlert.css.map +1 -1
- package/dist/InlineAlert.mjs +76 -85
- package/dist/InlineAlert.mjs.map +1 -1
- package/dist/Link.cjs +36 -39
- package/dist/Link.cjs.map +1 -1
- package/dist/Link.css +42 -48
- package/dist/Link.css.map +1 -1
- package/dist/Link.mjs +37 -40
- package/dist/Link.mjs.map +1 -1
- package/dist/Menu.cjs +335 -235
- package/dist/Menu.cjs.map +1 -1
- package/dist/Menu.css +130 -122
- package/dist/Menu.css.map +1 -1
- package/dist/Menu.mjs +337 -237
- package/dist/Menu.mjs.map +1 -1
- package/dist/Meter.cjs +66 -70
- package/dist/Meter.cjs.map +1 -1
- package/dist/Meter.css +69 -79
- package/dist/Meter.css.map +1 -1
- package/dist/Meter.mjs +66 -70
- package/dist/Meter.mjs.map +1 -1
- package/dist/Modal.cjs +36 -45
- package/dist/Modal.cjs.map +1 -1
- package/dist/Modal.css +49 -77
- package/dist/Modal.css.map +1 -1
- package/dist/Modal.mjs +37 -46
- package/dist/Modal.mjs.map +1 -1
- package/dist/NumberField.cjs +66 -69
- package/dist/NumberField.cjs.map +1 -1
- package/dist/NumberField.css +70 -76
- package/dist/NumberField.css.map +1 -1
- package/dist/NumberField.mjs +67 -70
- package/dist/NumberField.mjs.map +1 -1
- package/dist/Picker.cjs +214 -189
- package/dist/Picker.cjs.map +1 -1
- package/dist/Picker.css +92 -94
- package/dist/Picker.css.map +1 -1
- package/dist/Picker.mjs +215 -190
- package/dist/Picker.mjs.map +1 -1
- package/dist/Popover.cjs +48 -72
- package/dist/Popover.cjs.map +1 -1
- package/dist/Popover.css +59 -134
- package/dist/Popover.css.map +1 -1
- package/dist/Popover.mjs +49 -73
- package/dist/Popover.mjs.map +1 -1
- package/dist/ProgressBar.cjs +85 -87
- package/dist/ProgressBar.cjs.map +1 -1
- package/dist/ProgressBar.css +81 -91
- package/dist/ProgressBar.css.map +1 -1
- package/dist/ProgressBar.mjs +85 -87
- package/dist/ProgressBar.mjs.map +1 -1
- package/dist/ProgressCircle.cjs +16 -18
- package/dist/ProgressCircle.cjs.map +1 -1
- package/dist/ProgressCircle.css +17 -21
- package/dist/ProgressCircle.css.map +1 -1
- package/dist/ProgressCircle.mjs +16 -18
- package/dist/ProgressCircle.mjs.map +1 -1
- package/dist/Provider.cjs +5 -5
- package/dist/Provider.css +7 -11
- package/dist/Provider.css.map +1 -1
- package/dist/Provider.mjs +5 -5
- package/dist/Radio.cjs +54 -58
- package/dist/Radio.cjs.map +1 -1
- package/dist/Radio.css +50 -56
- package/dist/Radio.css.map +1 -1
- package/dist/Radio.mjs +55 -59
- package/dist/Radio.mjs.map +1 -1
- package/dist/RadioGroup.cjs +39 -43
- package/dist/RadioGroup.cjs.map +1 -1
- package/dist/RadioGroup.css +32 -38
- package/dist/RadioGroup.css.map +1 -1
- package/dist/RadioGroup.mjs +40 -44
- package/dist/RadioGroup.mjs.map +1 -1
- package/dist/RangeSlider.cjs +2 -3
- package/dist/RangeSlider.cjs.map +1 -1
- package/dist/RangeSlider.mjs +3 -4
- package/dist/RangeSlider.mjs.map +1 -1
- package/dist/SearchField.cjs +35 -38
- package/dist/SearchField.cjs.map +1 -1
- package/dist/SearchField.css +30 -36
- package/dist/SearchField.css.map +1 -1
- package/dist/SearchField.mjs +36 -39
- package/dist/SearchField.mjs.map +1 -1
- package/dist/SegmentedControl.cjs +71 -77
- package/dist/SegmentedControl.cjs.map +1 -1
- package/dist/SegmentedControl.css +63 -69
- package/dist/SegmentedControl.css.map +1 -1
- package/dist/SegmentedControl.mjs +73 -79
- package/dist/SegmentedControl.mjs.map +1 -1
- package/dist/Slider.cjs +111 -112
- package/dist/Slider.cjs.map +1 -1
- package/dist/Slider.css +87 -93
- package/dist/Slider.css.map +1 -1
- package/dist/Slider.mjs +112 -113
- package/dist/Slider.mjs.map +1 -1
- package/dist/StatusLight.cjs +28 -32
- package/dist/StatusLight.cjs.map +1 -1
- package/dist/StatusLight.css +26 -32
- package/dist/StatusLight.css.map +1 -1
- package/dist/StatusLight.mjs +28 -32
- package/dist/StatusLight.mjs.map +1 -1
- package/dist/Switch.cjs +56 -60
- package/dist/Switch.cjs.map +1 -1
- package/dist/Switch.css +48 -54
- package/dist/Switch.css.map +1 -1
- package/dist/Switch.mjs +57 -61
- package/dist/Switch.mjs.map +1 -1
- package/dist/TableView.cjs +271 -275
- package/dist/TableView.cjs.map +1 -1
- package/dist/TableView.css +104 -102
- package/dist/TableView.css.map +1 -1
- package/dist/TableView.mjs +273 -277
- package/dist/TableView.mjs.map +1 -1
- package/dist/Tabs.cjs +472 -191
- package/dist/Tabs.cjs.map +1 -1
- package/dist/Tabs.css +225 -139
- package/dist/Tabs.css.map +1 -1
- package/dist/Tabs.mjs +472 -191
- package/dist/Tabs.mjs.map +1 -1
- package/dist/TabsPicker.cjs +415 -0
- package/dist/TabsPicker.cjs.map +1 -0
- package/dist/TabsPicker.css +482 -0
- package/dist/TabsPicker.css.map +1 -0
- package/dist/TabsPicker.mjs +409 -0
- package/dist/TabsPicker.mjs.map +1 -0
- package/dist/TagGroup.cjs +126 -128
- package/dist/TagGroup.cjs.map +1 -1
- package/dist/TagGroup.css +93 -99
- package/dist/TagGroup.css.map +1 -1
- package/dist/TagGroup.mjs +126 -128
- package/dist/TagGroup.mjs.map +1 -1
- package/dist/TextField.cjs +44 -55
- package/dist/TextField.cjs.map +1 -1
- package/dist/TextField.css +33 -39
- package/dist/TextField.css.map +1 -1
- package/dist/TextField.mjs +45 -56
- package/dist/TextField.mjs.map +1 -1
- package/dist/ToggleButton.cjs +6 -9
- package/dist/ToggleButton.cjs.map +1 -1
- package/dist/ToggleButton.css +8 -12
- package/dist/ToggleButton.css.map +1 -1
- package/dist/ToggleButton.mjs +6 -9
- package/dist/ToggleButton.mjs.map +1 -1
- package/dist/ToggleButtonGroup.cjs +2 -5
- package/dist/ToggleButtonGroup.cjs.map +1 -1
- package/dist/ToggleButtonGroup.mjs +2 -5
- package/dist/ToggleButtonGroup.mjs.map +1 -1
- package/dist/Tooltip.cjs +49 -49
- package/dist/Tooltip.cjs.map +1 -1
- package/dist/Tooltip.css +55 -76
- package/dist/Tooltip.css.map +1 -1
- package/dist/Tooltip.mjs +50 -50
- package/dist/Tooltip.mjs.map +1 -1
- package/dist/TreeView.cjs +439 -0
- package/dist/TreeView.cjs.map +1 -0
- package/dist/TreeView.css +608 -0
- package/dist/TreeView.css.map +1 -0
- package/dist/TreeView.mjs +432 -0
- package/dist/TreeView.mjs.map +1 -0
- package/dist/ar-AE.cjs +10 -2
- package/dist/ar-AE.cjs.map +1 -1
- package/dist/ar-AE.mjs +10 -2
- package/dist/ar-AE.mjs.map +1 -1
- package/dist/bg-BG.cjs +11 -2
- package/dist/bg-BG.cjs.map +1 -1
- package/dist/bg-BG.mjs +11 -2
- package/dist/bg-BG.mjs.map +1 -1
- package/dist/cs-CZ.cjs +7 -2
- package/dist/cs-CZ.cjs.map +1 -1
- package/dist/cs-CZ.mjs +7 -2
- package/dist/cs-CZ.mjs.map +1 -1
- package/dist/da-DK.cjs +12 -4
- package/dist/da-DK.cjs.map +1 -1
- package/dist/da-DK.mjs +12 -4
- package/dist/da-DK.mjs.map +1 -1
- package/dist/de-DE.cjs +11 -2
- package/dist/de-DE.cjs.map +1 -1
- package/dist/de-DE.mjs +11 -2
- package/dist/de-DE.mjs.map +1 -1
- package/dist/el-GR.cjs +11 -2
- package/dist/el-GR.cjs.map +1 -1
- package/dist/el-GR.mjs +11 -2
- package/dist/el-GR.mjs.map +1 -1
- package/dist/en-US.cjs +8 -0
- package/dist/en-US.cjs.map +1 -1
- package/dist/en-US.mjs +8 -0
- package/dist/en-US.mjs.map +1 -1
- package/dist/es-ES.cjs +11 -2
- package/dist/es-ES.cjs.map +1 -1
- package/dist/es-ES.mjs +11 -2
- package/dist/es-ES.mjs.map +1 -1
- package/dist/et-EE.cjs +10 -2
- package/dist/et-EE.cjs.map +1 -1
- package/dist/et-EE.mjs +10 -2
- package/dist/et-EE.mjs.map +1 -1
- package/dist/fi-FI.cjs +10 -2
- package/dist/fi-FI.cjs.map +1 -1
- package/dist/fi-FI.mjs +10 -2
- package/dist/fi-FI.mjs.map +1 -1
- package/dist/fr-FR.cjs +11 -2
- package/dist/fr-FR.cjs.map +1 -1
- package/dist/fr-FR.mjs +11 -2
- package/dist/fr-FR.mjs.map +1 -1
- package/dist/he-IL.cjs +11 -2
- package/dist/he-IL.cjs.map +1 -1
- package/dist/he-IL.mjs +11 -2
- package/dist/he-IL.mjs.map +1 -1
- package/dist/hr-HR.cjs +7 -2
- package/dist/hr-HR.cjs.map +1 -1
- package/dist/hr-HR.mjs +7 -2
- package/dist/hr-HR.mjs.map +1 -1
- package/dist/hu-HU.cjs +10 -2
- package/dist/hu-HU.cjs.map +1 -1
- package/dist/hu-HU.mjs +10 -2
- package/dist/hu-HU.mjs.map +1 -1
- package/dist/it-IT.cjs +11 -2
- package/dist/it-IT.cjs.map +1 -1
- package/dist/it-IT.mjs +11 -2
- package/dist/it-IT.mjs.map +1 -1
- package/dist/ja-JP.cjs +10 -2
- package/dist/ja-JP.cjs.map +1 -1
- package/dist/ja-JP.mjs +10 -2
- package/dist/ja-JP.mjs.map +1 -1
- package/dist/ko-KR.cjs +12 -4
- package/dist/ko-KR.cjs.map +1 -1
- package/dist/ko-KR.mjs +12 -4
- package/dist/ko-KR.mjs.map +1 -1
- package/dist/lt-LT.cjs +9 -4
- package/dist/lt-LT.cjs.map +1 -1
- package/dist/lt-LT.mjs +9 -4
- package/dist/lt-LT.mjs.map +1 -1
- package/dist/lv-LV.cjs +11 -3
- package/dist/lv-LV.cjs.map +1 -1
- package/dist/lv-LV.mjs +11 -3
- package/dist/lv-LV.mjs.map +1 -1
- package/dist/main.cjs +9 -0
- package/dist/main.cjs.map +1 -1
- package/dist/module.mjs +5 -1
- package/dist/module.mjs.map +1 -1
- package/dist/nb-NO.cjs +9 -4
- package/dist/nb-NO.cjs.map +1 -1
- package/dist/nb-NO.mjs +9 -4
- package/dist/nb-NO.mjs.map +1 -1
- package/dist/nl-NL.cjs +10 -2
- package/dist/nl-NL.cjs.map +1 -1
- package/dist/nl-NL.mjs +10 -2
- package/dist/nl-NL.mjs.map +1 -1
- package/dist/pl-PL.cjs +8 -3
- package/dist/pl-PL.cjs.map +1 -1
- package/dist/pl-PL.mjs +8 -3
- package/dist/pl-PL.mjs.map +1 -1
- package/dist/pt-BR.cjs +11 -2
- package/dist/pt-BR.cjs.map +1 -1
- package/dist/pt-BR.mjs +11 -2
- package/dist/pt-BR.mjs.map +1 -1
- package/dist/pt-PT.cjs +11 -2
- package/dist/pt-PT.cjs.map +1 -1
- package/dist/pt-PT.mjs +11 -2
- package/dist/pt-PT.mjs.map +1 -1
- package/dist/ro-RO.cjs +12 -3
- package/dist/ro-RO.cjs.map +1 -1
- package/dist/ro-RO.mjs +12 -3
- package/dist/ro-RO.mjs.map +1 -1
- package/dist/ru-RU.cjs +7 -2
- package/dist/ru-RU.cjs.map +1 -1
- package/dist/ru-RU.mjs +7 -2
- package/dist/ru-RU.mjs.map +1 -1
- package/dist/sk-SK.cjs +7 -2
- package/dist/sk-SK.cjs.map +1 -1
- package/dist/sk-SK.mjs +7 -2
- package/dist/sk-SK.mjs.map +1 -1
- package/dist/sl-SI.cjs +7 -2
- package/dist/sl-SI.cjs.map +1 -1
- package/dist/sl-SI.mjs +7 -2
- package/dist/sl-SI.mjs.map +1 -1
- package/dist/sr-SP.cjs +7 -2
- package/dist/sr-SP.cjs.map +1 -1
- package/dist/sr-SP.mjs +7 -2
- package/dist/sr-SP.mjs.map +1 -1
- package/dist/sv-SE.cjs +11 -2
- package/dist/sv-SE.cjs.map +1 -1
- package/dist/sv-SE.mjs +11 -2
- package/dist/sv-SE.mjs.map +1 -1
- package/dist/tr-TR.cjs +10 -2
- package/dist/tr-TR.cjs.map +1 -1
- package/dist/tr-TR.mjs +10 -2
- package/dist/tr-TR.mjs.map +1 -1
- package/dist/types.d.ts +227 -168
- package/dist/types.d.ts.map +1 -1
- package/dist/uk-UA.cjs +7 -2
- package/dist/uk-UA.cjs.map +1 -1
- package/dist/uk-UA.mjs +7 -2
- package/dist/uk-UA.mjs.map +1 -1
- package/dist/zh-CN.cjs +10 -2
- package/dist/zh-CN.cjs.map +1 -1
- package/dist/zh-CN.mjs +10 -2
- package/dist/zh-CN.mjs.map +1 -1
- package/dist/zh-TW.cjs +10 -2
- package/dist/zh-TW.cjs.map +1 -1
- package/dist/zh-TW.mjs +10 -2
- package/dist/zh-TW.mjs.map +1 -1
- package/icons/3DMaterial.cjs.map +1 -1
- package/icons/3DMaterial.mjs.map +1 -1
- package/icons/ABC.cjs +36 -0
- package/icons/ABC.cjs.map +1 -0
- package/icons/ABC.mjs +25 -0
- package/icons/ABC.mjs.map +1 -0
- package/icons/AlertDiamond.cjs.map +1 -1
- package/icons/AlertDiamond.mjs.map +1 -1
- package/icons/Animation.cjs.map +1 -1
- package/icons/Animation.mjs.map +1 -1
- package/icons/AnimationNo.cjs.map +1 -1
- package/icons/AnimationNo.mjs.map +1 -1
- package/icons/App.cjs +42 -0
- package/icons/App.cjs.map +1 -0
- package/icons/App.mjs +31 -0
- package/icons/App.mjs.map +1 -0
- package/icons/AspectRatio.cjs.map +1 -1
- package/icons/AspectRatio.mjs.map +1 -1
- package/icons/Asset.cjs +1 -5
- package/icons/Asset.cjs.map +1 -1
- package/icons/Asset.mjs +1 -5
- package/icons/Asset.mjs.map +1 -1
- package/icons/AudioWave.cjs.map +1 -1
- package/icons/AudioWave.mjs.map +1 -1
- package/icons/BadgeVerified.cjs.map +1 -1
- package/icons/BadgeVerified.mjs.map +1 -1
- package/icons/Bell.cjs.map +1 -1
- package/icons/Bell.mjs.map +1 -1
- package/icons/Bookmark.cjs +36 -0
- package/icons/Bookmark.cjs.map +1 -0
- package/icons/Bookmark.mjs +25 -0
- package/icons/Bookmark.mjs.map +1 -0
- package/icons/Brand.cjs.map +1 -1
- package/icons/Brand.mjs.map +1 -1
- package/icons/Building.cjs +62 -0
- package/icons/Building.cjs.map +1 -0
- package/icons/Building.mjs +51 -0
- package/icons/Building.mjs.map +1 -0
- package/icons/CalendarEdit.cjs.map +1 -1
- package/icons/CalendarEdit.mjs.map +1 -1
- package/icons/CallCenter.cjs +36 -0
- package/icons/CallCenter.cjs.map +1 -0
- package/icons/CallCenter.mjs +25 -0
- package/icons/CallCenter.mjs.map +1 -0
- package/icons/CameraProperties.cjs.map +1 -1
- package/icons/CameraProperties.mjs.map +1 -1
- package/icons/Channel.cjs.map +1 -1
- package/icons/Channel.mjs.map +1 -1
- package/icons/ChartBarVert.cjs +36 -0
- package/icons/ChartBarVert.cjs.map +1 -0
- package/icons/ChartBarVert.mjs +25 -0
- package/icons/ChartBarVert.mjs.map +1 -0
- package/icons/ChartPie.cjs +36 -0
- package/icons/ChartPie.cjs.map +1 -0
- package/icons/ChartPie.mjs +25 -0
- package/icons/ChartPie.mjs.map +1 -0
- package/icons/ChartTrend.cjs +36 -0
- package/icons/ChartTrend.cjs.map +1 -0
- package/icons/ChartTrend.mjs +25 -0
- package/icons/ChartTrend.mjs.map +1 -0
- package/icons/Chat.cjs +36 -0
- package/icons/Chat.cjs.map +1 -0
- package/icons/Chat.mjs +25 -0
- package/icons/Chat.mjs.map +1 -0
- package/icons/CheckBox.cjs.map +1 -1
- package/icons/CheckBox.mjs.map +1 -1
- package/icons/Checkmark.cjs +8 -8
- package/icons/Checkmark.cjs.map +1 -1
- package/icons/Checkmark.mjs +8 -8
- package/icons/Checkmark.mjs.map +1 -1
- package/icons/ChevronDoubleLeft.cjs +42 -0
- package/icons/ChevronDoubleLeft.cjs.map +1 -0
- package/icons/ChevronDoubleLeft.d.ts +5 -0
- package/icons/ChevronDoubleLeft.mjs +31 -0
- package/icons/ChevronDoubleLeft.mjs.map +1 -0
- package/icons/ChevronDoubleRight.cjs +42 -0
- package/icons/ChevronDoubleRight.cjs.map +1 -0
- package/icons/ChevronDoubleRight.d.ts +5 -0
- package/icons/ChevronDoubleRight.mjs +31 -0
- package/icons/ChevronDoubleRight.mjs.map +1 -0
- package/icons/ChevronDown.cjs +8 -8
- package/icons/ChevronDown.cjs.map +1 -1
- package/icons/ChevronDown.mjs +8 -8
- package/icons/ChevronDown.mjs.map +1 -1
- package/icons/ChevronLeft.cjs.map +1 -1
- package/icons/ChevronLeft.mjs.map +1 -1
- package/icons/ChevronRight.cjs.map +1 -1
- package/icons/ChevronRight.mjs.map +1 -1
- package/icons/ChevronUp.cjs +36 -0
- package/icons/ChevronUp.cjs.map +1 -0
- package/icons/ChevronUp.d.ts +5 -0
- package/icons/ChevronUp.mjs +25 -0
- package/icons/ChevronUp.mjs.map +1 -0
- package/icons/Circle.cjs.map +1 -1
- package/icons/Circle.mjs.map +1 -1
- package/icons/Close.cjs.map +1 -1
- package/icons/Close.mjs.map +1 -1
- package/icons/CloseCaptions.cjs.map +1 -1
- package/icons/CloseCaptions.mjs.map +1 -1
- package/icons/Code.cjs +36 -0
- package/icons/Code.cjs.map +1 -0
- package/icons/Code.d.ts +5 -0
- package/icons/Code.mjs +25 -0
- package/icons/Code.mjs.map +1 -0
- package/icons/Collection.cjs.map +1 -1
- package/icons/Collection.mjs.map +1 -1
- package/icons/ColorHarmony.cjs.map +1 -1
- package/icons/ColorHarmony.mjs.map +1 -1
- package/icons/CommentCheckmark.cjs.map +1 -1
- package/icons/CommentCheckmark.mjs.map +1 -1
- package/icons/CommentHide.cjs.map +1 -1
- package/icons/CommentHide.mjs.map +1 -1
- package/icons/CommentRemove.cjs.map +1 -1
- package/icons/CommentRemove.mjs.map +1 -1
- package/icons/Compare.cjs +42 -0
- package/icons/Compare.cjs.map +1 -0
- package/icons/Compare.d.ts +5 -0
- package/icons/Compare.mjs +31 -0
- package/icons/Compare.mjs.map +1 -0
- package/icons/ContextualTaskBar.cjs.map +1 -1
- package/icons/ContextualTaskBar.mjs.map +1 -1
- package/icons/CornerRadiusBottomLeft.cjs.map +1 -1
- package/icons/CornerRadiusBottomLeft.mjs.map +1 -1
- package/icons/CornerRadiusBottomRight.cjs.map +1 -1
- package/icons/CornerRadiusBottomRight.mjs.map +1 -1
- package/icons/CornerRadiusTopLeft.cjs.map +1 -1
- package/icons/CornerRadiusTopLeft.mjs.map +1 -1
- package/icons/CornerRadiusTopRight.cjs.map +1 -1
- package/icons/CornerRadiusTopRight.mjs.map +1 -1
- package/icons/CursorClick.cjs.map +1 -1
- package/icons/CursorClick.mjs.map +1 -1
- package/icons/Data.cjs +1 -1
- package/icons/Data.cjs.map +1 -1
- package/icons/Data.mjs +1 -1
- package/icons/Data.mjs.map +1 -1
- package/icons/DataAdd.cjs.map +1 -1
- package/icons/DataAdd.mjs.map +1 -1
- package/icons/DataRefresh.cjs +42 -0
- package/icons/DataRefresh.cjs.map +1 -0
- package/icons/DataRefresh.d.ts +5 -0
- package/icons/DataRefresh.mjs +31 -0
- package/icons/DataRefresh.mjs.map +1 -0
- package/icons/DataSettings.cjs +2 -2
- package/icons/DataSettings.cjs.map +1 -1
- package/icons/DataSettings.mjs +2 -2
- package/icons/DataSettings.mjs.map +1 -1
- package/icons/DataUpload.cjs +2 -2
- package/icons/DataUpload.cjs.map +1 -1
- package/icons/DataUpload.mjs +2 -2
- package/icons/DataUpload.mjs.map +1 -1
- package/icons/DeviceTablet.cjs.map +1 -1
- package/icons/DeviceTablet.mjs.map +1 -1
- package/icons/Draw.cjs.map +1 -1
- package/icons/Draw.mjs.map +1 -1
- package/icons/Edit.cjs.map +1 -1
- package/icons/Edit.mjs.map +1 -1
- package/icons/EditNo.cjs.map +1 -1
- package/icons/EditNo.mjs.map +1 -1
- package/icons/Email.cjs.map +1 -1
- package/icons/Email.mjs.map +1 -1
- package/icons/Enterprise.cjs +46 -0
- package/icons/Enterprise.cjs.map +1 -0
- package/icons/Enterprise.d.ts +5 -0
- package/icons/Enterprise.mjs +35 -0
- package/icons/Enterprise.mjs.map +1 -0
- package/icons/Export.cjs +42 -0
- package/icons/Export.cjs.map +1 -0
- package/icons/Export.d.ts +5 -0
- package/icons/Export.mjs +31 -0
- package/icons/Export.mjs.map +1 -0
- package/icons/Filter.cjs.map +1 -1
- package/icons/Filter.mjs.map +1 -1
- package/icons/FlipHorizontal.cjs +1 -21
- package/icons/FlipHorizontal.cjs.map +1 -1
- package/icons/FlipHorizontal.mjs +1 -21
- package/icons/FlipHorizontal.mjs.map +1 -1
- package/icons/FlipVertical.cjs +1 -21
- package/icons/FlipVertical.cjs.map +1 -1
- package/icons/FlipVertical.mjs +1 -21
- package/icons/FlipVertical.mjs.map +1 -1
- package/icons/FolderMoveTo.cjs.map +1 -1
- package/icons/FolderMoveTo.mjs.map +1 -1
- package/icons/FolderSearch.cjs +42 -0
- package/icons/FolderSearch.cjs.map +1 -0
- package/icons/FolderSearch.d.ts +5 -0
- package/icons/FolderSearch.mjs +31 -0
- package/icons/FolderSearch.mjs.map +1 -0
- package/icons/FontPicker.cjs.map +1 -1
- package/icons/FontPicker.mjs.map +1 -1
- package/icons/GlobeGrid.cjs.map +1 -1
- package/icons/GlobeGrid.mjs.map +1 -1
- package/icons/GradientHorizontal.cjs.map +1 -1
- package/icons/GradientHorizontal.mjs.map +1 -1
- package/icons/GridsAndRulers.cjs.map +1 -1
- package/icons/GridsAndRulers.mjs.map +1 -1
- package/icons/Icon.cjs.map +1 -1
- package/icons/Icon.mjs.map +1 -1
- package/icons/Image.cjs.map +1 -1
- package/icons/Image.mjs.map +1 -1
- package/icons/ImageAdd.cjs +1 -5
- package/icons/ImageAdd.cjs.map +1 -1
- package/icons/ImageAdd.mjs +1 -5
- package/icons/ImageAdd.mjs.map +1 -1
- package/icons/ImageBackgroundRemove.cjs.map +1 -1
- package/icons/ImageBackgroundRemove.mjs.map +1 -1
- package/icons/Images.cjs.map +1 -1
- package/icons/Images.mjs.map +1 -1
- package/icons/Import.cjs +42 -0
- package/icons/Import.cjs.map +1 -0
- package/icons/Import.d.ts +5 -0
- package/icons/Import.mjs +31 -0
- package/icons/Import.mjs.map +1 -0
- package/icons/Key.cjs +36 -0
- package/icons/Key.cjs.map +1 -0
- package/icons/Key.d.ts +5 -0
- package/icons/Key.mjs +25 -0
- package/icons/Key.mjs.map +1 -0
- package/icons/ListMultiSelect.cjs.map +1 -1
- package/icons/ListMultiSelect.mjs.map +1 -1
- package/icons/ListNumbered.cjs.map +1 -1
- package/icons/ListNumbered.mjs.map +1 -1
- package/icons/Logo.cjs.map +1 -1
- package/icons/Logo.mjs.map +1 -1
- package/icons/Market.cjs.map +1 -1
- package/icons/Market.mjs.map +1 -1
- package/icons/Microphone.cjs.map +1 -1
- package/icons/Microphone.mjs.map +1 -1
- package/icons/MicrophoneOff.cjs.map +1 -1
- package/icons/MicrophoneOff.mjs.map +1 -1
- package/icons/MusicNote.cjs.map +1 -1
- package/icons/MusicNote.mjs.map +1 -1
- package/icons/OrientationPortrait.cjs.map +1 -1
- package/icons/OrientationPortrait.mjs.map +1 -1
- package/icons/Pause.cjs.map +1 -1
- package/icons/Pause.mjs.map +1 -1
- package/icons/PauseCircle.cjs.map +1 -1
- package/icons/PauseCircle.mjs.map +1 -1
- package/icons/PeopleGroup.cjs +36 -0
- package/icons/PeopleGroup.cjs.map +1 -0
- package/icons/PeopleGroup.d.ts +5 -0
- package/icons/PeopleGroup.mjs +25 -0
- package/icons/PeopleGroup.mjs.map +1 -0
- package/icons/Percentage.cjs.map +1 -1
- package/icons/Percentage.mjs.map +1 -1
- package/icons/PinOff.cjs.map +1 -1
- package/icons/PinOff.mjs.map +1 -1
- package/icons/PinOn.cjs.map +1 -1
- package/icons/PinOn.mjs.map +1 -1
- package/icons/Play.cjs.map +1 -1
- package/icons/Play.mjs.map +1 -1
- package/icons/PluginGear.cjs.map +1 -1
- package/icons/PluginGear.mjs.map +1 -1
- package/icons/Polygon6.cjs.map +1 -1
- package/icons/Polygon6.mjs.map +1 -1
- package/icons/Publish.cjs.map +1 -1
- package/icons/Publish.mjs.map +1 -1
- package/icons/PublishNo.cjs.map +1 -1
- package/icons/PublishNo.mjs.map +1 -1
- package/icons/RadioButton.cjs.map +1 -1
- package/icons/RadioButton.mjs.map +1 -1
- package/icons/RectangleHoriz.cjs.map +1 -1
- package/icons/RectangleHoriz.mjs.map +1 -1
- package/icons/RocketQuickActions.cjs.map +1 -1
- package/icons/RocketQuickActions.mjs.map +1 -1
- package/icons/RotateCW.cjs.map +1 -1
- package/icons/RotateCW.mjs.map +1 -1
- package/icons/Ruler.cjs.map +1 -1
- package/icons/Ruler.mjs.map +1 -1
- package/icons/SaveFloppy.cjs +36 -0
- package/icons/SaveFloppy.cjs.map +1 -0
- package/icons/SaveFloppy.d.ts +5 -0
- package/icons/SaveFloppy.mjs +25 -0
- package/icons/SaveFloppy.mjs.map +1 -0
- package/icons/Select.cjs.map +1 -1
- package/icons/Select.mjs.map +1 -1
- package/icons/Send.cjs.map +1 -1
- package/icons/Send.mjs.map +1 -1
- package/icons/Shuffle.cjs.map +1 -1
- package/icons/Shuffle.mjs.map +1 -1
- package/icons/Skeleton.cjs +8 -6
- package/icons/Skeleton.cjs.map +1 -1
- package/icons/Skeleton.css +8 -10
- package/icons/Skeleton.css.map +1 -1
- package/icons/Skeleton.mjs +9 -7
- package/icons/Skeleton.mjs.map +1 -1
- package/icons/SlowConnectionCircle.cjs.map +1 -1
- package/icons/SlowConnectionCircle.mjs.map +1 -1
- package/icons/SpeedFast.cjs +36 -0
- package/icons/SpeedFast.cjs.map +1 -0
- package/icons/SpeedFast.d.ts +5 -0
- package/icons/SpeedFast.mjs +25 -0
- package/icons/SpeedFast.mjs.map +1 -0
- package/icons/StepBackward.cjs.map +1 -1
- package/icons/StepBackward.mjs.map +1 -1
- package/icons/StepForward.cjs.map +1 -1
- package/icons/StepForward.mjs.map +1 -1
- package/icons/Table.cjs.map +1 -1
- package/icons/Table.mjs.map +1 -1
- package/icons/Tag.cjs.map +1 -1
- package/icons/Tag.mjs.map +1 -1
- package/icons/Target.cjs.map +1 -1
- package/icons/Target.mjs.map +1 -1
- package/icons/TextBold.cjs.map +1 -1
- package/icons/TextBold.mjs.map +1 -1
- package/icons/TextHighlight.cjs.map +1 -1
- package/icons/TextHighlight.mjs.map +1 -1
- package/icons/TextIncrease.cjs.map +1 -1
- package/icons/TextIncrease.mjs.map +1 -1
- package/icons/TextNumbers.cjs.map +1 -1
- package/icons/TextNumbers.mjs.map +1 -1
- package/icons/TextParagraph.cjs.map +1 -1
- package/icons/TextParagraph.mjs.map +1 -1
- package/icons/TextReplaceComment.cjs.map +1 -1
- package/icons/TextReplaceComment.mjs.map +1 -1
- package/icons/Tools.cjs.map +1 -1
- package/icons/Tools.mjs.map +1 -1
- package/icons/TouchOneFingerSwipeLeftRight.cjs.map +1 -1
- package/icons/TouchOneFingerSwipeLeftRight.mjs.map +1 -1
- package/icons/Transcript.cjs.map +1 -1
- package/icons/Transcript.mjs.map +1 -1
- package/icons/Translate.cjs.map +1 -1
- package/icons/Translate.mjs.map +1 -1
- package/icons/UserAvatarCursor.cjs.map +1 -1
- package/icons/UserAvatarCursor.mjs.map +1 -1
- package/icons/UserEdit.cjs.map +1 -1
- package/icons/UserEdit.mjs.map +1 -1
- package/icons/UserGroup.cjs.map +1 -1
- package/icons/UserGroup.mjs.map +1 -1
- package/icons/UserSettings.cjs +44 -0
- package/icons/UserSettings.cjs.map +1 -0
- package/icons/UserSettings.d.ts +5 -0
- package/icons/UserSettings.mjs +33 -0
- package/icons/UserSettings.mjs.map +1 -0
- package/icons/VectorDraw.cjs.map +1 -1
- package/icons/VectorDraw.mjs.map +1 -1
- package/icons/ViewGridFluid.cjs +36 -0
- package/icons/ViewGridFluid.cjs.map +1 -0
- package/icons/ViewGridFluid.d.ts +5 -0
- package/icons/ViewGridFluid.mjs +25 -0
- package/icons/ViewGridFluid.mjs.map +1 -0
- package/icons/ZoomIn.cjs.map +1 -1
- package/icons/ZoomIn.mjs.map +1 -1
- package/icons/ZoomOut.cjs.map +1 -1
- package/icons/ZoomOut.mjs.map +1 -1
- package/package.json +19 -21
- package/src/Accordion.tsx +6 -9
- package/src/ActionBar.tsx +229 -0
- package/src/ActionButton.tsx +27 -54
- package/src/ActionButtonGroup.tsx +9 -11
- package/src/ActionMenu.tsx +6 -9
- package/src/AlertDialog.tsx +5 -8
- package/src/Avatar.tsx +6 -9
- package/src/AvatarGroup.tsx +6 -9
- package/src/Badge.tsx +32 -16
- package/src/Breadcrumbs.tsx +19 -25
- package/src/Button.tsx +201 -158
- package/src/ButtonGroup.tsx +6 -9
- package/src/Card.tsx +2 -2
- package/src/CardView.tsx +54 -377
- package/src/Checkbox.tsx +7 -10
- package/src/CheckboxGroup.tsx +8 -11
- package/src/ClearButton.tsx +2 -5
- package/src/CloseButton.tsx +22 -32
- package/src/ColorArea.tsx +6 -9
- package/src/ColorField.tsx +6 -9
- package/src/ColorSlider.tsx +6 -9
- package/src/ColorSwatch.tsx +7 -10
- package/src/ColorSwatchPicker.tsx +6 -10
- package/src/ColorWheel.tsx +6 -9
- package/src/ComboBox.tsx +7 -9
- package/src/Content.tsx +23 -39
- package/src/ContextualHelp.tsx +7 -10
- package/src/CustomDialog.tsx +5 -8
- package/src/Dialog.tsx +6 -9
- package/src/Disclosure.tsx +16 -25
- package/src/Divider.tsx +17 -26
- package/src/DropZone.tsx +7 -10
- package/src/Field.tsx +26 -33
- package/src/Form.tsx +7 -10
- package/src/FullscreenDialog.tsx +5 -8
- package/src/Icon.tsx +2 -2
- package/src/IllustratedMessage.tsx +7 -10
- package/src/Image.tsx +21 -10
- package/src/InlineAlert.tsx +6 -10
- package/src/Link.tsx +15 -23
- package/src/Menu.tsx +77 -36
- package/src/Meter.tsx +14 -24
- package/src/Modal.tsx +22 -52
- package/src/NumberField.tsx +6 -9
- package/src/Picker.tsx +88 -69
- package/src/Popover.tsx +32 -105
- package/src/ProgressBar.tsx +15 -25
- package/src/ProgressCircle.tsx +19 -25
- package/src/Radio.tsx +6 -9
- package/src/RadioGroup.tsx +8 -11
- package/src/RangeSlider.tsx +3 -6
- package/src/SearchField.tsx +6 -9
- package/src/SegmentedControl.tsx +16 -25
- package/src/Skeleton.tsx +6 -8
- package/src/Slider.tsx +3 -6
- package/src/StatusLight.tsx +7 -10
- package/src/Switch.tsx +7 -10
- package/src/TableView.tsx +120 -121
- package/src/Tabs.tsx +450 -147
- package/src/TabsPicker.tsx +350 -0
- package/src/TagGroup.tsx +11 -18
- package/src/TextField.tsx +22 -30
- package/src/ToggleButton.tsx +9 -11
- package/src/ToggleButtonGroup.tsx +6 -9
- package/src/Tooltip.tsx +34 -55
- package/src/TreeView.tsx +450 -0
- package/src/bar-utils.ts +3 -10
- package/src/index.ts +4 -0
- package/src/style-utils.ts +15 -9
- package/style/__tests__/style-macro.test.js +3 -7
- package/style/dist/main.cjs +1 -0
- package/style/dist/main.cjs.map +1 -1
- package/style/dist/module.mjs +2 -2
- package/style/dist/module.mjs.map +1 -1
- package/style/dist/spectrum-theme.cjs +72 -5
- package/style/dist/spectrum-theme.cjs.map +1 -1
- package/style/dist/spectrum-theme.mjs +72 -6
- package/style/dist/spectrum-theme.mjs.map +1 -1
- package/style/dist/style-macro.cjs +18 -4
- package/style/dist/style-macro.cjs.map +1 -1
- package/style/dist/style-macro.mjs +18 -4
- package/style/dist/style-macro.mjs.map +1 -1
- package/style/dist/types.d.ts +50 -29
- package/style/dist/types.d.ts.map +1 -1
- package/style/index.ts +1 -1
- package/style/spectrum-theme.ts +72 -8
- package/style/style-macro.ts +29 -7
- package/style/tokens.ts +30 -0
- package/style/types.ts +1 -1
- package/icons/CloudStateDefault.cjs +0 -36
- package/icons/CloudStateDefault.cjs.map +0 -1
- package/icons/CloudStateDefault.mjs +0 -25
- package/icons/CloudStateDefault.mjs.map +0 -1
- package/icons/CloudStateDisconnected.cjs +0 -36
- package/icons/CloudStateDisconnected.cjs.map +0 -1
- package/icons/CloudStateDisconnected.mjs +0 -25
- package/icons/CloudStateDisconnected.mjs.map +0 -1
- package/icons/CloudStateError.cjs +0 -36
- package/icons/CloudStateError.cjs.map +0 -1
- package/icons/CloudStateError.mjs +0 -25
- package/icons/CloudStateError.mjs.map +0 -1
- package/icons/CloudStateErrorRed.cjs +0 -46
- package/icons/CloudStateErrorRed.cjs.map +0 -1
- package/icons/CloudStateErrorRed.mjs +0 -35
- package/icons/CloudStateErrorRed.mjs.map +0 -1
- package/icons/CloudStateInProgress.cjs +0 -36
- package/icons/CloudStateInProgress.cjs.map +0 -1
- package/icons/CloudStateInProgress.mjs +0 -25
- package/icons/CloudStateInProgress.mjs.map +0 -1
- package/icons/CloudStateOnline.cjs +0 -50
- package/icons/CloudStateOnline.cjs.map +0 -1
- package/icons/CloudStateOnline.mjs +0 -39
- package/icons/CloudStateOnline.mjs.map +0 -1
- package/icons/CloudStatePaused.cjs +0 -36
- package/icons/CloudStatePaused.cjs.map +0 -1
- package/icons/CloudStatePaused.mjs +0 -25
- package/icons/CloudStatePaused.mjs.map +0 -1
- package/icons/CloudStatePending.cjs +0 -42
- package/icons/CloudStatePending.cjs.map +0 -1
- package/icons/CloudStatePending.mjs +0 -31
- package/icons/CloudStatePending.mjs.map +0 -1
- package/icons/CloudStateSlowConnection.cjs +0 -36
- package/icons/CloudStateSlowConnection.cjs.map +0 -1
- package/icons/CloudStateSlowConnection.mjs +0 -25
- package/icons/CloudStateSlowConnection.mjs.map +0 -1
- /package/icons/{CloudStateDefault.d.ts → ABC.d.ts} +0 -0
- /package/icons/{CloudStateDisconnected.d.ts → App.d.ts} +0 -0
- /package/icons/{CloudStateError.d.ts → Bookmark.d.ts} +0 -0
- /package/icons/{CloudStateErrorRed.d.ts → Building.d.ts} +0 -0
- /package/icons/{CloudStateInProgress.d.ts → CallCenter.d.ts} +0 -0
- /package/icons/{CloudStateOnline.d.ts → ChartBarVert.d.ts} +0 -0
- /package/icons/{CloudStatePaused.d.ts → ChartPie.d.ts} +0 -0
- /package/icons/{CloudStatePending.d.ts → ChartTrend.d.ts} +0 -0
- /package/icons/{CloudStateSlowConnection.d.ts → Chat.d.ts} +0 -0
package/src/Tabs.tsx
CHANGED
|
@@ -11,28 +11,32 @@
|
|
|
11
11
|
*/
|
|
12
12
|
|
|
13
13
|
import {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
14
|
+
TabListProps as AriaTabListProps,
|
|
15
|
+
TabPanel as AriaTabPanel,
|
|
16
|
+
TabPanelProps as AriaTabPanelProps,
|
|
17
|
+
TabProps as AriaTabProps,
|
|
18
|
+
TabsProps as AriaTabsProps,
|
|
19
|
+
ContextValue,
|
|
20
|
+
Group,
|
|
21
|
+
Provider,
|
|
22
|
+
Tab as RACTab,
|
|
23
|
+
TabList as RACTabList,
|
|
24
|
+
Tabs as RACTabs,
|
|
25
|
+
TabListStateContext
|
|
26
|
+
} from 'react-aria-components';
|
|
27
27
|
import {centerBaseline} from './CenterBaseline';
|
|
28
|
-
import {Collection, DOMRef, DOMRefValue, Key, Node, Orientation} from '@react-types/shared';
|
|
29
|
-
import {
|
|
30
|
-
import {
|
|
28
|
+
import {Collection, DOMRef, DOMRefValue, Key, Node, Orientation, RefObject} from '@react-types/shared';
|
|
29
|
+
import {CollectionBuilder} from '@react-aria/collections';
|
|
30
|
+
import {createContext, forwardRef, ReactNode, useCallback, useContext, useEffect, useMemo, useRef, useState} from 'react';
|
|
31
|
+
import {focusRing, size, style} from '../style' with {type: 'macro'};
|
|
31
32
|
import {getAllowedOverrides, StyleProps, StylesPropWithHeight, UnsafeStyles} from './style-utils' with {type: 'macro'};
|
|
32
33
|
import {IconContext} from './Icon';
|
|
34
|
+
import {inertValue, useEffectEvent, useId, useLabels, useLayoutEffect, useResizeObserver} from '@react-aria/utils';
|
|
35
|
+
import {Picker, PickerItem} from './TabsPicker';
|
|
33
36
|
import {Text, TextContext} from './Content';
|
|
37
|
+
import {useControlledState} from '@react-stately/utils';
|
|
34
38
|
import {useDOMRef} from '@react-spectrum/utils';
|
|
35
|
-
import {
|
|
39
|
+
import {useHasTabbableChild} from '@react-aria/focus';
|
|
36
40
|
import {useLocale} from '@react-aria/i18n';
|
|
37
41
|
import {useSpectrumContextProps} from './useSpectrumContextProps';
|
|
38
42
|
|
|
@@ -40,108 +44,104 @@ export interface TabsProps extends Omit<AriaTabsProps, 'className' | 'style' | '
|
|
|
40
44
|
/** Spectrum-defined styles, returned by the `style()` macro. */
|
|
41
45
|
styles?: StylesPropWithHeight,
|
|
42
46
|
/** The content to display in the tabs. */
|
|
43
|
-
children
|
|
47
|
+
children: ReactNode,
|
|
44
48
|
/**
|
|
45
49
|
* The amount of space between the tabs.
|
|
46
50
|
* @default 'regular'
|
|
47
51
|
*/
|
|
48
|
-
density?: 'compact' | 'regular'
|
|
52
|
+
density?: 'compact' | 'regular',
|
|
53
|
+
/**
|
|
54
|
+
* Defines if the text within the tabs should be hidden and only the icon should be shown.
|
|
55
|
+
* The text is always visible when the item is collapsed into a picker.
|
|
56
|
+
* @default 'show'
|
|
57
|
+
*/
|
|
58
|
+
labelBehavior?: 'show' | 'hide'
|
|
49
59
|
}
|
|
50
60
|
|
|
51
61
|
export interface TabProps extends Omit<AriaTabProps, 'children' | 'style' | 'className'>, StyleProps {
|
|
52
62
|
/** The content to display in the tab. */
|
|
53
|
-
children
|
|
63
|
+
children: ReactNode
|
|
54
64
|
}
|
|
55
65
|
|
|
56
|
-
export interface TabListProps<T> extends Omit<AriaTabListProps<T>, '
|
|
66
|
+
export interface TabListProps<T> extends Omit<AriaTabListProps<T>, 'style' | 'className' | 'aria-label' | 'aria-labelledby'>, StyleProps {
|
|
57
67
|
/** The content to display in the tablist. */
|
|
58
|
-
children
|
|
68
|
+
children: ReactNode | ((item: T) => ReactNode)
|
|
59
69
|
}
|
|
60
70
|
|
|
61
71
|
export interface TabPanelProps extends Omit<AriaTabPanelProps, 'children' | 'style' | 'className'>, UnsafeStyles {
|
|
62
72
|
/** Spectrum-defined styles, returned by the `style()` macro. */
|
|
63
73
|
styles?: StylesPropWithHeight,
|
|
64
74
|
/** The content to display in the tab panels. */
|
|
65
|
-
children
|
|
75
|
+
children: ReactNode
|
|
66
76
|
}
|
|
67
77
|
|
|
68
|
-
export const TabsContext = createContext<ContextValue<TabsProps
|
|
69
|
-
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
minHeight: 0,
|
|
76
|
-
minWidth: 0
|
|
77
|
-
}, getAllowedOverrides({height: true}));
|
|
78
|
-
|
|
79
|
-
export function TabPanel(props: TabPanelProps) {
|
|
80
|
-
return (
|
|
81
|
-
<AriaTabPanel
|
|
82
|
-
{...props}
|
|
83
|
-
style={props.UNSAFE_style}
|
|
84
|
-
className={(props.UNSAFE_className || '') + tabPanel(null, props.styles)} />
|
|
85
|
-
);
|
|
86
|
-
}
|
|
78
|
+
export const TabsContext = createContext<ContextValue<Partial<TabsProps>, DOMRefValue<HTMLDivElement>>>(null);
|
|
79
|
+
const InternalTabsContext = createContext<Partial<TabsProps>>({});
|
|
80
|
+
const CollapseContext = createContext({
|
|
81
|
+
showTabs: true,
|
|
82
|
+
menuId: '',
|
|
83
|
+
valueId: ''
|
|
84
|
+
});
|
|
87
85
|
|
|
88
|
-
const
|
|
89
|
-
...focusRing(),
|
|
90
|
-
display: 'flex',
|
|
91
|
-
color: {
|
|
92
|
-
default: 'neutral-subdued',
|
|
93
|
-
isSelected: 'neutral',
|
|
94
|
-
isHovered: 'neutral-subdued',
|
|
95
|
-
isDisabled: 'disabled',
|
|
96
|
-
forcedColors: {
|
|
97
|
-
isSelected: 'Highlight',
|
|
98
|
-
isDisabled: 'GrayText'
|
|
99
|
-
}
|
|
100
|
-
},
|
|
101
|
-
borderRadius: 'sm',
|
|
102
|
-
gap: 'text-to-visual',
|
|
103
|
-
height: {
|
|
104
|
-
density: {
|
|
105
|
-
compact: 32,
|
|
106
|
-
regular: 48
|
|
107
|
-
}
|
|
108
|
-
},
|
|
109
|
-
alignItems: 'center',
|
|
86
|
+
const tabs = style({
|
|
110
87
|
position: 'relative',
|
|
111
|
-
|
|
112
|
-
flexShrink: 0,
|
|
113
|
-
transition: 'default'
|
|
114
|
-
}, getAllowedOverrides());
|
|
115
|
-
|
|
116
|
-
const icon = style({
|
|
88
|
+
display: 'flex',
|
|
117
89
|
flexShrink: 0,
|
|
118
|
-
'
|
|
119
|
-
|
|
120
|
-
|
|
90
|
+
font: 'ui',
|
|
91
|
+
flexDirection: {
|
|
92
|
+
orientation: {
|
|
93
|
+
horizontal: 'column'
|
|
94
|
+
}
|
|
121
95
|
}
|
|
122
|
-
});
|
|
96
|
+
}, getAllowedOverrides({height: true}));
|
|
123
97
|
|
|
124
|
-
|
|
125
|
-
|
|
98
|
+
/**
|
|
99
|
+
* Tabs organize content into multiple sections and allow users to navigate between them. The content under the set of tabs should be related and form a coherent unit.
|
|
100
|
+
*/
|
|
101
|
+
export const Tabs = forwardRef(function Tabs(props: TabsProps, ref: DOMRef<HTMLDivElement>) {
|
|
102
|
+
[props, ref] = useSpectrumContextProps(props, ref, TabsContext);
|
|
103
|
+
let {
|
|
104
|
+
density = 'regular',
|
|
105
|
+
isDisabled,
|
|
106
|
+
disabledKeys,
|
|
107
|
+
orientation = 'horizontal',
|
|
108
|
+
labelBehavior = 'show'
|
|
109
|
+
} = props;
|
|
110
|
+
let domRef = useDOMRef(ref);
|
|
111
|
+
let [value, setValue] = useControlledState(props.selectedKey, props.defaultSelectedKey ?? null!, props.onSelectionChange);
|
|
112
|
+
|
|
113
|
+
if (!props['aria-label'] && !props['aria-labelledby']) {
|
|
114
|
+
throw new Error('An aria-label or aria-labelledby prop is required on Tabs for accessibility.');
|
|
115
|
+
}
|
|
126
116
|
|
|
127
117
|
return (
|
|
128
|
-
<
|
|
129
|
-
{
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
118
|
+
<Provider
|
|
119
|
+
values={[
|
|
120
|
+
[InternalTabsContext, {
|
|
121
|
+
density,
|
|
122
|
+
isDisabled,
|
|
123
|
+
orientation,
|
|
124
|
+
disabledKeys,
|
|
125
|
+
selectedKey: value,
|
|
126
|
+
onSelectionChange: setValue,
|
|
127
|
+
labelBehavior,
|
|
128
|
+
'aria-label': props['aria-label'],
|
|
129
|
+
'aria-labelledby': props['aria-labelledby']
|
|
130
|
+
}]
|
|
131
|
+
]}>
|
|
132
|
+
<CollectionBuilder content={props.children}>
|
|
133
|
+
{collection => (
|
|
134
|
+
<CollapsingTabs
|
|
135
|
+
{...props}
|
|
136
|
+
selectedKey={value}
|
|
137
|
+
onSelectionChange={setValue}
|
|
138
|
+
collection={collection}
|
|
139
|
+
containerRef={domRef} />
|
|
140
|
+
)}
|
|
141
|
+
</CollectionBuilder>
|
|
142
|
+
</Provider>
|
|
143
143
|
);
|
|
144
|
-
}
|
|
144
|
+
});
|
|
145
145
|
|
|
146
146
|
const tablist = style({
|
|
147
147
|
display: 'flex',
|
|
@@ -151,6 +151,14 @@ const tablist = style({
|
|
|
151
151
|
density: {
|
|
152
152
|
compact: 24,
|
|
153
153
|
regular: 32
|
|
154
|
+
},
|
|
155
|
+
labelBehavior: {
|
|
156
|
+
hide: {
|
|
157
|
+
density: {
|
|
158
|
+
compact: 16,
|
|
159
|
+
regular: 24
|
|
160
|
+
}
|
|
161
|
+
}
|
|
154
162
|
}
|
|
155
163
|
}
|
|
156
164
|
}
|
|
@@ -175,7 +183,15 @@ const tablist = style({
|
|
|
175
183
|
});
|
|
176
184
|
|
|
177
185
|
export function TabList<T extends object>(props: TabListProps<T>) {
|
|
178
|
-
let {
|
|
186
|
+
let {showTabs} = useContext(CollapseContext) ?? {};
|
|
187
|
+
|
|
188
|
+
if (showTabs) {
|
|
189
|
+
return <TabListInner {...props} />;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function TabListInner<T extends object>(props: TabListProps<T>) {
|
|
194
|
+
let {density, isDisabled, disabledKeys, orientation, labelBehavior, 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledBy} = useContext(InternalTabsContext) ?? {};
|
|
179
195
|
let state = useContext(TabListStateContext);
|
|
180
196
|
let [selectedTab, setSelectedTab] = useState<HTMLElement | undefined>(undefined);
|
|
181
197
|
let tablistRef = useRef<HTMLDivElement>(null);
|
|
@@ -198,34 +214,16 @@ export function TabList<T extends object>(props: TabListProps<T>) {
|
|
|
198
214
|
<TabLine disabledKeys={disabledKeys} isDisabled={isDisabled} selectedTab={selectedTab} orientation={orientation} density={density} />}
|
|
199
215
|
<RACTabList
|
|
200
216
|
{...props}
|
|
217
|
+
aria-label={ariaLabel}
|
|
218
|
+
aria-labelledby={ariaLabelledBy}
|
|
201
219
|
ref={tablistRef}
|
|
202
|
-
className={renderProps => tablist({...renderProps, density})} />
|
|
220
|
+
className={renderProps => tablist({...renderProps, labelBehavior, density})} />
|
|
203
221
|
{orientation === 'horizontal' &&
|
|
204
222
|
<TabLine disabledKeys={disabledKeys} isDisabled={isDisabled} selectedTab={selectedTab} orientation={orientation} density={density} />}
|
|
205
223
|
</div>
|
|
206
224
|
);
|
|
207
225
|
}
|
|
208
226
|
|
|
209
|
-
function isAllTabsDisabled<T>(collection: Collection<Node<T>> | null, disabledKeys: Set<Key>) {
|
|
210
|
-
let testKey: Key | null = null;
|
|
211
|
-
if (collection && collection.size > 0) {
|
|
212
|
-
testKey = collection.getFirstKey();
|
|
213
|
-
|
|
214
|
-
let index = 0;
|
|
215
|
-
while (testKey && index < collection.size) {
|
|
216
|
-
// We have to check if the item in the collection has a key in disabledKeys or has the isDisabled prop set directly on it
|
|
217
|
-
if (!disabledKeys.has(testKey) && !collection.getItem(testKey)?.props?.isDisabled) {
|
|
218
|
-
return false;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
testKey = collection.getKeyAfter(testKey);
|
|
222
|
-
index++;
|
|
223
|
-
}
|
|
224
|
-
return true;
|
|
225
|
-
}
|
|
226
|
-
return false;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
227
|
interface TabLineProps {
|
|
230
228
|
disabledKeys: Iterable<Key> | undefined,
|
|
231
229
|
isDisabled: boolean | undefined,
|
|
@@ -279,7 +277,7 @@ function TabLine(props: TabLineProps) {
|
|
|
279
277
|
// We want to add disabled styling to the selection indicator only if all the Tabs are disabled
|
|
280
278
|
let [isDisabled, setIsDisabled] = useState<boolean>(false);
|
|
281
279
|
useEffect(() => {
|
|
282
|
-
let isDisabled = isTabsDisabled || isAllTabsDisabled(state?.collection
|
|
280
|
+
let isDisabled = isTabsDisabled || isAllTabsDisabled(state?.collection, disabledKeys ? new Set(disabledKeys) : new Set(null));
|
|
283
281
|
setIsDisabled(isDisabled);
|
|
284
282
|
}, [state?.collection, disabledKeys, isTabsDisabled, setIsDisabled]);
|
|
285
283
|
|
|
@@ -314,53 +312,358 @@ function TabLine(props: TabLineProps) {
|
|
|
314
312
|
|
|
315
313
|
useLayoutEffect(() => {
|
|
316
314
|
onResize();
|
|
317
|
-
}, [onResize, state?.selectedItem?.key, direction, orientation
|
|
315
|
+
}, [onResize, state?.selectedItem?.key, density, direction, orientation]);
|
|
318
316
|
|
|
319
317
|
return (
|
|
320
318
|
<div style={{...style}} className={selectedIndicator({isDisabled, orientation})} />
|
|
321
319
|
);
|
|
322
320
|
}
|
|
323
321
|
|
|
324
|
-
const
|
|
322
|
+
const tab = style({
|
|
323
|
+
...focusRing(),
|
|
325
324
|
display: 'flex',
|
|
325
|
+
color: {
|
|
326
|
+
default: 'neutral-subdued',
|
|
327
|
+
isSelected: 'neutral',
|
|
328
|
+
isHovered: 'neutral-subdued',
|
|
329
|
+
isDisabled: 'disabled',
|
|
330
|
+
forcedColors: {
|
|
331
|
+
isSelected: 'Highlight',
|
|
332
|
+
isDisabled: 'GrayText'
|
|
333
|
+
}
|
|
334
|
+
},
|
|
335
|
+
borderRadius: 'sm',
|
|
336
|
+
gap: 'text-to-visual',
|
|
337
|
+
height: {
|
|
338
|
+
density: {
|
|
339
|
+
compact: 32,
|
|
340
|
+
regular: 48
|
|
341
|
+
}
|
|
342
|
+
},
|
|
343
|
+
alignItems: 'center',
|
|
344
|
+
position: 'relative',
|
|
345
|
+
cursor: 'default',
|
|
326
346
|
flexShrink: 0,
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
horizontal: 'column'
|
|
347
|
+
transition: 'default',
|
|
348
|
+
paddingX: {
|
|
349
|
+
labelBehavior: {
|
|
350
|
+
hide: size(6)
|
|
332
351
|
}
|
|
352
|
+
},
|
|
353
|
+
disableTapHighlight: true
|
|
354
|
+
}, getAllowedOverrides());
|
|
355
|
+
|
|
356
|
+
const icon = style({
|
|
357
|
+
display: 'block',
|
|
358
|
+
flexShrink: 0,
|
|
359
|
+
'--iconPrimary': {
|
|
360
|
+
type: 'fill',
|
|
361
|
+
value: 'currentColor'
|
|
333
362
|
}
|
|
334
|
-
}
|
|
363
|
+
});
|
|
335
364
|
|
|
336
|
-
function
|
|
337
|
-
|
|
338
|
-
let {
|
|
339
|
-
density = 'regular',
|
|
340
|
-
isDisabled,
|
|
341
|
-
disabledKeys,
|
|
342
|
-
orientation = 'horizontal'
|
|
343
|
-
} = props;
|
|
344
|
-
let domRef = useDOMRef(ref);
|
|
365
|
+
export function Tab(props: TabProps) {
|
|
366
|
+
let {density, labelBehavior} = useContext(InternalTabsContext) ?? {};
|
|
345
367
|
|
|
368
|
+
let contentId = useId();
|
|
369
|
+
let ariaLabelledBy = props['aria-labelledby'] || '';
|
|
346
370
|
return (
|
|
347
|
-
<
|
|
371
|
+
<RACTab
|
|
348
372
|
{...props}
|
|
349
|
-
|
|
373
|
+
// @ts-ignore
|
|
374
|
+
originalProps={props}
|
|
375
|
+
aria-labelledby={`${labelBehavior === 'hide' ? contentId : ''} ${ariaLabelledBy}`}
|
|
350
376
|
style={props.UNSAFE_style}
|
|
351
|
-
className={renderProps => (props.UNSAFE_className || '') +
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
{
|
|
357
|
-
|
|
358
|
-
|
|
377
|
+
className={renderProps => (props.UNSAFE_className || '') + tab({...renderProps, density, labelBehavior}, props.styles)}>
|
|
378
|
+
{({
|
|
379
|
+
// @ts-ignore
|
|
380
|
+
isMenu
|
|
381
|
+
}) => {
|
|
382
|
+
if (isMenu) {
|
|
383
|
+
return props.children;
|
|
384
|
+
} else {
|
|
385
|
+
return (
|
|
386
|
+
<Provider
|
|
387
|
+
values={[
|
|
388
|
+
[TextContext, {
|
|
389
|
+
id: contentId,
|
|
390
|
+
styles:
|
|
391
|
+
style({
|
|
392
|
+
order: 1,
|
|
393
|
+
display: {
|
|
394
|
+
labelBehavior: {
|
|
395
|
+
hide: 'none'
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
})({labelBehavior})
|
|
399
|
+
}],
|
|
400
|
+
[IconContext, {
|
|
401
|
+
render: centerBaseline({slot: 'icon', styles: style({order: 0})}),
|
|
402
|
+
styles: icon
|
|
403
|
+
}]
|
|
404
|
+
]}>
|
|
405
|
+
{typeof props.children === 'string' ? <Text>{props.children}</Text> : props.children}
|
|
406
|
+
</Provider>
|
|
407
|
+
);
|
|
408
|
+
}
|
|
409
|
+
}}
|
|
410
|
+
</RACTab>
|
|
359
411
|
);
|
|
360
412
|
}
|
|
361
413
|
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
414
|
+
const tabPanel = style({
|
|
415
|
+
...focusRing(),
|
|
416
|
+
marginTop: 4,
|
|
417
|
+
color: 'gray-800',
|
|
418
|
+
flexGrow: 1,
|
|
419
|
+
flexBasis: '[0%]',
|
|
420
|
+
minHeight: 0,
|
|
421
|
+
minWidth: 0
|
|
422
|
+
}, getAllowedOverrides({height: true}));
|
|
423
|
+
|
|
424
|
+
export function TabPanel(props: TabPanelProps) {
|
|
425
|
+
let {showTabs} = useContext(CollapseContext);
|
|
426
|
+
let {selectedKey} = useContext(InternalTabsContext);
|
|
427
|
+
if (showTabs) {
|
|
428
|
+
return (
|
|
429
|
+
<AriaTabPanel
|
|
430
|
+
{...props}
|
|
431
|
+
style={props.UNSAFE_style}
|
|
432
|
+
className={renderProps => (props.UNSAFE_className ?? '') + tabPanel(renderProps, props.styles)} />
|
|
433
|
+
);
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
if (props.id !== selectedKey) {
|
|
437
|
+
return null;
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
return <CollapsedTabPanel {...props} />;
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
function CollapsedTabPanel(props: TabPanelProps) {
|
|
444
|
+
let {UNSAFE_style, UNSAFE_className = '', ...otherProps} = props;
|
|
445
|
+
let {menuId, valueId} = useContext(CollapseContext);
|
|
446
|
+
let ref = useRef(null);
|
|
447
|
+
let tabIndex = useHasTabbableChild(ref) ? undefined : 0;
|
|
448
|
+
|
|
449
|
+
return (
|
|
450
|
+
<Group
|
|
451
|
+
{...otherProps}
|
|
452
|
+
ref={ref}
|
|
453
|
+
aria-labelledby={menuId + ' ' + valueId}
|
|
454
|
+
tabIndex={tabIndex}
|
|
455
|
+
style={UNSAFE_style}
|
|
456
|
+
className={renderProps => UNSAFE_className + tabPanel(renderProps, props.styles)} />
|
|
457
|
+
);
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
function isAllTabsDisabled<T>(collection: Collection<Node<T>> | undefined, disabledKeys: Set<Key>) {
|
|
461
|
+
let testKey: Key | null = null;
|
|
462
|
+
if (collection && collection.size > 0) {
|
|
463
|
+
testKey = collection.getFirstKey();
|
|
464
|
+
|
|
465
|
+
let index = 0;
|
|
466
|
+
while (testKey && index < collection.size) {
|
|
467
|
+
// We have to check if the item in the collection has a key in disabledKeys or has the isDisabled prop set directly on it
|
|
468
|
+
if (!disabledKeys.has(testKey) && !collection.getItem(testKey)?.props?.isDisabled) {
|
|
469
|
+
return false;
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
testKey = collection.getKeyAfter(testKey);
|
|
473
|
+
index++;
|
|
474
|
+
}
|
|
475
|
+
return true;
|
|
476
|
+
}
|
|
477
|
+
return false;
|
|
478
|
+
}
|
|
479
|
+
|
|
480
|
+
let HiddenTabs = function (props: {
|
|
481
|
+
listRef: RefObject<HTMLDivElement | null>,
|
|
482
|
+
items: Array<Node<any>>,
|
|
483
|
+
size?: string,
|
|
484
|
+
density?: 'compact' | 'regular'
|
|
485
|
+
}) {
|
|
486
|
+
let {listRef, items, size, density} = props;
|
|
487
|
+
|
|
488
|
+
return (
|
|
489
|
+
<div
|
|
490
|
+
// @ts-ignore
|
|
491
|
+
inert={inertValue(true)}
|
|
492
|
+
ref={listRef}
|
|
493
|
+
className={style({
|
|
494
|
+
display: '[inherit]',
|
|
495
|
+
flexDirection: '[inherit]',
|
|
496
|
+
gap: '[inherit]',
|
|
497
|
+
flexWrap: '[inherit]',
|
|
498
|
+
position: 'absolute',
|
|
499
|
+
inset: 0,
|
|
500
|
+
visibility: 'hidden',
|
|
501
|
+
overflow: 'hidden',
|
|
502
|
+
opacity: 0
|
|
503
|
+
})}>
|
|
504
|
+
{items.map((item) => {
|
|
505
|
+
// pull off individual props as an allow list, don't want refs or other props getting through
|
|
506
|
+
return (
|
|
507
|
+
<div
|
|
508
|
+
data-hidden-tab
|
|
509
|
+
style={item.props.UNSAFE_style}
|
|
510
|
+
key={item.key}
|
|
511
|
+
className={item.props.className({size, density})}>
|
|
512
|
+
{item.props.children({size, density})}
|
|
513
|
+
</div>
|
|
514
|
+
);
|
|
515
|
+
})}
|
|
516
|
+
</div>
|
|
517
|
+
);
|
|
518
|
+
};
|
|
519
|
+
|
|
520
|
+
let TabsMenu = (props: {valueId: string, items: Array<Node<any>>, onSelectionChange: TabsProps['onSelectionChange']} & Omit<TabsProps, 'children'>) => {
|
|
521
|
+
let {id, items, 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledBy, valueId} = props;
|
|
522
|
+
let {density, onSelectionChange, selectedKey, isDisabled, disabledKeys, labelBehavior} = useContext(InternalTabsContext);
|
|
523
|
+
let state = useContext(TabListStateContext);
|
|
524
|
+
let allKeysDisabled = useMemo(() => {
|
|
525
|
+
return isAllTabsDisabled(state?.collection, disabledKeys ? new Set(disabledKeys) : new Set());
|
|
526
|
+
}, [state?.collection, disabledKeys]);
|
|
527
|
+
let labelProps = useLabels({
|
|
528
|
+
id,
|
|
529
|
+
'aria-label': ariaLabel,
|
|
530
|
+
'aria-labelledby': ariaLabelledBy
|
|
531
|
+
});
|
|
532
|
+
|
|
533
|
+
return (
|
|
534
|
+
<div
|
|
535
|
+
className={style({
|
|
536
|
+
display: 'flex',
|
|
537
|
+
flexShrink: 0,
|
|
538
|
+
alignItems: 'center',
|
|
539
|
+
height: {
|
|
540
|
+
density: {
|
|
541
|
+
compact: 32,
|
|
542
|
+
regular: 48
|
|
543
|
+
}
|
|
544
|
+
}})({density})}>
|
|
545
|
+
<Picker
|
|
546
|
+
id={id}
|
|
547
|
+
valueId={valueId}
|
|
548
|
+
{...labelProps}
|
|
549
|
+
aria-describedby={props['aria-describedby']}
|
|
550
|
+
aria-details={props['aria-details']}
|
|
551
|
+
isDisabled={isDisabled || allKeysDisabled}
|
|
552
|
+
density={density!}
|
|
553
|
+
labelBehavior={labelBehavior}
|
|
554
|
+
items={items}
|
|
555
|
+
disabledKeys={disabledKeys}
|
|
556
|
+
selectedKey={selectedKey}
|
|
557
|
+
onSelectionChange={onSelectionChange}>
|
|
558
|
+
{(item: Node<any>) => {
|
|
559
|
+
return (
|
|
560
|
+
<PickerItem
|
|
561
|
+
{...item.props.originalProps}
|
|
562
|
+
isDisabled={isDisabled || allKeysDisabled}
|
|
563
|
+
key={item.key}>
|
|
564
|
+
{item.props.children({density, isMenu: true})}
|
|
565
|
+
</PickerItem>
|
|
566
|
+
);
|
|
567
|
+
}}
|
|
568
|
+
</Picker>
|
|
569
|
+
</div>
|
|
570
|
+
);
|
|
571
|
+
};
|
|
572
|
+
|
|
573
|
+
let CollapsingTabs = ({collection, containerRef, ...props}: {collection: Collection<Node<unknown>>, containerRef: any} & TabsProps) => {
|
|
574
|
+
let {density = 'regular', orientation = 'horizontal', labelBehavior = 'show', onSelectionChange} = props;
|
|
575
|
+
let [showItems, _setShowItems] = useState(true);
|
|
576
|
+
showItems = orientation === 'vertical' ? true : showItems;
|
|
577
|
+
let setShowItems = useCallback((value: boolean) => {
|
|
578
|
+
if (orientation === 'vertical') {
|
|
579
|
+
// if orientation is vertical, we always show the items
|
|
580
|
+
_setShowItems(true);
|
|
581
|
+
} else {
|
|
582
|
+
_setShowItems(value);
|
|
583
|
+
}
|
|
584
|
+
}, [orientation]);
|
|
585
|
+
|
|
586
|
+
let {direction} = useLocale();
|
|
587
|
+
|
|
588
|
+
let children = useMemo(() => [...collection], [collection]);
|
|
589
|
+
|
|
590
|
+
let listRef = useRef<HTMLDivElement | null>(null);
|
|
591
|
+
let updateOverflow = useEffectEvent(() => {
|
|
592
|
+
if (orientation === 'vertical' || !listRef.current || !containerRef?.current) {
|
|
593
|
+
return;
|
|
594
|
+
}
|
|
595
|
+
let container = listRef.current;
|
|
596
|
+
let containerRect = container.getBoundingClientRect();
|
|
597
|
+
let tabs = container.querySelectorAll('[data-hidden-tab]');
|
|
598
|
+
let lastTab = tabs[tabs.length - 1];
|
|
599
|
+
let lastTabRect = lastTab.getBoundingClientRect();
|
|
600
|
+
if (direction === 'ltr') {
|
|
601
|
+
setShowItems?.(lastTabRect.right <= containerRect.right);
|
|
602
|
+
} else {
|
|
603
|
+
setShowItems?.(lastTabRect.left >= containerRect.left);
|
|
604
|
+
}
|
|
605
|
+
});
|
|
606
|
+
|
|
607
|
+
useResizeObserver({ref: containerRef, onResize: updateOverflow});
|
|
608
|
+
|
|
609
|
+
useLayoutEffect(() => {
|
|
610
|
+
if (collection.size > 0) {
|
|
611
|
+
queueMicrotask(updateOverflow);
|
|
612
|
+
}
|
|
613
|
+
}, [collection.size, updateOverflow]);
|
|
614
|
+
|
|
615
|
+
// start with null so that the first render won't have a flicker
|
|
616
|
+
let prevOrientation = useRef<Orientation | null>(null);
|
|
617
|
+
useLayoutEffect(() => {
|
|
618
|
+
if (collection.size > 0 && prevOrientation.current !== orientation) {
|
|
619
|
+
updateOverflow();
|
|
620
|
+
}
|
|
621
|
+
prevOrientation.current = orientation;
|
|
622
|
+
}, [collection.size, updateOverflow, orientation]);
|
|
623
|
+
|
|
624
|
+
useEffect(() => {
|
|
625
|
+
// Recalculate visible tags when fonts are loaded.
|
|
626
|
+
document.fonts?.ready.then(() => updateOverflow());
|
|
627
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
628
|
+
}, []);
|
|
629
|
+
|
|
630
|
+
let menuId = useId();
|
|
631
|
+
let valueId = useId();
|
|
632
|
+
|
|
633
|
+
let contents: ReactNode;
|
|
634
|
+
if (showItems) {
|
|
635
|
+
contents = (
|
|
636
|
+
<RACTabs
|
|
637
|
+
{...props}
|
|
638
|
+
style={{display: 'contents'}}>
|
|
639
|
+
{props.children}
|
|
640
|
+
</RACTabs>
|
|
641
|
+
);
|
|
642
|
+
} else {
|
|
643
|
+
contents = (
|
|
644
|
+
<>
|
|
645
|
+
<TabsMenu
|
|
646
|
+
id={menuId}
|
|
647
|
+
valueId={valueId}
|
|
648
|
+
items={children}
|
|
649
|
+
onSelectionChange={onSelectionChange}
|
|
650
|
+
aria-label={props['aria-label']}
|
|
651
|
+
aria-describedby={props['aria-labelledby']} />
|
|
652
|
+
<CollapseContext.Provider value={{showTabs: false, menuId, valueId}}>
|
|
653
|
+
{props.children}
|
|
654
|
+
</CollapseContext.Provider>
|
|
655
|
+
</>
|
|
656
|
+
);
|
|
657
|
+
}
|
|
658
|
+
|
|
659
|
+
return (
|
|
660
|
+
<div style={props.UNSAFE_style} className={(props.UNSAFE_className || '') + tabs({orientation}, props.styles)} ref={containerRef}>
|
|
661
|
+
<div className={tablist({orientation, labelBehavior, density})}>
|
|
662
|
+
<HiddenTabs items={children} density={density} listRef={listRef} />
|
|
663
|
+
</div>
|
|
664
|
+
<CollapseContext.Provider value={{showTabs: true, menuId, valueId}}>
|
|
665
|
+
{contents}
|
|
666
|
+
</CollapseContext.Provider>
|
|
667
|
+
</div>
|
|
668
|
+
);
|
|
669
|
+
};
|