@cssui/react 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapter-react/components/breadcrumb/Breadcrumb.d.ts +8 -0
- package/dist/adapter-react/components/breadcrumb/Breadcrumb.d.ts.map +1 -0
- package/dist/adapter-react/components/breadcrumb/Breadcrumb.js +170 -0
- package/dist/adapter-react/components/breadcrumb/Breadcrumb.js.map +1 -0
- package/dist/adapter-react/components/breadcrumb/index.d.ts +2 -0
- package/dist/adapter-react/components/breadcrumb/index.d.ts.map +1 -0
- package/dist/adapter-react/components/button/Button.d.ts +10 -0
- package/dist/adapter-react/components/button/Button.d.ts.map +1 -0
- package/dist/adapter-react/components/button/Button.js +49 -0
- package/dist/adapter-react/components/button/Button.js.map +1 -0
- package/dist/adapter-react/components/button/index.d.ts +3 -0
- package/dist/adapter-react/components/button/index.d.ts.map +1 -0
- package/dist/adapter-react/components/carousel/Carousel.d.ts +12 -0
- package/dist/adapter-react/components/carousel/Carousel.d.ts.map +1 -0
- package/dist/adapter-react/components/carousel/Carousel.js +155 -0
- package/dist/adapter-react/components/carousel/Carousel.js.map +1 -0
- package/dist/adapter-react/components/carousel/index.d.ts +3 -0
- package/dist/adapter-react/components/carousel/index.d.ts.map +1 -0
- package/dist/adapter-react/components/checkbox/Checkbox.d.ts +11 -0
- package/dist/adapter-react/components/checkbox/Checkbox.d.ts.map +1 -0
- package/dist/adapter-react/components/checkbox/Checkbox.js +69 -0
- package/dist/adapter-react/components/checkbox/Checkbox.js.map +1 -0
- package/dist/adapter-react/components/checkbox/CheckboxGroup.d.ts +22 -0
- package/dist/adapter-react/components/checkbox/CheckboxGroup.d.ts.map +1 -0
- package/dist/adapter-react/components/checkbox/CheckboxGroup.js +86 -0
- package/dist/adapter-react/components/checkbox/CheckboxGroup.js.map +1 -0
- package/dist/adapter-react/components/checkbox/index.d.ts +5 -0
- package/dist/adapter-react/components/checkbox/index.d.ts.map +1 -0
- package/dist/adapter-react/components/date-picker/DatePicker.d.ts +8 -0
- package/dist/adapter-react/components/date-picker/DatePicker.d.ts.map +1 -0
- package/dist/adapter-react/components/date-picker/DatePicker.js +438 -0
- package/dist/adapter-react/components/date-picker/DatePicker.js.map +1 -0
- package/dist/adapter-react/components/date-picker/index.d.ts +2 -0
- package/dist/adapter-react/components/date-picker/index.d.ts.map +1 -0
- package/dist/adapter-react/components/divider/Divider.d.ts +13 -0
- package/dist/adapter-react/components/divider/Divider.d.ts.map +1 -0
- package/dist/adapter-react/components/divider/Divider.js +31 -0
- package/dist/adapter-react/components/divider/Divider.js.map +1 -0
- package/dist/adapter-react/components/divider/index.d.ts +3 -0
- package/dist/adapter-react/components/divider/index.d.ts.map +1 -0
- package/dist/adapter-react/components/float-button/FloatButton.d.ts +17 -0
- package/dist/adapter-react/components/float-button/FloatButton.d.ts.map +1 -0
- package/dist/adapter-react/components/float-button/FloatButton.js +97 -0
- package/dist/adapter-react/components/float-button/FloatButton.js.map +1 -0
- package/dist/adapter-react/components/float-button/FloatButtonGroup.d.ts +9 -0
- package/dist/adapter-react/components/float-button/FloatButtonGroup.d.ts.map +1 -0
- package/dist/adapter-react/components/float-button/FloatButtonGroup.js +61 -0
- package/dist/adapter-react/components/float-button/FloatButtonGroup.js.map +1 -0
- package/dist/adapter-react/components/float-button/context.d.ts +3 -0
- package/dist/adapter-react/components/float-button/context.d.ts.map +1 -0
- package/dist/adapter-react/components/float-button/context.js +6 -0
- package/dist/adapter-react/components/float-button/context.js.map +1 -0
- package/dist/adapter-react/components/float-button/index.d.ts +5 -0
- package/dist/adapter-react/components/float-button/index.d.ts.map +1 -0
- package/dist/adapter-react/components/form/Form.d.ts +13 -0
- package/dist/adapter-react/components/form/Form.d.ts.map +1 -0
- package/dist/adapter-react/components/form/Form.js +355 -0
- package/dist/adapter-react/components/form/Form.js.map +1 -0
- package/dist/adapter-react/components/form/index.d.ts +4 -0
- package/dist/adapter-react/components/form/index.d.ts.map +1 -0
- package/dist/adapter-react/components/grid/Grid.d.ts +8 -0
- package/dist/adapter-react/components/grid/Grid.d.ts.map +1 -0
- package/dist/adapter-react/components/grid/Grid.js +51 -0
- package/dist/adapter-react/components/grid/Grid.js.map +1 -0
- package/dist/adapter-react/components/grid/GridItem.d.ts +8 -0
- package/dist/adapter-react/components/grid/GridItem.d.ts.map +1 -0
- package/dist/adapter-react/components/grid/GridItem.js +31 -0
- package/dist/adapter-react/components/grid/GridItem.js.map +1 -0
- package/dist/adapter-react/components/grid/index.d.ts +6 -0
- package/dist/adapter-react/components/grid/index.d.ts.map +1 -0
- package/dist/adapter-react/components/icon/Icon.d.ts +18 -0
- package/dist/adapter-react/components/icon/Icon.d.ts.map +1 -0
- package/dist/adapter-react/components/icon/Icon.js +51 -0
- package/dist/adapter-react/components/icon/Icon.js.map +1 -0
- package/dist/adapter-react/components/icon/index.d.ts +3 -0
- package/dist/adapter-react/components/icon/index.d.ts.map +1 -0
- package/dist/adapter-react/components/input/Input.d.ts +10 -0
- package/dist/adapter-react/components/input/Input.d.ts.map +1 -0
- package/dist/adapter-react/components/input/Input.js +79 -0
- package/dist/adapter-react/components/input/Input.js.map +1 -0
- package/dist/adapter-react/components/input/index.d.ts +3 -0
- package/dist/adapter-react/components/input/index.d.ts.map +1 -0
- package/dist/adapter-react/components/input-bar/InputBar.d.ts +9 -0
- package/dist/adapter-react/components/input-bar/InputBar.d.ts.map +1 -0
- package/dist/adapter-react/components/input-bar/InputBar.js +136 -0
- package/dist/adapter-react/components/input-bar/InputBar.js.map +1 -0
- package/dist/adapter-react/components/input-bar/index.d.ts +3 -0
- package/dist/adapter-react/components/input-bar/index.d.ts.map +1 -0
- package/dist/adapter-react/components/input-number/InputNumber.d.ts +9 -0
- package/dist/adapter-react/components/input-number/InputNumber.d.ts.map +1 -0
- package/dist/adapter-react/components/input-number/InputNumber.js +135 -0
- package/dist/adapter-react/components/input-number/InputNumber.js.map +1 -0
- package/dist/adapter-react/components/input-number/index.d.ts +2 -0
- package/dist/adapter-react/components/input-number/index.d.ts.map +1 -0
- package/dist/adapter-react/components/modal/Modal.d.ts +18 -0
- package/dist/adapter-react/components/modal/Modal.d.ts.map +1 -0
- package/dist/adapter-react/components/modal/Modal.js +108 -0
- package/dist/adapter-react/components/modal/Modal.js.map +1 -0
- package/dist/adapter-react/components/modal/index.d.ts +6 -0
- package/dist/adapter-react/components/modal/index.d.ts.map +1 -0
- package/dist/adapter-react/components/nav-menu/NavMenu.d.ts +11 -0
- package/dist/adapter-react/components/nav-menu/NavMenu.d.ts.map +1 -0
- package/dist/adapter-react/components/nav-menu/NavMenu.js +197 -0
- package/dist/adapter-react/components/nav-menu/NavMenu.js.map +1 -0
- package/dist/adapter-react/components/nav-menu/index.d.ts +3 -0
- package/dist/adapter-react/components/nav-menu/index.d.ts.map +1 -0
- package/dist/adapter-react/components/pagination/Pagination.d.ts +11 -0
- package/dist/adapter-react/components/pagination/Pagination.d.ts.map +1 -0
- package/dist/adapter-react/components/pagination/Pagination.js +128 -0
- package/dist/adapter-react/components/pagination/Pagination.js.map +1 -0
- package/dist/adapter-react/components/pagination/index.d.ts +3 -0
- package/dist/adapter-react/components/pagination/index.d.ts.map +1 -0
- package/dist/adapter-react/components/radio/Radio.d.ts +12 -0
- package/dist/adapter-react/components/radio/Radio.d.ts.map +1 -0
- package/dist/adapter-react/components/radio/Radio.js +83 -0
- package/dist/adapter-react/components/radio/Radio.js.map +1 -0
- package/dist/adapter-react/components/radio/RadioGroup.d.ts +24 -0
- package/dist/adapter-react/components/radio/RadioGroup.d.ts.map +1 -0
- package/dist/adapter-react/components/radio/RadioGroup.js +97 -0
- package/dist/adapter-react/components/radio/RadioGroup.js.map +1 -0
- package/dist/adapter-react/components/radio/index.d.ts +7 -0
- package/dist/adapter-react/components/radio/index.d.ts.map +1 -0
- package/dist/adapter-react/components/select/Select.d.ts +9 -0
- package/dist/adapter-react/components/select/Select.d.ts.map +1 -0
- package/dist/adapter-react/components/select/Select.js +189 -0
- package/dist/adapter-react/components/select/Select.js.map +1 -0
- package/dist/adapter-react/components/select/index.d.ts +3 -0
- package/dist/adapter-react/components/select/index.d.ts.map +1 -0
- package/dist/adapter-react/components/sidebar/Sidebar.d.ts +13 -0
- package/dist/adapter-react/components/sidebar/Sidebar.d.ts.map +1 -0
- package/dist/adapter-react/components/sidebar/Sidebar.js +242 -0
- package/dist/adapter-react/components/sidebar/Sidebar.js.map +1 -0
- package/dist/adapter-react/components/sidebar/index.d.ts +3 -0
- package/dist/adapter-react/components/sidebar/index.d.ts.map +1 -0
- package/dist/adapter-react/components/slider/Slider.d.ts +9 -0
- package/dist/adapter-react/components/slider/Slider.d.ts.map +1 -0
- package/dist/adapter-react/components/slider/Slider.js +150 -0
- package/dist/adapter-react/components/slider/Slider.js.map +1 -0
- package/dist/adapter-react/components/slider/index.d.ts +3 -0
- package/dist/adapter-react/components/slider/index.d.ts.map +1 -0
- package/dist/adapter-react/components/steps/Steps.d.ts +11 -0
- package/dist/adapter-react/components/steps/Steps.d.ts.map +1 -0
- package/dist/adapter-react/components/steps/Steps.js +172 -0
- package/dist/adapter-react/components/steps/Steps.js.map +1 -0
- package/dist/adapter-react/components/steps/index.d.ts +3 -0
- package/dist/adapter-react/components/steps/index.d.ts.map +1 -0
- package/dist/adapter-react/components/switch/Switch.d.ts +11 -0
- package/dist/adapter-react/components/switch/Switch.d.ts.map +1 -0
- package/dist/adapter-react/components/switch/Switch.js +98 -0
- package/dist/adapter-react/components/switch/Switch.js.map +1 -0
- package/dist/adapter-react/components/switch/index.d.ts +2 -0
- package/dist/adapter-react/components/switch/index.d.ts.map +1 -0
- package/dist/adapter-react/components/table/Table.d.ts +15 -0
- package/dist/adapter-react/components/table/Table.d.ts.map +1 -0
- package/dist/adapter-react/components/table/Table.js +211 -0
- package/dist/adapter-react/components/table/Table.js.map +1 -0
- package/dist/adapter-react/components/table/index.d.ts +3 -0
- package/dist/adapter-react/components/table/index.d.ts.map +1 -0
- package/dist/adapter-react/components/tabs/Tabs.d.ts +9 -0
- package/dist/adapter-react/components/tabs/Tabs.d.ts.map +1 -0
- package/dist/adapter-react/components/tabs/Tabs.js +62 -0
- package/dist/adapter-react/components/tabs/Tabs.js.map +1 -0
- package/dist/adapter-react/components/tabs/index.d.ts +2 -0
- package/dist/adapter-react/components/tabs/index.d.ts.map +1 -0
- package/dist/adapter-react/components/time-picker/TimePicker.d.ts +9 -0
- package/dist/adapter-react/components/time-picker/TimePicker.d.ts.map +1 -0
- package/dist/adapter-react/components/time-picker/TimePicker.js +271 -0
- package/dist/adapter-react/components/time-picker/TimePicker.js.map +1 -0
- package/dist/adapter-react/components/time-picker/index.d.ts +2 -0
- package/dist/adapter-react/components/time-picker/index.d.ts.map +1 -0
- package/dist/adapter-react/components/toast/Toast.d.ts +25 -0
- package/dist/adapter-react/components/toast/Toast.d.ts.map +1 -0
- package/dist/adapter-react/components/toast/Toast.js +223 -0
- package/dist/adapter-react/components/toast/Toast.js.map +1 -0
- package/dist/adapter-react/components/toast/index.d.ts +3 -0
- package/dist/adapter-react/components/toast/index.d.ts.map +1 -0
- package/dist/adapter-react/components/toolbars/Toolbar.d.ts +11 -0
- package/dist/adapter-react/components/toolbars/Toolbar.d.ts.map +1 -0
- package/dist/adapter-react/components/toolbars/Toolbar.js +66 -0
- package/dist/adapter-react/components/toolbars/Toolbar.js.map +1 -0
- package/dist/adapter-react/components/toolbars/index.d.ts +3 -0
- package/dist/adapter-react/components/toolbars/index.d.ts.map +1 -0
- package/dist/adapter-react/components/tooltip/Tooltip.d.ts +9 -0
- package/dist/adapter-react/components/tooltip/Tooltip.d.ts.map +1 -0
- package/dist/adapter-react/components/tooltip/Tooltip.js +141 -0
- package/dist/adapter-react/components/tooltip/Tooltip.js.map +1 -0
- package/dist/adapter-react/components/tooltip/index.d.ts +2 -0
- package/dist/adapter-react/components/tooltip/index.d.ts.map +1 -0
- package/dist/adapter-react/hooks/index.d.ts +12 -0
- package/dist/adapter-react/hooks/index.d.ts.map +1 -0
- package/dist/adapter-react/hooks/index.js +43 -0
- package/dist/adapter-react/hooks/index.js.map +1 -0
- package/dist/adapter-react/hooks/useControlled.d.ts +7 -0
- package/dist/adapter-react/hooks/useControlled.d.ts.map +1 -0
- package/dist/adapter-react/hooks/useControlled.js +21 -0
- package/dist/adapter-react/hooks/useControlled.js.map +1 -0
- package/dist/adapter-react/hooks/useEvent.d.ts +2 -0
- package/dist/adapter-react/hooks/useEvent.d.ts.map +1 -0
- package/dist/adapter-react/hooks/useMergedState.d.ts +4 -0
- package/dist/adapter-react/hooks/useMergedState.d.ts.map +1 -0
- package/dist/adapter-react/hooks/useMergedState.js +15 -0
- package/dist/adapter-react/hooks/useMergedState.js.map +1 -0
- package/dist/adapter-react/index.d.ts +37 -0
- package/dist/adapter-react/index.d.ts.map +1 -0
- package/dist/adapter-react/runtime/createComponent.d.ts +3 -0
- package/dist/adapter-react/runtime/createComponent.d.ts.map +1 -0
- package/dist/adapter-react/runtime/createComponent.js +6 -0
- package/dist/adapter-react/runtime/createComponent.js.map +1 -0
- package/dist/adapter-react/runtime/createProps.d.ts +2 -0
- package/dist/adapter-react/runtime/createProps.d.ts.map +1 -0
- package/dist/adapter-react/runtime/forwardRef.d.ts +3 -0
- package/dist/adapter-react/runtime/forwardRef.d.ts.map +1 -0
- package/dist/adapter-react/runtime/forwardRef.js +6 -0
- package/dist/adapter-react/runtime/forwardRef.js.map +1 -0
- package/dist/adapter-react/runtime/index.d.ts +5 -0
- package/dist/adapter-react/runtime/index.d.ts.map +1 -0
- package/dist/adapter-react/runtime/withInstall.d.ts +3 -0
- package/dist/adapter-react/runtime/withInstall.d.ts.map +1 -0
- package/dist/adapter-react/runtime/withInstall.js +6 -0
- package/dist/adapter-react/runtime/withInstall.js.map +1 -0
- package/dist/adapter-react/style/index.d.ts +2 -0
- package/dist/adapter-react/style/index.d.ts.map +1 -0
- package/dist/adapter-react/style/injectStyle.d.ts +2 -0
- package/dist/adapter-react/style/injectStyle.d.ts.map +1 -0
- package/dist/adapter-react/types.d.ts +6 -0
- package/dist/adapter-react/types.d.ts.map +1 -0
- package/dist/breadcrumb/index.d.ts +2 -2
- package/dist/breadcrumb/index.js +34 -1
- package/dist/breadcrumb/index.js.map +1 -0
- package/dist/breadcrumb/style.css +219 -1
- package/dist/button/index.d.ts +2 -2
- package/dist/button/index.js +34 -1
- package/dist/button/index.js.map +1 -0
- package/dist/button/style.css +151 -1
- package/dist/carousel/index.d.ts +2 -2
- package/dist/carousel/index.js +34 -1
- package/dist/carousel/index.js.map +1 -0
- package/dist/carousel/style.css +196 -1
- package/dist/checkbox/index.d.ts +3 -3
- package/dist/checkbox/index.js +34 -2
- package/dist/checkbox/index.js.map +1 -0
- package/dist/checkbox/style.css +135 -1
- package/dist/components/breadcrumb/index.d.ts +61 -0
- package/dist/components/breadcrumb/index.d.ts.map +1 -0
- package/dist/components/breadcrumb/index.js +49 -0
- package/dist/components/breadcrumb/index.js.map +1 -0
- package/dist/components/breadcrumb/style.css +219 -0
- package/dist/components/button/index.d.ts +15 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/index.js +11 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/button/style.css +151 -0
- package/dist/components/carousel/index.d.ts +38 -0
- package/dist/components/carousel/index.d.ts.map +1 -0
- package/dist/components/carousel/index.js +33 -0
- package/dist/components/carousel/index.js.map +1 -0
- package/dist/components/carousel/style.css +196 -0
- package/dist/components/checkbox/index.d.ts +36 -0
- package/dist/components/checkbox/index.d.ts.map +1 -0
- package/dist/components/checkbox/index.js +34 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/checkbox/style.css +135 -0
- package/dist/components/date-picker/index.d.ts +53 -0
- package/dist/components/date-picker/index.d.ts.map +1 -0
- package/dist/components/date-picker/index.js +105 -0
- package/dist/components/date-picker/index.js.map +1 -0
- package/dist/components/date-picker/style.css +491 -0
- package/dist/components/divider/index.d.ts +12 -0
- package/dist/components/divider/index.d.ts.map +1 -0
- package/dist/components/divider/index.js +23 -0
- package/dist/components/divider/index.js.map +1 -0
- package/dist/components/divider/style.css +100 -0
- package/dist/components/float-button/index.d.ts +32 -0
- package/dist/components/float-button/index.d.ts.map +1 -0
- package/dist/components/float-button/index.js +23 -0
- package/dist/components/float-button/index.js.map +1 -0
- package/dist/components/float-button/style.css +176 -0
- package/dist/components/form/index.d.ts +79 -0
- package/dist/components/form/index.d.ts.map +1 -0
- package/dist/components/form/index.js +144 -0
- package/dist/components/form/index.js.map +1 -0
- package/dist/components/form/style.css +79 -0
- package/dist/components/grid/index.d.ts +34 -0
- package/dist/components/grid/index.d.ts.map +1 -0
- package/dist/components/grid/index.js +109 -0
- package/dist/components/grid/index.js.map +1 -0
- package/dist/components/grid/style.css +189 -0
- package/dist/components/icon/index.d.ts +35 -0
- package/dist/components/icon/index.d.ts.map +1 -0
- package/dist/components/icon/index.js +16 -0
- package/dist/components/icon/index.js.map +1 -0
- package/dist/components/icon/style.css +28 -0
- package/dist/components/input/index.d.ts +29 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/index.js +19 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/input/style.css +110 -0
- package/dist/components/input-bar/index.d.ts +31 -0
- package/dist/components/input-bar/index.d.ts.map +1 -0
- package/dist/components/input-bar/index.js +18 -0
- package/dist/components/input-bar/index.js.map +1 -0
- package/dist/components/input-bar/style.css +180 -0
- package/dist/components/input-number/index.d.ts +28 -0
- package/dist/components/input-number/index.d.ts.map +1 -0
- package/dist/components/input-number/index.js +21 -0
- package/dist/components/input-number/index.js.map +1 -0
- package/dist/components/input-number/style.css +109 -0
- package/dist/components/modal/index.d.ts +17 -0
- package/dist/components/modal/index.d.ts.map +1 -0
- package/dist/components/modal/index.js +10 -0
- package/dist/components/modal/index.js.map +1 -0
- package/dist/components/modal/style.css +150 -0
- package/dist/components/nav-menu/index.d.ts +35 -0
- package/dist/components/nav-menu/index.d.ts.map +1 -0
- package/dist/components/nav-menu/index.js +47 -0
- package/dist/components/nav-menu/index.js.map +1 -0
- package/dist/components/nav-menu/style.css +241 -0
- package/dist/components/pagination/index.d.ts +32 -0
- package/dist/components/pagination/index.d.ts.map +1 -0
- package/dist/components/pagination/index.js +35 -0
- package/dist/components/pagination/index.js.map +1 -0
- package/dist/components/pagination/style.css +150 -0
- package/dist/components/radio/index.d.ts +45 -0
- package/dist/components/radio/index.d.ts.map +1 -0
- package/dist/components/radio/index.js +48 -0
- package/dist/components/radio/index.js.map +1 -0
- package/dist/components/radio/style.css +294 -0
- package/dist/components/select/index.d.ts +30 -0
- package/dist/components/select/index.d.ts.map +1 -0
- package/dist/components/select/index.js +16 -0
- package/dist/components/select/index.js.map +1 -0
- package/dist/components/select/style.css +255 -0
- package/dist/components/sidebar/index.d.ts +19 -0
- package/dist/components/sidebar/index.d.ts.map +1 -0
- package/dist/components/sidebar/index.js +23 -0
- package/dist/components/sidebar/index.js.map +1 -0
- package/dist/components/sidebar/style.css +270 -0
- package/dist/components/slider/index.d.ts +29 -0
- package/dist/components/slider/index.d.ts.map +1 -0
- package/dist/components/slider/index.js +24 -0
- package/dist/components/slider/index.js.map +1 -0
- package/dist/components/slider/style.css +206 -0
- package/dist/components/src/index.d.ts +28 -0
- package/dist/components/src/index.d.ts.map +1 -0
- package/dist/components/steps/index.d.ts +41 -0
- package/dist/components/steps/index.d.ts.map +1 -0
- package/dist/components/steps/index.js +32 -0
- package/dist/components/steps/index.js.map +1 -0
- package/dist/components/steps/style.css +286 -0
- package/dist/components/switch/index.d.ts +16 -0
- package/dist/components/switch/index.d.ts.map +1 -0
- package/dist/components/switch/index.js +17 -0
- package/dist/components/switch/index.js.map +1 -0
- package/dist/components/switch/style.css +160 -0
- package/dist/components/table/index.d.ts +49 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/index.js +74 -0
- package/dist/components/table/index.js.map +1 -0
- package/dist/components/table/style.css +131 -0
- package/dist/components/tabs/index.d.ts +34 -0
- package/dist/components/tabs/index.d.ts.map +1 -0
- package/dist/components/tabs/index.js +21 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/tabs/style.css +146 -0
- package/dist/components/time-picker/index.d.ts +56 -0
- package/dist/components/time-picker/index.d.ts.map +1 -0
- package/dist/components/time-picker/index.js +84 -0
- package/dist/components/time-picker/index.js.map +1 -0
- package/dist/components/time-picker/style.css +258 -0
- package/dist/components/toast/index.d.ts +41 -0
- package/dist/components/toast/index.d.ts.map +1 -0
- package/dist/components/toast/index.js +24 -0
- package/dist/components/toast/index.js.map +1 -0
- package/dist/components/toast/style.css +117 -0
- package/dist/components/toolbars/index.d.ts +31 -0
- package/dist/components/toolbars/index.d.ts.map +1 -0
- package/dist/components/toolbars/index.js +32 -0
- package/dist/components/toolbars/index.js.map +1 -0
- package/dist/components/toolbars/style.css +220 -0
- package/dist/components/tooltip/index.d.ts +31 -0
- package/dist/components/tooltip/index.d.ts.map +1 -0
- package/dist/components/tooltip/index.js +17 -0
- package/dist/components/tooltip/index.js.map +1 -0
- package/dist/components/tooltip/style.css +138 -0
- package/dist/date-picker/index.d.ts +2 -2
- package/dist/date-picker/index.js +34 -1
- package/dist/date-picker/index.js.map +1 -0
- package/dist/date-picker/style.css +491 -1
- package/dist/divider/index.d.ts +2 -2
- package/dist/divider/index.js +34 -1
- package/dist/divider/index.js.map +1 -0
- package/dist/divider/style.css +100 -1
- package/dist/float-button/index.d.ts +2 -2
- package/dist/float-button/index.js +34 -1
- package/dist/float-button/index.js.map +1 -0
- package/dist/float-button/style.css +176 -1
- package/dist/form/index.d.ts +2 -2
- package/dist/form/index.js +34 -1
- package/dist/form/index.js.map +1 -0
- package/dist/form/style.css +79 -1
- package/dist/grid/index.d.ts +2 -2
- package/dist/grid/index.js +34 -1
- package/dist/grid/index.js.map +1 -0
- package/dist/grid/style.css +189 -1
- package/dist/icon/index.d.ts +2 -2
- package/dist/icon/index.js +34 -1
- package/dist/icon/index.js.map +1 -0
- package/dist/icon/style.css +28 -1
- package/dist/icons/react/add_circle.js +26 -0
- package/dist/icons/react/add_circle.js.map +1 -0
- package/dist/icons/react/arrow_back.js +26 -0
- package/dist/icons/react/arrow_back.js.map +1 -0
- package/dist/icons/react/arrow_drop_down.js +26 -0
- package/dist/icons/react/arrow_drop_down.js.map +1 -0
- package/dist/icons/react/arrow_forward.js +26 -0
- package/dist/icons/react/arrow_forward.js.map +1 -0
- package/dist/icons/react/calendar_month.js +26 -0
- package/dist/icons/react/calendar_month.js.map +1 -0
- package/dist/icons/react/check.js +26 -0
- package/dist/icons/react/check.js.map +1 -0
- package/dist/icons/react/chevron_right.js +26 -0
- package/dist/icons/react/chevron_right.js.map +1 -0
- package/dist/icons/react/close.js +26 -0
- package/dist/icons/react/close.js.map +1 -0
- package/dist/icons/react/config.js +26 -0
- package/dist/icons/react/config.js.map +1 -0
- package/dist/icons/react/dark_mode.js +26 -0
- package/dist/icons/react/dark_mode.js.map +1 -0
- package/dist/icons/react/do_not_disturb_on.js +26 -0
- package/dist/icons/react/do_not_disturb_on.js.map +1 -0
- package/dist/icons/react/error.js +26 -0
- package/dist/icons/react/error.js.map +1 -0
- package/dist/icons/react/home.js +29 -0
- package/dist/icons/react/home.js.map +1 -0
- package/dist/icons/react/index.js +27 -0
- package/dist/icons/react/index.js.map +1 -0
- package/dist/icons/react/info.js +26 -0
- package/dist/icons/react/info.js.map +1 -0
- package/dist/icons/react/logo_Block.js +26 -0
- package/dist/icons/react/logo_Block.js.map +1 -0
- package/dist/icons/react/logo_Horizontal.js +26 -0
- package/dist/icons/react/logo_Horizontal.js.map +1 -0
- package/dist/icons/react/looks_3.js +26 -0
- package/dist/icons/react/looks_3.js.map +1 -0
- package/dist/icons/react/looks_one.js +26 -0
- package/dist/icons/react/looks_one.js.map +1 -0
- package/dist/icons/react/looks_two.js +26 -0
- package/dist/icons/react/looks_two.js.map +1 -0
- package/dist/icons/react/menu.js +26 -0
- package/dist/icons/react/menu.js.map +1 -0
- package/dist/icons/react/menu_open.js +26 -0
- package/dist/icons/react/menu_open.js.map +1 -0
- package/dist/icons/react/more_horiz.js +29 -0
- package/dist/icons/react/more_horiz.js.map +1 -0
- package/dist/icons/react/schedule.js +26 -0
- package/dist/icons/react/schedule.js.map +1 -0
- package/dist/icons/react/search.js +26 -0
- package/dist/icons/react/search.js.map +1 -0
- package/dist/icons/react/sunny.js +26 -0
- package/dist/icons/react/sunny.js.map +1 -0
- package/dist/icons/react/warning.js +26 -0
- package/dist/icons/react/warning.js.map +1 -0
- package/dist/index.css +5214 -0
- package/dist/index.css.map +1 -0
- package/dist/input/index.d.ts +2 -2
- package/dist/input/index.js +34 -1
- package/dist/input/index.js.map +1 -0
- package/dist/input/style.css +110 -1
- package/dist/input-bar/index.d.ts +2 -2
- package/dist/input-bar/index.js +34 -1
- package/dist/input-bar/index.js.map +1 -0
- package/dist/input-bar/style.css +180 -1
- package/dist/input-number/index.d.ts +1 -1
- package/dist/input-number/index.js +34 -1
- package/dist/input-number/index.js.map +1 -0
- package/dist/input-number/style.css +109 -1
- package/dist/modal/index.d.ts +2 -2
- package/dist/modal/index.js +34 -1
- package/dist/modal/index.js.map +1 -0
- package/dist/modal/style.css +150 -1
- package/dist/nav-menu/index.d.ts +2 -2
- package/dist/nav-menu/index.js +34 -1
- package/dist/nav-menu/index.js.map +1 -0
- package/dist/nav-menu/style.css +241 -1
- package/dist/pagination/index.d.ts +1 -1
- package/dist/pagination/index.js +34 -1
- package/dist/pagination/index.js.map +1 -0
- package/dist/pagination/style.css +150 -1
- package/dist/radio/index.d.ts +3 -3
- package/dist/radio/index.js +34 -2
- package/dist/radio/index.js.map +1 -0
- package/dist/radio/style.css +294 -1
- package/dist/select/index.d.ts +2 -2
- package/dist/select/index.js +34 -1
- package/dist/select/index.js.map +1 -0
- package/dist/select/style.css +255 -1
- package/dist/sidebar/index.d.ts +2 -2
- package/dist/sidebar/index.js +34 -1
- package/dist/sidebar/index.js.map +1 -0
- package/dist/sidebar/style.css +270 -1
- package/dist/slider/index.d.ts +2 -2
- package/dist/slider/index.js +34 -1
- package/dist/slider/index.js.map +1 -0
- package/dist/slider/style.css +206 -1
- package/dist/src/index.js +33 -31
- package/dist/src/index.js.map +1 -0
- package/dist/steps/index.d.ts +1 -1
- package/dist/steps/index.js +34 -1
- package/dist/steps/index.js.map +1 -0
- package/dist/steps/style.css +286 -1
- package/dist/switch/index.d.ts +2 -2
- package/dist/switch/index.js +34 -1
- package/dist/switch/index.js.map +1 -0
- package/dist/switch/style.css +160 -1
- package/dist/table/index.d.ts +1 -1
- package/dist/table/index.js +34 -1
- package/dist/table/index.js.map +1 -0
- package/dist/table/style.css +131 -1
- package/dist/tabs/index.d.ts +2 -2
- package/dist/tabs/index.js +34 -1
- package/dist/tabs/index.js.map +1 -0
- package/dist/tabs/style.css +146 -1
- package/dist/time-picker/index.d.ts +2 -2
- package/dist/time-picker/index.js +34 -1
- package/dist/time-picker/index.js.map +1 -0
- package/dist/time-picker/style.css +258 -1
- package/dist/toast/index.d.ts +4 -4
- package/dist/toast/index.js +38 -3
- package/dist/toast/index.js.map +1 -0
- package/dist/toast/style.css +117 -1
- package/dist/toolbars/index.d.ts +3 -3
- package/dist/toolbars/index.js +34 -1
- package/dist/toolbars/index.js.map +1 -0
- package/dist/toolbars/style.css +220 -1
- package/dist/tooltip/index.d.ts +1 -1
- package/dist/tooltip/index.js +34 -1
- package/dist/tooltip/index.js.map +1 -0
- package/dist/tooltip/style.css +138 -1
- package/dist/utils/src/index.js +6 -0
- package/dist/utils/src/index.js.map +1 -0
- package/package.json +7 -7
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type HTMLAttributes, type MouseEvent } from 'react';
|
|
2
|
+
import { type NavMenuItem, type NavMenuProps as BaseNavMenuProps, type NavMenuValue } from '../../../components/nav-menu/index';
|
|
3
|
+
import '../../../components/nav-menu/style.css';
|
|
4
|
+
export interface NavMenuProps extends Omit<BaseNavMenuProps, 'className'>, Omit<HTMLAttributes<HTMLElement>, 'onChange'> {
|
|
5
|
+
value?: NavMenuValue;
|
|
6
|
+
defaultValue?: NavMenuValue;
|
|
7
|
+
onChange?: (value: NavMenuValue, item: NavMenuItem, event: MouseEvent<HTMLElement>) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const NavMenu: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<NavMenuProps & import("react").RefAttributes<HTMLElement>>>;
|
|
10
|
+
export default NavMenu;
|
|
11
|
+
//# sourceMappingURL=NavMenu.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NavMenu.d.ts","sourceRoot":"","sources":["../../../components/nav-menu/NavMenu.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,UAAU,EAMhB,MAAM,OAAO,CAAA;AACd,OAAO,EAKL,KAAK,WAAW,EAChB,KAAK,YAAY,IAAI,gBAAgB,EACrC,KAAK,YAAY,EAClB,MAAM,4BAA4B,CAAA;AAMnC,OAAO,sCAAsC,CAAA;AAE7C,MAAM,WAAW,YACf,SAAQ,IAAI,CAAC,gBAAgB,EAAE,WAAW,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,UAAU,CAAC;IAC1F,KAAK,CAAC,EAAE,YAAY,CAAA;IACpB,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,CAAC,WAAW,CAAC,KAAK,IAAI,CAAA;CAC5F;AA8PD,eAAO,MAAM,OAAO,4IAAgC,CAAA;AAEpD,eAAe,OAAO,CAAA"}
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import { useMemo, useState, useRef, useEffect } from 'react';
|
|
3
|
+
import { findNavMenuItemPath, hasNavMenuChildren, getNavMenuClassNames, getNavMenuItemClassNames } from '../../../components/nav-menu/index.js';
|
|
4
|
+
import { cn } from '../../../utils/src/index.js';
|
|
5
|
+
import { useMergedState } from '../../hooks/useMergedState.js';
|
|
6
|
+
import { createComponent } from '../../runtime/createComponent.js';
|
|
7
|
+
import { withInstall } from '../../runtime/withInstall.js';
|
|
8
|
+
import { forwardRef } from '../../runtime/forwardRef.js';
|
|
9
|
+
import IconComponent from '../icon/Icon.js';
|
|
10
|
+
|
|
11
|
+
const NavMenuComponent = createComponent(
|
|
12
|
+
forwardRef((props, ref) => {
|
|
13
|
+
const {
|
|
14
|
+
items = [],
|
|
15
|
+
value,
|
|
16
|
+
defaultValue,
|
|
17
|
+
theme = "light",
|
|
18
|
+
className,
|
|
19
|
+
onChange,
|
|
20
|
+
...restProps
|
|
21
|
+
} = props;
|
|
22
|
+
const [currentValue, setCurrentValue] = useMergedState(defaultValue, {
|
|
23
|
+
value
|
|
24
|
+
});
|
|
25
|
+
const selectedPath = useMemo(
|
|
26
|
+
() => findNavMenuItemPath(items, currentValue),
|
|
27
|
+
[items, currentValue]
|
|
28
|
+
);
|
|
29
|
+
const selectedRootValue = selectedPath[0]?.value;
|
|
30
|
+
const selectedValues = useMemo(
|
|
31
|
+
() => new Set(selectedPath.map((item) => item.value)),
|
|
32
|
+
[selectedPath]
|
|
33
|
+
);
|
|
34
|
+
const [openRootValue, setOpenRootValue] = useState(void 0);
|
|
35
|
+
const rootRef = useRef(null);
|
|
36
|
+
const setRootRef = (node) => {
|
|
37
|
+
rootRef.current = node;
|
|
38
|
+
if (typeof ref === "function") {
|
|
39
|
+
ref(node);
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
if (ref) {
|
|
43
|
+
ref.current = node;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
useEffect(() => {
|
|
47
|
+
if (openRootValue === void 0) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
if (!items.some((item) => item.value === openRootValue)) {
|
|
51
|
+
setOpenRootValue(void 0);
|
|
52
|
+
}
|
|
53
|
+
}, [items, openRootValue]);
|
|
54
|
+
useEffect(() => {
|
|
55
|
+
if (openRootValue === void 0) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const handlePointerDown = (event) => {
|
|
59
|
+
const target = event.target;
|
|
60
|
+
if (!target || !rootRef.current || rootRef.current.contains(target)) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
setOpenRootValue(void 0);
|
|
64
|
+
};
|
|
65
|
+
document.addEventListener("pointerdown", handlePointerDown);
|
|
66
|
+
return () => {
|
|
67
|
+
document.removeEventListener("pointerdown", handlePointerDown);
|
|
68
|
+
};
|
|
69
|
+
}, [openRootValue]);
|
|
70
|
+
const handleSelect = (item, event, closePanel = true) => {
|
|
71
|
+
if (item.disabled) {
|
|
72
|
+
event.preventDefault();
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
setCurrentValue(item.value);
|
|
76
|
+
if (closePanel) {
|
|
77
|
+
setOpenRootValue(void 0);
|
|
78
|
+
}
|
|
79
|
+
onChange?.(item.value, item, event);
|
|
80
|
+
};
|
|
81
|
+
const handleRootClick = (item, event) => {
|
|
82
|
+
if (item.disabled) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (hasNavMenuChildren(item)) {
|
|
86
|
+
setOpenRootValue((prev) => prev === item.value ? void 0 : item.value);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
handleSelect(item, event, false);
|
|
90
|
+
setOpenRootValue(void 0);
|
|
91
|
+
};
|
|
92
|
+
const renderItemContent = (item, iconSize) => /* @__PURE__ */ jsxs("span", { className: "css-nav-menu__item-main", children: [
|
|
93
|
+
item.icon && /* @__PURE__ */ jsx("span", { className: "css-nav-menu__item-icon", children: /* @__PURE__ */ jsx(IconComponent, { name: item.icon, size: iconSize }) }),
|
|
94
|
+
/* @__PURE__ */ jsx("span", { className: "css-nav-menu__item-label", children: item.label })
|
|
95
|
+
] });
|
|
96
|
+
const renderRootAction = (item) => {
|
|
97
|
+
const active = openRootValue === item.value || selectedRootValue === item.value;
|
|
98
|
+
const classes = getNavMenuItemClassNames({
|
|
99
|
+
active,
|
|
100
|
+
expanded: openRootValue === item.value,
|
|
101
|
+
disabled: item.disabled});
|
|
102
|
+
return /* @__PURE__ */ jsx(
|
|
103
|
+
"button",
|
|
104
|
+
{
|
|
105
|
+
type: "button",
|
|
106
|
+
className: classes,
|
|
107
|
+
"aria-expanded": hasNavMenuChildren(item) ? openRootValue === item.value : void 0,
|
|
108
|
+
onClick: (event) => handleRootClick(item, event),
|
|
109
|
+
children: renderItemContent(item, 16)
|
|
110
|
+
}
|
|
111
|
+
);
|
|
112
|
+
};
|
|
113
|
+
const renderPanelLink = (item, nested = false) => {
|
|
114
|
+
const classes = cn(
|
|
115
|
+
"css-nav-menu__panel-link",
|
|
116
|
+
currentValue === item.value && "css-nav-menu__panel-link--active",
|
|
117
|
+
item.disabled && "css-nav-menu__panel-link--disabled",
|
|
118
|
+
nested && "css-nav-menu__panel-link--nested"
|
|
119
|
+
);
|
|
120
|
+
if (item.href) {
|
|
121
|
+
return /* @__PURE__ */ jsx(
|
|
122
|
+
"a",
|
|
123
|
+
{
|
|
124
|
+
href: item.disabled ? void 0 : item.href,
|
|
125
|
+
className: classes,
|
|
126
|
+
"aria-disabled": item.disabled || void 0,
|
|
127
|
+
onClick: (event) => handleSelect(item, event),
|
|
128
|
+
children: renderItemContent(item, 14)
|
|
129
|
+
}
|
|
130
|
+
);
|
|
131
|
+
}
|
|
132
|
+
return /* @__PURE__ */ jsx(
|
|
133
|
+
"button",
|
|
134
|
+
{
|
|
135
|
+
type: "button",
|
|
136
|
+
className: classes,
|
|
137
|
+
disabled: item.disabled,
|
|
138
|
+
onClick: (event) => handleSelect(item, event),
|
|
139
|
+
children: renderItemContent(item, 14)
|
|
140
|
+
}
|
|
141
|
+
);
|
|
142
|
+
};
|
|
143
|
+
const renderPanelTitle = (item) => {
|
|
144
|
+
const classes = cn(
|
|
145
|
+
"css-nav-menu__panel-title",
|
|
146
|
+
selectedValues.has(item.value) && !hasNavMenuChildren(item) && "css-nav-menu__panel-link--active"
|
|
147
|
+
);
|
|
148
|
+
return /* @__PURE__ */ jsx(
|
|
149
|
+
"button",
|
|
150
|
+
{
|
|
151
|
+
type: "button",
|
|
152
|
+
className: classes,
|
|
153
|
+
disabled: item.disabled,
|
|
154
|
+
onClick: (event) => handleSelect(item, event),
|
|
155
|
+
children: renderItemContent(item, 16)
|
|
156
|
+
}
|
|
157
|
+
);
|
|
158
|
+
};
|
|
159
|
+
const renderPanelNode = (item, nested = false) => {
|
|
160
|
+
if (!hasNavMenuChildren(item)) {
|
|
161
|
+
return /* @__PURE__ */ jsx("li", { className: "css-nav-menu__panel-link-item", children: renderPanelLink(item, nested) }, item.value);
|
|
162
|
+
}
|
|
163
|
+
return /* @__PURE__ */ jsxs("li", { className: "css-nav-menu__panel-group", children: [
|
|
164
|
+
renderPanelTitle(item),
|
|
165
|
+
/* @__PURE__ */ jsx(
|
|
166
|
+
"ul",
|
|
167
|
+
{
|
|
168
|
+
className: cn("css-nav-menu__panel-list", nested && "css-nav-menu__panel-list--nested"),
|
|
169
|
+
children: item.children?.map((child) => renderPanelNode(child, true))
|
|
170
|
+
}
|
|
171
|
+
)
|
|
172
|
+
] }, item.value);
|
|
173
|
+
};
|
|
174
|
+
const openRootItem = items.find((item) => item.value === openRootValue);
|
|
175
|
+
return /* @__PURE__ */ jsxs(
|
|
176
|
+
"nav",
|
|
177
|
+
{
|
|
178
|
+
ref: setRootRef,
|
|
179
|
+
className: cn(getNavMenuClassNames({ theme }), className),
|
|
180
|
+
"aria-label": "\u5BFC\u822A\u83DC\u5355",
|
|
181
|
+
...restProps,
|
|
182
|
+
children: [
|
|
183
|
+
/* @__PURE__ */ jsx("ul", { className: "css-nav-menu__root", children: items.map((item) => /* @__PURE__ */ jsx("li", { children: renderRootAction(item) }, item.value)) }),
|
|
184
|
+
openRootItem && hasNavMenuChildren(openRootItem) ? /* @__PURE__ */ jsx("div", { className: "css-nav-menu__panel", children: /* @__PURE__ */ jsx("ul", { className: "css-nav-menu__panel-grid", children: openRootItem.children?.map((item) => /* @__PURE__ */ jsx("li", { className: "css-nav-menu__panel-column", children: hasNavMenuChildren(item) ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
185
|
+
renderPanelTitle(item),
|
|
186
|
+
/* @__PURE__ */ jsx("ul", { className: "css-nav-menu__panel-list", children: item.children?.map((child) => renderPanelNode(child, true)) })
|
|
187
|
+
] }) : renderPanelLink(item) }, item.value)) }) }) : null
|
|
188
|
+
]
|
|
189
|
+
}
|
|
190
|
+
);
|
|
191
|
+
})
|
|
192
|
+
);
|
|
193
|
+
NavMenuComponent.displayName = "CssNavMenu";
|
|
194
|
+
const NavMenu = withInstall(NavMenuComponent);
|
|
195
|
+
|
|
196
|
+
export { NavMenu };
|
|
197
|
+
//# sourceMappingURL=NavMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NavMenu.js","sources":["../../../../../adapter-react/components/nav-menu/NavMenu.tsx"],"sourcesContent":["import {\r\n type HTMLAttributes,\r\n type MouseEvent,\r\n type MutableRefObject,\r\n useEffect,\r\n useMemo,\r\n useRef,\r\n useState,\r\n} from 'react'\r\nimport {\r\n findNavMenuItemPath,\r\n getNavMenuClassNames,\r\n getNavMenuItemClassNames,\r\n hasNavMenuChildren,\r\n type NavMenuItem,\r\n type NavMenuProps as BaseNavMenuProps,\r\n type NavMenuValue,\r\n} from '@cssui/components/nav-menu'\r\nimport { cn } from '@cssui/utils'\r\nimport { useMergedState } from '../../hooks'\r\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\r\nimport Icon from '../icon/Icon'\r\n\r\nimport '@cssui/components/nav-menu/style.css'\r\n\r\nexport interface NavMenuProps\r\n extends Omit<BaseNavMenuProps, 'className'>, Omit<HTMLAttributes<HTMLElement>, 'onChange'> {\r\n value?: NavMenuValue\r\n defaultValue?: NavMenuValue\r\n onChange?: (value: NavMenuValue, item: NavMenuItem, event: MouseEvent<HTMLElement>) => void\r\n}\r\n\r\nconst NavMenuComponent = createComponent(\r\n forwardRef<HTMLElement, NavMenuProps>((props, ref) => {\r\n const {\r\n items = [],\r\n value,\r\n defaultValue,\r\n theme = 'light',\r\n className,\r\n onChange,\r\n ...restProps\r\n } = props\r\n\r\n const [currentValue, setCurrentValue] = useMergedState<NavMenuValue | undefined>(defaultValue, {\r\n value,\r\n })\r\n const selectedPath = useMemo(\r\n () => findNavMenuItemPath(items, currentValue),\r\n [items, currentValue]\r\n )\r\n const selectedRootValue = selectedPath[0]?.value\r\n const selectedValues = useMemo(\r\n () => new Set<NavMenuValue>(selectedPath.map(item => item.value)),\r\n [selectedPath]\r\n )\r\n const [openRootValue, setOpenRootValue] = useState<NavMenuValue | undefined>(undefined)\r\n const rootRef = useRef<HTMLElement | null>(null)\r\n\r\n const setRootRef = (node: HTMLElement | null) => {\r\n rootRef.current = node\r\n\r\n if (typeof ref === 'function') {\r\n ref(node)\r\n return\r\n }\r\n\r\n if (ref) {\r\n ;(ref as MutableRefObject<HTMLElement | null>).current = node\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if (openRootValue === undefined) {\r\n return\r\n }\r\n\r\n if (!items.some(item => item.value === openRootValue)) {\r\n setOpenRootValue(undefined)\r\n }\r\n }, [items, openRootValue])\r\n\r\n useEffect(() => {\r\n if (openRootValue === undefined) {\r\n return\r\n }\r\n\r\n const handlePointerDown = (event: PointerEvent) => {\r\n const target = event.target as Node | null\r\n\r\n if (!target || !rootRef.current || rootRef.current.contains(target)) {\r\n return\r\n }\r\n\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n document.addEventListener('pointerdown', handlePointerDown)\r\n\r\n return () => {\r\n document.removeEventListener('pointerdown', handlePointerDown)\r\n }\r\n }, [openRootValue])\r\n\r\n const handleSelect = (\r\n item: NavMenuItem,\r\n event: MouseEvent<HTMLButtonElement | HTMLAnchorElement>,\r\n closePanel = true\r\n ) => {\r\n if (item.disabled) {\r\n event.preventDefault()\r\n return\r\n }\r\n\r\n setCurrentValue(item.value)\r\n\r\n if (closePanel) {\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n onChange?.(item.value, item, event as MouseEvent<HTMLElement>)\r\n }\r\n\r\n const handleRootClick = (item: NavMenuItem, event: MouseEvent<HTMLButtonElement>) => {\r\n if (item.disabled) {\r\n return\r\n }\r\n\r\n if (hasNavMenuChildren(item)) {\r\n setOpenRootValue(prev => (prev === item.value ? undefined : item.value))\r\n return\r\n }\r\n\r\n handleSelect(item, event, false)\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n const renderItemContent = (item: NavMenuItem, iconSize: number) => (\r\n <span className=\"css-nav-menu__item-main\">\r\n {item.icon && (\r\n <span className=\"css-nav-menu__item-icon\">\r\n <Icon name={item.icon as any} size={iconSize} />\r\n </span>\r\n )}\r\n <span className=\"css-nav-menu__item-label\">{item.label}</span>\r\n </span>\r\n )\r\n\r\n const renderRootAction = (item: NavMenuItem) => {\r\n const active = openRootValue === item.value || selectedRootValue === item.value\r\n const classes = getNavMenuItemClassNames({\r\n active,\r\n expanded: openRootValue === item.value,\r\n disabled: item.disabled,\r\n root: true,\r\n })\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n aria-expanded={hasNavMenuChildren(item) ? openRootValue === item.value : undefined}\r\n onClick={event => handleRootClick(item, event)}\r\n >\r\n {renderItemContent(item, 16)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelLink = (item: NavMenuItem, nested = false) => {\r\n const classes = cn(\r\n 'css-nav-menu__panel-link',\r\n currentValue === item.value && 'css-nav-menu__panel-link--active',\r\n item.disabled && 'css-nav-menu__panel-link--disabled',\r\n nested && 'css-nav-menu__panel-link--nested'\r\n )\r\n\r\n if (item.href) {\r\n return (\r\n <a\r\n href={item.disabled ? undefined : item.href}\r\n className={classes}\r\n aria-disabled={item.disabled || undefined}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 14)}\r\n </a>\r\n )\r\n }\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n disabled={item.disabled}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 14)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelTitle = (item: NavMenuItem) => {\r\n const classes = cn(\r\n 'css-nav-menu__panel-title',\r\n selectedValues.has(item.value) &&\r\n !hasNavMenuChildren(item) &&\r\n 'css-nav-menu__panel-link--active'\r\n )\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n disabled={item.disabled}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 16)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelNode = (item: NavMenuItem, nested = false): JSX.Element => {\r\n if (!hasNavMenuChildren(item)) {\r\n return (\r\n <li key={item.value} className=\"css-nav-menu__panel-link-item\">\r\n {renderPanelLink(item, nested)}\r\n </li>\r\n )\r\n }\r\n\r\n return (\r\n <li key={item.value} className=\"css-nav-menu__panel-group\">\r\n {renderPanelTitle(item)}\r\n <ul\r\n className={cn('css-nav-menu__panel-list', nested && 'css-nav-menu__panel-list--nested')}\r\n >\r\n {item.children?.map(child => renderPanelNode(child, true))}\r\n </ul>\r\n </li>\r\n )\r\n }\r\n\r\n const openRootItem = items.find(item => item.value === openRootValue)\r\n\r\n return (\r\n <nav\r\n ref={setRootRef}\r\n className={cn(getNavMenuClassNames({ theme }), className)}\r\n aria-label=\"导航菜单\"\r\n {...restProps}\r\n >\r\n <ul className=\"css-nav-menu__root\">\r\n {items.map(item => (\r\n <li key={item.value}>{renderRootAction(item)}</li>\r\n ))}\r\n </ul>\r\n {openRootItem && hasNavMenuChildren(openRootItem) ? (\r\n <div className=\"css-nav-menu__panel\">\r\n <ul className=\"css-nav-menu__panel-grid\">\r\n {openRootItem.children?.map(item => (\r\n <li key={item.value} className=\"css-nav-menu__panel-column\">\r\n {hasNavMenuChildren(item) ? (\r\n <>\r\n {renderPanelTitle(item)}\r\n <ul className=\"css-nav-menu__panel-list\">\r\n {item.children?.map(child => renderPanelNode(child, true))}\r\n </ul>\r\n </>\r\n ) : (\r\n renderPanelLink(item)\r\n )}\r\n </li>\r\n ))}\r\n </ul>\r\n </div>\r\n ) : null}\r\n </nav>\r\n )\r\n })\r\n)\r\n\r\nNavMenuComponent.displayName = 'CssNavMenu'\r\n\r\nexport const NavMenu = withInstall(NavMenuComponent)\r\n\r\nexport default NavMenu\r\n"],"names":["Icon"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/nav-menu/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type HTMLAttributes } from 'react';
|
|
2
|
+
import { type PaginationProps as BasePaginationProps } from '../../../components/pagination/index';
|
|
3
|
+
import '../../../components/pagination/style.css';
|
|
4
|
+
export interface PaginationProps extends Omit<BasePaginationProps, 'onChange'>, Omit<HTMLAttributes<HTMLDivElement>, 'children' | 'onChange'> {
|
|
5
|
+
/** 非受控默认页码 */
|
|
6
|
+
defaultCurrent?: number;
|
|
7
|
+
onChange?: (page: number) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const Pagination: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<PaginationProps & import("react").RefAttributes<HTMLDivElement>>>;
|
|
10
|
+
export default Pagination;
|
|
11
|
+
//# sourceMappingURL=Pagination.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Pagination.d.ts","sourceRoot":"","sources":["../../../components/pagination/Pagination.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6C,KAAK,cAAc,EAAE,MAAM,OAAO,CAAA;AACtF,OAAO,EAKL,KAAK,eAAe,IAAI,mBAAmB,EAC5C,MAAM,8BAA8B,CAAA;AAMrC,OAAO,wCAAwC,CAAA;AAE/C,MAAM,WAAW,eACf,SACE,IAAI,CAAC,mBAAmB,EAAE,UAAU,CAAC,EACrC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,GAAG,UAAU,CAAC;IAC/D,cAAc;IACd,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;CAClC;AA0HD,eAAO,MAAM,UAAU,kJAAmC,CAAA;AAE1D,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useMemo, useState, useEffect, useCallback } from 'react';
|
|
3
|
+
import { getPaginationPageCount, clampPaginationPage, getPaginationRecordRange, getPaginationClassNames } from '../../../components/pagination/index.js';
|
|
4
|
+
import { cn } from '../../../utils/src/index.js';
|
|
5
|
+
import { createComponent } from '../../runtime/createComponent.js';
|
|
6
|
+
import { withInstall } from '../../runtime/withInstall.js';
|
|
7
|
+
import { forwardRef } from '../../runtime/forwardRef.js';
|
|
8
|
+
import IconComponent from '../icon/Icon.js';
|
|
9
|
+
import { Select } from '../select/Select.js';
|
|
10
|
+
|
|
11
|
+
const PaginationComponent = createComponent(
|
|
12
|
+
forwardRef((props, ref) => {
|
|
13
|
+
const {
|
|
14
|
+
current,
|
|
15
|
+
defaultCurrent = 1,
|
|
16
|
+
total = 0,
|
|
17
|
+
pageSize = 15,
|
|
18
|
+
align = "end",
|
|
19
|
+
showTotal = false,
|
|
20
|
+
className,
|
|
21
|
+
onChange,
|
|
22
|
+
...restProps
|
|
23
|
+
} = props;
|
|
24
|
+
const totalPages = useMemo(() => getPaginationPageCount({ total, pageSize }), [pageSize, total]);
|
|
25
|
+
const [innerCurrent, setInnerCurrent] = useState(current ?? defaultCurrent);
|
|
26
|
+
const isControlled = current !== void 0;
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
if (!isControlled) {
|
|
29
|
+
setInnerCurrent((previous) => clampPaginationPage(previous, totalPages));
|
|
30
|
+
}
|
|
31
|
+
}, [isControlled, totalPages]);
|
|
32
|
+
const currentPage = clampPaginationPage(
|
|
33
|
+
isControlled ? current ?? 1 : innerCurrent,
|
|
34
|
+
totalPages
|
|
35
|
+
);
|
|
36
|
+
const recordRange = useMemo(
|
|
37
|
+
() => getPaginationRecordRange({ current: currentPage, total, pageSize }),
|
|
38
|
+
[currentPage, pageSize, total]
|
|
39
|
+
);
|
|
40
|
+
const pageOptions = useMemo(
|
|
41
|
+
() => Array.from({ length: totalPages }, (_, index) => index + 1),
|
|
42
|
+
[totalPages]
|
|
43
|
+
);
|
|
44
|
+
const pageSelectOptions = useMemo(
|
|
45
|
+
() => pageOptions.map((page) => ({
|
|
46
|
+
label: String(page),
|
|
47
|
+
value: String(page)
|
|
48
|
+
})),
|
|
49
|
+
[pageOptions]
|
|
50
|
+
);
|
|
51
|
+
const classNames = cn(getPaginationClassNames({ align, showTotal }), className);
|
|
52
|
+
const handlePageChange = useCallback(
|
|
53
|
+
(nextPage) => {
|
|
54
|
+
const normalizedPage = clampPaginationPage(nextPage, totalPages);
|
|
55
|
+
if (normalizedPage === currentPage) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
if (!isControlled) {
|
|
59
|
+
setInnerCurrent(normalizedPage);
|
|
60
|
+
}
|
|
61
|
+
onChange?.(normalizedPage);
|
|
62
|
+
},
|
|
63
|
+
[currentPage, isControlled, onChange, totalPages]
|
|
64
|
+
);
|
|
65
|
+
return /* @__PURE__ */ jsxs("div", { ref, className: classNames, ...restProps, children: [
|
|
66
|
+
showTotal ? /* @__PURE__ */ jsxs("div", { className: "css-pagination__summary", "aria-live": "polite", children: [
|
|
67
|
+
/* @__PURE__ */ jsxs("p", { className: "css-pagination__summary-line", children: [
|
|
68
|
+
"Total Records: ",
|
|
69
|
+
/* @__PURE__ */ jsx("strong", { children: total })
|
|
70
|
+
] }),
|
|
71
|
+
/* @__PURE__ */ jsxs("p", { className: "css-pagination__summary-line", children: [
|
|
72
|
+
"Now Showing records: ",
|
|
73
|
+
recordRange.start,
|
|
74
|
+
"-",
|
|
75
|
+
recordRange.end
|
|
76
|
+
] })
|
|
77
|
+
] }) : null,
|
|
78
|
+
/* @__PURE__ */ jsxs("div", { className: "css-pagination__controls", children: [
|
|
79
|
+
/* @__PURE__ */ jsx(
|
|
80
|
+
"button",
|
|
81
|
+
{
|
|
82
|
+
type: "button",
|
|
83
|
+
className: "css-pagination__arrow",
|
|
84
|
+
onClick: () => handlePageChange(currentPage - 1),
|
|
85
|
+
disabled: currentPage <= 1,
|
|
86
|
+
"aria-label": "\u4E0A\u4E00\u9875",
|
|
87
|
+
children: /* @__PURE__ */ jsx(IconComponent, { name: "ChevronRight", size: 20, rotate: 180 })
|
|
88
|
+
}
|
|
89
|
+
),
|
|
90
|
+
/* @__PURE__ */ jsxs("div", { className: "css-pagination__selector", children: [
|
|
91
|
+
/* @__PURE__ */ jsx("span", { className: "css-pagination__sr-only", children: "\u9009\u62E9\u9875\u7801" }),
|
|
92
|
+
/* @__PURE__ */ jsx(
|
|
93
|
+
Select,
|
|
94
|
+
{
|
|
95
|
+
value: String(currentPage),
|
|
96
|
+
options: pageSelectOptions,
|
|
97
|
+
onChange: (value) => {
|
|
98
|
+
if (typeof value === "string") {
|
|
99
|
+
handlePageChange(Number(value));
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
)
|
|
104
|
+
] }),
|
|
105
|
+
showTotal ? /* @__PURE__ */ jsxs("span", { className: "css-pagination__page-count", children: [
|
|
106
|
+
"of ",
|
|
107
|
+
totalPages
|
|
108
|
+
] }) : null,
|
|
109
|
+
/* @__PURE__ */ jsx(
|
|
110
|
+
"button",
|
|
111
|
+
{
|
|
112
|
+
type: "button",
|
|
113
|
+
className: "css-pagination__arrow",
|
|
114
|
+
onClick: () => handlePageChange(currentPage + 1),
|
|
115
|
+
disabled: currentPage >= totalPages,
|
|
116
|
+
"aria-label": "\u4E0B\u4E00\u9875",
|
|
117
|
+
children: /* @__PURE__ */ jsx(IconComponent, { name: "ChevronRight", size: 20 })
|
|
118
|
+
}
|
|
119
|
+
)
|
|
120
|
+
] })
|
|
121
|
+
] });
|
|
122
|
+
})
|
|
123
|
+
);
|
|
124
|
+
PaginationComponent.displayName = "CssPagination";
|
|
125
|
+
const Pagination = withInstall(PaginationComponent);
|
|
126
|
+
|
|
127
|
+
export { Pagination, Pagination as default };
|
|
128
|
+
//# sourceMappingURL=Pagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Pagination.js","sources":["../../../../../adapter-react/components/pagination/Pagination.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useState, type HTMLAttributes } from 'react'\nimport {\n clampPaginationPage,\n getPaginationClassNames,\n getPaginationPageCount,\n getPaginationRecordRange,\n type PaginationProps as BasePaginationProps,\n} from '@cssui/components/pagination'\nimport { cn } from '@cssui/utils'\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\nimport Icon from '../icon/Icon'\nimport Select from '../select/Select'\n\nimport '@cssui/components/pagination/style.css'\n\nexport interface PaginationProps\n extends\n Omit<BasePaginationProps, 'onChange'>,\n Omit<HTMLAttributes<HTMLDivElement>, 'children' | 'onChange'> {\n /** 非受控默认页码 */\n defaultCurrent?: number\n onChange?: (page: number) => void\n}\n\nconst PaginationComponent = createComponent(\n forwardRef<HTMLDivElement, PaginationProps>((props, ref) => {\n const {\n current,\n defaultCurrent = 1,\n total = 0,\n pageSize = 15,\n align = 'end',\n showTotal = false,\n className,\n onChange,\n ...restProps\n } = props\n\n const totalPages = useMemo(() => getPaginationPageCount({ total, pageSize }), [pageSize, total])\n const [innerCurrent, setInnerCurrent] = useState(current ?? defaultCurrent)\n const isControlled = current !== undefined\n\n useEffect(() => {\n if (!isControlled) {\n setInnerCurrent(previous => clampPaginationPage(previous, totalPages))\n }\n }, [isControlled, totalPages])\n\n const currentPage = clampPaginationPage(\n isControlled ? (current ?? 1) : innerCurrent,\n totalPages\n )\n const recordRange = useMemo(\n () => getPaginationRecordRange({ current: currentPage, total, pageSize }),\n [currentPage, pageSize, total]\n )\n const pageOptions = useMemo(\n () => Array.from({ length: totalPages }, (_, index) => index + 1),\n [totalPages]\n )\n const pageSelectOptions = useMemo(\n () =>\n pageOptions.map(page => ({\n label: String(page),\n value: String(page),\n })),\n [pageOptions]\n )\n\n const classNames = cn(getPaginationClassNames({ align, showTotal }), className)\n\n const handlePageChange = useCallback(\n (nextPage: number) => {\n const normalizedPage = clampPaginationPage(nextPage, totalPages)\n\n if (normalizedPage === currentPage) {\n return\n }\n\n if (!isControlled) {\n setInnerCurrent(normalizedPage)\n }\n\n onChange?.(normalizedPage)\n },\n [currentPage, isControlled, onChange, totalPages]\n )\n\n return (\n <div ref={ref} className={classNames} {...restProps}>\n {showTotal ? (\n <div className=\"css-pagination__summary\" aria-live=\"polite\">\n <p className=\"css-pagination__summary-line\">\n Total Records: <strong>{total}</strong>\n </p>\n <p className=\"css-pagination__summary-line\">\n Now Showing records: {recordRange.start}-{recordRange.end}\n </p>\n </div>\n ) : null}\n\n <div className=\"css-pagination__controls\">\n <button\n type=\"button\"\n className=\"css-pagination__arrow\"\n onClick={() => handlePageChange(currentPage - 1)}\n disabled={currentPage <= 1}\n aria-label=\"上一页\"\n >\n <Icon name=\"ChevronRight\" size={20} rotate={180} />\n </button>\n\n <div className=\"css-pagination__selector\">\n <span className=\"css-pagination__sr-only\">选择页码</span>\n <Select\n value={String(currentPage)}\n options={pageSelectOptions}\n onChange={value => {\n if (typeof value === 'string') {\n handlePageChange(Number(value))\n }\n }}\n />\n </div>\n\n {showTotal ? <span className=\"css-pagination__page-count\">of {totalPages}</span> : null}\n\n <button\n type=\"button\"\n className=\"css-pagination__arrow\"\n onClick={() => handlePageChange(currentPage + 1)}\n disabled={currentPage >= totalPages}\n aria-label=\"下一页\"\n >\n <Icon name=\"ChevronRight\" size={20} />\n </button>\n </div>\n </div>\n )\n })\n)\n\nPaginationComponent.displayName = 'CssPagination'\n\nexport const Pagination = withInstall(PaginationComponent)\n\nexport default Pagination\n"],"names":["Icon"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/pagination/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAClD,YAAY,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ChangeEvent } from 'react';
|
|
2
|
+
import { type RadioProps as BaseRadioProps } from '../../../components/radio/index';
|
|
3
|
+
import '../../../components/radio/style.css';
|
|
4
|
+
export interface RadioProps extends Omit<BaseRadioProps, 'onChange'> {
|
|
5
|
+
defaultChecked?: boolean;
|
|
6
|
+
icon?: React.ReactNode | string;
|
|
7
|
+
onChange?: (checked: boolean, event: ChangeEvent<HTMLInputElement>) => void;
|
|
8
|
+
[key: string]: any;
|
|
9
|
+
}
|
|
10
|
+
export declare const Radio: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<Omit<RadioProps, "ref"> & import("react").RefAttributes<HTMLInputElement>>>;
|
|
11
|
+
export default Radio;
|
|
12
|
+
//# sourceMappingURL=Radio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Radio.d.ts","sourceRoot":"","sources":["../../../components/radio/Radio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AACxC,OAAO,EAEL,KAAK,UAAU,IAAI,cAAc,EAElC,MAAM,yBAAyB,CAAA;AAKhC,OAAO,mCAAmC,CAAA;AAE1C,MAAM,WAAW,UAAW,SAAQ,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC;IAClE,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAA;IAC/B,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;IAC3E,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB;AA2FD,eAAO,MAAM,KAAK,4JAA8B,CAAA;AAEhD,eAAe,KAAK,CAAA"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { getRadioClassNames } from '../../../components/radio/index.js';
|
|
3
|
+
import { createComponent } from '../../runtime/createComponent.js';
|
|
4
|
+
import { withInstall } from '../../runtime/withInstall.js';
|
|
5
|
+
import { forwardRef } from '../../runtime/forwardRef.js';
|
|
6
|
+
import IconComponent from '../icon/Icon.js';
|
|
7
|
+
import { useRadioGroupContext } from './RadioGroup.js';
|
|
8
|
+
|
|
9
|
+
const RadioComponent = createComponent(
|
|
10
|
+
forwardRef((props, ref) => {
|
|
11
|
+
const {
|
|
12
|
+
checked,
|
|
13
|
+
defaultChecked,
|
|
14
|
+
disabled,
|
|
15
|
+
error,
|
|
16
|
+
label,
|
|
17
|
+
children,
|
|
18
|
+
className,
|
|
19
|
+
onChange,
|
|
20
|
+
value,
|
|
21
|
+
variant,
|
|
22
|
+
icon,
|
|
23
|
+
iconOnly,
|
|
24
|
+
name,
|
|
25
|
+
...restProps
|
|
26
|
+
} = props;
|
|
27
|
+
const groupContext = useRadioGroupContext();
|
|
28
|
+
const mergedDisabled = groupContext?.disabled || disabled;
|
|
29
|
+
const mergedError = groupContext?.error || error;
|
|
30
|
+
const mergedVariant = variant ?? groupContext?.variant ?? "default";
|
|
31
|
+
const mergedIconOnly = iconOnly ?? groupContext?.iconOnly ?? false;
|
|
32
|
+
const mergedName = name ?? groupContext?.name;
|
|
33
|
+
const groupChecked = groupContext && value !== void 0 ? groupContext.value === value : void 0;
|
|
34
|
+
const mergedChecked = groupChecked ?? checked;
|
|
35
|
+
const radioClassName = getRadioClassNames({
|
|
36
|
+
disabled: mergedDisabled,
|
|
37
|
+
error: mergedError,
|
|
38
|
+
className,
|
|
39
|
+
variant: mergedVariant,
|
|
40
|
+
iconOnly: mergedIconOnly
|
|
41
|
+
});
|
|
42
|
+
const handleChange = (event) => {
|
|
43
|
+
if (mergedDisabled) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
if (groupContext && value !== void 0) {
|
|
47
|
+
groupContext.onChange?.(value, event);
|
|
48
|
+
}
|
|
49
|
+
onChange?.(event.target.checked, event);
|
|
50
|
+
};
|
|
51
|
+
const renderedIcon = typeof icon === "string" ? /* @__PURE__ */ jsx(IconComponent, { name: icon, size: 20, className: "css-radio__icon" }) : icon;
|
|
52
|
+
return /* @__PURE__ */ jsxs("label", { className: radioClassName, children: [
|
|
53
|
+
/* @__PURE__ */ jsx(
|
|
54
|
+
"input",
|
|
55
|
+
{
|
|
56
|
+
ref,
|
|
57
|
+
type: "radio",
|
|
58
|
+
className: "css-radio__input",
|
|
59
|
+
checked: mergedChecked,
|
|
60
|
+
defaultChecked,
|
|
61
|
+
disabled: mergedDisabled,
|
|
62
|
+
name: mergedName,
|
|
63
|
+
value,
|
|
64
|
+
onChange: handleChange,
|
|
65
|
+
...restProps
|
|
66
|
+
}
|
|
67
|
+
),
|
|
68
|
+
/* @__PURE__ */ jsx("span", { className: "css-radio__indicator" }),
|
|
69
|
+
(renderedIcon || label || children) && /* @__PURE__ */ jsxs("span", { className: "css-radio__content", children: [
|
|
70
|
+
renderedIcon ? /* @__PURE__ */ jsx("span", { className: "css-radio__icon", children: renderedIcon }) : null,
|
|
71
|
+
(label || children) && /* @__PURE__ */ jsxs("span", { className: "css-radio__label", children: [
|
|
72
|
+
label,
|
|
73
|
+
children
|
|
74
|
+
] })
|
|
75
|
+
] })
|
|
76
|
+
] });
|
|
77
|
+
})
|
|
78
|
+
);
|
|
79
|
+
RadioComponent.displayName = "CssRadio";
|
|
80
|
+
const Radio = withInstall(RadioComponent);
|
|
81
|
+
|
|
82
|
+
export { Radio, Radio as default };
|
|
83
|
+
//# sourceMappingURL=Radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Radio.js","sources":["../../../../../adapter-react/components/radio/Radio.tsx"],"sourcesContent":["import type { ChangeEvent } from 'react'\nimport {\n getRadioClassNames,\n type RadioProps as BaseRadioProps,\n type RadioValue,\n} from '@cssui/components/radio'\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\nimport Icon from '../icon/Icon'\nimport { useRadioGroupContext } from './RadioGroup'\n\nimport '@cssui/components/radio/style.css'\n\nexport interface RadioProps extends Omit<BaseRadioProps, 'onChange'> {\n defaultChecked?: boolean\n icon?: React.ReactNode | string\n onChange?: (checked: boolean, event: ChangeEvent<HTMLInputElement>) => void\n [key: string]: any\n}\n\nconst RadioComponent = createComponent(\n forwardRef<HTMLInputElement, RadioProps>((props, ref) => {\n const {\n checked,\n defaultChecked,\n disabled,\n error,\n label,\n children,\n className,\n onChange,\n value,\n variant,\n icon,\n iconOnly,\n name,\n ...restProps\n } = props\n\n const groupContext = useRadioGroupContext()\n const mergedDisabled = groupContext?.disabled || disabled\n const mergedError = groupContext?.error || error\n const mergedVariant = variant ?? groupContext?.variant ?? 'default'\n const mergedIconOnly = iconOnly ?? groupContext?.iconOnly ?? false\n const mergedName = name ?? groupContext?.name\n const groupChecked =\n groupContext && value !== undefined ? groupContext.value === (value as RadioValue) : undefined\n const mergedChecked = groupChecked ?? checked\n\n const radioClassName = getRadioClassNames({\n disabled: mergedDisabled,\n error: mergedError,\n className,\n variant: mergedVariant,\n iconOnly: mergedIconOnly,\n })\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n if (mergedDisabled) {\n return\n }\n\n if (groupContext && value !== undefined) {\n groupContext.onChange?.(value as RadioValue, event)\n }\n\n onChange?.(event.target.checked, event)\n }\n\n const renderedIcon =\n typeof icon === 'string' ? (\n <Icon name={icon as any} size={20} className=\"css-radio__icon\" />\n ) : (\n icon\n )\n\n return (\n <label className={radioClassName}>\n <input\n ref={ref}\n type=\"radio\"\n className=\"css-radio__input\"\n checked={mergedChecked}\n defaultChecked={defaultChecked}\n disabled={mergedDisabled}\n name={mergedName}\n value={value as string | number | readonly string[] | undefined}\n onChange={handleChange}\n {...restProps}\n />\n <span className=\"css-radio__indicator\" />\n {(renderedIcon || label || children) && (\n <span className=\"css-radio__content\">\n {renderedIcon ? <span className=\"css-radio__icon\">{renderedIcon}</span> : null}\n {(label || children) && (\n <span className=\"css-radio__label\">\n {label}\n {children}\n </span>\n )}\n </span>\n )}\n </label>\n )\n })\n)\n\nRadioComponent.displayName = 'CssRadio'\n\nexport const Radio = withInstall(RadioComponent)\n\nexport default Radio\n"],"names":["Icon"],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { type ChangeEvent, type ReactNode } from 'react';
|
|
2
|
+
import { type RadioGroupOption as BaseRadioGroupOption, type RadioGroupProps as BaseRadioGroupProps, type RadioValue, type RadioVariant, type RadioDirection } from '../../../components/radio/index';
|
|
3
|
+
export interface RadioGroupOption extends Omit<BaseRadioGroupOption, 'icon'> {
|
|
4
|
+
icon?: string | ReactNode;
|
|
5
|
+
}
|
|
6
|
+
export interface RadioGroupProps extends Omit<BaseRadioGroupProps, 'onChange' | 'options'> {
|
|
7
|
+
options?: RadioGroupOption[];
|
|
8
|
+
direction?: RadioDirection;
|
|
9
|
+
onChange?: (value: RadioValue, event?: ChangeEvent<HTMLInputElement>) => void;
|
|
10
|
+
}
|
|
11
|
+
export interface RadioGroupContextValue {
|
|
12
|
+
name?: string;
|
|
13
|
+
value?: RadioValue;
|
|
14
|
+
disabled?: boolean;
|
|
15
|
+
error?: boolean;
|
|
16
|
+
variant?: RadioVariant;
|
|
17
|
+
iconOnly?: boolean;
|
|
18
|
+
onChange?: (value: RadioValue, event: ChangeEvent<HTMLInputElement>) => void;
|
|
19
|
+
}
|
|
20
|
+
export declare const RadioGroupContext: import("react").Context<RadioGroupContextValue | null>;
|
|
21
|
+
export declare function useRadioGroupContext(): RadioGroupContextValue | null;
|
|
22
|
+
export declare const RadioGroup: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<RadioGroupProps & import("react").RefAttributes<HTMLDivElement>>>;
|
|
23
|
+
export default RadioGroup;
|
|
24
|
+
//# sourceMappingURL=RadioGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioGroup.d.ts","sourceRoot":"","sources":["../../../components/radio/RadioGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6C,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AACnG,OAAO,EAEL,KAAK,gBAAgB,IAAI,oBAAoB,EAC7C,KAAK,eAAe,IAAI,mBAAmB,EAC3C,KAAK,UAAU,EACf,KAAK,YAAY,EACjB,KAAK,cAAc,EACpB,MAAM,yBAAyB,CAAA;AAMhC,MAAM,WAAW,gBAAiB,SAAQ,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC;IAC1E,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;CAC1B;AAED,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,mBAAmB,EAAE,UAAU,GAAG,SAAS,CAAC;IACxF,OAAO,CAAC,EAAE,gBAAgB,EAAE,CAAA;IAC5B,SAAS,CAAC,EAAE,cAAc,CAAA;IAC1B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;CAC9E;AAED,MAAM,WAAW,sBAAsB;IACrC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,UAAU,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,OAAO,CAAC,EAAE,YAAY,CAAA;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;CAC7E;AAED,eAAO,MAAM,iBAAiB,wDAAqD,CAAA;AAEnF,wBAAgB,oBAAoB,kCAEnC;AA+FD,eAAO,MAAM,UAAU,kJAAmC,CAAA;AAE1D,eAAe,UAAU,CAAA"}
|