@para-ui/core 5.0.0-beta.11 → 5.0.0-beta.13
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/AGENTS.md +315 -0
- package/AlignBox/component.json +89 -0
- package/Anchor/component.json +130 -0
- package/Argv/component.json +216 -0
- package/AutoBox/component.json +133 -0
- package/AutoButton/component.json +109 -0
- package/AutoTips/component.json +121 -0
- package/Badge/component.json +92 -0
- package/Breadcrumbs/component.json +142 -0
- package/Button/component.json +168 -0
- package/ButtonGroup/component.json +132 -0
- package/Card/component.json +162 -0
- package/Carousel/component.json +142 -0
- package/Cascader/component.json +196 -0
- package/Checkbox/component.json +138 -0
- package/CheckboxGroup/component.json +152 -0
- package/CodeEditor/component.json +189 -0
- package/Collapse/component.json +166 -0
- package/CollapseBox/component.json +84 -0
- package/CollapseLayout/component.json +155 -0
- package/ColorPicker/component.json +142 -0
- package/ComboSelect/component.json +181 -0
- package/Container/component.json +111 -0
- package/ContentBox/component.json +81 -0
- package/CopyText/component.json +118 -0
- package/CycleSelector/component.json +98 -0
- package/DatePicker/component.json +192 -0
- package/Descriptions/component.json +142 -0
- package/Desktop/component.json +171 -0
- package/DragVerify/component.json +114 -0
- package/Drawer/component.json +200 -0
- package/Dropdown/component.json +147 -0
- package/DynamicMultiBox/component.json +278 -0
- package/Empty/component.json +123 -0
- package/FieldForm/component.json +196 -0
- package/Form/component.json +161 -0
- package/FormItem/component.json +171 -0
- package/FunctionModal/component.json +197 -0
- package/Help/component.json +118 -0
- package/HelperText/component.json +126 -0
- package/Image/component.json +165 -0
- package/InputCode/component.json +191 -0
- package/InputLang/component.json +205 -0
- package/InputNumber/component.json +162 -0
- package/Label/component.json +126 -0
- package/Loading/component.json +91 -0
- package/Menu/component.json +180 -0
- package/Message/component.json +246 -0
- package/Modal/component.json +277 -0
- package/MultiBox/component.json +216 -0
- package/Notification/component.json +184 -0
- package/OperateBtn/component.json +134 -0
- package/PageHeader/component.json +112 -0
- package/Pagination/component.json +181 -0
- package/PasswordRules/component.json +105 -0
- package/PopConfirm/component.json +227 -0
- package/PopMenu/component.json +131 -0
- package/Popover/component.json +165 -0
- package/Progress/component.json +161 -0
- package/Prompt/component.json +144 -0
- package/Querying/component.json +96 -0
- package/QuickReply/component.json +129 -0
- package/Radio/component.json +136 -0
- package/RadioGroup/component.json +149 -0
- package/RangeInput/component.json +198 -0
- package/Result/component.json +104 -0
- package/ScrollBar/component.json +115 -0
- package/Search/component.json +177 -0
- package/Select/component.json +244 -0
- package/SelectInput/component.json +184 -0
- package/Selector/component.json +203 -0
- package/SelectorPicker/component.json +179 -0
- package/SingleBox/component.json +151 -0
- package/Slider/component.json +181 -0
- package/SortBox/component.json +108 -0
- package/Status/component.json +104 -0
- package/Stepper/component.json +129 -0
- package/Switch/component.json +207 -0
- package/Table/component.json +547 -0
- package/Tabs/component.json +227 -0
- package/Tag/component.json +221 -0
- package/TextEditor/component.json +186 -0
- package/TextField/component.json +290 -0
- package/TimePicker/component.json +176 -0
- package/Timeline/component.json +110 -0
- package/Title/component.json +156 -0
- package/ToggleButton/component.json +153 -0
- package/Tooltip/component.json +176 -0
- package/Transfer/component.json +157 -0
- package/Tree/component.json +512 -0
- package/Upload/component.json +450 -0
- package/ai-workflows/01-crud-list-multi-drawer.md +278 -0
- package/ai-workflows/02-rbac-operation-buttons.md +290 -0
- package/ai-workflows/03-complex-form-async-cascade.md +350 -0
- package/ai-workflows/04-array-field-form.md +281 -0
- package/ai-workflows/05-popconfirm-async-message-queue.md +333 -0
- package/ai-workflows/06-modal-drawer-form-workflow.md +385 -0
- package/ai-workflows/07-search-filter-table-trio.md +387 -0
- package/ai-workflows/08-table-advanced-features.md +365 -0
- package/ai-workflows/09-batch-operation-export-progress.md +367 -0
- package/ai-workflows/10-cross-component-state-coordination.md +412 -0
- package/es/AlignBox/component.json +89 -0
- package/es/AlignBox/index.css +1 -1
- package/es/AlignBox/index.d.ts +6 -2
- package/es/AlignBox/index.js +1 -1
- package/es/AlignBox/style/index.css +1 -1
- package/es/Anchor/anchorMenu/index.d.ts +2 -1
- package/es/Anchor/anchorMenu/index.js +36 -33
- package/es/Anchor/component.json +130 -0
- package/es/Anchor/index.js +52 -49
- package/es/Anchor/type.d.ts +8 -4
- package/es/Argv/component.json +216 -0
- package/es/Argv/dataGenerator/index.js +1 -1
- package/es/Argv/index.d.ts +5 -6
- package/es/Argv/index.js +1 -1
- package/es/AutoBox/component.json +133 -0
- package/es/AutoBox/index.d.ts +3 -3
- package/es/AutoBox/index.js +1 -1
- package/es/AutoBox/protal.d.ts +2 -2
- package/es/AutoBox/protal.js +33 -30
- package/es/AutoButton/component.json +109 -0
- package/es/AutoButton/index.js +1 -1
- package/es/AutoTips/autoTipsMultiline/index.d.ts +1 -1
- package/es/AutoTips/autoTipsMultiline/index.js +1 -1
- package/es/AutoTips/component.json +121 -0
- package/es/AutoTips/index.js +1 -1
- package/es/Badge/component.json +92 -0
- package/es/Breadcrumbs/component.json +142 -0
- package/es/Breadcrumbs/index.js +1 -1
- package/es/Button/SplitButton.d.ts +2 -2
- package/es/Button/component.json +168 -0
- package/es/Button/index.js +44 -44
- package/es/ButtonGroup/component.json +132 -0
- package/es/ButtonGroup/index.d.ts +1 -1
- package/es/Card/component.json +162 -0
- package/es/Card/index.d.ts +2 -2
- package/es/Card/index.js +2 -2
- package/es/Carousel/component.json +142 -0
- package/es/Carousel/index.d.ts +1 -1
- package/es/Cascader/Cascader.js +1 -1
- package/es/Cascader/OptionList/Column.js +1 -1
- package/es/Cascader/OptionList/index.js +1 -1
- package/es/Cascader/component.json +196 -0
- package/es/Cascader/hooks/useEntities.js +7 -7
- package/es/Cascader/interface.d.ts +1 -0
- package/es/Cascader/utils/commonUtil.d.ts +1 -1
- package/es/Cascader/utils/commonUtil.js +16 -16
- package/es/Cascader/utils/treeUtil.d.ts +14 -5
- package/es/Cascader/utils/treeUtil.js +1 -1
- package/es/Checkbox/component.json +138 -0
- package/es/CheckboxGroup/component.json +152 -0
- package/es/CheckboxGroup/index.js +1 -1
- package/es/CodeEditor/component.json +189 -0
- package/es/CodeEditor/index.d.ts +11 -10
- package/es/CodeEditor/index.js +19 -19
- package/es/Collapse/component.json +166 -0
- package/es/Collapse/index.d.ts +1 -1
- package/es/Collapse/index.js +23 -22
- package/es/CollapseBox/component.json +84 -0
- package/es/CollapseLayout/component.json +155 -0
- package/es/ColorPicker/component.json +142 -0
- package/es/ComboSelect/component.json +181 -0
- package/es/ComboSelect/index.js +115 -109
- package/es/ComboSelect/interface.d.ts +2 -2
- package/es/ComboSelect/utils.d.ts +3 -3
- package/es/ComboSelect/utils.js +1 -1
- package/es/Container/component.json +111 -0
- package/es/ContentBox/component.json +81 -0
- package/es/CopyText/component.json +118 -0
- package/es/CycleSelector/component.json +98 -0
- package/es/CycleSelector/index.js +14 -13
- package/es/DatePicker/component.json +192 -0
- package/es/DatePicker/generatePicker/generateRangePicker.js +11 -11
- package/es/DatePicker/generatePicker/generateSinglePicker.js +2 -2
- package/es/Descriptions/component.json +142 -0
- package/es/Descriptions/index.d.ts +1 -1
- package/es/Desktop/component.json +171 -0
- package/es/Desktop/index.js +1 -1
- package/es/DragVerify/component.json +114 -0
- package/es/DragVerify/index.js +19 -19
- package/es/Drawer/component.json +200 -0
- package/es/Drawer/index.js +86 -86
- package/es/Drawer/interface.d.ts +1 -1
- package/es/Drawer/util.d.ts +1 -6
- package/es/Drawer/util.js +9 -6
- package/es/Dropdown/component.json +147 -0
- package/es/Dropdown/index.js +1 -1
- package/es/DynamicMultiBox/component.json +278 -0
- package/es/DynamicMultiBox/formItem.d.ts +1 -1
- package/es/DynamicMultiBox/index.js +1 -1
- package/es/DynamicMultiBox/rowForm.d.ts +2 -2
- package/es/Empty/component.json +123 -0
- package/es/Empty/index.css +1 -1
- package/es/Empty/index.d.ts +2 -2
- package/es/Empty/index.js +27 -26
- package/es/Empty/style/index.css +1 -1
- package/es/FieldForm/FieldFormItem/ItemHolder.js +1 -1
- package/es/FieldForm/FieldFormItem/MemoInput.d.ts +2 -2
- package/es/FieldForm/FieldFormItem/StatusProvider.js +1 -1
- package/es/FieldForm/FieldFormItem/index.d.ts +6 -6
- package/es/FieldForm/Form.d.ts +2 -2
- package/es/FieldForm/Form.js +1 -1
- package/es/FieldForm/FormItemInput.js +1 -1
- package/es/FieldForm/FormItemLabel.js +1 -1
- package/es/FieldForm/FormList.d.ts +2 -2
- package/es/FieldForm/component.json +196 -0
- package/es/FieldForm/context.d.ts +5 -1
- package/es/FieldForm/context.js +2 -2
- package/es/FieldForm/hooks/useForm.d.ts +4 -3
- package/es/FieldForm/hooks/useFormInstance.d.ts +1 -1
- package/es/FieldForm/hooks/useFormItemStatus.d.ts +9 -5
- package/es/FieldForm/hooks/useFormItemStatus.js +2 -2
- package/es/FieldForm/hooks/useItemRef.d.ts +1 -1
- package/es/FieldForm/hooks/useItemRef.js +6 -6
- package/es/Form/component.json +161 -0
- package/es/Form/index.d.ts +52 -49
- package/es/Form/index.js +1 -1
- package/es/FormItem/compoments/defaultCompoments/index.d.ts +5 -5
- package/es/FormItem/compoments/defaultCompoments/index.js +12 -11
- package/es/FormItem/compoments/formCheckboxGroup/index.d.ts +2 -2
- package/es/FormItem/compoments/formFile/index.js +8 -8
- package/es/FormItem/compoments/formRadioGroup/index.d.ts +1 -1
- package/es/FormItem/compoments/formSelect/index.d.ts +1 -1
- package/es/FormItem/component.json +171 -0
- package/es/FormItem/index.d.ts +5 -5
- package/es/FormItem/index.js +23 -23
- package/es/FormItem/itemType.js +1 -1
- package/es/FunctionModal/component.json +197 -0
- package/es/FunctionModal/dialog.d.ts +1 -1
- package/es/FunctionModal/modalContext.d.ts +4 -1
- package/es/GlobalContext/confirmLocale.js +1 -1
- package/es/GlobalContext/index.js +1 -1
- package/es/Help/component.json +118 -0
- package/es/HelperText/component.json +126 -0
- package/es/Image/PreviewGroup.js +1 -1
- package/es/Image/component.json +165 -0
- package/es/Image/index.js +1 -1
- package/es/InputCode/component.json +191 -0
- package/es/InputCode/index.d.ts +2 -2
- package/es/InputLang/component.json +205 -0
- package/es/InputLang/index.js +2 -2
- package/es/InputNumber/component.json +162 -0
- package/es/Label/component.json +126 -0
- package/es/Label/index.d.ts +2 -2
- package/es/Loading/component.json +91 -0
- package/es/Menu/component.json +180 -0
- package/es/Menu/verticalMenuList.js +1 -1
- package/es/Message/component.json +246 -0
- package/es/Message/index.d.ts +2 -2
- package/es/Message/index.js +2 -2
- package/es/Modal/Confirm/index.d.ts +1 -1
- package/es/Modal/Confirm/index.js +1 -1
- package/es/Modal/component.json +277 -0
- package/es/Modal/index.d.ts +85 -5
- package/es/Modal/index.js +159 -122
- package/es/Modal/interface.d.ts +1 -0
- package/es/MultiBox/component.json +216 -0
- package/es/MultiBox/index.js +19 -14
- package/es/Notification/component.json +184 -0
- package/es/OperateBtn/component.json +134 -0
- package/es/OperateBtn/index.d.ts +3 -3
- package/es/PageHeader/component.json +112 -0
- package/es/PageHeader/horizontalMeun.js +1 -1
- package/es/PageHeader/horizontalMeunRight.js +1 -1
- package/es/Pagination/component.json +181 -0
- package/es/Pagination/index.js +15 -15
- package/es/ParauiProvider/index.js +1 -1
- package/es/PasswordRules/component.json +105 -0
- package/es/PasswordRules/index.d.ts +4 -4
- package/es/PopConfirm/component.json +227 -0
- package/es/PopConfirm/index.d.ts +1 -1
- package/es/PopConfirm/index.js +1 -1
- package/es/PopMenu/component.json +131 -0
- package/es/PopMenu/hooks.d.ts +1 -1
- package/es/PopMenu/index.js +8 -8
- package/es/Popover/component.json +165 -0
- package/es/Popover/index.js +1 -1
- package/es/Progress/component.json +161 -0
- package/es/Prompt/component.json +144 -0
- package/es/Querying/component.json +96 -0
- package/es/Querying/index.css +1 -1
- package/es/Querying/index.d.ts +2 -2
- package/es/Querying/index.js +20 -19
- package/es/Querying/style/index.css +1 -1
- package/es/QuickReply/QuickReplyCode/index.js +1 -1
- package/es/QuickReply/component.json +129 -0
- package/es/QuickReply/index.d.ts +1 -1
- package/es/Radio/component.json +136 -0
- package/es/RadioGroup/component.json +149 -0
- package/es/RangeInput/component.json +198 -0
- package/es/RangeInput/index.js +20 -20
- package/es/Result/component.json +104 -0
- package/es/ScrollBar/component.json +115 -0
- package/es/Search/component.json +177 -0
- package/es/Search/index.d.ts +1 -1
- package/es/Select/component.json +244 -0
- package/es/Select/index.js +114 -114
- package/es/SelectInput/component.json +184 -0
- package/es/Selector/component.json +203 -0
- package/es/Selector/index.js +56 -50
- package/es/Selector/interface.d.ts +2 -2
- package/es/Selector/selectorData/index.js +1 -1
- package/es/Selector/selectorMain/index.js +3 -3
- package/es/Selector/selectorNode/index.js +1 -1
- package/es/Selector/util.d.ts +3 -3
- package/es/Selector/util.js +6 -12
- package/es/SelectorPicker/component.json +179 -0
- package/es/SelectorPicker/index.d.ts +5 -5
- package/es/SelectorPicker/index.js +15 -15
- package/es/SingleBox/component.json +151 -0
- package/es/SingleBox/index.d.ts +2 -2
- package/es/Slider/component.json +181 -0
- package/es/SortBox/component.json +108 -0
- package/es/Status/component.json +104 -0
- package/es/Stepper/component.json +129 -0
- package/es/Stepper/index.d.ts +2 -2
- package/es/Switch/component.json +207 -0
- package/es/Switch/index.css +1 -1
- package/es/Switch/index.d.ts +3 -2
- package/es/Switch/index.js +60 -59
- package/es/Switch/style/index.css +1 -1
- package/es/Table/component.json +547 -0
- package/es/Table/index.d.ts +2 -2
- package/es/Table/index.js +385 -382
- package/es/Table/interface.d.ts +30 -0
- package/es/Table/tableHead.js +1 -1
- package/es/Table/util.d.ts +1 -1
- package/es/Table/util.js +3 -12
- package/es/Tabs/component.json +227 -0
- package/es/Tag/component.json +221 -0
- package/es/Tag/index.css +1 -1
- package/es/Tag/index.d.ts +1 -1
- package/es/Tag/index.js +20 -20
- package/es/Tag/style/index.css +1 -1
- package/es/TextEditor/component.json +186 -0
- package/es/TextEditor/index.d.ts +5 -5
- package/es/TextEditor/index.js +1 -1
- package/es/TextField/component.json +290 -0
- package/es/TextField/index.d.ts +2 -2
- package/es/TextField/index.js +1 -1
- package/es/TimePicker/component.json +176 -0
- package/es/Timeline/component.json +110 -0
- package/es/Title/component.json +156 -0
- package/es/ToggleButton/component.json +153 -0
- package/es/ToggleButton/index.js +1 -1
- package/es/Tooltip/component.json +176 -0
- package/es/Tooltip/index.js +58 -53
- package/es/Tooltip/interface.d.ts +14 -1
- package/es/Tooltip/utils.js +6 -6
- package/es/Transfer/component.json +157 -0
- package/es/Tree/OperateBar/index.js +1 -1
- package/es/Tree/Tree.js +3 -3
- package/es/Tree/component.json +512 -0
- package/es/Tree/interface.d.ts +1 -1
- package/es/Upload/component.json +450 -0
- package/es/Upload/util.js +1 -1
- package/es/Utils/snack-kit-shims.d.ts +18 -0
- package/es/Utils/snack-kit-shims.js +19 -0
- package/es/Utils/type.d.ts +0 -2
- package/es/_virtual/index.js +5 -3
- package/es/_virtual/index2.js +2 -5
- package/es/index.d.ts +2 -0
- package/es/index.js +1 -1
- package/es/locale/en_US.d.ts +361 -0
- package/es/locale/en_US.js +364 -0
- package/es/locale/index.d.ts +1 -723
- package/es/locale/index2.js +10 -0
- package/es/locale/zh_CN.d.ts +361 -0
- package/es/locale/zh_CN.js +364 -0
- package/es/node_modules/classnames/index.js +1 -1
- package/lib/AlignBox/component.json +89 -0
- package/lib/AlignBox/index.css +1 -1
- package/lib/AlignBox/index.d.ts +6 -2
- package/lib/AlignBox/index.js +1 -1
- package/lib/AlignBox/style/index.css +1 -1
- package/lib/Anchor/anchorMenu/index.d.ts +2 -1
- package/lib/Anchor/anchorMenu/index.js +1 -1
- package/lib/Anchor/component.json +130 -0
- package/lib/Anchor/index.js +1 -1
- package/lib/Anchor/type.d.ts +8 -4
- package/lib/Argv/component.json +216 -0
- package/lib/Argv/dataGenerator/index.js +1 -1
- package/lib/Argv/index.d.ts +5 -6
- package/lib/Argv/index.js +1 -1
- package/lib/AutoBox/component.json +133 -0
- package/lib/AutoBox/index.d.ts +3 -3
- package/lib/AutoBox/index.js +1 -1
- package/lib/AutoBox/protal.d.ts +2 -2
- package/lib/AutoBox/protal.js +1 -1
- package/lib/AutoButton/component.json +109 -0
- package/lib/AutoButton/index.js +1 -1
- package/lib/AutoTips/autoTipsMultiline/index.d.ts +1 -1
- package/lib/AutoTips/autoTipsMultiline/index.js +1 -1
- package/lib/AutoTips/component.json +121 -0
- package/lib/AutoTips/index.js +1 -1
- package/lib/Badge/component.json +92 -0
- package/lib/Breadcrumbs/component.json +142 -0
- package/lib/Breadcrumbs/index.js +1 -1
- package/lib/Button/SplitButton.d.ts +2 -2
- package/lib/Button/component.json +168 -0
- package/lib/Button/index.js +1 -1
- package/lib/ButtonGroup/component.json +132 -0
- package/lib/ButtonGroup/index.d.ts +1 -1
- package/lib/Card/component.json +162 -0
- package/lib/Card/index.d.ts +2 -2
- package/lib/Card/index.js +1 -1
- package/lib/Carousel/component.json +142 -0
- package/lib/Carousel/index.d.ts +1 -1
- package/lib/Cascader/Cascader.js +1 -1
- package/lib/Cascader/OptionList/Column.js +1 -1
- package/lib/Cascader/OptionList/index.js +1 -1
- package/lib/Cascader/component.json +196 -0
- package/lib/Cascader/hooks/useEntities.js +1 -1
- package/lib/Cascader/interface.d.ts +1 -0
- package/lib/Cascader/utils/commonUtil.d.ts +1 -1
- package/lib/Cascader/utils/commonUtil.js +1 -1
- package/lib/Cascader/utils/treeUtil.d.ts +14 -5
- package/lib/Cascader/utils/treeUtil.js +1 -1
- package/lib/Checkbox/component.json +138 -0
- package/lib/CheckboxGroup/component.json +152 -0
- package/lib/CheckboxGroup/index.js +1 -1
- package/lib/CodeEditor/component.json +189 -0
- package/lib/CodeEditor/index.d.ts +11 -10
- package/lib/CodeEditor/index.js +1 -1
- package/lib/Collapse/component.json +166 -0
- package/lib/Collapse/index.d.ts +1 -1
- package/lib/Collapse/index.js +1 -1
- package/lib/CollapseBox/component.json +84 -0
- package/lib/CollapseLayout/component.json +155 -0
- package/lib/ColorPicker/component.json +142 -0
- package/lib/ComboSelect/component.json +181 -0
- package/lib/ComboSelect/index.js +1 -1
- package/lib/ComboSelect/interface.d.ts +2 -2
- package/lib/ComboSelect/utils.d.ts +3 -3
- package/lib/ComboSelect/utils.js +1 -1
- package/lib/Container/component.json +111 -0
- package/lib/ContentBox/component.json +81 -0
- package/lib/CopyText/component.json +118 -0
- package/lib/CycleSelector/component.json +98 -0
- package/lib/CycleSelector/index.js +1 -1
- package/lib/DatePicker/component.json +192 -0
- package/lib/DatePicker/generatePicker/generateRangePicker.js +1 -1
- package/lib/DatePicker/generatePicker/generateSinglePicker.js +1 -1
- package/lib/Descriptions/component.json +142 -0
- package/lib/Descriptions/index.d.ts +1 -1
- package/lib/Desktop/component.json +171 -0
- package/lib/Desktop/index.js +1 -1
- package/lib/DragVerify/component.json +114 -0
- package/lib/DragVerify/index.js +1 -1
- package/lib/Drawer/component.json +200 -0
- package/lib/Drawer/index.js +1 -1
- package/lib/Drawer/interface.d.ts +1 -1
- package/lib/Drawer/util.d.ts +1 -6
- package/lib/Drawer/util.js +1 -1
- package/lib/Dropdown/component.json +147 -0
- package/lib/Dropdown/index.js +1 -1
- package/lib/DynamicMultiBox/component.json +278 -0
- package/lib/DynamicMultiBox/formItem.d.ts +1 -1
- package/lib/DynamicMultiBox/index.js +1 -1
- package/lib/DynamicMultiBox/rowForm.d.ts +2 -2
- package/lib/Empty/component.json +123 -0
- package/lib/Empty/index.css +1 -1
- package/lib/Empty/index.d.ts +2 -2
- package/lib/Empty/index.js +1 -1
- package/lib/Empty/style/index.css +1 -1
- package/lib/FieldForm/FieldFormItem/ItemHolder.js +1 -1
- package/lib/FieldForm/FieldFormItem/MemoInput.d.ts +2 -2
- package/lib/FieldForm/FieldFormItem/StatusProvider.js +1 -1
- package/lib/FieldForm/FieldFormItem/index.d.ts +6 -6
- package/lib/FieldForm/Form.d.ts +2 -2
- package/lib/FieldForm/Form.js +1 -1
- package/lib/FieldForm/FormItemInput.js +1 -1
- package/lib/FieldForm/FormItemLabel.js +1 -1
- package/lib/FieldForm/FormList.d.ts +2 -2
- package/lib/FieldForm/component.json +196 -0
- package/lib/FieldForm/context.d.ts +5 -1
- package/lib/FieldForm/context.js +1 -1
- package/lib/FieldForm/hooks/useForm.d.ts +4 -3
- package/lib/FieldForm/hooks/useFormInstance.d.ts +1 -1
- package/lib/FieldForm/hooks/useFormItemStatus.d.ts +9 -5
- package/lib/FieldForm/hooks/useFormItemStatus.js +1 -1
- package/lib/FieldForm/hooks/useItemRef.d.ts +1 -1
- package/lib/FieldForm/hooks/useItemRef.js +1 -1
- package/lib/Form/component.json +161 -0
- package/lib/Form/index.d.ts +52 -49
- package/lib/Form/index.js +1 -1
- package/lib/FormItem/compoments/defaultCompoments/index.d.ts +5 -5
- package/lib/FormItem/compoments/defaultCompoments/index.js +1 -1
- package/lib/FormItem/compoments/formCheckboxGroup/index.d.ts +2 -2
- package/lib/FormItem/compoments/formFile/index.js +1 -1
- package/lib/FormItem/compoments/formRadioGroup/index.d.ts +1 -1
- package/lib/FormItem/compoments/formSelect/index.d.ts +1 -1
- package/lib/FormItem/component.json +171 -0
- package/lib/FormItem/index.d.ts +5 -5
- package/lib/FormItem/index.js +1 -1
- package/lib/FormItem/itemType.js +1 -1
- package/lib/FunctionModal/component.json +197 -0
- package/lib/FunctionModal/dialog.d.ts +1 -1
- package/lib/FunctionModal/modalContext.d.ts +4 -1
- package/lib/GlobalContext/confirmLocale.js +1 -1
- package/lib/GlobalContext/index.js +1 -1
- package/lib/Help/component.json +118 -0
- package/lib/HelperText/component.json +126 -0
- package/lib/Image/PreviewGroup.js +1 -1
- package/lib/Image/component.json +165 -0
- package/lib/Image/index.js +1 -1
- package/lib/InputCode/component.json +191 -0
- package/lib/InputCode/index.d.ts +2 -2
- package/lib/InputLang/component.json +205 -0
- package/lib/InputLang/index.js +1 -1
- package/lib/InputNumber/component.json +162 -0
- package/lib/Label/component.json +126 -0
- package/lib/Label/index.d.ts +2 -2
- package/lib/Loading/component.json +91 -0
- package/lib/Menu/component.json +180 -0
- package/lib/Menu/verticalMenuList.js +1 -1
- package/lib/Message/component.json +246 -0
- package/lib/Message/index.d.ts +2 -2
- package/lib/Message/index.js +1 -1
- package/lib/Modal/Confirm/index.d.ts +1 -1
- package/lib/Modal/Confirm/index.js +1 -1
- package/lib/Modal/component.json +277 -0
- package/lib/Modal/index.d.ts +85 -5
- package/lib/Modal/index.js +1 -1
- package/lib/Modal/interface.d.ts +1 -0
- package/lib/MultiBox/component.json +216 -0
- package/lib/MultiBox/index.js +1 -1
- package/lib/Notification/component.json +184 -0
- package/lib/OperateBtn/component.json +134 -0
- package/lib/OperateBtn/index.d.ts +3 -3
- package/lib/PageHeader/component.json +112 -0
- package/lib/PageHeader/horizontalMeun.js +1 -1
- package/lib/PageHeader/horizontalMeunRight.js +1 -1
- package/lib/Pagination/component.json +181 -0
- package/lib/Pagination/index.js +1 -1
- package/lib/ParauiProvider/index.js +1 -1
- package/lib/PasswordRules/component.json +105 -0
- package/lib/PasswordRules/index.d.ts +4 -4
- package/lib/PopConfirm/component.json +227 -0
- package/lib/PopConfirm/index.d.ts +1 -1
- package/lib/PopConfirm/index.js +1 -1
- package/lib/PopMenu/component.json +131 -0
- package/lib/PopMenu/hooks.d.ts +1 -1
- package/lib/PopMenu/index.js +1 -1
- package/lib/Popover/component.json +165 -0
- package/lib/Popover/index.js +1 -1
- package/lib/Progress/component.json +161 -0
- package/lib/Prompt/component.json +144 -0
- package/lib/Querying/component.json +96 -0
- package/lib/Querying/index.css +1 -1
- package/lib/Querying/index.d.ts +2 -2
- package/lib/Querying/index.js +1 -1
- package/lib/Querying/style/index.css +1 -1
- package/lib/QuickReply/QuickReplyCode/index.js +1 -1
- package/lib/QuickReply/component.json +129 -0
- package/lib/QuickReply/index.d.ts +1 -1
- package/lib/Radio/component.json +136 -0
- package/lib/RadioGroup/component.json +149 -0
- package/lib/RangeInput/component.json +198 -0
- package/lib/RangeInput/index.js +1 -1
- package/lib/Result/component.json +104 -0
- package/lib/ScrollBar/component.json +115 -0
- package/lib/Search/component.json +177 -0
- package/lib/Search/index.d.ts +1 -1
- package/lib/Select/component.json +244 -0
- package/lib/Select/index.js +1 -1
- package/lib/SelectInput/component.json +184 -0
- package/lib/Selector/component.json +203 -0
- package/lib/Selector/index.js +1 -1
- package/lib/Selector/interface.d.ts +2 -2
- package/lib/Selector/selectorData/index.js +1 -1
- package/lib/Selector/selectorMain/index.js +1 -1
- package/lib/Selector/selectorNode/index.js +1 -1
- package/lib/Selector/util.d.ts +3 -3
- package/lib/Selector/util.js +1 -1
- package/lib/SelectorPicker/component.json +179 -0
- package/lib/SelectorPicker/index.d.ts +5 -5
- package/lib/SelectorPicker/index.js +1 -1
- package/lib/SingleBox/component.json +151 -0
- package/lib/SingleBox/index.d.ts +2 -2
- package/lib/Slider/component.json +181 -0
- package/lib/SortBox/component.json +108 -0
- package/lib/Status/component.json +104 -0
- package/lib/Stepper/component.json +129 -0
- package/lib/Stepper/index.d.ts +2 -2
- package/lib/Switch/component.json +207 -0
- package/lib/Switch/index.css +1 -1
- package/lib/Switch/index.d.ts +3 -2
- package/lib/Switch/index.js +1 -1
- package/lib/Switch/style/index.css +1 -1
- package/lib/Table/component.json +547 -0
- package/lib/Table/index.d.ts +2 -2
- package/lib/Table/index.js +1 -1
- package/lib/Table/interface.d.ts +30 -0
- package/lib/Table/tableHead.js +1 -1
- package/lib/Table/util.d.ts +1 -1
- package/lib/Table/util.js +1 -1
- package/lib/Tabs/component.json +227 -0
- package/lib/Tag/component.json +221 -0
- package/lib/Tag/index.css +1 -1
- package/lib/Tag/index.d.ts +1 -1
- package/lib/Tag/index.js +1 -1
- package/lib/Tag/style/index.css +1 -1
- package/lib/TextEditor/component.json +186 -0
- package/lib/TextEditor/index.d.ts +5 -5
- package/lib/TextEditor/index.js +1 -1
- package/lib/TextField/component.json +290 -0
- package/lib/TextField/index.d.ts +2 -2
- package/lib/TextField/index.js +1 -1
- package/lib/TimePicker/component.json +176 -0
- package/lib/Timeline/component.json +110 -0
- package/lib/Title/component.json +156 -0
- package/lib/ToggleButton/component.json +153 -0
- package/lib/ToggleButton/index.js +1 -1
- package/lib/Tooltip/component.json +176 -0
- package/lib/Tooltip/index.js +1 -1
- package/lib/Tooltip/interface.d.ts +14 -1
- package/lib/Tooltip/utils.js +1 -1
- package/lib/Transfer/component.json +157 -0
- package/lib/Tree/OperateBar/index.js +2 -2
- package/lib/Tree/Tree.js +1 -1
- package/lib/Tree/component.json +512 -0
- package/lib/Tree/interface.d.ts +1 -1
- package/lib/Upload/component.json +450 -0
- package/lib/Upload/util.js +1 -1
- package/lib/Utils/snack-kit-shims.d.ts +18 -0
- package/lib/Utils/snack-kit-shims.js +2 -0
- package/lib/Utils/type.d.ts +0 -2
- package/lib/_virtual/index.js +1 -1
- package/lib/_virtual/index2.js +1 -1
- package/lib/index.d.ts +2 -0
- package/lib/index.js +1 -1
- package/lib/locale/en_US.d.ts +361 -0
- package/lib/locale/en_US.js +2 -0
- package/lib/locale/index.d.ts +1 -723
- package/lib/locale/index2.js +2 -0
- package/lib/locale/zh_CN.d.ts +361 -0
- package/lib/locale/zh_CN.js +2 -0
- package/lib/node_modules/classnames/index.js +1 -1
- package/package.json +11 -4
- package/es/_virtual/index3.js +0 -5
- package/es/_virtual/index4.js +0 -5
- package/es/node_modules/@para-snack/core/dist/index.js +0 -5231
- package/lib/_virtual/index3.js +0 -2
- package/lib/_virtual/index4.js +0 -2
- package/lib/node_modules/@para-snack/core/dist/index.js +0 -20
- /package/es/{Utils/Hooks → Hooks}/useResizeObserver.d.ts +0 -0
- /package/es/{Utils/Hooks → Hooks}/useResizeObserver.js +0 -0
- /package/lib/{Utils/Hooks → Hooks}/useResizeObserver.d.ts +0 -0
- /package/lib/{Utils/Hooks → Hooks}/useResizeObserver.js +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "Card",
|
|
3
|
+
"category": "Data Display",
|
|
4
|
+
"description": "list-driven 卡片容器——按 list 数据源渲染多张卡片,支持每行个数 / 加载更多 / 投影边框配置。**注意:不是 antd 风格的单卡片容器**(没有 title / extra / hoverable / actions 这些 prop)",
|
|
5
|
+
"semantic": {
|
|
6
|
+
"intent": [
|
|
7
|
+
"卡片网格容器",
|
|
8
|
+
"信息分组",
|
|
9
|
+
"列表卡片展示"
|
|
10
|
+
],
|
|
11
|
+
"useCases": [
|
|
12
|
+
"仪表盘卡片网格",
|
|
13
|
+
"商品卡片网格",
|
|
14
|
+
"应用列表"
|
|
15
|
+
],
|
|
16
|
+
"riskLevel": "low"
|
|
17
|
+
},
|
|
18
|
+
"variants": {
|
|
19
|
+
"default": {
|
|
20
|
+
"meaning": "标准卡片网格"
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
"states": [
|
|
24
|
+
"default",
|
|
25
|
+
"loadingMore"
|
|
26
|
+
],
|
|
27
|
+
"idealProps": {
|
|
28
|
+
"list": {
|
|
29
|
+
"type": "CardItemProps[]",
|
|
30
|
+
"itemSchema": {
|
|
31
|
+
"render": { "type": "ReactNode", "description": "卡片内容,静态 ReactNode(不是函数),闭包引用循环变量:data.map(d => ({ render: <div>{d.title}</div> }))" },
|
|
32
|
+
"style": { "type": "React.CSSProperties", "description": "透传到该卡片外层 div 的样式(可覆盖 boxShadow / border 等组件级配置)" }
|
|
33
|
+
},
|
|
34
|
+
"description": "卡片数据源数组。**`CardItemProps = { render?: ReactNode; style?: CSSProperties; [key]: any }`**——核心字段:①`render` 是**静态 ReactNode**(不是 `(item) => ReactNode` 函数!直接写 JSX 即可,需引用循环变量时用闭包:`docs.map(d => ({ render: <div>{d.title}</div> }))`,不要写 `render: () => <div>{d.title}</div>`);②`style` 透传到该卡片外层 div;③允许任意业务字段平铺存放(`id` / `title` 等仅供业务方在 render 中闭包引用,不被 Card 内部使用)。**list 项**不需要传 React `key`——src 内部用数组 index 做 key。"
|
|
35
|
+
},
|
|
36
|
+
"lineNum": {
|
|
37
|
+
"type": "number | CardLineNumProps[]",
|
|
38
|
+
"itemSchema": {
|
|
39
|
+
"width": { "type": "number", "required": true, "description": "容器宽度阈值(px),当容器宽度超过此值时使用此断点配置" },
|
|
40
|
+
"size": { "type": "number", "required": true, "description": "该断点下每行展示的卡片数" }
|
|
41
|
+
},
|
|
42
|
+
"description": "**每行展示的卡片数**(不是总行数!)。与 `width` 互斥:仅当未传 `width` 时 `lineNum` 才生效,每张卡片宽度按容器宽度均分。传数组可做响应式:`[{width: 容器宽阈值, size: 该断点每行个数}]`,src 按 width 升序匹配第一个 `item.width > 容器宽` 的 size;都不命中时取最大档 size。**src 行为细节**(DEFECT-006):src 内部按 width 升序自动 sort,Infinity 作 width 合法且与 `>` 比较恒真;\"最大档\" = 排序后最后一项(width 最大),与 size 数值无关。"
|
|
43
|
+
},
|
|
44
|
+
"width": {
|
|
45
|
+
"type": "string",
|
|
46
|
+
"default": "300px",
|
|
47
|
+
"description": "每张卡片固定宽度(与 `lineNum` 互斥,**`width` 优先级高于 `lineNum`**——src 在 `props.width === undefined` 时才进入 `lineNum` 分支)。仅接受 px 等具体单位字符串;不支持 `'auto'` / 百分比(src 直接 inline style 透传,但宽度模式下 Card 不会重新计算 marginRight 收尾对齐)。"
|
|
48
|
+
},
|
|
49
|
+
"height": {
|
|
50
|
+
"type": "string",
|
|
51
|
+
"default": "140px",
|
|
52
|
+
"description": "每张卡片高度。仅接受 px 等具体单位字符串;**不支持 `'auto'`**——src 把 height 直接写到外层 div inline style,'auto' 会让卡片高度按 render 内容撑开但失去等高网格视觉。如需自适应内容高度,需在 render 内部用 `display: flex; flex-direction: column` 自管理。**height 不支持 'auto' / 百分比**(DEFECT-008):如需高度跟随内容,父组件需先测量后传 px 字符串(可用 ResizeObserver),Card 不感知父容器高度变化。"
|
|
53
|
+
},
|
|
54
|
+
"boxShadow": {
|
|
55
|
+
"type": "boolean | string",
|
|
56
|
+
"default": false,
|
|
57
|
+
"description": "是否带投影。`true` 默认值 `'1px 1px 10px 2px rgba(212,218,227,0.40)'`(src/Card/index.tsx:203);传字符串则直接作为 CSS box-shadow 值透传。**作用于所有卡片**(组件级);单卡覆盖在 list[].style.boxShadow 中传值,后者优先(Card-DEFECT-003(详见 docs/superpowers/ai-test/defects.md))。"
|
|
58
|
+
},
|
|
59
|
+
"border": {
|
|
60
|
+
"type": "boolean | string",
|
|
61
|
+
"default": false,
|
|
62
|
+
"description": "是否带边框。`true` 默认值 `'1px solid rgba(212, 218, 227, 0.4)'`(src/Card/index.tsx:210);传字符串则直接作为 CSS border 简写值(如 `'2px dashed #1677ff'`)透传。**作用于所有卡片**(组件级);单卡覆盖在 list[].style.border 中传值,后者优先(Card-DEFECT-003(详见 docs/superpowers/ai-test/defects.md))。"
|
|
63
|
+
},
|
|
64
|
+
"marginRight": {
|
|
65
|
+
"type": "string",
|
|
66
|
+
"default": "20px",
|
|
67
|
+
"description": "**卡片之间的右间距**(不是 Card 容器外边距)。每张卡片 inline `style.marginRight`;每行最后一张卡片自动重置为 0。"
|
|
68
|
+
},
|
|
69
|
+
"marginBottom": {
|
|
70
|
+
"type": "string",
|
|
71
|
+
"default": "20px",
|
|
72
|
+
"description": "**卡片之间的下间距**(不是 Card 容器外边距)。每张卡片 inline `style.marginBottom`。"
|
|
73
|
+
},
|
|
74
|
+
"showMore": {
|
|
75
|
+
"type": "boolean",
|
|
76
|
+
"default": false,
|
|
77
|
+
"description": "是否启用『加载更多』机制(与 `onMore` 配合:showMore=true 时滚动到底部触发 onMore;底部展示 moreRender / loadingMoreRender 文案)。**注意**:5.x 没有独立 `hasMore` prop——『已加载完所有数据』需在业务方 `onMore` 内自行判断后 return 短路(参见 do 段)。议题见 discussions/Card-hasMore-prop.md。"
|
|
78
|
+
},
|
|
79
|
+
"moreRender": {
|
|
80
|
+
"type": "ReactNode",
|
|
81
|
+
"default": "intl('more')",
|
|
82
|
+
"description": "底部『可加载』状态展示节点(非 loading 时)。点击后触发 onMore。与 loadingMoreRender 互斥:loadingMore 状态展示 loadingMoreRender,否则展示 moreRender。"
|
|
83
|
+
},
|
|
84
|
+
"loadingMoreRender": {
|
|
85
|
+
"type": "ReactNode",
|
|
86
|
+
"default": "intl('loadingMore')",
|
|
87
|
+
"description": "底部『加载中』状态展示节点(onMore 执行期间)。与 moreRender 互斥(见 moreRender 描述)。"
|
|
88
|
+
},
|
|
89
|
+
"onMore": {
|
|
90
|
+
"type": "function",
|
|
91
|
+
"signature": "() => Promise<void> | void",
|
|
92
|
+
"description": "加载更多回调(showMore=true 时滚动到底部触发)。返回 Promise 时 Card 自动管理 loadingMore 状态——业务方应在 onMore 内 await 数据请求后 setState 追加 list;同步返回时立即结束 loading。**业务方需自行维护 hasMore 标记**:到达末页时在 onMore 入口 `if (!hasMore) return` 短路。"
|
|
93
|
+
},
|
|
94
|
+
"backgroundImage": {
|
|
95
|
+
"type": "string",
|
|
96
|
+
"description": "**作用于所有卡片的统一背景图**(组件级,Card-DEFECT-002(详见 docs/superpowers/ai-test/defects.md):所有卡片共享同一张背景图,不是按 list[].cover 渲染单卡封面)。url 设置后 Card 自动追加 `backgroundSize: 100% 100%; backgroundRepeat: no-repeat`。如需每张卡封面不同,请在 list[].render 内自管理图片渲染。"
|
|
97
|
+
},
|
|
98
|
+
"className": {
|
|
99
|
+
"type": "string",
|
|
100
|
+
"description": "卡片容器自定义类名(src/Card/index.tsx:33 interface 实证,透传到根容器 div)"
|
|
101
|
+
},
|
|
102
|
+
"style": {
|
|
103
|
+
"type": "React.CSSProperties",
|
|
104
|
+
"description": "卡片容器自定义样式(src/Card/index.tsx:35 interface 实证,透传到根容器 div)"
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
"do": [
|
|
108
|
+
"用 list 一次传入数据源,让 Card 自动按 lineNum / width 排版",
|
|
109
|
+
"**业务数据派生 list 时**:用 `data.map(d => ({ render: <CardContent {...d} /> }))` 或 `data.map(d => ({ render: <div>{d.title}</div> }))` —— render 直接写 JSX 节点(闭包引用循环变量 d),**不要写 `render: () => <div>...</div>` 函数形式**",
|
|
110
|
+
"**自定义渲染撑满整张卡片**:render 节点内部用 `<div style={{ height: '100%', display: 'flex', flexDirection: 'column' }}>...</div>`,因为 Card 已经把外层 div 高度固定为 props.height",
|
|
111
|
+
"在 render 根 div 加 `boxSizing: border-box`(DEFECT-007):因 Card 外层 height 固定时,padding 默认会撑超溢出",
|
|
112
|
+
"需要响应式列数时给 lineNum 传数组(按容器宽断点;按 width 升序匹配第一个超过容器宽的档位)",
|
|
113
|
+
"数据较多时启用 showMore + onMore 实现分页加载;**业务方在 onMore 入口判断业务侧 hasMore 标记,到达末页 `if (!hasMore) return`** 短路(src 无 hasMore prop)",
|
|
114
|
+
"lineNum / width 二选一即可——传 width 时 lineNum 不生效(src 在 props.width === undefined 时才进入 lineNum 分支)",
|
|
115
|
+
"list 项不需要传 React `key`——src 内部用数组 index 做 key(业务字段 `id` 仅供业务方 render 内闭包引用)"
|
|
116
|
+
],
|
|
117
|
+
"dont": [
|
|
118
|
+
"**不要把 render 写成 `() => ReactNode` 函数形式**——CardItemProps.render 是静态 `ReactNode`,传函数会被 React 当作 child 直接渲染,触发 `Warning: Functions are not valid as a React child` 警告(runtime 层验证失败)",
|
|
119
|
+
"lineNum 与 width 同时传(互斥;src 在 width 已定义时直接走 width 分支,lineNum 被忽略)",
|
|
120
|
+
"在 list 中传入超大 ReactNode 致渲染卡顿(应只放轻量数据,render 用 memo)",
|
|
121
|
+
"**试图传 antd 风格 prop**:`title` / `extra` / `hoverable` / `actions` / `cover` / `renderItem` / `dataSource` —— 这些 prop 不存在;自定义渲染只能通过 `list[].render` 节点",
|
|
122
|
+
"传 `height='auto'` 或百分比——src 直接 inline 透传,'auto' 会让卡片高度按内容撑开但失去等高视觉",
|
|
123
|
+
"依赖 `showMore=false` 切换来停止 onMore 触发——切换 false 会让底部按钮消失但已触发的 onMore 不会撤销;正确做法是 `onMore` 内 `if (!业务侧 hasMore) return`"
|
|
124
|
+
],
|
|
125
|
+
"events": {
|
|
126
|
+
"onMore": {
|
|
127
|
+
"signature": "() => Promise<void> | void",
|
|
128
|
+
"asyncSupported": true,
|
|
129
|
+
"examples": [
|
|
130
|
+
"基础分页加载:onMore={async () => { const data = await api.getPage(page++); setList(prev => [...prev, ...data]); }}",
|
|
131
|
+
"Card 自动管理 loadingMore 状态——onMore 执行期间显示 loadingMoreRender,执行完毕自动恢复",
|
|
132
|
+
"业务侧维护 hasMore 标记:onMore={async () => { if (!hasMore) return; const res = await load(); if (!res.hasNext) setHasMore(false); }}"
|
|
133
|
+
],
|
|
134
|
+
"commonMistakes": [
|
|
135
|
+
"期望 src 自动检测是否到达末页——src 无 hasMore prop,到达末页需在 onMore 内 return 短路",
|
|
136
|
+
"依赖 showMore=false 停止触发——切换 false 只隐藏底部按钮,已触发的 onMore Promise 不会撤销",
|
|
137
|
+
"onMore 里直接 setState 覆盖整个 list 而非追加——滚动加载应追加新数据:setList(prev => [...prev, ...newItems])"
|
|
138
|
+
]
|
|
139
|
+
}
|
|
140
|
+
},
|
|
141
|
+
"typescriptPitfalls": [
|
|
142
|
+
{
|
|
143
|
+
"issue": "list[].render 是静态 ReactNode,不是 (item) => ReactNode 函数——传函数导致 React child 警告",
|
|
144
|
+
"wrong": "const list = data.map(d => ({ render: () => <CardContent data={d} /> })); // 函数被当作 child 渲染,报 Warning",
|
|
145
|
+
"right": "const list = data.map(d => ({ render: <CardContent data={d} /> })); // 闭包引用 d,直接写 JSX"
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
"issue": "lineNum 与 width 互斥——同时传时 width 优先(src 在 props.width === undefined 时才进 lineNum 分支)",
|
|
149
|
+
"wrong": "// 期望 lineNum 和 width 都生效\n<Card list={list} width='300px' lineNum={4} /> // lineNum 被忽略",
|
|
150
|
+
"right": "// 二选一:固定宽度用 width;响应式列数用 lineNum(不传 width)\n<Card list={list} lineNum={4} />"
|
|
151
|
+
},
|
|
152
|
+
{
|
|
153
|
+
"issue": "height 不支持 'auto'——src 直接 inline 透传,'auto' 会破坏等高网格视觉",
|
|
154
|
+
"wrong": "<Card list={list} height='auto' /> // 卡片高度按内容撑开,等高网格失效",
|
|
155
|
+
"right": "// 如需自适应内容高度,先测量再传 px 字符串,或在 render 内部自管理\n<Card list={list} height='200px' />"
|
|
156
|
+
}
|
|
157
|
+
],
|
|
158
|
+
"mapping": {
|
|
159
|
+
"realComponent": "Card",
|
|
160
|
+
"adapter": null
|
|
161
|
+
}
|
|
162
|
+
}
|
package/lib/Card/index.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { default as React, FunctionComponent, ReactNode } from 'react';
|
|
|
2
2
|
export interface CardItemProps {
|
|
3
3
|
render?: ReactNode;
|
|
4
4
|
style?: React.CSSProperties;
|
|
5
|
-
[name: string]:
|
|
5
|
+
[name: string]: unknown;
|
|
6
6
|
}
|
|
7
7
|
export interface CardLineNumProps {
|
|
8
8
|
/** 容器宽度 */
|
|
@@ -41,7 +41,7 @@ export interface CardProps {
|
|
|
41
41
|
loadingMoreRender?: ReactNode;
|
|
42
42
|
/** 加载更多事件 */
|
|
43
43
|
onMore?: () => Promise<void> | void;
|
|
44
|
-
[name: string]:
|
|
44
|
+
[name: string]: unknown;
|
|
45
45
|
}
|
|
46
46
|
export declare const Card: FunctionComponent<CardProps>;
|
|
47
47
|
export default Card;
|
package/lib/Card/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});require('./index.css');const m=require("../_virtual/jsx-runtime.js"),l=require("react"),T=require("../GlobalContext/constant.js"),P=require("clsx"),G=require("../GlobalContext/useFormatMessage.js"),J=require("./lang/index.js"),K=require("../
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});require('./index.css');const m=require("../_virtual/jsx-runtime.js"),l=require("react"),T=require("../GlobalContext/constant.js"),P=require("clsx"),G=require("../GlobalContext/useFormatMessage.js"),J=require("./lang/index.js"),K=require("../Hooks/useResizeObserver.js");;/* empty css */const $=i=>{const{className:k,style:B,list:b,boxShadow:f,border:x,backgroundImage:w,width:z="300px",height:F="140px",lineNum:h,marginRight:C="20px",marginBottom:W="20px",showMore:p=!1,moreRender:N,loadingMoreRender:y,onMore:L}=i,v=G.default("Card",J.default),[Q,A]=l.useState(),[S,j]=l.useState(!1),r=l.useRef({}),e=l.useRef(null);r.current.onMore=L,K.default({dom:e.current,cb:()=>q(),timer:0}),l.useEffect(()=>(e.current?.addEventListener("scroll",H),()=>{e.current?.removeEventListener("scroll",H)}),[]),l.useEffect(()=>{q()},[b,h]);const q=()=>{if(!e.current)return;const o=e.current.getBoundingClientRect(),c=e.current.querySelector(".card-list"),t=e.current.querySelector(".card-list > .card-item"),I=t.getBoundingClientRect(),u=parseFloat(t.style.marginRight),g=e.current.scrollHeight>e.current.clientHeight;let n=Math.floor((c.clientWidth+u)/(I.width+u));if(i.width===void 0&&i.lineNum){if(typeof h=="number")n=h;else{const d=i.lineNum.sort((s,R)=>s.width-R.width);for(let s=0,R=d.length;s<R;s++){const M=d[s];if(M.width>o.width){n=M.size;break}else s===d.length-1&&(n=M.size)}}let a=(n-1)*u;g&&(a=a+4);const D=`${a/n}px`;r.current.itemWidth=`calc(${1/n*100}% - ${D})`,e.current.querySelectorAll(".card-list > .card-item").forEach(d=>{d.style.width=r.current.itemWidth||""})}n!==r.current.lineNumCom&&(r.current.lineNumCom=n,A(n))},H=()=>{if(!(!p||!e.current||!r.current.onMore||r.current.loadingMore)&&e.current.scrollHeight-(e.current.clientHeight+e.current.scrollTop)<1){if(r.current.pos?.clientHeight===e.current.clientHeight&&r.current.pos?.scrollTop===e.current.scrollTop&&r.current.pos?.scrollHeight===e.current.scrollHeight){r.current.pos={};return}r.current.pos={clientHeight:e.current.clientHeight,scrollTop:e.current.scrollTop,scrollHeight:e.current.scrollHeight},E()}},E=async()=>{r.current.loadingMore||(r.current.loadingMore=!0,j(!0),await r.current.onMore(),j(!1),r.current.loadingMore=!1)},O=(o,c)=>{const t={height:F,marginBottom:W,marginRight:C};if(f&&(f===!0?t.boxShadow="1px 1px 10px 2px rgba(212,218,227,0.40)":t.boxShadow=f),x&&(x===!0?t.border="1px solid rgba(212, 218, 227, 0.4)":t.border=x),w&&(t.backgroundImage=w,t.backgroundSize="100% 100%",t.backgroundRepeat="no-repeat"),h===void 0&&(t.width=z),i.width){if(e.current){const u=e.current.querySelector(".card-list").clientWidth,g=parseFloat(C),n=parseFloat(i.width),a=r.current.lineNumCom*(n+g)-g;u-a<=n&&r.current.lineNumCom&&(c+1)%r.current.lineNumCom===0&&(t.marginRight=0)}}else r.current.lineNumCom&&(c+1)%r.current.lineNumCom===0&&(t.marginRight=0);return{...t,...o.style}},_=()=>S?y||v({id:"loadingMore"}):N||v({id:"more"});return m.jsxRuntimeExports.jsxs("div",{className:P(k,`${T.$prefixCls}-card`,{[`${T.$prefixCls}-card-more`]:p&&!S}),style:B,ref:e,children:[m.jsxRuntimeExports.jsx("div",{className:"card-list",children:b?.map((o,c)=>m.jsxRuntimeExports.jsx("div",{className:"card-item",style:O(o,c),children:o.render},c))}),p&&m.jsxRuntimeExports.jsx("div",{className:"more",children:m.jsxRuntimeExports.jsx("div",{className:"more-content",onClick:E,children:_()})})]})};exports.Card=$;exports.default=$;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "Carousel",
|
|
3
|
+
"category": "Data Display",
|
|
4
|
+
"description": "走马灯,用于一组图片或卡片的轮播",
|
|
5
|
+
"semantic": {
|
|
6
|
+
"intent": [
|
|
7
|
+
"轮播展示",
|
|
8
|
+
"吸引注意",
|
|
9
|
+
"节省空间"
|
|
10
|
+
],
|
|
11
|
+
"useCases": [
|
|
12
|
+
"首页 Banner",
|
|
13
|
+
"产品展示",
|
|
14
|
+
"图片画廊"
|
|
15
|
+
],
|
|
16
|
+
"riskLevel": "low"
|
|
17
|
+
},
|
|
18
|
+
"variants": {
|
|
19
|
+
"default": {
|
|
20
|
+
"meaning": "默认轮播"
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
"states": [
|
|
24
|
+
"active"
|
|
25
|
+
],
|
|
26
|
+
"idealProps": {
|
|
27
|
+
"autoplay": {
|
|
28
|
+
"type": "boolean",
|
|
29
|
+
"default": false,
|
|
30
|
+
"description": "是否自动切换"
|
|
31
|
+
},
|
|
32
|
+
"autoplaySpeed": {
|
|
33
|
+
"type": "number",
|
|
34
|
+
"default": 3000,
|
|
35
|
+
"description": "自动播放间隔(ms),需配合 autoplay=true 使用",
|
|
36
|
+
"required": false
|
|
37
|
+
},
|
|
38
|
+
"infinite": {
|
|
39
|
+
"type": "boolean",
|
|
40
|
+
"default": true,
|
|
41
|
+
"description": "无限循环;设为 false 时到最后一张停止",
|
|
42
|
+
"required": false
|
|
43
|
+
},
|
|
44
|
+
"slidesToShow": {
|
|
45
|
+
"type": "number",
|
|
46
|
+
"default": 1,
|
|
47
|
+
"description": "一帧显示幻灯片数",
|
|
48
|
+
"required": false
|
|
49
|
+
},
|
|
50
|
+
"slidesToScroll": {
|
|
51
|
+
"type": "number",
|
|
52
|
+
"default": 1,
|
|
53
|
+
"description": "一次滚动幻灯片数",
|
|
54
|
+
"required": false
|
|
55
|
+
},
|
|
56
|
+
"arrows": {
|
|
57
|
+
"type": "boolean",
|
|
58
|
+
"default": false,
|
|
59
|
+
"description": "是否显示前后箭头",
|
|
60
|
+
"required": false
|
|
61
|
+
},
|
|
62
|
+
"dotPosition": {
|
|
63
|
+
"type": "enum",
|
|
64
|
+
"values": ["top", "bottom", "left", "right"],
|
|
65
|
+
"default": "bottom",
|
|
66
|
+
"description": "指示点位置",
|
|
67
|
+
"required": false
|
|
68
|
+
},
|
|
69
|
+
"pauseOnHover": {
|
|
70
|
+
"type": "boolean",
|
|
71
|
+
"default": true,
|
|
72
|
+
"description": "悬停时暂停自动播放",
|
|
73
|
+
"required": false
|
|
74
|
+
},
|
|
75
|
+
"dots": {
|
|
76
|
+
"type": "boolean",
|
|
77
|
+
"default": true,
|
|
78
|
+
"description": "是否显示指示点"
|
|
79
|
+
},
|
|
80
|
+
"effect": {
|
|
81
|
+
"type": "enum",
|
|
82
|
+
"values": [
|
|
83
|
+
"scrollx",
|
|
84
|
+
"fade"
|
|
85
|
+
],
|
|
86
|
+
"default": "scrollx",
|
|
87
|
+
"description": "动画效果"
|
|
88
|
+
},
|
|
89
|
+
"afterChange": {
|
|
90
|
+
"type": "function",
|
|
91
|
+
"signature": "(current: number) => void",
|
|
92
|
+
"description": "切换面板的回调"
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
"do": [
|
|
96
|
+
"使用高质量的图片",
|
|
97
|
+
"限制 Carousel 的数量(<5)以保证性能",
|
|
98
|
+
"需要命令式控制(goTo/next/prev)时通过 forwardRef + useRef<CarouselRef> 获取实例方法"
|
|
99
|
+
],
|
|
100
|
+
"dont": [
|
|
101
|
+
"在移动端使用非触摸友好的 Carousel",
|
|
102
|
+
"自动播放速度过快 (<2s) 导致用户无法看清",
|
|
103
|
+
"不要传 prevArrow / nextArrow prop——这两个 prop 已从 CarouselProps 中移除(TypeScript 会报错);自定义箭头外观请通过 CSS 覆盖 `.slick-prev` / `.slick-next` 样式"
|
|
104
|
+
],
|
|
105
|
+
"events": {
|
|
106
|
+
"afterChange": {
|
|
107
|
+
"signature": "(current: number) => void",
|
|
108
|
+
"asyncSupported": false,
|
|
109
|
+
"examples": [
|
|
110
|
+
"切换后同步外部状态:afterChange={(index) => setActiveIndex(index)}",
|
|
111
|
+
"切换后更新指示器:afterChange={(index) => setTitle(slides[index].title)}",
|
|
112
|
+
"切换后埋点:afterChange={(index) => analytics.track('carousel_change', { slide: index })}"
|
|
113
|
+
],
|
|
114
|
+
"commonMistakes": [
|
|
115
|
+
"期望 beforeChange 回调——CarouselProps 只有 afterChange,beforeChange 来自 react-slick Settings 但未在 CarouselProps 类型覆盖中暴露",
|
|
116
|
+
"期望 afterChange 在自动播放切换时也触发——autoplay 切换同样会触发 afterChange",
|
|
117
|
+
"current 参数是 0-based 索引,从 infinite=true 模式下 current 可能超过 children 数量(react-slick 克隆节点)"
|
|
118
|
+
]
|
|
119
|
+
}
|
|
120
|
+
},
|
|
121
|
+
"typescriptPitfalls": [
|
|
122
|
+
{
|
|
123
|
+
"issue": "prevArrow 和 nextArrow 已从 CarouselProps 中通过 Omit 移除——传入会有 TS 报错",
|
|
124
|
+
"wrong": "<Carousel prevArrow={<MyPrev />} nextArrow={<MyNext />} /> // TS: Omit<Settings, '...prevArrow | nextArrow'>",
|
|
125
|
+
"right": "// 通过 CSS 覆盖箭头样式\n// .paraui-v4-carousel .slick-prev { ... }\n// .paraui-v4-carousel .slick-next { ... }"
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
"issue": "CarouselRef 的命令式方法(goTo/next/prev/play/pause)需要通过 forwardRef 接收,useRef 泛型必须指定",
|
|
129
|
+
"wrong": "const ref = useRef(null);\n// ref.current.goTo(2); // TS: null 上不存在 goTo",
|
|
130
|
+
"right": "import type { CarouselRef } from '@para-ui/core/Carousel';\nconst ref = useRef<CarouselRef>(null);\n// ref.current?.goTo(2);"
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
"issue": "effect prop 值只有 'scrollx' | 'fade'——不是 react-slick 原生的 fade boolean,内部做了映射",
|
|
134
|
+
"wrong": "<Carousel fade={true} /> // fade 是 react-slick 原生字段,CarouselProps 用 effect 替代",
|
|
135
|
+
"right": "<Carousel effect='fade' /> // src 内部将 effect='fade' 映射为 newProps.fade=true"
|
|
136
|
+
}
|
|
137
|
+
],
|
|
138
|
+
"mapping": {
|
|
139
|
+
"realComponent": "Carousel",
|
|
140
|
+
"adapter": null
|
|
141
|
+
}
|
|
142
|
+
}
|
package/lib/Carousel/index.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { default as React } from 'react';
|
|
|
2
2
|
import { Settings } from 'react-slick';
|
|
3
3
|
export type CarouselEffect = 'scrollx' | 'fade';
|
|
4
4
|
export type DotPosition = 'top' | 'bottom' | 'left' | 'right';
|
|
5
|
-
export interface CarouselProps extends Omit<Settings, 'dots' | 'dotsClass'> {
|
|
5
|
+
export interface CarouselProps extends Omit<Settings, 'dots' | 'dotsClass' | 'prevArrow' | 'nextArrow'> {
|
|
6
6
|
/** 动画效果函数 */
|
|
7
7
|
effect?: CarouselEffect;
|
|
8
8
|
/** style */
|
package/lib/Cascader/Cascader.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const s=require("../_virtual/jsx-runtime.js"),He=require("rc-select"),re=require("clsx"),Ke=require("rc-select/lib/hooks/useId"),Le=require("rc-tree/lib/utils/conductUtil"),Fe=require("../node_modules/@para-ui/icons/Right/index.js"),ae=require("rc-util/lib/hooks/useEvent"),Ue=require("rc-util/lib/hooks/useMergedState"),ze=require("../node_modules/@para-ui/icons/Down/index.js"),Be=require("../node_modules/@para-ui/icons/CloseCircleF/index.js"),Je=require("react"),Ge=require("./context.js"),Qe=require("./hooks/useDisplayValues.js"),Xe=require("./hooks/useEntities.js"),Ye=require("./hooks/useMissingValues.js"),Ze=require("./OptionList/index.js"),f=require("./utils/commonUtil.js"),T=require("./utils/treeUtil.js"),et=require("@
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const s=require("../_virtual/jsx-runtime.js"),He=require("rc-select"),re=require("clsx"),Ke=require("rc-select/lib/hooks/useId"),Le=require("rc-tree/lib/utils/conductUtil"),Fe=require("../node_modules/@para-ui/icons/Right/index.js"),ae=require("rc-util/lib/hooks/useEvent"),Ue=require("rc-util/lib/hooks/useMergedState"),ze=require("../node_modules/@para-ui/icons/Down/index.js"),Be=require("../node_modules/@para-ui/icons/CloseCircleF/index.js"),Je=require("react"),Ge=require("./context.js"),Qe=require("./hooks/useDisplayValues.js"),Xe=require("./hooks/useEntities.js"),Ye=require("./hooks/useMissingValues.js"),Ze=require("./OptionList/index.js"),f=require("./utils/commonUtil.js"),T=require("./utils/treeUtil.js"),et=require("@snack-kit/lib"),j=require("../GlobalContext/constant.js"),ie=require("../Tooltip/index.js"),tt=require("./lang/index.js"),st=require("../GlobalContext/useFormatMessage.js"),nt=require("../HelperText/index.js");function ot(o){const l=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(o){for(const p in o)if(p!=="default"){const E=Object.getOwnPropertyDescriptor(o,p);Object.defineProperty(l,p,E.get?E:{enumerable:!0,get:()=>o[p]})}}return l.default=o,Object.freeze(l)}const n=ot(Je);function rt(o){return Array.isArray(o)&&Array.isArray(o[0])}function _(o){return o?rt(o)?o:(o.length===0?[]:[o]).map(l=>Array.isArray(l)?l:[l]):[]}const S=n.forwardRef((o,l)=>{const p=st.default("Cascader",tt.default),{id:E,prefixCls:le=`${j.$prefixCls}-cascader`,fieldNames:I,className:at,defaultValue:ce,value:y,changeOnSelect:W,onChange:R,displayRender:ue,expandTrigger:A,options:g,optionsTitle:H=[],dropdownPrefixCls:K,loadData:L,popupVisible:F,open:N,popupClassName:de,dropdownClassName:pe,dropdownMenuColumnStyle:U,popupPlacement:me,placement:he,onDropdownVisibleChange:xe,onPopupVisibleChange:fe,expandIcon:z=s.jsxRuntimeExports.jsx(Fe.Right,{}),loadingIcon:B,placeholder:q=p({id:"placeholder"}),allClear:ge=!0,menuMaxHight:Ce=158,expandJoin:je="/",disabled:V=!1,loading:w,disabledTooltip:M,error:J=!1,hideErrorDom:Ee,helperText:ye="",children:G,dropdownMatchSelectWidth:Re=!1,showCheckedStrategy:Q=f.SHOW_PARENT,...Ve}=o,we=Ke(E),[v,be]=Ue(ce,{value:y,postState:_}),c=n.useMemo(()=>f.fillFieldNames(I),[JSON.stringify(I)]),u=n.useMemo(()=>g||[],[g]),m=Xe.default(u,c),C=n.useCallback(e=>{const t=m();return e.map(r=>{const{nodes:i}=t[r];return i.map(a=>a[c.value])})},[m,c]),[h,X]=n.useState(),[P,D]=n.useState(!1),[Y,Oe]=n.useState("auto"),x=n.useRef({id:et.UUID(),level:1}),Se=e=>_(e).map(i=>T.toPathOptions(i,u,c).map(a=>a.option));n.useEffect(()=>{if(!y)return;const t=Se(y)[0];t&&X(t.map(r=>r?.label).join(je))},[y]);const Z=Ye.default(u,c),[b,ee,te]=n.useMemo(()=>{const[e,t]=Z(v);if(!v.length)return[e,[],t];const r=f.toPathKeys(e),i=m(),{checkedKeys:a,halfCheckedKeys:d}=Le.conductCheck(r,!0,i);return[C(a),C(d),t]},[v,m,C,Z]),Ne=n.useMemo(()=>{const e=f.toPathKeys(b),t=T.formatStrategyValues(e,m,Q);return[...te,...C(t)]},[b,m,C,te,Q]),qe=Qe.default(Ne,u,c,!1,ue),se=ae(e=>{be(e);const t=_(e),r=t.map(d=>T.toPathOptions(d,u,c).map(O=>O.option)),i=t[0],a=r[0];R&&R(i,a||[])}),k=ae(e=>{se(e)}),Me=(e,t)=>{if(t.type==="clear"){se([]);return}const{valueCells:r}=t.values[0];k(r)},ve=pe||de,Pe=he||me,De=e=>{D(e),xe?.(e),fe?.(e)},ne=n.useMemo(()=>({options:u,optionsTitle:H,fieldNames:c,values:b,menuMaxHight:Ce,halfValues:ee,changeOnSelect:W,onSelect:k,menuWidth:Y,dropdownPrefixCls:K,loadData:L,expandTrigger:A,expandIcon:z,loadingIcon:B,dropdownMenuColumnStyle:U,loading:w}),[Y,u,x,H,c,b,ee,W,k,K,L,A,z,B,U,w]),oe=!u.length,ke=(e,t=1)=>{let r=t;const i=[...e.map(a=>({option:a,depth:1}))];for(;i.length>0&&r<3;){const a=i.pop();if(!a)break;const{option:d,depth:O}=a;r=Math.max(r,O),d.children&&d.children.length>0&&i.push(...d.children.map(Ae=>({option:Ae,depth:O+1})))}return r};n.useEffect(()=>{D(!!(N!==void 0?N:F))},[N,F]),n.useEffect(()=>(window.addEventListener("resize",$),()=>{window.removeEventListener("resize",$)}),[]),n.useEffect(()=>{const t=g?.[0]?.children;x.current.level=!t||t.length<1||w?1:ke(g||[]),$()},[g,w]);const $e=e=>{e.stopPropagation(),X(""),R&&R([],[]),D(!1),ne.values=[]},$=()=>{const e=document.getElementById(`${x.current.id}`);if(!e)return;const{clientWidth:t}=e;Oe((t/x.current.level).toFixed(2))},Te=n.useMemo(()=>s.jsxRuntimeExports.jsx(s.jsxRuntimeExports.Fragment,{children:h?V&&M?s.jsxRuntimeExports.jsx(ie.Tooltip,{disabled:!0,children:s.jsxRuntimeExports.jsx("span",{className:"select-label-text",children:h})}):s.jsxRuntimeExports.jsx("span",{className:"select-label-text",children:h}):V&&M?s.jsxRuntimeExports.jsx(ie.Tooltip,{disabled:!0,...M,children:s.jsxRuntimeExports.jsx("span",{className:"select-label-placeholder",children:q})}):s.jsxRuntimeExports.jsx("span",{className:"select-label-placeholder",children:q})}),[h,q]),_e=()=>{if(ge)return s.jsxRuntimeExports.jsx("span",{className:"clean-up-icon",onClick:$e,children:s.jsxRuntimeExports.jsx(Be.CloseCircleF,{})})},Ie=n.useMemo(()=>{const e=re(`${j.$prefixCls}-cascader-select-content`,{[`${j.$prefixCls}-cascader-select-value`]:h,[`${j.$prefixCls}-cascader-select-disabled`]:V,[`${j.$prefixCls}-cascader-error`]:J}),t=re("select-svg",{"select-svg-open":P});return G||s.jsxRuntimeExports.jsxs("div",{className:e,id:x.current.id,children:[Te,s.jsxRuntimeExports.jsxs("span",{className:t,children:[s.jsxRuntimeExports.jsx(ze.Down,{}),_e()]})]})},[h,P,x]),We=oe?{}:{minWidth:"auto"};return s.jsxRuntimeExports.jsxs(Ge.default.Provider,{value:ne,children:[s.jsxRuntimeExports.jsx(He.BaseSelect,{...Ve,ref:l,disabled:V,id:we,prefixCls:le,dropdownMatchSelectWidth:Re,dropdownStyle:We,showSearch:!1,searchValue:"",onSearch:()=>{console.log("not search")},displayValues:qe,onDisplayValuesChange:Me,OptionList:Ze.default,emptyOptions:oe,open:P,dropdownClassName:ve,placement:Pe,onDropdownVisibleChange:De,getRawInputElement:()=>Ie}),s.jsxRuntimeExports.jsx(nt.default,{className:"text-field-error-text",error:J,helperText:ye,hideErrorDom:Ee})]})});process.env.NODE_ENV!=="production"&&(S.displayName="Cascader");S.SHOW_PARENT=f.SHOW_PARENT;S.SHOW_CHILD=f.SHOW_CHILD;exports.default=S;
|
|
2
2
|
//# sourceMappingURL=Cascader.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../_virtual/jsx-runtime.js"),Y=require("../../_virtual/
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../_virtual/jsx-runtime.js"),Y=require("../../_virtual/index.js"),Z=require("react"),K=require("../context.js"),O=require("../utils/commonUtil.js"),V=require("../../Tooltip/index.js");require("../../node_modules/@para-ui/icons/SvgIcon/index.js");const ee=require("../../node_modules/@para-ui/icons/Forbid/index.js"),te=require("../../node_modules/@para-ui/icons/LoadingF/index.js"),C=require("../../GlobalContext/constant.js"),ne=require("../lang/index.js"),y=require("../../AutoTips/index.js"),se=require("../../GlobalContext/useFormatMessage.js");function ie(s){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const o in s)if(o!=="default"){const x=Object.getOwnPropertyDescriptor(s,o);Object.defineProperty(r,o,x.get?x:{enumerable:!0,get:()=>s[o]})}}return r.default=s,Object.freeze(r)}const k=ie(Z),F="__cascader_fix_label__";function re({prefixCls:s,options:r,multiple:o,activeValue:x,prevValuePath:E,titleIndex:b,onToggleOpen:L,onSelect:M,onActive:S,checkedSet:$,loadingKeys:_,isSelectable:w,searchValue:D}){const I=`${s}-menu ${C.$prefixCls}-scrollbar-small`,n=`${s}-menu-item`,{fieldNames:m,changeOnSelect:P,expandTrigger:A,expandIcon:q,loadingIcon:v,optionsTitle:j,dropdownMenuColumnStyle:z,menuMaxHight:B,menuWidth:H,loading:X}=k.useContext(K.default),N=A==="hover",U=se.default("OptionList",ne.default),W=k.useMemo(()=>r.map(t=>{const{disabled:p,disableCheckbox:f,disableTitle:h}=t,i=t[F]??t[m.label],l=t[m.value],g=O.isLeaf(t,m),c=[...E,l],u=O.toPathKey(c),d=_.includes(u),R=$.has(u);return{disabled:p,disableTitle:h,label:i,value:l,isLeaf:g,isLoading:d,checked:R,option:t,disableCheckbox:f,fullPath:c,fullPathKey:u}}),[r,$,m,_,E]),G=()=>j.length<1||!j[b]?null:e.jsxRuntimeExports.jsx("span",{className:"menu-title",children:j[b]});return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsx("ul",{className:I,role:"menu",style:{width:Number(H),maxHeight:B},children:X?e.jsxRuntimeExports.jsxs("div",{className:`${C.$prefixCls}-cascader-loading`,children:[e.jsxRuntimeExports.jsx("span",{children:"加载中"}),e.jsxRuntimeExports.jsx(te.LoadingF,{className:"loading-icon"})]}):e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[G(),W.map(({disabled:t,label:p,value:f,disableTitle:h,isLeaf:i,isLoading:l,checked:g,option:c,fullPath:u,fullPathKey:d,disableCheckbox:R})=>{const T=()=>{if(t||D)return;const a=[...u];N&&i&&a.pop(),S(a)},J=()=>{w(c)&&M(u,i)};typeof c.title=="string"&&c.title;const Q=()=>{const a={marginRight:"4px",fontSize:"11px",color:"inherit"};return e.jsxRuntimeExports.jsxs("span",{children:[e.jsxRuntimeExports.jsx(ee.Forbid,{style:a}),h||U({id:"disableTilte"})]})};return e.jsxRuntimeExports.jsxs("li",{className:Y.default(n,{[`${n}-expand`]:!i,[`${n}-active`]:x===f||x===d,[`${n}-disabled`]:t,[`${n}-loading`]:l}),style:z,role:"menuitemcheckbox","aria-checked":g,"data-path-key":d,onClick:()=>{T(),!R&&(!o||i)&&J()},onDoubleClick:()=>{P&&L(!1)},onMouseEnter:()=>{N&&T()},onMouseDown:a=>{a.preventDefault()},children:[t?e.jsxRuntimeExports.jsx(V.Tooltip,{arrow:!1,placement:"topLeft",title:Q(),children:e.jsxRuntimeExports.jsx("div",{className:`${n}-content`,children:e.jsxRuntimeExports.jsx(y.default,{children:p})})}):e.jsxRuntimeExports.jsx("div",{className:`${n}-content`,children:e.jsxRuntimeExports.jsx(y.default,{children:p})}),!l&&q&&!i&&e.jsxRuntimeExports.jsx("div",{className:`${n}-expand-icon`,children:q}),l&&v&&e.jsxRuntimeExports.jsx("div",{className:`${n}-loading-icon`,children:v})]},d)})]})})})}exports.FIX_LABEL=F;exports.default=re;
|
|
2
2
|
//# sourceMappingURL=Column.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const v=require("../../_virtual/jsx-runtime.js"),Q=require("../../_virtual/
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const v=require("../../_virtual/jsx-runtime.js"),Q=require("../../_virtual/index.js"),W=require("rc-select"),Z=require("react"),ee=require("../context.js"),c=require("../utils/commonUtil.js"),E=require("../utils/treeUtil.js"),te=require("./CacheContent.js"),M=require("./Column.js"),oe=require("./useActive.js");function ne(a){const d=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(a){for(const u in a)if(u!=="default"){const p=Object.getOwnPropertyDescriptor(a,u);Object.defineProperty(d,u,p.get?p:{enumerable:!0,get:()=>a[u]})}}return d.default=a,Object.freeze(d)}const r=ne(Z),se=r.forwardRef((a,d)=>{const{prefixCls:u,multiple:p,searchValue:P,toggleOpen:C,notFoundContent:V,direction:w,open:k}=W.useBaseProps(),L=r.useRef(),T=w==="rtl",{options:f,values:x,halfValues:b,fieldNames:s,changeOnSelect:j,onSelect:A,dropdownPrefixCls:D,loadData:q,expandTrigger:N,loading:ce}=r.useContext(ee.default),h=D||u,[m,K]=r.useState([]),$=e=>{if(!q||P)return;const o=E.toPathOptions(e,f,s).map(({option:l})=>l),n=o[o.length-1];if(n&&!c.isLeaf(n,s)){const l=c.toPathKey(e);K(g=>[...g,l]),q(o)}};r.useEffect(()=>{m.length&&m.forEach(e=>{const t=c.toPathValueStr(e),o=E.toPathOptions(t,f,s,!0).map(({option:l})=>l),n=o[o.length-1];(!n||n[s.children]||c.isLeaf(n,s))&&K(l=>l.filter(g=>g!==e))})},[f,m,s]);const F=r.useMemo(()=>new Set(c.toPathKeys(x)),[x]),I=r.useMemo(()=>new Set(c.toPathKeys(b)),[b]),[i,B]=oe.default(),U=e=>{B(e),$(e)},z=e=>{const{disabled:t}=e,o=c.isLeaf(e,s);return!t&&(o||j||p)},X=(e,t,o=!1)=>{A(e),!p&&(t||j&&(N==="hover"||o))&&C(!1)},O=r.useMemo(()=>f,[P,f]),R=r.useMemo(()=>{const e=[{options:O}];let t=O;const o=c.getFullPathKeys(t,s);for(let n=0;n<i.length;n+=1){const l=i[n],S=t.find((J,_)=>(o[_]?c.toPathKey(o[_]):J[s.value])===l)?.[s.children];if(!S?.length)break;t=S,e.push({options:S})}return e},[O,i,s]);r.useEffect(()=>{for(let e=0;e<i.length;e+=1){const t=i.slice(0,e+1),o=c.toPathKey(t),n=L.current?.querySelector(`li[data-path-key="${o.replace(/\\{0,2}"/g,'\\"')}"]`);n&&c.scrollIntoParentView(n)}},[i]);const y=!R[0]?.options?.length,Y=[{[s.value]:"__EMPTY__",[M.FIX_LABEL]:V,disabled:!0}],G={...a,multiple:!y&&p,onSelect:X,onActive:U,onToggleOpen:C,checkedSet:F,halfCheckedSet:I,loadingKeys:m,isSelectable:z},H=(y?[{options:Y}]:R).map((e,t)=>{const o=i.slice(0,t),n=i[t];return v.jsxRuntimeExports.jsx(M.default,{titleIndex:t,...G,searchValue:P,prefixCls:h,options:e.options,prevValuePath:o,activeValue:n},t)});return v.jsxRuntimeExports.jsx(te.default,{open:k,children:v.jsxRuntimeExports.jsx("div",{className:Q.default(`${h}-menus`,{[`${h}-menu-empty`]:y,[`${h}-rtl`]:T}),ref:L,children:H})})});exports.default=se;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|