@causw/core 0.0.9 → 0.0.11
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/_virtual/rolldown_runtime.cjs +29 -0
- package/dist/assets/avatar/default.cjs +11 -0
- package/dist/assets/avatar/default.mjs +6 -0
- package/dist/assets/avatar/default.mjs.map +1 -0
- package/dist/components/Avatar/Avatar.cjs +46 -0
- package/dist/components/Avatar/Avatar.d.cts +25 -0
- package/dist/components/Avatar/Avatar.d.cts.map +1 -0
- package/dist/components/Avatar/Avatar.d.mts +26 -0
- package/dist/components/Avatar/Avatar.d.mts.map +1 -0
- package/dist/components/Avatar/Avatar.mjs +45 -0
- package/dist/components/Avatar/Avatar.mjs.map +1 -0
- package/dist/components/Avatar/Avatar.styles.cjs +22 -0
- package/dist/components/Avatar/Avatar.styles.d.cts +75 -0
- package/dist/components/Avatar/Avatar.styles.d.cts.map +1 -0
- package/dist/components/Avatar/Avatar.styles.d.mts +75 -0
- package/dist/components/Avatar/Avatar.styles.d.mts.map +1 -0
- package/dist/components/Avatar/Avatar.styles.mjs +22 -0
- package/dist/components/Avatar/Avatar.styles.mjs.map +1 -0
- package/dist/components/Avatar/index.d.mts +2 -0
- package/dist/components/Box/Box.cjs +24 -0
- package/dist/components/Box/Box.d.cts +22 -0
- package/dist/components/Box/Box.d.cts.map +1 -0
- package/dist/components/Box/Box.d.mts +23 -0
- package/dist/components/Box/Box.d.mts.map +1 -0
- package/dist/components/Box/Box.mjs +23 -0
- package/dist/components/Box/Box.mjs.map +1 -0
- package/dist/components/Box/Box.styles.cjs +48 -0
- package/dist/components/Box/Box.styles.d.cts +105 -0
- package/dist/components/Box/Box.styles.d.cts.map +1 -0
- package/dist/components/Box/Box.styles.d.mts +105 -0
- package/dist/components/Box/Box.styles.d.mts.map +1 -0
- package/dist/components/Box/Box.styles.mjs +48 -0
- package/dist/components/Box/Box.styles.mjs.map +1 -0
- package/dist/components/Box/index.d.mts +2 -0
- package/dist/components/Button/Button.cjs +23 -0
- package/dist/components/Button/Button.d.cts +19 -0
- package/dist/components/Button/Button.d.cts.map +1 -0
- package/dist/components/Button/Button.d.mts +20 -0
- package/dist/components/Button/Button.d.mts.map +1 -0
- package/dist/components/Button/Button.mjs +23 -0
- package/dist/components/Button/Button.mjs.map +1 -0
- package/dist/components/Button/Button.styles.cjs +35 -0
- package/dist/components/Button/Button.styles.d.cts +63 -0
- package/dist/components/Button/Button.styles.d.cts.map +1 -0
- package/dist/components/Button/Button.styles.d.mts +63 -0
- package/dist/components/Button/Button.styles.d.mts.map +1 -0
- package/dist/components/Button/Button.styles.mjs +35 -0
- package/dist/components/Button/Button.styles.mjs.map +1 -0
- package/dist/components/Button/index.d.mts +1 -0
- package/dist/components/CTAButton/CTAButton.cjs +22 -0
- package/dist/components/CTAButton/CTAButton.d.cts +18 -0
- package/dist/components/CTAButton/CTAButton.d.cts.map +1 -0
- package/dist/components/CTAButton/CTAButton.d.mts +19 -0
- package/dist/components/CTAButton/CTAButton.d.mts.map +1 -0
- package/dist/components/CTAButton/CTAButton.mjs +22 -0
- package/dist/components/CTAButton/CTAButton.mjs.map +1 -0
- package/dist/components/CTAButton/CTAButton.styles.cjs +32 -0
- package/dist/components/CTAButton/CTAButton.styles.d.cts +57 -0
- package/dist/components/CTAButton/CTAButton.styles.d.cts.map +1 -0
- package/dist/components/CTAButton/CTAButton.styles.d.mts +57 -0
- package/dist/components/CTAButton/CTAButton.styles.d.mts.map +1 -0
- package/dist/components/CTAButton/CTAButton.styles.mjs +32 -0
- package/dist/components/CTAButton/CTAButton.styles.mjs.map +1 -0
- package/dist/components/CTAButton/index.d.mts +1 -0
- package/dist/components/Checkbox/Checkbox.cjs +83 -0
- package/dist/components/Checkbox/Checkbox.d.cts +44 -0
- package/dist/components/Checkbox/Checkbox.d.cts.map +1 -0
- package/dist/components/Checkbox/Checkbox.d.mts +46 -0
- package/dist/components/Checkbox/Checkbox.d.mts.map +1 -0
- package/dist/components/Checkbox/Checkbox.mjs +82 -0
- package/dist/components/Checkbox/Checkbox.mjs.map +1 -0
- package/dist/components/Checkbox/Checkbox.styles.cjs +31 -0
- package/dist/components/Checkbox/Checkbox.styles.d.cts +75 -0
- package/dist/components/Checkbox/Checkbox.styles.d.cts.map +1 -0
- package/dist/components/Checkbox/Checkbox.styles.d.mts +75 -0
- package/dist/components/Checkbox/Checkbox.styles.d.mts.map +1 -0
- package/dist/components/Checkbox/Checkbox.styles.mjs +31 -0
- package/dist/components/Checkbox/Checkbox.styles.mjs.map +1 -0
- package/dist/components/Checkbox/index.d.mts +1 -0
- package/dist/components/Chip/Chip.cjs +29 -0
- package/dist/components/Chip/Chip.d.cts +22 -0
- package/dist/components/Chip/Chip.d.cts.map +1 -0
- package/dist/components/Chip/Chip.d.mts +23 -0
- package/dist/components/Chip/Chip.d.mts.map +1 -0
- package/dist/components/Chip/Chip.mjs +28 -0
- package/dist/components/Chip/Chip.mjs.map +1 -0
- package/dist/components/Chip/Chip.styles.cjs +30 -0
- package/dist/components/Chip/Chip.styles.d.cts +51 -0
- package/dist/components/Chip/Chip.styles.d.cts.map +1 -0
- package/dist/components/Chip/Chip.styles.d.mts +51 -0
- package/dist/components/Chip/Chip.styles.d.mts.map +1 -0
- package/dist/components/Chip/Chip.styles.mjs +30 -0
- package/dist/components/Chip/Chip.styles.mjs.map +1 -0
- package/dist/components/Chip/index.d.mts +2 -0
- package/dist/components/Dialog/Dialog.cjs +59 -0
- package/dist/components/Dialog/Dialog.d.cts +57 -0
- package/dist/components/Dialog/Dialog.d.cts.map +1 -0
- package/dist/components/Dialog/Dialog.d.mts +58 -0
- package/dist/components/Dialog/Dialog.d.mts.map +1 -0
- package/dist/components/Dialog/Dialog.mjs +58 -0
- package/dist/components/Dialog/Dialog.mjs.map +1 -0
- package/dist/components/Dialog/Dialog.styles.cjs +35 -0
- package/dist/components/Dialog/Dialog.styles.d.cts +46 -0
- package/dist/components/Dialog/Dialog.styles.d.cts.map +1 -0
- package/dist/components/Dialog/Dialog.styles.d.mts +46 -0
- package/dist/components/Dialog/Dialog.styles.d.mts.map +1 -0
- package/dist/components/Dialog/Dialog.styles.mjs +33 -0
- package/dist/components/Dialog/Dialog.styles.mjs.map +1 -0
- package/dist/components/Dialog/index.d.mts +2 -0
- package/dist/components/Dropdown/Dropdown.cjs +39 -0
- package/dist/components/Dropdown/Dropdown.d.cts +36 -0
- package/dist/components/Dropdown/Dropdown.d.cts.map +1 -0
- package/dist/components/Dropdown/Dropdown.d.mts +36 -0
- package/dist/components/Dropdown/Dropdown.d.mts.map +1 -0
- package/dist/components/Dropdown/Dropdown.mjs +37 -0
- package/dist/components/Dropdown/Dropdown.mjs.map +1 -0
- package/dist/components/Dropdown/Dropdown.styles.cjs +19 -0
- package/dist/components/Dropdown/Dropdown.styles.d.cts +54 -0
- package/dist/components/Dropdown/Dropdown.styles.d.cts.map +1 -0
- package/dist/components/Dropdown/Dropdown.styles.d.mts +54 -0
- package/dist/components/Dropdown/Dropdown.styles.d.mts.map +1 -0
- package/dist/components/Dropdown/Dropdown.styles.mjs +19 -0
- package/dist/components/Dropdown/Dropdown.styles.mjs.map +1 -0
- package/dist/components/Dropdown/index.d.mts +2 -0
- package/dist/components/Field/Field.cjs +80 -0
- package/dist/components/Field/Field.d.cts +59 -0
- package/dist/components/Field/Field.d.cts.map +1 -0
- package/dist/components/Field/Field.d.mts +60 -0
- package/dist/components/Field/Field.d.mts.map +1 -0
- package/dist/components/Field/Field.mjs +79 -0
- package/dist/components/Field/Field.mjs.map +1 -0
- package/dist/components/Field/Field.styles.cjs +13 -0
- package/dist/components/Field/Field.styles.mjs +13 -0
- package/dist/components/Field/Field.styles.mjs.map +1 -0
- package/dist/components/Field/index.d.mts +1 -0
- package/dist/components/Flex/Flex.cjs +25 -0
- package/dist/components/Flex/Flex.d.cts +24 -0
- package/dist/components/Flex/Flex.d.cts.map +1 -0
- package/dist/components/Flex/Flex.d.mts +25 -0
- package/dist/components/Flex/Flex.d.mts.map +1 -0
- package/dist/components/Flex/Flex.mjs +24 -0
- package/dist/components/Flex/Flex.mjs.map +1 -0
- package/dist/components/Flex/Flex.styles.cjs +50 -0
- package/dist/components/Flex/Flex.styles.d.cts +16 -0
- package/dist/components/Flex/Flex.styles.d.cts.map +1 -0
- package/dist/components/Flex/Flex.styles.d.mts +16 -0
- package/dist/components/Flex/Flex.styles.d.mts.map +1 -0
- package/dist/components/Flex/Flex.styles.mjs +51 -0
- package/dist/components/Flex/Flex.styles.mjs.map +1 -0
- package/dist/components/Flex/index.d.mts +2 -0
- package/dist/components/Float/Float.cjs +32 -0
- package/dist/components/Float/Float.d.cts +25 -0
- package/dist/components/Float/Float.d.cts.map +1 -0
- package/dist/components/Float/Float.d.mts +26 -0
- package/dist/components/Float/Float.d.mts.map +1 -0
- package/dist/components/Float/Float.mjs +31 -0
- package/dist/components/Float/Float.mjs.map +1 -0
- package/dist/components/Float/Float.styles.cjs +39 -0
- package/dist/components/Float/Float.styles.d.cts +58 -0
- package/dist/components/Float/Float.styles.d.cts.map +1 -0
- package/dist/components/Float/Float.styles.d.mts +58 -0
- package/dist/components/Float/Float.styles.d.mts.map +1 -0
- package/dist/components/Float/Float.styles.mjs +38 -0
- package/dist/components/Float/Float.styles.mjs.map +1 -0
- package/dist/components/Float/index.d.mts +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.cjs +18 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.d.cts +16 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.d.cts.map +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.d.mts +17 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.d.mts.map +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.mjs +18 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.mjs.map +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.cjs +15 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.cts +24 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.cts.map +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.mts +24 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.mts.map +1 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.mjs +15 -0
- package/dist/components/FloatingActionButton/FloatingActionButton.styles.mjs.map +1 -0
- package/dist/components/FloatingActionButton/index.d.mts +1 -0
- package/dist/components/Grid/Grid.cjs +24 -0
- package/dist/components/Grid/Grid.d.cts +22 -0
- package/dist/components/Grid/Grid.d.cts.map +1 -0
- package/dist/components/Grid/Grid.d.mts +23 -0
- package/dist/components/Grid/Grid.d.mts.map +1 -0
- package/dist/components/Grid/Grid.mjs +23 -0
- package/dist/components/Grid/Grid.mjs.map +1 -0
- package/dist/components/Grid/Grid.styles.cjs +56 -0
- package/dist/components/Grid/Grid.styles.d.cts +126 -0
- package/dist/components/Grid/Grid.styles.d.cts.map +1 -0
- package/dist/components/Grid/Grid.styles.d.mts +126 -0
- package/dist/components/Grid/Grid.styles.d.mts.map +1 -0
- package/dist/components/Grid/Grid.styles.mjs +56 -0
- package/dist/components/Grid/Grid.styles.mjs.map +1 -0
- package/dist/components/Grid/index.d.mts +1 -0
- package/dist/components/HStack/HStack.cjs +17 -0
- package/dist/components/HStack/HStack.d.cts +15 -0
- package/dist/components/HStack/HStack.d.cts.map +1 -0
- package/dist/components/HStack/HStack.d.mts +16 -0
- package/dist/components/HStack/HStack.d.mts.map +1 -0
- package/dist/components/HStack/HStack.mjs +16 -0
- package/dist/components/HStack/HStack.mjs.map +1 -0
- package/dist/components/HStack/index.d.mts +1 -0
- package/dist/components/Modal/Modal.cjs +81 -0
- package/dist/components/Modal/Modal.d.cts +64 -0
- package/dist/components/Modal/Modal.d.cts.map +1 -0
- package/dist/components/Modal/Modal.d.mts +65 -0
- package/dist/components/Modal/Modal.d.mts.map +1 -0
- package/dist/components/Modal/Modal.mjs +80 -0
- package/dist/components/Modal/Modal.mjs.map +1 -0
- package/dist/components/Modal/Modal.styles.cjs +49 -0
- package/dist/components/Modal/Modal.styles.d.cts +108 -0
- package/dist/components/Modal/Modal.styles.d.cts.map +1 -0
- package/dist/components/Modal/Modal.styles.d.mts +108 -0
- package/dist/components/Modal/Modal.styles.d.mts.map +1 -0
- package/dist/components/Modal/Modal.styles.mjs +49 -0
- package/dist/components/Modal/Modal.styles.mjs.map +1 -0
- package/dist/components/Modal/index.d.mts +2 -0
- package/dist/components/Primitive/Primitive.cjs +35 -0
- package/dist/components/Primitive/Primitive.d.cts +77 -0
- package/dist/components/Primitive/Primitive.d.cts.map +1 -0
- package/dist/components/Primitive/Primitive.d.mts +77 -0
- package/dist/components/Primitive/Primitive.d.mts.map +1 -0
- package/dist/components/Primitive/Primitive.mjs +34 -0
- package/dist/components/Primitive/Primitive.mjs.map +1 -0
- package/dist/components/Primitive/index.d.mts +1 -0
- package/dist/components/Radio/Radio.cjs +97 -0
- package/dist/components/Radio/Radio.d.cts +48 -0
- package/dist/components/Radio/Radio.d.cts.map +1 -0
- package/dist/components/Radio/Radio.d.mts +49 -0
- package/dist/components/Radio/Radio.d.mts.map +1 -0
- package/dist/components/Radio/Radio.mjs +94 -0
- package/dist/components/Radio/Radio.mjs.map +1 -0
- package/dist/components/Radio/Radio.styles.cjs +32 -0
- package/dist/components/Radio/Radio.styles.mjs +32 -0
- package/dist/components/Radio/Radio.styles.mjs.map +1 -0
- package/dist/components/Radio/index.d.mts +1 -0
- package/dist/components/RatioChart/RatioChart.cjs +182 -0
- package/dist/components/RatioChart/RatioChart.d.cts +66 -0
- package/dist/components/RatioChart/RatioChart.d.cts.map +1 -0
- package/dist/components/RatioChart/RatioChart.d.mts +66 -0
- package/dist/components/RatioChart/RatioChart.d.mts.map +1 -0
- package/dist/components/RatioChart/RatioChart.mjs +181 -0
- package/dist/components/RatioChart/RatioChart.mjs.map +1 -0
- package/dist/components/RatioChart/RatioChart.styles.cjs +42 -0
- package/dist/components/RatioChart/RatioChart.styles.mjs +42 -0
- package/dist/components/RatioChart/RatioChart.styles.mjs.map +1 -0
- package/dist/components/RatioChart/RatioChartEditor.cjs +121 -0
- package/dist/components/RatioChart/RatioChartEditor.d.cts +44 -0
- package/dist/components/RatioChart/RatioChartEditor.d.cts.map +1 -0
- package/dist/components/RatioChart/RatioChartEditor.d.mts +44 -0
- package/dist/components/RatioChart/RatioChartEditor.d.mts.map +1 -0
- package/dist/components/RatioChart/RatioChartEditor.mjs +120 -0
- package/dist/components/RatioChart/RatioChartEditor.mjs.map +1 -0
- package/dist/components/RatioChart/RatioChartEditor.styles.cjs +23 -0
- package/dist/components/RatioChart/RatioChartEditor.styles.mjs +23 -0
- package/dist/components/RatioChart/RatioChartEditor.styles.mjs.map +1 -0
- package/dist/components/RatioChart/index.d.mts +2 -0
- package/dist/components/Select/Select.cjs +84 -0
- package/dist/components/Select/Select.d.cts +60 -0
- package/dist/components/Select/Select.d.cts.map +1 -0
- package/dist/components/Select/Select.d.mts +60 -0
- package/dist/components/Select/Select.d.mts.map +1 -0
- package/dist/components/Select/Select.mjs +82 -0
- package/dist/components/Select/Select.mjs.map +1 -0
- package/dist/components/Select/Select.styles.cjs +44 -0
- package/dist/components/Select/Select.styles.d.cts +72 -0
- package/dist/components/Select/Select.styles.d.cts.map +1 -0
- package/dist/components/Select/Select.styles.d.mts +72 -0
- package/dist/components/Select/Select.styles.d.mts.map +1 -0
- package/dist/components/Select/Select.styles.mjs +44 -0
- package/dist/components/Select/Select.styles.mjs.map +1 -0
- package/dist/components/Select/index.d.mts +2 -0
- package/dist/components/Separator/Separator.cjs +21 -0
- package/dist/components/Separator/Separator.d.cts +18 -0
- package/dist/components/Separator/Separator.d.cts.map +1 -0
- package/dist/components/Separator/Separator.d.mts +19 -0
- package/dist/components/Separator/Separator.d.mts.map +1 -0
- package/dist/components/Separator/Separator.mjs +20 -0
- package/dist/components/Separator/Separator.mjs.map +1 -0
- package/dist/components/Separator/Separator.styles.cjs +15 -0
- package/dist/components/Separator/Separator.styles.d.cts +24 -0
- package/dist/components/Separator/Separator.styles.d.cts.map +1 -0
- package/dist/components/Separator/Separator.styles.d.mts +24 -0
- package/dist/components/Separator/Separator.styles.d.mts.map +1 -0
- package/dist/components/Separator/Separator.styles.mjs +15 -0
- package/dist/components/Separator/Separator.styles.mjs.map +1 -0
- package/dist/components/Separator/index.d.mts +2 -0
- package/dist/components/Spacer/Spacer.cjs +20 -0
- package/dist/components/Spacer/Spacer.d.cts +18 -0
- package/dist/components/Spacer/Spacer.d.cts.map +1 -0
- package/dist/components/Spacer/Spacer.d.mts +19 -0
- package/dist/components/Spacer/Spacer.d.mts.map +1 -0
- package/dist/components/Spacer/Spacer.mjs +19 -0
- package/dist/components/Spacer/Spacer.mjs.map +1 -0
- package/dist/components/Spacer/Spacer.styles.cjs +24 -0
- package/dist/components/Spacer/Spacer.styles.d.cts +51 -0
- package/dist/components/Spacer/Spacer.styles.d.cts.map +1 -0
- package/dist/components/Spacer/Spacer.styles.d.mts +51 -0
- package/dist/components/Spacer/Spacer.styles.d.mts.map +1 -0
- package/dist/components/Spacer/Spacer.styles.mjs +24 -0
- package/dist/components/Spacer/Spacer.styles.mjs.map +1 -0
- package/dist/components/Spacer/index.d.mts +2 -0
- package/dist/components/Stack/Stack.cjs +28 -0
- package/dist/components/Stack/Stack.d.cts +26 -0
- package/dist/components/Stack/Stack.d.cts.map +1 -0
- package/dist/components/Stack/Stack.d.mts +27 -0
- package/dist/components/Stack/Stack.d.mts.map +1 -0
- package/dist/components/Stack/Stack.mjs +27 -0
- package/dist/components/Stack/Stack.mjs.map +1 -0
- package/dist/components/Stack/Stack.styles.cjs +42 -0
- package/dist/components/Stack/Stack.styles.d.cts +84 -0
- package/dist/components/Stack/Stack.styles.d.cts.map +1 -0
- package/dist/components/Stack/Stack.styles.d.mts +84 -0
- package/dist/components/Stack/Stack.styles.d.mts.map +1 -0
- package/dist/components/Stack/Stack.styles.mjs +42 -0
- package/dist/components/Stack/Stack.styles.mjs.map +1 -0
- package/dist/components/Stack/index.d.mts +2 -0
- package/dist/components/Tab/Tab.cjs +103 -0
- package/dist/components/Tab/Tab.d.cts +84 -0
- package/dist/components/Tab/Tab.d.cts.map +1 -0
- package/dist/components/Tab/Tab.d.mts +85 -0
- package/dist/components/Tab/Tab.d.mts.map +1 -0
- package/dist/components/Tab/Tab.mjs +102 -0
- package/dist/components/Tab/Tab.mjs.map +1 -0
- package/dist/components/Tab/Tab.styles.cjs +35 -0
- package/dist/components/Tab/Tab.styles.d.cts +51 -0
- package/dist/components/Tab/Tab.styles.d.cts.map +1 -0
- package/dist/components/Tab/Tab.styles.d.mts +51 -0
- package/dist/components/Tab/Tab.styles.d.mts.map +1 -0
- package/dist/components/Tab/Tab.styles.mjs +35 -0
- package/dist/components/Tab/Tab.styles.mjs.map +1 -0
- package/dist/components/Tab/index.d.mts +2 -0
- package/dist/components/Text/Text.cjs +20 -0
- package/dist/components/Text/Text.d.cts +24 -0
- package/dist/components/Text/Text.d.cts.map +1 -0
- package/dist/components/Text/Text.d.mts +25 -0
- package/dist/components/Text/Text.d.mts.map +1 -0
- package/dist/components/Text/Text.mjs +20 -0
- package/dist/components/Text/Text.mjs.map +1 -0
- package/dist/components/Text/Text.styles.cjs +58 -0
- package/dist/components/Text/Text.styles.d.cts +150 -0
- package/dist/components/Text/Text.styles.d.cts.map +1 -0
- package/dist/components/Text/Text.styles.d.mts +150 -0
- package/dist/components/Text/Text.styles.d.mts.map +1 -0
- package/dist/components/Text/Text.styles.mjs +58 -0
- package/dist/components/Text/Text.styles.mjs.map +1 -0
- package/dist/components/Text/index.d.mts +2 -0
- package/dist/components/TextArea/TextArea.cjs +52 -0
- package/dist/components/TextArea/TextArea.d.cts +42 -0
- package/dist/components/TextArea/TextArea.d.cts.map +1 -0
- package/dist/components/TextArea/TextArea.d.mts +43 -0
- package/dist/components/TextArea/TextArea.d.mts.map +1 -0
- package/dist/components/TextArea/TextArea.mjs +51 -0
- package/dist/components/TextArea/TextArea.mjs.map +1 -0
- package/dist/components/TextArea/TextArea.styles.cjs +33 -0
- package/dist/components/TextArea/TextArea.styles.d.cts +84 -0
- package/dist/components/TextArea/TextArea.styles.d.cts.map +1 -0
- package/dist/components/TextArea/TextArea.styles.d.mts +84 -0
- package/dist/components/TextArea/TextArea.styles.d.mts.map +1 -0
- package/dist/components/TextArea/TextArea.styles.mjs +33 -0
- package/dist/components/TextArea/TextArea.styles.mjs.map +1 -0
- package/dist/components/TextArea/index.d.mts +1 -0
- package/dist/components/TextInput/TextInput.cjs +48 -0
- package/dist/components/TextInput/TextInput.d.cts +32 -0
- package/dist/components/TextInput/TextInput.d.cts.map +1 -0
- package/dist/components/TextInput/TextInput.d.mts +33 -0
- package/dist/components/TextInput/TextInput.d.mts.map +1 -0
- package/dist/components/TextInput/TextInput.mjs +47 -0
- package/dist/components/TextInput/TextInput.mjs.map +1 -0
- package/dist/components/TextInput/TextInput.styles.cjs +43 -0
- package/dist/components/TextInput/TextInput.styles.d.cts +81 -0
- package/dist/components/TextInput/TextInput.styles.d.cts.map +1 -0
- package/dist/components/TextInput/TextInput.styles.d.mts +81 -0
- package/dist/components/TextInput/TextInput.styles.d.mts.map +1 -0
- package/dist/components/TextInput/TextInput.styles.mjs +43 -0
- package/dist/components/TextInput/TextInput.styles.mjs.map +1 -0
- package/dist/components/TextInput/index.d.mts +2 -0
- package/dist/components/Toast/Toast.cjs +42 -0
- package/dist/components/Toast/Toast.d.cts +27 -0
- package/dist/components/Toast/Toast.d.cts.map +1 -0
- package/dist/components/Toast/Toast.d.mts +27 -0
- package/dist/components/Toast/Toast.d.mts.map +1 -0
- package/dist/components/Toast/Toast.mjs +39 -0
- package/dist/components/Toast/Toast.mjs.map +1 -0
- package/dist/components/Toast/Toast.styles.cjs +20 -0
- package/dist/components/Toast/Toast.styles.d.cts +36 -0
- package/dist/components/Toast/Toast.styles.d.cts.map +1 -0
- package/dist/components/Toast/Toast.styles.d.mts +36 -0
- package/dist/components/Toast/Toast.styles.d.mts.map +1 -0
- package/dist/components/Toast/Toast.styles.mjs +20 -0
- package/dist/components/Toast/Toast.styles.mjs.map +1 -0
- package/dist/components/Toast/index.d.mts +2 -0
- package/dist/components/Toggle/Toggle.cjs +71 -0
- package/dist/components/Toggle/Toggle.d.cts +44 -0
- package/dist/components/Toggle/Toggle.d.cts.map +1 -0
- package/dist/components/Toggle/Toggle.d.mts +46 -0
- package/dist/components/Toggle/Toggle.d.mts.map +1 -0
- package/dist/components/Toggle/Toggle.mjs +70 -0
- package/dist/components/Toggle/Toggle.mjs.map +1 -0
- package/dist/components/Toggle/Toggle.styles.cjs +31 -0
- package/dist/components/Toggle/Toggle.styles.d.cts +75 -0
- package/dist/components/Toggle/Toggle.styles.d.cts.map +1 -0
- package/dist/components/Toggle/Toggle.styles.d.mts +75 -0
- package/dist/components/Toggle/Toggle.styles.d.mts.map +1 -0
- package/dist/components/Toggle/Toggle.styles.mjs +31 -0
- package/dist/components/Toggle/Toggle.styles.mjs.map +1 -0
- package/dist/components/Toggle/index.d.mts +1 -0
- package/dist/components/VStack/VStack.cjs +17 -0
- package/dist/components/VStack/VStack.d.cts +15 -0
- package/dist/components/VStack/VStack.d.cts.map +1 -0
- package/dist/components/VStack/VStack.d.mts +16 -0
- package/dist/components/VStack/VStack.d.mts.map +1 -0
- package/dist/components/VStack/VStack.mjs +16 -0
- package/dist/components/VStack/VStack.mjs.map +1 -0
- package/dist/components/VStack/index.d.mts +1 -0
- package/dist/components/index.d.mts +74 -0
- package/dist/hooks/field/useFieldContext.cjs +18 -0
- package/dist/hooks/field/useFieldContext.mjs +17 -0
- package/dist/hooks/field/useFieldContext.mjs.map +1 -0
- package/dist/hooks/ratioChart/useRatioChartContext.cjs +14 -0
- package/dist/hooks/ratioChart/useRatioChartContext.mjs +13 -0
- package/dist/hooks/ratioChart/useRatioChartContext.mjs.map +1 -0
- package/dist/index.cjs +73 -0
- package/dist/index.d.cts +50 -0
- package/dist/index.d.mts +52 -207
- package/dist/index.mjs +35 -658
- package/dist/utils/converter/converter.cjs +9 -0
- package/dist/utils/converter/converter.d.cts +5 -0
- package/dist/utils/converter/converter.d.cts.map +1 -0
- package/dist/utils/converter/converter.d.mts +5 -0
- package/dist/utils/converter/converter.d.mts.map +1 -0
- package/dist/utils/converter/converter.mjs +9 -0
- package/dist/utils/converter/converter.mjs.map +1 -0
- package/dist/utils/index.d.mts +6 -0
- package/dist/utils/mergeStyles/index.d.mts +1 -0
- package/dist/utils/mergeStyles/mergeStyles.cjs +18 -0
- package/dist/utils/mergeStyles/mergeStyles.d.cts +14 -0
- package/dist/utils/mergeStyles/mergeStyles.d.cts.map +1 -0
- package/dist/utils/mergeStyles/mergeStyles.d.mts +14 -0
- package/dist/utils/mergeStyles/mergeStyles.d.mts.map +1 -0
- package/dist/utils/mergeStyles/mergeStyles.mjs +18 -0
- package/dist/utils/mergeStyles/mergeStyles.mjs.map +1 -0
- package/dist/utils/polymorphic/index.d.mts +1 -0
- package/dist/utils/polymorphic/polymorphic.d.cts +24 -0
- package/dist/utils/polymorphic/polymorphic.d.cts.map +1 -0
- package/dist/utils/polymorphic/polymorphic.d.mts +24 -0
- package/dist/utils/polymorphic/polymorphic.d.mts.map +1 -0
- package/dist/utils/splitter/splitter.cjs +12 -0
- package/dist/utils/splitter/splitter.d.cts +5 -0
- package/dist/utils/splitter/splitter.d.cts.map +1 -0
- package/dist/utils/splitter/splitter.d.mts +5 -0
- package/dist/utils/splitter/splitter.d.mts.map +1 -0
- package/dist/utils/splitter/splitter.mjs +12 -0
- package/dist/utils/splitter/splitter.mjs.map +1 -0
- package/package.json +22 -10
- package/src/styles/global.css +162 -79
- package/dist/index.d.ts +0 -207
- package/dist/index.js +0 -674
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import * as react_jsx_runtime25 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/RatioChart/RatioChart.d.ts
|
|
5
|
+
interface RatioChartRootSingleProps extends Omit<React.ComponentProps<'div'>, 'defaultValue'> {
|
|
6
|
+
mode?: 'single';
|
|
7
|
+
value?: string;
|
|
8
|
+
defaultValue?: string;
|
|
9
|
+
onValueChange?: (value: string) => void;
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
}
|
|
12
|
+
interface RatioChartRootMultipleProps extends Omit<React.ComponentProps<'div'>, 'defaultValue'> {
|
|
13
|
+
mode: 'multiple';
|
|
14
|
+
value?: string[];
|
|
15
|
+
defaultValue?: string[];
|
|
16
|
+
onValueChange?: (value: string[]) => void;
|
|
17
|
+
disabled?: boolean;
|
|
18
|
+
}
|
|
19
|
+
type RatioChartRootProps = RatioChartRootSingleProps | RatioChartRootMultipleProps;
|
|
20
|
+
interface RatioChartItemProps extends Omit<React.ComponentProps<'button'>, 'value'> {
|
|
21
|
+
value: string;
|
|
22
|
+
label: string;
|
|
23
|
+
count?: number;
|
|
24
|
+
ratio?: number;
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
}
|
|
27
|
+
interface RatioChartFooterProps extends React.ComponentProps<'div'> {
|
|
28
|
+
endDate?: Date;
|
|
29
|
+
endTime?: string;
|
|
30
|
+
hideParticipantCount?: boolean;
|
|
31
|
+
}
|
|
32
|
+
declare const RatioChart: {
|
|
33
|
+
(props: RatioChartRootProps): react_jsx_runtime25.JSX.Element;
|
|
34
|
+
displayName: string;
|
|
35
|
+
} & {
|
|
36
|
+
Root: {
|
|
37
|
+
(props: RatioChartRootProps): react_jsx_runtime25.JSX.Element;
|
|
38
|
+
displayName: string;
|
|
39
|
+
};
|
|
40
|
+
Item: {
|
|
41
|
+
({
|
|
42
|
+
value,
|
|
43
|
+
label,
|
|
44
|
+
count,
|
|
45
|
+
ratio,
|
|
46
|
+
disabled: itemDisabled,
|
|
47
|
+
className,
|
|
48
|
+
...props
|
|
49
|
+
}: RatioChartItemProps): react_jsx_runtime25.JSX.Element;
|
|
50
|
+
displayName: string;
|
|
51
|
+
};
|
|
52
|
+
Footer: {
|
|
53
|
+
({
|
|
54
|
+
endDate,
|
|
55
|
+
endTime,
|
|
56
|
+
hideParticipantCount,
|
|
57
|
+
className,
|
|
58
|
+
children,
|
|
59
|
+
...props
|
|
60
|
+
}: RatioChartFooterProps): react_jsx_runtime25.JSX.Element;
|
|
61
|
+
displayName: string;
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
//#endregion
|
|
65
|
+
export { RatioChart, RatioChartFooterProps, RatioChartItemProps, RatioChartRootProps };
|
|
66
|
+
//# sourceMappingURL=RatioChart.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RatioChart.d.mts","names":[],"sources":["../../../src/components/RatioChart/RatioChart.tsx"],"mappings":";;;;UAUU,yBAAA,SAAkC,IAAA,CAC1C,KAAA,CAAM,cAAA;EAGN,IAAA;EACA,KAAA;EACA,YAAA;EACA,aAAA,IAAiB,KAAA;EACjB,QAAA;AAAA;AAAA,UAIQ,2BAAA,SAAoC,IAAA,CAC5C,KAAA,CAAM,cAAA;EAGN,IAAA;EACA,KAAA;EACA,YAAA;EACA,aAAA,IAAiB,KAAA;EACjB,QAAA;AAAA;AAAA,KAGU,mBAAA,GACR,yBAAA,GACA,2BAAA;AAAA,UAmIa,mBAAA,SAA4B,IAAA,CAC3C,KAAA,CAAM,cAAA;EAGN,KAAA;EACA,KAAA;EACA,KAAA;EACA,KAAA;EACA,QAAA;AAAA;AAAA,UAuGe,qBAAA,SAA8B,KAAA,CAAM,cAAA;EACnD,OAAA,GAAU,IAAA;EACV,OAAA;EACA,oBAAA;AAAA;AAAA,cA8DW,UAAA;EAAA,QAjTkB,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;YAAnB,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;;;;;;;;;OAoJ/C,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;;;;;;;;OAiInB,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { RatioChartContext, useRatioChartContext } from "../../hooks/ratioChart/useRatioChartContext.mjs";
|
|
2
|
+
import { mergeStyles } from "../../utils/mergeStyles/mergeStyles.mjs";
|
|
3
|
+
import { ratioChart } from "./RatioChart.styles.mjs";
|
|
4
|
+
import React, { useCallback, useEffect, useMemo, useState } from "react";
|
|
5
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
6
|
+
|
|
7
|
+
//#region src/components/RatioChart/RatioChart.tsx
|
|
8
|
+
const RatioChartRoot = (props) => {
|
|
9
|
+
const { mode = "single", value: valueProp, defaultValue, onValueChange, disabled, children, className, ...rest } = props;
|
|
10
|
+
const [internalSingleValue, setInternalSingleValue] = useState(() => mode === "single" && typeof defaultValue === "string" ? defaultValue : "");
|
|
11
|
+
const [internalMultipleValue, setInternalMultipleValue] = useState(() => mode === "multiple" && Array.isArray(defaultValue) ? defaultValue : []);
|
|
12
|
+
const [counts, setCounts] = useState(/* @__PURE__ */ new Map());
|
|
13
|
+
const isControlled = valueProp !== void 0;
|
|
14
|
+
const currentValue = mode === "single" ? isControlled ? valueProp : internalSingleValue : isControlled ? valueProp : internalMultipleValue;
|
|
15
|
+
const isSelected = useCallback((itemValue) => {
|
|
16
|
+
if (mode === "single") return currentValue === itemValue;
|
|
17
|
+
return currentValue.includes(itemValue);
|
|
18
|
+
}, [mode, currentValue]);
|
|
19
|
+
const onSelect = useCallback((itemValue) => {
|
|
20
|
+
if (disabled) return;
|
|
21
|
+
if (mode === "single") {
|
|
22
|
+
if (!isControlled) setInternalSingleValue(itemValue);
|
|
23
|
+
onValueChange?.(itemValue);
|
|
24
|
+
} else {
|
|
25
|
+
const currentArray = currentValue;
|
|
26
|
+
const newValue = currentArray.includes(itemValue) ? currentArray.filter((v) => v !== itemValue) : [...currentArray, itemValue];
|
|
27
|
+
if (!isControlled) setInternalMultipleValue(newValue);
|
|
28
|
+
onValueChange?.(newValue);
|
|
29
|
+
}
|
|
30
|
+
}, [
|
|
31
|
+
mode,
|
|
32
|
+
disabled,
|
|
33
|
+
isControlled,
|
|
34
|
+
currentValue,
|
|
35
|
+
onValueChange
|
|
36
|
+
]);
|
|
37
|
+
const registerCount = useCallback((itemValue, count) => {
|
|
38
|
+
setCounts((prev) => new Map(prev).set(itemValue, count));
|
|
39
|
+
}, []);
|
|
40
|
+
const unregisterCount = useCallback((itemValue) => {
|
|
41
|
+
setCounts((prev) => {
|
|
42
|
+
const next = new Map(prev);
|
|
43
|
+
next.delete(itemValue);
|
|
44
|
+
return next;
|
|
45
|
+
});
|
|
46
|
+
}, []);
|
|
47
|
+
const totalCount = useMemo(() => {
|
|
48
|
+
let total = 0;
|
|
49
|
+
counts.forEach((c) => total += c);
|
|
50
|
+
return total;
|
|
51
|
+
}, [counts]);
|
|
52
|
+
const getRatio = useCallback((itemValue) => {
|
|
53
|
+
const count = counts.get(itemValue) ?? 0;
|
|
54
|
+
return totalCount > 0 ? Math.round(count / totalCount * 100) : 0;
|
|
55
|
+
}, [counts, totalCount]);
|
|
56
|
+
const styles = ratioChart({ disabled });
|
|
57
|
+
return /* @__PURE__ */ jsx(RatioChartContext.Provider, {
|
|
58
|
+
value: {
|
|
59
|
+
value: currentValue,
|
|
60
|
+
mode,
|
|
61
|
+
disabled,
|
|
62
|
+
onSelect,
|
|
63
|
+
isSelected,
|
|
64
|
+
counts,
|
|
65
|
+
registerCount,
|
|
66
|
+
unregisterCount,
|
|
67
|
+
totalCount,
|
|
68
|
+
getRatio
|
|
69
|
+
},
|
|
70
|
+
children: /* @__PURE__ */ jsx("div", {
|
|
71
|
+
role: "group",
|
|
72
|
+
className: mergeStyles(styles.root(), className),
|
|
73
|
+
...rest,
|
|
74
|
+
children
|
|
75
|
+
})
|
|
76
|
+
});
|
|
77
|
+
};
|
|
78
|
+
const RatioChartItem = ({ value, label, count, ratio, disabled: itemDisabled, className, ...props }) => {
|
|
79
|
+
const { disabled: rootDisabled, onSelect, isSelected, registerCount, unregisterCount, getRatio } = useRatioChartContext();
|
|
80
|
+
const disabled = itemDisabled || rootDisabled;
|
|
81
|
+
const selected = isSelected(value);
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
if (count !== void 0) {
|
|
84
|
+
registerCount(value, count);
|
|
85
|
+
return () => unregisterCount(value);
|
|
86
|
+
}
|
|
87
|
+
}, [
|
|
88
|
+
count,
|
|
89
|
+
value,
|
|
90
|
+
registerCount,
|
|
91
|
+
unregisterCount
|
|
92
|
+
]);
|
|
93
|
+
const handleClick = () => {
|
|
94
|
+
if (!disabled) onSelect(value);
|
|
95
|
+
};
|
|
96
|
+
const handleKeyDown = (e) => {
|
|
97
|
+
if ((e.key === "Enter" || e.key === " ") && !disabled) {
|
|
98
|
+
e.preventDefault();
|
|
99
|
+
onSelect(value);
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
const displayRatio = count !== void 0 ? getRatio(value) : ratio ?? 0;
|
|
103
|
+
const showRatio = count !== void 0 || ratio !== void 0;
|
|
104
|
+
const styles = ratioChart({
|
|
105
|
+
disabled,
|
|
106
|
+
selected
|
|
107
|
+
});
|
|
108
|
+
const lightContent = ratioChart({ contentVariant: "light" });
|
|
109
|
+
const darkContent = ratioChart({ contentVariant: "dark" });
|
|
110
|
+
const contentElement = /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx("span", {
|
|
111
|
+
className: styles.label(),
|
|
112
|
+
children: label
|
|
113
|
+
}), showRatio && /* @__PURE__ */ jsxs("span", {
|
|
114
|
+
className: styles.ratio(),
|
|
115
|
+
children: [displayRatio, "%"]
|
|
116
|
+
})] });
|
|
117
|
+
return /* @__PURE__ */ jsxs("button", {
|
|
118
|
+
type: "button",
|
|
119
|
+
role: "option",
|
|
120
|
+
"aria-selected": selected,
|
|
121
|
+
disabled,
|
|
122
|
+
onClick: handleClick,
|
|
123
|
+
onKeyDown: handleKeyDown,
|
|
124
|
+
className: mergeStyles(styles.item(), className),
|
|
125
|
+
style: { minWidth: 0 },
|
|
126
|
+
...props,
|
|
127
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
128
|
+
className: styles.fill(),
|
|
129
|
+
style: { width: `${displayRatio}%` }
|
|
130
|
+
}), selected ? /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx("span", {
|
|
131
|
+
className: lightContent.content(),
|
|
132
|
+
style: { clipPath: `inset(0 ${100 - displayRatio}% 0 0)` },
|
|
133
|
+
children: contentElement
|
|
134
|
+
}), /* @__PURE__ */ jsx("span", {
|
|
135
|
+
className: darkContent.content(),
|
|
136
|
+
style: { clipPath: `inset(0 0 0 ${displayRatio}%)` },
|
|
137
|
+
children: contentElement
|
|
138
|
+
})] }) : /* @__PURE__ */ jsx("span", {
|
|
139
|
+
className: darkContent.content(),
|
|
140
|
+
children: contentElement
|
|
141
|
+
})]
|
|
142
|
+
});
|
|
143
|
+
};
|
|
144
|
+
function formatTimeRemaining(endDate) {
|
|
145
|
+
const now = /* @__PURE__ */ new Date();
|
|
146
|
+
const diff = endDate.getTime() - now.getTime();
|
|
147
|
+
if (diff <= 0) return "종료됨";
|
|
148
|
+
const totalHours = diff / (1e3 * 60 * 60);
|
|
149
|
+
const totalMinutes = diff / (1e3 * 60);
|
|
150
|
+
if (totalHours >= 24) return `${Math.round(totalHours / 24)}일 후 종료`;
|
|
151
|
+
if (totalHours >= 1) return `${Math.floor(totalHours)}시간 후 종료`;
|
|
152
|
+
return `${Math.floor(totalMinutes)}분 후 종료`;
|
|
153
|
+
}
|
|
154
|
+
const RatioChartFooter = ({ endDate, endTime, hideParticipantCount, className, children, ...props }) => {
|
|
155
|
+
const { totalCount } = useRatioChartContext();
|
|
156
|
+
const displayEndTime = endDate ? formatTimeRemaining(endDate) : endTime;
|
|
157
|
+
const styles = ratioChart();
|
|
158
|
+
return /* @__PURE__ */ jsx("div", {
|
|
159
|
+
className: mergeStyles(styles.footer(), className),
|
|
160
|
+
...props,
|
|
161
|
+
children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [!hideParticipantCount && /* @__PURE__ */ jsxs("span", {
|
|
162
|
+
className: styles.footerText(),
|
|
163
|
+
children: [totalCount, "명 참여"]
|
|
164
|
+
}), displayEndTime && /* @__PURE__ */ jsx("span", {
|
|
165
|
+
className: styles.footerText(),
|
|
166
|
+
children: displayEndTime
|
|
167
|
+
})] })
|
|
168
|
+
});
|
|
169
|
+
};
|
|
170
|
+
RatioChartRoot.displayName = "RatioChart.Root";
|
|
171
|
+
RatioChartItem.displayName = "RatioChart.Item";
|
|
172
|
+
RatioChartFooter.displayName = "RatioChart.Footer";
|
|
173
|
+
const RatioChart = Object.assign(RatioChartRoot, {
|
|
174
|
+
Root: RatioChartRoot,
|
|
175
|
+
Item: RatioChartItem,
|
|
176
|
+
Footer: RatioChartFooter
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
//#endregion
|
|
180
|
+
export { RatioChart };
|
|
181
|
+
//# sourceMappingURL=RatioChart.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RatioChart.mjs","names":[],"sources":["../../../src/components/RatioChart/RatioChart.tsx"],"sourcesContent":["import React, { useState, useCallback, useMemo, useEffect } from 'react';\nimport { mergeStyles } from '../../utils';\nimport { RatioChartContext } from '../../hooks/ratioChart/useRatioChartContext';\nimport {\n useRatioChartContext,\n type RatioChartSelectionMode,\n} from '../../hooks/ratioChart';\nimport { ratioChart } from './RatioChart.styles';\n\n// Root Props - 단일 선택\ninterface RatioChartRootSingleProps extends Omit<\n React.ComponentProps<'div'>,\n 'defaultValue'\n> {\n mode?: 'single';\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n disabled?: boolean;\n}\n\n// Root Props - 다중 선택\ninterface RatioChartRootMultipleProps extends Omit<\n React.ComponentProps<'div'>,\n 'defaultValue'\n> {\n mode: 'multiple';\n value?: string[];\n defaultValue?: string[];\n onValueChange?: (value: string[]) => void;\n disabled?: boolean;\n}\n\nexport type RatioChartRootProps =\n | RatioChartRootSingleProps\n | RatioChartRootMultipleProps;\n\nconst RatioChartRoot = (props: RatioChartRootProps) => {\n const {\n mode = 'single',\n value: valueProp,\n defaultValue,\n onValueChange,\n disabled,\n children,\n className,\n ...rest\n } = props;\n\n // 단일 선택 내부 상태\n const [internalSingleValue, setInternalSingleValue] = useState<string>(() =>\n mode === 'single' && typeof defaultValue === 'string' ? defaultValue : '',\n );\n\n // 다중 선택 내부 상태\n const [internalMultipleValue, setInternalMultipleValue] = useState<string[]>(\n () =>\n mode === 'multiple' && Array.isArray(defaultValue) ? defaultValue : [],\n );\n\n // count 기반 자동 비율 계산을 위한 state\n const [counts, setCounts] = useState<Map<string, number>>(new Map());\n\n const isControlled = valueProp !== undefined;\n\n const currentValue =\n mode === 'single'\n ? isControlled\n ? (valueProp as string)\n : internalSingleValue\n : isControlled\n ? (valueProp as string[])\n : internalMultipleValue;\n\n const isSelected = useCallback(\n (itemValue: string) => {\n if (mode === 'single') {\n return currentValue === itemValue;\n }\n return (currentValue as string[]).includes(itemValue);\n },\n [mode, currentValue],\n );\n\n const onSelect = useCallback(\n (itemValue: string) => {\n if (disabled) return;\n\n if (mode === 'single') {\n if (!isControlled) {\n setInternalSingleValue(itemValue);\n }\n (onValueChange as ((value: string) => void) | undefined)?.(itemValue);\n } else {\n const currentArray = currentValue as string[];\n const newValue = currentArray.includes(itemValue)\n ? currentArray.filter((v) => v !== itemValue)\n : [...currentArray, itemValue];\n\n if (!isControlled) {\n setInternalMultipleValue(newValue);\n }\n (onValueChange as ((value: string[]) => void) | undefined)?.(newValue);\n }\n },\n [mode, disabled, isControlled, currentValue, onValueChange],\n );\n\n // count 등록/해제 함수\n const registerCount = useCallback((itemValue: string, count: number) => {\n setCounts((prev) => new Map(prev).set(itemValue, count));\n }, []);\n\n const unregisterCount = useCallback((itemValue: string) => {\n setCounts((prev) => {\n const next = new Map(prev);\n next.delete(itemValue);\n return next;\n });\n }, []);\n\n // 전체 count 합계\n const totalCount = useMemo(() => {\n let total = 0;\n counts.forEach((c) => (total += c));\n return total;\n }, [counts]);\n\n // 항목의 비율 계산\n const getRatio = useCallback(\n (itemValue: string) => {\n const count = counts.get(itemValue) ?? 0;\n return totalCount > 0 ? Math.round((count / totalCount) * 100) : 0;\n },\n [counts, totalCount],\n );\n\n const styles = ratioChart({ disabled });\n\n return (\n <RatioChartContext.Provider\n value={{\n value: currentValue,\n mode: mode as RatioChartSelectionMode,\n disabled,\n onSelect,\n isSelected,\n counts,\n registerCount,\n unregisterCount,\n totalCount,\n getRatio,\n }}\n >\n <div\n role=\"group\"\n className={mergeStyles(styles.root(), className)}\n {...rest}\n >\n {children}\n </div>\n </RatioChartContext.Provider>\n );\n};\n\n// Item Props\nexport interface RatioChartItemProps extends Omit<\n React.ComponentProps<'button'>,\n 'value'\n> {\n value: string;\n label: string;\n count?: number; // count만 전달하면 자동으로 비율 계산\n ratio?: number; // 0-100, 직접 비율 지정 (count사용 시 count 우선)\n disabled?: boolean;\n}\n\nconst RatioChartItem = ({\n value,\n label,\n count,\n ratio,\n disabled: itemDisabled,\n className,\n ...props\n}: RatioChartItemProps) => {\n const {\n disabled: rootDisabled,\n onSelect,\n isSelected,\n registerCount,\n unregisterCount,\n getRatio,\n } = useRatioChartContext();\n const disabled = itemDisabled || rootDisabled;\n const selected = isSelected(value);\n\n // count가 있으면 등록\n useEffect(() => {\n if (count !== undefined) {\n registerCount(value, count);\n return () => unregisterCount(value);\n }\n }, [count, value, registerCount, unregisterCount]);\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value);\n }\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n if ((e.key === 'Enter' || e.key === ' ') && !disabled) {\n e.preventDefault();\n onSelect(value);\n }\n };\n\n // count가 있으면 자동 계산, 없으면 ratio prop 사용, 둘 다 없으면 0\n const displayRatio = count !== undefined ? getRatio(value) : (ratio ?? 0);\n // ratio 표시 여부: count가 있거나 ratio가 명시적으로 지정된 경우\n const showRatio = count !== undefined || ratio !== undefined;\n\n const styles = ratioChart({ disabled, selected });\n const lightContent = ratioChart({ contentVariant: 'light' });\n const darkContent = ratioChart({ contentVariant: 'dark' });\n\n // 텍스트 컨텐츠\n const contentElement = (\n <>\n <span className={styles.label()}>{label}</span>\n {showRatio && <span className={styles.ratio()}>{displayRatio}%</span>}\n </>\n );\n\n return (\n <button\n type=\"button\"\n role=\"option\"\n aria-selected={selected}\n disabled={disabled}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n className={mergeStyles(styles.item(), className)}\n style={{ minWidth: 0 }}\n {...props}\n >\n {/* 비율 배경 */}\n <span className={styles.fill()} style={{ width: `${displayRatio}%` }} />\n\n {selected ? (\n <>\n {/* selected: 흰색 텍스트 (fill 영역에서만 보임) */}\n <span\n className={lightContent.content()}\n style={{ clipPath: `inset(0 ${100 - displayRatio}% 0 0)` }}\n >\n {contentElement}\n </span>\n\n {/* selected: 검은색 텍스트 (fill 밖에서만 보임) */}\n <span\n className={darkContent.content()}\n style={{ clipPath: `inset(0 0 0 ${displayRatio}%)` }}\n >\n {contentElement}\n </span>\n </>\n ) : (\n /* unselected: 검은색 텍스트 하나만 */\n <span className={darkContent.content()}>{contentElement}</span>\n )}\n </button>\n );\n};\n\n// Footer Props\nexport interface RatioChartFooterProps extends React.ComponentProps<'div'> {\n endDate?: Date; // 종료 시간 자동 계산\n endTime?: string; // 직접 문자열 지정\n hideParticipantCount?: boolean;\n}\n\n// 남은 시간 계산\nfunction formatTimeRemaining(endDate: Date): string {\n const now = new Date();\n const diff = endDate.getTime() - now.getTime();\n\n if (diff <= 0) return '종료됨';\n\n const totalHours = diff / (1000 * 60 * 60);\n const totalMinutes = diff / (1000 * 60);\n\n // 24시간 이상이면 일 단위 (12시간 기준 반올림/내림)\n if (totalHours >= 24) {\n return `${Math.round(totalHours / 24)}일 후 종료`;\n }\n\n // 1시간 이상이면 시간 단위 (내림)\n if (totalHours >= 1) {\n return `${Math.floor(totalHours)}시간 후 종료`;\n }\n\n // 그 외 분 단위 (내림)\n return `${Math.floor(totalMinutes)}분 후 종료`;\n}\n\nconst RatioChartFooter = ({\n endDate,\n endTime,\n hideParticipantCount,\n className,\n children,\n ...props\n}: RatioChartFooterProps) => {\n const { totalCount } = useRatioChartContext();\n\n // endDate가 있으면 자동 계산, 없으면 endTime 사용\n const displayEndTime = endDate ? formatTimeRemaining(endDate) : endTime;\n\n const styles = ratioChart();\n\n return (\n <div className={mergeStyles(styles.footer(), className)} {...props}>\n {children ?? (\n <>\n {!hideParticipantCount && (\n <span className={styles.footerText()}>{totalCount}명 참여</span>\n )}\n {displayEndTime && (\n <span className={styles.footerText()}>{displayEndTime}</span>\n )}\n </>\n )}\n </div>\n );\n};\n\nRatioChartRoot.displayName = 'RatioChart.Root';\nRatioChartItem.displayName = 'RatioChart.Item';\nRatioChartFooter.displayName = 'RatioChart.Footer';\n\nexport const RatioChart = Object.assign(RatioChartRoot, {\n Root: RatioChartRoot,\n Item: RatioChartItem,\n Footer: RatioChartFooter,\n});\n"],"mappings":";;;;;;;AAqCA,MAAM,kBAAkB,UAA+B;CACrD,MAAM,EACJ,OAAO,UACP,OAAO,WACP,cACA,eACA,UACA,UACA,WACA,GAAG,SACD;CAGJ,MAAM,CAAC,qBAAqB,0BAA0B,eACpD,SAAS,YAAY,OAAO,iBAAiB,WAAW,eAAe,GACxE;CAGD,MAAM,CAAC,uBAAuB,4BAA4B,eAEtD,SAAS,cAAc,MAAM,QAAQ,aAAa,GAAG,eAAe,EAAE,CACzE;CAGD,MAAM,CAAC,QAAQ,aAAa,yBAA8B,IAAI,KAAK,CAAC;CAEpE,MAAM,eAAe,cAAc;CAEnC,MAAM,eACJ,SAAS,WACL,eACG,YACD,sBACF,eACG,YACD;CAER,MAAM,aAAa,aAChB,cAAsB;AACrB,MAAI,SAAS,SACX,QAAO,iBAAiB;AAE1B,SAAQ,aAA0B,SAAS,UAAU;IAEvD,CAAC,MAAM,aAAa,CACrB;CAED,MAAM,WAAW,aACd,cAAsB;AACrB,MAAI,SAAU;AAEd,MAAI,SAAS,UAAU;AACrB,OAAI,CAAC,aACH,wBAAuB,UAAU;AAEnC,GAAC,gBAA0D,UAAU;SAChE;GACL,MAAM,eAAe;GACrB,MAAM,WAAW,aAAa,SAAS,UAAU,GAC7C,aAAa,QAAQ,MAAM,MAAM,UAAU,GAC3C,CAAC,GAAG,cAAc,UAAU;AAEhC,OAAI,CAAC,aACH,0BAAyB,SAAS;AAEpC,GAAC,gBAA4D,SAAS;;IAG1E;EAAC;EAAM;EAAU;EAAc;EAAc;EAAc,CAC5D;CAGD,MAAM,gBAAgB,aAAa,WAAmB,UAAkB;AACtE,aAAW,SAAS,IAAI,IAAI,KAAK,CAAC,IAAI,WAAW,MAAM,CAAC;IACvD,EAAE,CAAC;CAEN,MAAM,kBAAkB,aAAa,cAAsB;AACzD,aAAW,SAAS;GAClB,MAAM,OAAO,IAAI,IAAI,KAAK;AAC1B,QAAK,OAAO,UAAU;AACtB,UAAO;IACP;IACD,EAAE,CAAC;CAGN,MAAM,aAAa,cAAc;EAC/B,IAAI,QAAQ;AACZ,SAAO,SAAS,MAAO,SAAS,EAAG;AACnC,SAAO;IACN,CAAC,OAAO,CAAC;CAGZ,MAAM,WAAW,aACd,cAAsB;EACrB,MAAM,QAAQ,OAAO,IAAI,UAAU,IAAI;AACvC,SAAO,aAAa,IAAI,KAAK,MAAO,QAAQ,aAAc,IAAI,GAAG;IAEnE,CAAC,QAAQ,WAAW,CACrB;CAED,MAAM,SAAS,WAAW,EAAE,UAAU,CAAC;AAEvC,QACE,oBAAC,kBAAkB;EACjB,OAAO;GACL,OAAO;GACD;GACN;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACD;YAED,oBAAC;GACC,MAAK;GACL,WAAW,YAAY,OAAO,MAAM,EAAE,UAAU;GAChD,GAAI;GAEH;IACG;GACqB;;AAgBjC,MAAM,kBAAkB,EACtB,OACA,OACA,OACA,OACA,UAAU,cACV,WACA,GAAG,YACsB;CACzB,MAAM,EACJ,UAAU,cACV,UACA,YACA,eACA,iBACA,aACE,sBAAsB;CAC1B,MAAM,WAAW,gBAAgB;CACjC,MAAM,WAAW,WAAW,MAAM;AAGlC,iBAAgB;AACd,MAAI,UAAU,QAAW;AACvB,iBAAc,OAAO,MAAM;AAC3B,gBAAa,gBAAgB,MAAM;;IAEpC;EAAC;EAAO;EAAO;EAAe;EAAgB,CAAC;CAElD,MAAM,oBAAoB;AACxB,MAAI,CAAC,SACH,UAAS,MAAM;;CAInB,MAAM,iBAAiB,MAA8C;AACnE,OAAK,EAAE,QAAQ,WAAW,EAAE,QAAQ,QAAQ,CAAC,UAAU;AACrD,KAAE,gBAAgB;AAClB,YAAS,MAAM;;;CAKnB,MAAM,eAAe,UAAU,SAAY,SAAS,MAAM,GAAI,SAAS;CAEvE,MAAM,YAAY,UAAU,UAAa,UAAU;CAEnD,MAAM,SAAS,WAAW;EAAE;EAAU;EAAU,CAAC;CACjD,MAAM,eAAe,WAAW,EAAE,gBAAgB,SAAS,CAAC;CAC5D,MAAM,cAAc,WAAW,EAAE,gBAAgB,QAAQ,CAAC;CAG1D,MAAM,iBACJ,4CACE,oBAAC;EAAK,WAAW,OAAO,OAAO;YAAG;GAAa,EAC9C,aAAa,qBAAC;EAAK,WAAW,OAAO,OAAO;aAAG,cAAa;GAAQ,IACpE;AAGL,QACE,qBAAC;EACC,MAAK;EACL,MAAK;EACL,iBAAe;EACL;EACV,SAAS;EACT,WAAW;EACX,WAAW,YAAY,OAAO,MAAM,EAAE,UAAU;EAChD,OAAO,EAAE,UAAU,GAAG;EACtB,GAAI;aAGJ,oBAAC;GAAK,WAAW,OAAO,MAAM;GAAE,OAAO,EAAE,OAAO,GAAG,aAAa,IAAI;IAAI,EAEvE,WACC,4CAEE,oBAAC;GACC,WAAW,aAAa,SAAS;GACjC,OAAO,EAAE,UAAU,WAAW,MAAM,aAAa,SAAS;aAEzD;IACI,EAGP,oBAAC;GACC,WAAW,YAAY,SAAS;GAChC,OAAO,EAAE,UAAU,eAAe,aAAa,KAAK;aAEnD;IACI,IACN,GAGH,oBAAC;GAAK,WAAW,YAAY,SAAS;aAAG;IAAsB;GAE1D;;AAYb,SAAS,oBAAoB,SAAuB;CAClD,MAAM,sBAAM,IAAI,MAAM;CACtB,MAAM,OAAO,QAAQ,SAAS,GAAG,IAAI,SAAS;AAE9C,KAAI,QAAQ,EAAG,QAAO;CAEtB,MAAM,aAAa,QAAQ,MAAO,KAAK;CACvC,MAAM,eAAe,QAAQ,MAAO;AAGpC,KAAI,cAAc,GAChB,QAAO,GAAG,KAAK,MAAM,aAAa,GAAG,CAAC;AAIxC,KAAI,cAAc,EAChB,QAAO,GAAG,KAAK,MAAM,WAAW,CAAC;AAInC,QAAO,GAAG,KAAK,MAAM,aAAa,CAAC;;AAGrC,MAAM,oBAAoB,EACxB,SACA,SACA,sBACA,WACA,UACA,GAAG,YACwB;CAC3B,MAAM,EAAE,eAAe,sBAAsB;CAG7C,MAAM,iBAAiB,UAAU,oBAAoB,QAAQ,GAAG;CAEhE,MAAM,SAAS,YAAY;AAE3B,QACE,oBAAC;EAAI,WAAW,YAAY,OAAO,QAAQ,EAAE,UAAU;EAAE,GAAI;YAC1D,YACC,4CACG,CAAC,wBACA,qBAAC;GAAK,WAAW,OAAO,YAAY;cAAG,YAAW;IAAW,EAE9D,kBACC,oBAAC;GAAK,WAAW,OAAO,YAAY;aAAG;IAAsB,IAE9D;GAED;;AAIV,eAAe,cAAc;AAC7B,eAAe,cAAc;AAC7B,iBAAiB,cAAc;AAE/B,MAAa,aAAa,OAAO,OAAO,gBAAgB;CACtD,MAAM;CACN,MAAM;CACN,QAAQ;CACT,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
|
|
2
|
+
let tailwind_variants = require("tailwind-variants");
|
|
3
|
+
|
|
4
|
+
//#region src/components/RatioChart/RatioChart.styles.ts
|
|
5
|
+
const ratioChart = (0, tailwind_variants.tv)({
|
|
6
|
+
slots: {
|
|
7
|
+
root: "flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto",
|
|
8
|
+
item: "relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200",
|
|
9
|
+
fill: "absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300",
|
|
10
|
+
content: "absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point",
|
|
11
|
+
label: "truncate",
|
|
12
|
+
ratio: "flex-shrink-0",
|
|
13
|
+
footer: "flex items-end justify-between px-[0.25rem]",
|
|
14
|
+
footerText: "typo-body-14 text-gray-400"
|
|
15
|
+
},
|
|
16
|
+
variants: {
|
|
17
|
+
disabled: {
|
|
18
|
+
true: {
|
|
19
|
+
root: "opacity-50 cursor-not-allowed",
|
|
20
|
+
item: "cursor-not-allowed"
|
|
21
|
+
},
|
|
22
|
+
false: { item: "cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset" }
|
|
23
|
+
},
|
|
24
|
+
selected: {
|
|
25
|
+
true: { fill: "bg-gray-900" },
|
|
26
|
+
false: { fill: "bg-gray-200" }
|
|
27
|
+
},
|
|
28
|
+
contentVariant: {
|
|
29
|
+
light: { content: "text-white font-bold" },
|
|
30
|
+
dark: { content: "text-gray-800 font-medium" }
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
defaultVariants: {
|
|
34
|
+
disabled: false,
|
|
35
|
+
selected: false,
|
|
36
|
+
contentVariant: "dark"
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
const ratioChartKeys = ratioChart.variantKeys;
|
|
40
|
+
|
|
41
|
+
//#endregion
|
|
42
|
+
exports.ratioChart = ratioChart;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { tv } from "tailwind-variants";
|
|
2
|
+
|
|
3
|
+
//#region src/components/RatioChart/RatioChart.styles.ts
|
|
4
|
+
const ratioChart = tv({
|
|
5
|
+
slots: {
|
|
6
|
+
root: "flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto",
|
|
7
|
+
item: "relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200",
|
|
8
|
+
fill: "absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300",
|
|
9
|
+
content: "absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point",
|
|
10
|
+
label: "truncate",
|
|
11
|
+
ratio: "flex-shrink-0",
|
|
12
|
+
footer: "flex items-end justify-between px-[0.25rem]",
|
|
13
|
+
footerText: "typo-body-14 text-gray-400"
|
|
14
|
+
},
|
|
15
|
+
variants: {
|
|
16
|
+
disabled: {
|
|
17
|
+
true: {
|
|
18
|
+
root: "opacity-50 cursor-not-allowed",
|
|
19
|
+
item: "cursor-not-allowed"
|
|
20
|
+
},
|
|
21
|
+
false: { item: "cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset" }
|
|
22
|
+
},
|
|
23
|
+
selected: {
|
|
24
|
+
true: { fill: "bg-gray-900" },
|
|
25
|
+
false: { fill: "bg-gray-200" }
|
|
26
|
+
},
|
|
27
|
+
contentVariant: {
|
|
28
|
+
light: { content: "text-white font-bold" },
|
|
29
|
+
dark: { content: "text-gray-800 font-medium" }
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
defaultVariants: {
|
|
33
|
+
disabled: false,
|
|
34
|
+
selected: false,
|
|
35
|
+
contentVariant: "dark"
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
const ratioChartKeys = ratioChart.variantKeys;
|
|
39
|
+
|
|
40
|
+
//#endregion
|
|
41
|
+
export { ratioChart };
|
|
42
|
+
//# sourceMappingURL=RatioChart.styles.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RatioChart.styles.mjs","names":[],"sources":["../../../src/components/RatioChart/RatioChart.styles.ts"],"sourcesContent":["import { tv, type VariantProps } from 'tailwind-variants';\n\nexport const ratioChart = tv({\n slots: {\n root: 'flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto', // 컨테이너 (5개부터 스크롤)\n item: 'relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200', // 개별 항목 버튼 (크기 고정)\n fill: 'absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300', // 비율 배경\n content:\n 'absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point', // 텍스트 오버레이\n label: 'truncate', // 라벨 텍스트\n ratio: 'flex-shrink-0', // 퍼센트 텍스트\n footer: 'flex items-end justify-between px-[0.25rem]', // 푸터 컨테이너\n footerText: 'typo-body-14 text-gray-400', // 푸터 텍스트\n },\n variants: {\n disabled: {\n true: {\n root: 'opacity-50 cursor-not-allowed',\n item: 'cursor-not-allowed',\n },\n false: {\n item: 'cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset',\n },\n },\n selected: {\n true: {\n fill: 'bg-gray-900',\n },\n false: {\n fill: 'bg-gray-200',\n },\n },\n contentVariant: {\n light: {\n content: 'text-white font-bold',\n },\n dark: {\n content: 'text-gray-800 font-medium',\n },\n },\n },\n defaultVariants: {\n disabled: false,\n selected: false,\n contentVariant: 'dark',\n },\n});\n\nexport type RatioChartVariants = VariantProps<typeof ratioChart>;\nexport const ratioChartKeys = ratioChart.variantKeys;\n"],"mappings":";;;AAEA,MAAa,aAAa,GAAG;CAC3B,OAAO;EACL,MAAM;EACN,MAAM;EACN,MAAM;EACN,SACE;EACF,OAAO;EACP,OAAO;EACP,QAAQ;EACR,YAAY;EACb;CACD,UAAU;EACR,UAAU;GACR,MAAM;IACJ,MAAM;IACN,MAAM;IACP;GACD,OAAO,EACL,MAAM,+GACP;GACF;EACD,UAAU;GACR,MAAM,EACJ,MAAM,eACP;GACD,OAAO,EACL,MAAM,eACP;GACF;EACD,gBAAgB;GACd,OAAO,EACL,SAAS,wBACV;GACD,MAAM,EACJ,SAAS,6BACV;GACF;EACF;CACD,iBAAiB;EACf,UAAU;EACV,UAAU;EACV,gBAAgB;EACjB;CACF,CAAC;AAGF,MAAa,iBAAiB,WAAW"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
|
|
2
|
+
const require_Checkbox = require('../Checkbox/Checkbox.cjs');
|
|
3
|
+
const require_mergeStyles = require('../../utils/mergeStyles/mergeStyles.cjs');
|
|
4
|
+
const require_RatioChartEditor_styles = require('./RatioChartEditor.styles.cjs');
|
|
5
|
+
let react = require("react");
|
|
6
|
+
react = require_rolldown_runtime.__toESM(react);
|
|
7
|
+
let react_jsx_runtime = require("react/jsx-runtime");
|
|
8
|
+
let _causw_icons = require("@causw/icons");
|
|
9
|
+
|
|
10
|
+
//#region src/components/RatioChart/RatioChartEditor.tsx
|
|
11
|
+
const RatioChartEditor = ({ options: optionsProp, onOptionsChange, allowMultiple: allowMultipleProp, onAllowMultipleChange, onDelete, minOptions = 2, placeholder = "내용을 입력해주세요", disabled, className, ...props }) => {
|
|
12
|
+
const baseId = (0, react.useId)();
|
|
13
|
+
const [internalOptions, setInternalOptions] = (0, react.useState)(() => {
|
|
14
|
+
const initial = [];
|
|
15
|
+
for (let i = 0; i < minOptions; i++) initial.push({
|
|
16
|
+
id: `${baseId}-${i}`,
|
|
17
|
+
value: ""
|
|
18
|
+
});
|
|
19
|
+
return initial;
|
|
20
|
+
});
|
|
21
|
+
const [internalAllowMultiple, setInternalAllowMultiple] = (0, react.useState)(false);
|
|
22
|
+
const isOptionsControlled = optionsProp !== void 0;
|
|
23
|
+
const isAllowMultipleControlled = allowMultipleProp !== void 0;
|
|
24
|
+
const options = isOptionsControlled ? optionsProp : internalOptions;
|
|
25
|
+
const allowMultiple = isAllowMultipleControlled ? allowMultipleProp : internalAllowMultiple;
|
|
26
|
+
const handleOptionChange = (0, react.useCallback)((id, value) => {
|
|
27
|
+
const newOptions = options.map((opt) => opt.id === id ? {
|
|
28
|
+
...opt,
|
|
29
|
+
value
|
|
30
|
+
} : opt);
|
|
31
|
+
if (!isOptionsControlled) setInternalOptions(newOptions);
|
|
32
|
+
onOptionsChange?.(newOptions);
|
|
33
|
+
}, [
|
|
34
|
+
options,
|
|
35
|
+
isOptionsControlled,
|
|
36
|
+
onOptionsChange
|
|
37
|
+
]);
|
|
38
|
+
const handleAddOption = (0, react.useCallback)(() => {
|
|
39
|
+
const newOption = {
|
|
40
|
+
id: `${baseId}-${Date.now()}`,
|
|
41
|
+
value: ""
|
|
42
|
+
};
|
|
43
|
+
const newOptions = [...options, newOption];
|
|
44
|
+
if (!isOptionsControlled) setInternalOptions(newOptions);
|
|
45
|
+
onOptionsChange?.(newOptions);
|
|
46
|
+
}, [
|
|
47
|
+
options,
|
|
48
|
+
isOptionsControlled,
|
|
49
|
+
onOptionsChange,
|
|
50
|
+
baseId
|
|
51
|
+
]);
|
|
52
|
+
const handleRemoveOption = (0, react.useCallback)((id) => {
|
|
53
|
+
if (options.length <= minOptions) return;
|
|
54
|
+
const newOptions = options.filter((opt) => opt.id !== id);
|
|
55
|
+
if (!isOptionsControlled) setInternalOptions(newOptions);
|
|
56
|
+
onOptionsChange?.(newOptions);
|
|
57
|
+
}, [
|
|
58
|
+
options,
|
|
59
|
+
minOptions,
|
|
60
|
+
isOptionsControlled,
|
|
61
|
+
onOptionsChange
|
|
62
|
+
]);
|
|
63
|
+
const handleAllowMultipleChange = (0, react.useCallback)((checked) => {
|
|
64
|
+
if (!isAllowMultipleControlled) setInternalAllowMultiple(checked);
|
|
65
|
+
onAllowMultipleChange?.(checked);
|
|
66
|
+
}, [isAllowMultipleControlled, onAllowMultipleChange]);
|
|
67
|
+
const canRemove = options.length > minOptions;
|
|
68
|
+
const styles = require_RatioChartEditor_styles.ratioChartEditor({ disabled });
|
|
69
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
70
|
+
className: require_mergeStyles.mergeStyles(styles.root(), className),
|
|
71
|
+
...props,
|
|
72
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
73
|
+
className: styles.fields(),
|
|
74
|
+
children: [options.map((option) => /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
75
|
+
className: styles.input(),
|
|
76
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", {
|
|
77
|
+
type: "text",
|
|
78
|
+
value: option.value,
|
|
79
|
+
onChange: (e) => handleOptionChange(option.id, e.target.value),
|
|
80
|
+
placeholder,
|
|
81
|
+
disabled,
|
|
82
|
+
className: styles.textInput()
|
|
83
|
+
}), canRemove && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
|
|
84
|
+
type: "button",
|
|
85
|
+
onClick: () => handleRemoveOption(option.id),
|
|
86
|
+
disabled,
|
|
87
|
+
className: styles.removeButton(),
|
|
88
|
+
"aria-label": "옵션 삭제",
|
|
89
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_causw_icons.CloseFilled, { size: 20 })
|
|
90
|
+
})]
|
|
91
|
+
}, option.id)), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("button", {
|
|
92
|
+
type: "button",
|
|
93
|
+
onClick: handleAddOption,
|
|
94
|
+
disabled,
|
|
95
|
+
className: styles.addButton(),
|
|
96
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(_causw_icons.Plus, { size: 20 }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
97
|
+
className: styles.addButtonText(),
|
|
98
|
+
children: "다른 선택 항목 추가"
|
|
99
|
+
})]
|
|
100
|
+
})]
|
|
101
|
+
}), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
102
|
+
className: styles.footer(),
|
|
103
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)(require_Checkbox.Checkbox, {
|
|
104
|
+
checked: allowMultiple,
|
|
105
|
+
onCheckedChange: handleAllowMultipleChange,
|
|
106
|
+
disabled,
|
|
107
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Checkbox.Checkbox.Indicator, {}), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Checkbox.Checkbox.Label, { children: "복수 선택 허용" })]
|
|
108
|
+
}), onDelete && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
|
|
109
|
+
type: "button",
|
|
110
|
+
onClick: onDelete,
|
|
111
|
+
disabled,
|
|
112
|
+
className: styles.deleteButton(),
|
|
113
|
+
children: "투표 삭제"
|
|
114
|
+
})]
|
|
115
|
+
})]
|
|
116
|
+
});
|
|
117
|
+
};
|
|
118
|
+
RatioChartEditor.displayName = "RatioChartEditor";
|
|
119
|
+
|
|
120
|
+
//#endregion
|
|
121
|
+
exports.RatioChartEditor = RatioChartEditor;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import * as react_jsx_runtime35 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/RatioChart/RatioChartEditor.d.ts
|
|
5
|
+
interface RatioChartEditorOption {
|
|
6
|
+
id: string;
|
|
7
|
+
value: string;
|
|
8
|
+
}
|
|
9
|
+
interface RatioChartEditorProps extends Omit<React.ComponentProps<'div'>, 'onChange'> {
|
|
10
|
+
/** 옵션 목록 */
|
|
11
|
+
options?: RatioChartEditorOption[];
|
|
12
|
+
/** 옵션 변경 콜백 */
|
|
13
|
+
onOptionsChange?: (options: RatioChartEditorOption[]) => void;
|
|
14
|
+
/** 복수 선택 허용 여부 */
|
|
15
|
+
allowMultiple?: boolean;
|
|
16
|
+
/** 복수 선택 변경 콜백 */
|
|
17
|
+
onAllowMultipleChange?: (allowMultiple: boolean) => void;
|
|
18
|
+
/** 투표 삭제 콜백 */
|
|
19
|
+
onDelete?: () => void;
|
|
20
|
+
/** 최소 옵션 수 (기본: 2) */
|
|
21
|
+
minOptions?: number;
|
|
22
|
+
/** 플레이스홀더 텍스트 */
|
|
23
|
+
placeholder?: string;
|
|
24
|
+
/** 비활성화 */
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
}
|
|
27
|
+
declare const RatioChartEditor: {
|
|
28
|
+
({
|
|
29
|
+
options: optionsProp,
|
|
30
|
+
onOptionsChange,
|
|
31
|
+
allowMultiple: allowMultipleProp,
|
|
32
|
+
onAllowMultipleChange,
|
|
33
|
+
onDelete,
|
|
34
|
+
minOptions,
|
|
35
|
+
placeholder,
|
|
36
|
+
disabled,
|
|
37
|
+
className,
|
|
38
|
+
...props
|
|
39
|
+
}: RatioChartEditorProps): react_jsx_runtime35.JSX.Element;
|
|
40
|
+
displayName: string;
|
|
41
|
+
};
|
|
42
|
+
//#endregion
|
|
43
|
+
export { RatioChartEditor, RatioChartEditorOption, RatioChartEditorProps };
|
|
44
|
+
//# sourceMappingURL=RatioChartEditor.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RatioChartEditor.d.cts","names":[],"sources":["../../../src/components/RatioChart/RatioChartEditor.tsx"],"mappings":";;;;UAMiB,sBAAA;EACf,EAAA;EACA,KAAA;AAAA;AAAA,UAGe,qBAAA,SAA8B,IAAA,CAC7C,KAAA,CAAM,cAAA;;EAIN,OAAA,GAAU,sBAAA;EARL;EAUL,eAAA,IAAmB,OAAA,EAAS,sBAAA;EAPS;EASrC,aAAA;EARA;EAUA,qBAAA,IAAyB,aAAA;EAJG;EAM5B,QAAA;EAbiD;EAejD,UAAA;EAf6C;EAiB7C,WAAA;EAhBM;EAkBN,QAAA;AAAA;AAAA,cAGW,gBAAA;EAAA;;;;;;;;;;;KAWV,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import * as react_jsx_runtime24 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/RatioChart/RatioChartEditor.d.ts
|
|
5
|
+
interface RatioChartEditorOption {
|
|
6
|
+
id: string;
|
|
7
|
+
value: string;
|
|
8
|
+
}
|
|
9
|
+
interface RatioChartEditorProps extends Omit<React.ComponentProps<'div'>, 'onChange'> {
|
|
10
|
+
/** 옵션 목록 */
|
|
11
|
+
options?: RatioChartEditorOption[];
|
|
12
|
+
/** 옵션 변경 콜백 */
|
|
13
|
+
onOptionsChange?: (options: RatioChartEditorOption[]) => void;
|
|
14
|
+
/** 복수 선택 허용 여부 */
|
|
15
|
+
allowMultiple?: boolean;
|
|
16
|
+
/** 복수 선택 변경 콜백 */
|
|
17
|
+
onAllowMultipleChange?: (allowMultiple: boolean) => void;
|
|
18
|
+
/** 투표 삭제 콜백 */
|
|
19
|
+
onDelete?: () => void;
|
|
20
|
+
/** 최소 옵션 수 (기본: 2) */
|
|
21
|
+
minOptions?: number;
|
|
22
|
+
/** 플레이스홀더 텍스트 */
|
|
23
|
+
placeholder?: string;
|
|
24
|
+
/** 비활성화 */
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
}
|
|
27
|
+
declare const RatioChartEditor: {
|
|
28
|
+
({
|
|
29
|
+
options: optionsProp,
|
|
30
|
+
onOptionsChange,
|
|
31
|
+
allowMultiple: allowMultipleProp,
|
|
32
|
+
onAllowMultipleChange,
|
|
33
|
+
onDelete,
|
|
34
|
+
minOptions,
|
|
35
|
+
placeholder,
|
|
36
|
+
disabled,
|
|
37
|
+
className,
|
|
38
|
+
...props
|
|
39
|
+
}: RatioChartEditorProps): react_jsx_runtime24.JSX.Element;
|
|
40
|
+
displayName: string;
|
|
41
|
+
};
|
|
42
|
+
//#endregion
|
|
43
|
+
export { RatioChartEditor, RatioChartEditorOption, RatioChartEditorProps };
|
|
44
|
+
//# sourceMappingURL=RatioChartEditor.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RatioChartEditor.d.mts","names":[],"sources":["../../../src/components/RatioChart/RatioChartEditor.tsx"],"mappings":";;;;UAMiB,sBAAA;EACf,EAAA;EACA,KAAA;AAAA;AAAA,UAGe,qBAAA,SAA8B,IAAA,CAC7C,KAAA,CAAM,cAAA;;EAIN,OAAA,GAAU,sBAAA;EARL;EAUL,eAAA,IAAmB,OAAA,EAAS,sBAAA;EAPS;EASrC,aAAA;EARA;EAUA,qBAAA,IAAyB,aAAA;EAJG;EAM5B,QAAA;EAbiD;EAejD,UAAA;EAf6C;EAiB7C,WAAA;EAhBM;EAkBN,QAAA;AAAA;AAAA,cAGW,gBAAA;EAAA;;;;;;;;;;;KAWV,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}
|