@regenbio/regenbio-components-react 1.2.14 → 1.2.16
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/.codecov.yml +6 -0
- package/.dumi/app.tsx +1 -0
- package/.dumi/tsconfig.json +4 -0
- package/.dumirc.ts +426 -0
- package/.eslintignore +12 -0
- package/.eslintrc.js +6 -0
- package/.fatherrc.base.ts +23 -0
- package/.github/ISSUE_TEMPLATE/bug_report.md +49 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +41 -0
- package/.github/ISSUE_TEMPLATE/question.md +29 -0
- package/.github/dependabot.yml +11 -0
- package/.github/workflows/build.yml +27 -0
- package/.github/workflows/codeql.yml +41 -0
- package/.github/workflows/coverage.yml +31 -0
- package/.github/workflows/issue-labeled.yml +37 -0
- package/.github/workflows/issue-open-check.yml +34 -0
- package/.github/workflows/pkg.pr.new.yml +37 -0
- package/.github/workflows/preview-build.yml +46 -0
- package/.github/workflows/preview-deploy.yml +92 -0
- package/.github/workflows/preview-start.yml +18 -0
- package/.github/workflows/rebase.yml +17 -0
- package/.prettierignore +9 -0
- package/.prettierrc.js +7 -0
- package/CONTRIBUTING.md +77 -0
- package/LICENSE.md +7 -0
- package/README.es-PR.md +199 -0
- package/README.md +203 -0
- package/README.zh-CN.md +203 -0
- package/docs/changelog.en-US.md +1115 -0
- package/docs/changelog.md +1136 -0
- package/docs/components/customization-value-type.tsx +222 -0
- package/docs/components/schema.$tab-api.md +8 -0
- package/docs/components/schema.en-US.md +477 -0
- package/docs/components/schema.md +477 -0
- package/docs/components/valueEnum-map.tsx +45 -0
- package/docs/components/valueType.tsx +299 -0
- package/docs/components.en-US.md +183 -0
- package/docs/components.md +78 -0
- package/docs/docs/faq.en-US.md +75 -0
- package/docs/docs/faq.md +75 -0
- package/docs/docs/index.en-US.md +53 -0
- package/docs/docs/index.md +56 -0
- package/docs/docs/intro.en-US.md +125 -0
- package/docs/docs/intro.md +126 -0
- package/docs/index.en-US.md +87 -0
- package/docs/index.md +56 -0
- package/docs/playground/index.en-US.md +14 -0
- package/docs/playground/index.md +14 -0
- package/docs/playground/pro-descriptions.en-US.md +10 -0
- package/docs/playground/pro-descriptions.md +10 -0
- package/docs/playground/pro-form.en-US.md +18 -0
- package/docs/playground/pro-form.md +19 -0
- package/docs/playground/pro-layout.en-US.md +16 -0
- package/docs/playground/pro-layout.md +17 -0
- package/docs/playground/pro-table.en-US.md +11 -0
- package/docs/playground/pro-table.md +11 -0
- package/lerna.json +21 -0
- package/package.json +164 -36
- package/packages/card/.fatherrc.ts +5 -0
- package/packages/card/CHANGELOG.md +1489 -0
- package/packages/card/README.md +19 -0
- package/packages/card/package.json +61 -0
- package/packages/card/src/ProCard.tsx +29 -0
- package/packages/card/src/components/Actions/index.tsx +40 -0
- package/packages/card/src/components/Actions/style.ts +102 -0
- package/packages/card/src/components/Card/index.tsx +293 -0
- package/packages/card/src/components/Card/style.ts +314 -0
- package/packages/card/src/components/CheckCard/Group.tsx +474 -0
- package/packages/card/src/components/CheckCard/demos/avatar.tsx +16 -0
- package/packages/card/src/components/CheckCard/demos/basic.tsx +18 -0
- package/packages/card/src/components/CheckCard/demos/compose.tsx +28 -0
- package/packages/card/src/components/CheckCard/demos/custom.tsx +9 -0
- package/packages/card/src/components/CheckCard/demos/defaultChecked.tsx +12 -0
- package/packages/card/src/components/CheckCard/demos/description.tsx +35 -0
- package/packages/card/src/components/CheckCard/demos/disabled.tsx +34 -0
- package/packages/card/src/components/CheckCard/demos/extra.tsx +41 -0
- package/packages/card/src/components/CheckCard/demos/form.tsx +58 -0
- package/packages/card/src/components/CheckCard/demos/grid.tsx +30 -0
- package/packages/card/src/components/CheckCard/demos/group.tsx +56 -0
- package/packages/card/src/components/CheckCard/demos/image.tsx +20 -0
- package/packages/card/src/components/CheckCard/demos/list.tsx +83 -0
- package/packages/card/src/components/CheckCard/demos/loading.tsx +3 -0
- package/packages/card/src/components/CheckCard/demos/multiple.tsx +51 -0
- package/packages/card/src/components/CheckCard/demos/single.tsx +23 -0
- package/packages/card/src/components/CheckCard/demos/size.tsx +23 -0
- package/packages/card/src/components/CheckCard/demos/title.tsx +22 -0
- package/packages/card/src/components/CheckCard/index.en-US.md +154 -0
- package/packages/card/src/components/CheckCard/index.md +154 -0
- package/packages/card/src/components/CheckCard/index.tsx +379 -0
- package/packages/card/src/components/CheckCard/style.ts +216 -0
- package/packages/card/src/components/Divider/index.tsx +42 -0
- package/packages/card/src/components/Divider/style.ts +48 -0
- package/packages/card/src/components/Loading/index.tsx +64 -0
- package/packages/card/src/components/Loading/style.ts +55 -0
- package/packages/card/src/components/Operation/index.tsx +38 -0
- package/packages/card/src/components/Operation/style.ts +33 -0
- package/packages/card/src/components/Statistic/index.tsx +129 -0
- package/packages/card/src/components/Statistic/style.ts +110 -0
- package/packages/card/src/components/StatisticCard/demos/basic.tsx +40 -0
- package/packages/card/src/components/StatisticCard/demos/chart.tsx +20 -0
- package/packages/card/src/components/StatisticCard/demos/fomula.tsx +37 -0
- package/packages/card/src/components/StatisticCard/demos/footer.tsx +42 -0
- package/packages/card/src/components/StatisticCard/demos/group-chart.tsx +65 -0
- package/packages/card/src/components/StatisticCard/demos/group.tsx +57 -0
- package/packages/card/src/components/StatisticCard/demos/horizontal-left.tsx +31 -0
- package/packages/card/src/components/StatisticCard/demos/horizontal.tsx +31 -0
- package/packages/card/src/components/StatisticCard/demos/icon.tsx +77 -0
- package/packages/card/src/components/StatisticCard/demos/layout.tsx +90 -0
- package/packages/card/src/components/StatisticCard/demos/status.tsx +46 -0
- package/packages/card/src/components/StatisticCard/demos/tabs-statistic.tsx +55 -0
- package/packages/card/src/components/StatisticCard/demos/tabs.tsx +55 -0
- package/packages/card/src/components/StatisticCard/demos/total-layout.tsx +136 -0
- package/packages/card/src/components/StatisticCard/demos/total.tsx +58 -0
- package/packages/card/src/components/StatisticCard/demos/trend.tsx +15 -0
- package/packages/card/src/components/StatisticCard/index.en-US.md +152 -0
- package/packages/card/src/components/StatisticCard/index.md +152 -0
- package/packages/card/src/components/StatisticCard/index.tsx +107 -0
- package/packages/card/src/components/StatisticCard/style.ts +48 -0
- package/packages/card/src/components/TabPane/index.tsx +94 -0
- package/packages/card/src/components/card.en-US.md +219 -0
- package/packages/card/src/components/card.md +212 -0
- package/packages/card/src/demos/actions.tsx +59 -0
- package/packages/card/src/demos/basic.tsx +54 -0
- package/packages/card/src/demos/bordered.tsx +15 -0
- package/packages/card/src/demos/collapsible.tsx +110 -0
- package/packages/card/src/demos/colspan.tsx +80 -0
- package/packages/card/src/demos/divider.tsx +36 -0
- package/packages/card/src/demos/group.tsx +19 -0
- package/packages/card/src/demos/gutter.tsx +29 -0
- package/packages/card/src/demos/headerBordered.tsx +15 -0
- package/packages/card/src/demos/headless.tsx +5 -0
- package/packages/card/src/demos/hoverable.tsx +11 -0
- package/packages/card/src/demos/inner.tsx +32 -0
- package/packages/card/src/demos/layout.tsx +18 -0
- package/packages/card/src/demos/loading.tsx +28 -0
- package/packages/card/src/demos/multipleLine.tsx +43 -0
- package/packages/card/src/demos/responsive.tsx +72 -0
- package/packages/card/src/demos/split.tsx +46 -0
- package/packages/card/src/demos/split2.tsx +30 -0
- package/packages/card/src/demos/split23.tsx +14 -0
- package/packages/card/src/demos/steps-v.tsx +59 -0
- package/packages/card/src/demos/tabs-card.tsx +18 -0
- package/packages/card/src/demos/tabs.tsx +56 -0
- package/packages/card/src/index.tsx +30 -0
- package/packages/card/src/typing.ts +100 -0
- package/packages/card/tsconfig.json +21 -0
- package/packages/components/.fatherrc.ts +15 -0
- package/packages/components/CHANGELOG.md +841 -0
- package/packages/components/README.md +19 -0
- package/packages/components/package.json +62 -0
- package/packages/components/src/index.tsx +12 -0
- package/packages/components/tsconfig.json +32 -0
- package/packages/descriptions/.fatherrc.ts +5 -0
- package/packages/descriptions/CHANGELOG.md +1740 -0
- package/packages/descriptions/README.md +53 -0
- package/packages/descriptions/package.json +60 -0
- package/packages/descriptions/src/components/descriptions.en-US.md +168 -0
- package/packages/descriptions/src/components/descriptions.md +173 -0
- package/packages/descriptions/src/demos/arrayDataIndex.tsx +66 -0
- package/packages/descriptions/src/demos/base.demo-test.tsx +36 -0
- package/packages/descriptions/src/demos/base.tsx +115 -0
- package/packages/descriptions/src/demos/columns.tsx +127 -0
- package/packages/descriptions/src/demos/customization-value-type.tsx +166 -0
- package/packages/descriptions/src/demos/dynamic-descriptions.tsx +319 -0
- package/packages/descriptions/src/demos/editable.tsx +138 -0
- package/packages/descriptions/src/demos/format.tsx +62 -0
- package/packages/descriptions/src/demos/request.tsx +37 -0
- package/packages/descriptions/src/demos/use-data-source.tsx +78 -0
- package/packages/descriptions/src/index.tsx +676 -0
- package/packages/descriptions/src/useFetchData.tsx +93 -0
- package/packages/descriptions/tsconfig.json +26 -0
- package/packages/field/.fatherrc.ts +5 -0
- package/packages/field/CHANGELOG.md +2017 -0
- package/packages/field/README.md +17 -0
- package/packages/field/package.json +56 -0
- package/packages/field/src/FieldHOC/index.tsx +55 -0
- package/packages/field/src/components/Cascader/index.tsx +167 -0
- package/packages/field/src/components/Checkbox/index.tsx +149 -0
- package/packages/field/src/components/Code/index.tsx +78 -0
- package/packages/field/src/components/ColorPicker/index.tsx +117 -0
- package/packages/field/src/components/ColorPicker/old.tsx +121 -0
- package/packages/field/src/components/DatePicker/index.tsx +143 -0
- package/packages/field/src/components/Digit/index.tsx +93 -0
- package/packages/field/src/components/DigitRange/index.tsx +150 -0
- package/packages/field/src/components/FromNow/index.tsx +67 -0
- package/packages/field/src/components/Image/index.tsx +61 -0
- package/packages/field/src/components/IndexColumn/index.tsx +54 -0
- package/packages/field/src/components/Money/index.tsx +454 -0
- package/packages/field/src/components/Options/index.tsx +89 -0
- package/packages/field/src/components/Password/index.tsx +71 -0
- package/packages/field/src/components/Percent/index.tsx +109 -0
- package/packages/field/src/components/Percent/util.ts +26 -0
- package/packages/field/src/components/Progress/index.tsx +81 -0
- package/packages/field/src/components/Radio/index.tsx +128 -0
- package/packages/field/src/components/RangePicker/index.tsx +166 -0
- package/packages/field/src/components/Rate/index.tsx +36 -0
- package/packages/field/src/components/Second/index.tsx +88 -0
- package/packages/field/src/components/Segmented/index.tsx +93 -0
- package/packages/field/src/components/Select/LightSelect/index.tsx +286 -0
- package/packages/field/src/components/Select/SearchSelect/index.tsx +334 -0
- package/packages/field/src/components/Select/index.tsx +562 -0
- package/packages/field/src/components/Slider/index.tsx +42 -0
- package/packages/field/src/components/Status/index.tsx +47 -0
- package/packages/field/src/components/Switch/index.tsx +77 -0
- package/packages/field/src/components/Text/index.tsx +68 -0
- package/packages/field/src/components/TextArea/index.tsx +53 -0
- package/packages/field/src/components/TextArea/readonly.tsx +46 -0
- package/packages/field/src/components/TimePicker/index.tsx +261 -0
- package/packages/field/src/components/TreeSelect/index.tsx +258 -0
- package/packages/field/src/components/field.md +42 -0
- package/packages/field/src/demos/base.tsx +431 -0
- package/packages/field/src/demos/base_test.tsx +509 -0
- package/packages/field/src/demos/search-value-autoClearSearchValue.tsx +41 -0
- package/packages/field/src/demos/search-value.tsx +96 -0
- package/packages/field/src/demos/select-request.tsx +30 -0
- package/packages/field/src/demos/tree-select-search-value.tsx +151 -0
- package/packages/field/src/index.tsx +678 -0
- package/packages/field/tsconfig.json +22 -0
- package/packages/form/.fatherrc.ts +5 -0
- package/packages/form/CHANGELOG.md +2781 -0
- package/packages/form/README.md +15 -0
- package/packages/form/package.json +70 -0
- package/packages/form/src/BaseForm/BaseForm.tsx +839 -0
- package/packages/form/src/BaseForm/EditOrReadOnlyContext.ts +7 -0
- package/packages/form/src/BaseForm/LightWrapper/index.tsx +159 -0
- package/packages/form/src/BaseForm/LightWrapper/style.ts +31 -0
- package/packages/form/src/BaseForm/createField.tsx +384 -0
- package/packages/form/src/BaseForm/index.ts +3 -0
- package/packages/form/src/FieldContext.tsx +39 -0
- package/packages/form/src/components/Captcha/index.tsx +156 -0
- package/packages/form/src/components/Cascader/index.tsx +36 -0
- package/packages/form/src/components/Checkbox/index.tsx +90 -0
- package/packages/form/src/components/ColorPicker/index.tsx +47 -0
- package/packages/form/src/components/DateMonthRangePicker/index.tsx +38 -0
- package/packages/form/src/components/DatePicker/DatePicker.tsx +35 -0
- package/packages/form/src/components/DatePicker/MonthPicker.tsx +35 -0
- package/packages/form/src/components/DatePicker/QuarterPicker.tsx +35 -0
- package/packages/form/src/components/DatePicker/WeekPicker.tsx +35 -0
- package/packages/form/src/components/DatePicker/YearPicker.tsx +35 -0
- package/packages/form/src/components/DatePicker/index.tsx +22 -0
- package/packages/form/src/components/DateQuarterRangePicker/index.tsx +39 -0
- package/packages/form/src/components/DateRangePicker/index.tsx +39 -0
- package/packages/form/src/components/DateTimePicker/index.tsx +36 -0
- package/packages/form/src/components/DateTimeRangePicker/index.tsx +39 -0
- package/packages/form/src/components/DateWeekRangePicker/index.tsx +38 -0
- package/packages/form/src/components/DateYearRangePicker/index.tsx +38 -0
- package/packages/form/src/components/Dependency/demos/dependency.tsx +112 -0
- package/packages/form/src/components/Dependency/demos/dependency2.tsx +106 -0
- package/packages/form/src/components/Dependency/index.en-US.md +54 -0
- package/packages/form/src/components/Dependency/index.md +52 -0
- package/packages/form/src/components/Dependency/index.tsx +111 -0
- package/packages/form/src/components/Digit/index.tsx +43 -0
- package/packages/form/src/components/DigitRange/index.tsx +51 -0
- package/packages/form/src/components/Field/index.tsx +144 -0
- package/packages/form/src/components/FieldSet/demos/captCha.tsx +67 -0
- package/packages/form/src/components/FieldSet/demos/components-other-readonly.tsx +465 -0
- package/packages/form/src/components/FieldSet/demos/components-other.tsx +336 -0
- package/packages/form/src/components/FieldSet/demos/datatime.tsx +89 -0
- package/packages/form/src/components/FieldSet/demos/fieldSet-light.tsx +58 -0
- package/packages/form/src/components/FieldSet/demos/form-fieldset.tsx +106 -0
- package/packages/form/src/components/FieldSet/demos/pro-form-captCha.tsx +70 -0
- package/packages/form/src/components/FieldSet/demos/search-select.tsx +90 -0
- package/packages/form/src/components/FieldSet/demos/upload.tsx +35 -0
- package/packages/form/src/components/FieldSet/index.en-US.md +529 -0
- package/packages/form/src/components/FieldSet/index.md +680 -0
- package/packages/form/src/components/FieldSet/index.tsx +151 -0
- package/packages/form/src/components/FormItem/index.tsx +445 -0
- package/packages/form/src/components/FormItemRender/index.tsx +219 -0
- package/packages/form/src/components/Group/demos/base-use.tsx +93 -0
- package/packages/form/src/components/Group/demos/countLimit.tsx +57 -0
- package/packages/form/src/components/Group/demos/customize.tsx +294 -0
- package/packages/form/src/components/Group/demos/dependency.tsx +70 -0
- package/packages/form/src/components/Group/demos/horizontal-layout.tsx +73 -0
- package/packages/form/src/components/Group/demos/list-tooltip.tsx +69 -0
- package/packages/form/src/components/Group/demos/list.tsx +127 -0
- package/packages/form/src/components/Group/demos/nested-list.tsx +66 -0
- package/packages/form/src/components/Group/demos/pro-form-list.tsx +126 -0
- package/packages/form/src/components/Group/index.en-US.md +326 -0
- package/packages/form/src/components/Group/index.md +373 -0
- package/packages/form/src/components/Group/index.tsx +182 -0
- package/packages/form/src/components/Group/style.ts +55 -0
- package/packages/form/src/components/List/ListContainer.tsx +187 -0
- package/packages/form/src/components/List/ListItem.tsx +569 -0
- package/packages/form/src/components/List/index.tsx +323 -0
- package/packages/form/src/components/List/style.ts +89 -0
- package/packages/form/src/components/LoginForm/demos/login-form-page.tsx +283 -0
- package/packages/form/src/components/LoginForm/demos/login-form.tsx +190 -0
- package/packages/form/src/components/LoginForm/index.en-US.md +45 -0
- package/packages/form/src/components/LoginForm/index.md +45 -0
- package/packages/form/src/components/ModalForm/demos/drawer-form-nested.tsx +265 -0
- package/packages/form/src/components/ModalForm/demos/drawer-form.tsx +129 -0
- package/packages/form/src/components/ModalForm/demos/modal-form-reset.tsx +112 -0
- package/packages/form/src/components/ModalForm/demos/modal-form-submitter.tsx +143 -0
- package/packages/form/src/components/ModalForm/demos/modal-form.tsx +112 -0
- package/packages/form/src/components/ModalForm/demos/visible-on-visible-change.tsx +187 -0
- package/packages/form/src/components/ModalForm/index.en-US.md +70 -0
- package/packages/form/src/components/ModalForm/index.md +68 -0
- package/packages/form/src/components/Money/index.tsx +47 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter-bordered.tsx +149 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter-collapse.tsx +28 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter-footer.tsx +88 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter-placement.tsx +89 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter-test.tsx +92 -0
- package/packages/form/src/components/QueryFilter/demos/light-filter.tsx +215 -0
- package/packages/form/src/components/QueryFilter/demos/query-filter-collapsed.tsx +18 -0
- package/packages/form/src/components/QueryFilter/demos/query-filter-defaultColsNumber.tsx +18 -0
- package/packages/form/src/components/QueryFilter/demos/query-filter-test.tsx +158 -0
- package/packages/form/src/components/QueryFilter/demos/query-filter-vertical.tsx +44 -0
- package/packages/form/src/components/QueryFilter/demos/query-filter.tsx +31 -0
- package/packages/form/src/components/QueryFilter/demos/search-filter.tsx +126 -0
- package/packages/form/src/components/QueryFilter/index.en-US.md +93 -0
- package/packages/form/src/components/QueryFilter/index.md +90 -0
- package/packages/form/src/components/Radio/index.tsx +89 -0
- package/packages/form/src/components/Rate/index.tsx +28 -0
- package/packages/form/src/components/SchemaForm/demos/ModalAndDrawerForm.tsx +68 -0
- package/packages/form/src/components/SchemaForm/demos/customization-value-type.tsx +174 -0
- package/packages/form/src/components/SchemaForm/demos/dependencies.tsx +125 -0
- package/packages/form/src/components/SchemaForm/demos/dependency.tsx +90 -0
- package/packages/form/src/components/SchemaForm/demos/dynamic-rerender.tsx +127 -0
- package/packages/form/src/components/SchemaForm/demos/embed.tsx +121 -0
- package/packages/form/src/components/SchemaForm/demos/form-list-required.tsx +142 -0
- package/packages/form/src/components/SchemaForm/demos/schema.tsx +311 -0
- package/packages/form/src/components/SchemaForm/demos/steps-form.tsx +203 -0
- package/packages/form/src/components/SchemaForm/demos/valueType.tsx +150 -0
- package/packages/form/src/components/SchemaForm/index.en-US.md +92 -0
- package/packages/form/src/components/SchemaForm/index.md +84 -0
- package/packages/form/src/components/SchemaForm/index.tsx +241 -0
- package/packages/form/src/components/SchemaForm/layoutType/Embed.tsx +3 -0
- package/packages/form/src/components/SchemaForm/layoutType/StepsForm.tsx +54 -0
- package/packages/form/src/components/SchemaForm/layoutType/index.ts +2 -0
- package/packages/form/src/components/SchemaForm/typing.ts +171 -0
- package/packages/form/src/components/SchemaForm/valueType/dependency.tsx +34 -0
- package/packages/form/src/components/SchemaForm/valueType/divider.tsx +13 -0
- package/packages/form/src/components/SchemaForm/valueType/field.tsx +91 -0
- package/packages/form/src/components/SchemaForm/valueType/formList.tsx +27 -0
- package/packages/form/src/components/SchemaForm/valueType/formSet.tsx +27 -0
- package/packages/form/src/components/SchemaForm/valueType/group.tsx +22 -0
- package/packages/form/src/components/SchemaForm/valueType/ignore.tsx +13 -0
- package/packages/form/src/components/SchemaForm/valueType/index.tsx +46 -0
- package/packages/form/src/components/Segmented/index.tsx +36 -0
- package/packages/form/src/components/Select/index.tsx +173 -0
- package/packages/form/src/components/Slider/index.tsx +62 -0
- package/packages/form/src/components/StepsForm/demos/add-or-edit-step-form.tsx +90 -0
- package/packages/form/src/components/StepsForm/demos/customize-steps-from.tsx +176 -0
- package/packages/form/src/components/StepsForm/demos/modal-step-form.tsx +153 -0
- package/packages/form/src/components/StepsForm/demos/multi-card-step-form.tsx +201 -0
- package/packages/form/src/components/StepsForm/demos/steps-form-vertical.tsx +153 -0
- package/packages/form/src/components/StepsForm/demos/steps-from.tsx +157 -0
- package/packages/form/src/components/StepsForm/index.en-US.md +50 -0
- package/packages/form/src/components/StepsForm/index.md +56 -0
- package/packages/form/src/components/Submitter/index.tsx +144 -0
- package/packages/form/src/components/Switch/index.tsx +45 -0
- package/packages/form/src/components/Text/index.tsx +176 -0
- package/packages/form/src/components/TextArea/index.tsx +27 -0
- package/packages/form/src/components/TimePicker/index.tsx +72 -0
- package/packages/form/src/components/TreeSelect/index.tsx +49 -0
- package/packages/form/src/components/UploadButton/index.tsx +133 -0
- package/packages/form/src/components/UploadDragger/index.tsx +134 -0
- package/packages/form/src/components/form.en-US.md +320 -0
- package/packages/form/src/components/form.md +480 -0
- package/packages/form/src/components/index.ts +67 -0
- package/packages/form/src/demos/antd.modify.tsx +62 -0
- package/packages/form/src/demos/antd.nest.tsx +56 -0
- package/packages/form/src/demos/antd.tsx +103 -0
- package/packages/form/src/demos/base-test.tsx +256 -0
- package/packages/form/src/demos/base.tsx +334 -0
- package/packages/form/src/demos/components-test.tsx +64 -0
- package/packages/form/src/demos/config-provider.tsx +67 -0
- package/packages/form/src/demos/dependency.tsx +85 -0
- package/packages/form/src/demos/form-control-render.tsx +81 -0
- package/packages/form/src/demos/form-item-render.tsx +164 -0
- package/packages/form/src/demos/form-layout-grid.tsx +130 -0
- package/packages/form/src/demos/form-layout.tsx +97 -0
- package/packages/form/src/demos/formRef.tsx +98 -0
- package/packages/form/src/demos/label-col.tsx +48 -0
- package/packages/form/src/demos/labelInValue.tsx +34 -0
- package/packages/form/src/demos/layout-change.tsx +347 -0
- package/packages/form/src/demos/layout-footer.tsx +168 -0
- package/packages/form/src/demos/linkage-customization.tsx +179 -0
- package/packages/form/src/demos/modalform-test.tsx +121 -0
- package/packages/form/src/demos/money.tsx +139 -0
- package/packages/form/src/demos/params-formref.tsx +36 -0
- package/packages/form/src/demos/pro-form-dependency.debug.tsx +95 -0
- package/packages/form/src/demos/pro-form-editableTable.tsx +148 -0
- package/packages/form/src/demos/sync-to-url.tsx +68 -0
- package/packages/form/src/demos/typings.d.ts +5 -0
- package/packages/form/src/helpers/grid.tsx +96 -0
- package/packages/form/src/helpers/index.ts +1 -0
- package/packages/form/src/index.tsx +56 -0
- package/packages/form/src/layouts/DrawerForm/index.tsx +386 -0
- package/packages/form/src/layouts/DrawerForm/style.ts +42 -0
- package/packages/form/src/layouts/LightFilter/index.tsx +337 -0
- package/packages/form/src/layouts/LightFilter/style.ts +64 -0
- package/packages/form/src/layouts/LoginForm/index.tsx +153 -0
- package/packages/form/src/layouts/LoginForm/style.ts +89 -0
- package/packages/form/src/layouts/LoginFormPage/index.tsx +231 -0
- package/packages/form/src/layouts/LoginFormPage/style.ts +154 -0
- package/packages/form/src/layouts/ModalForm/index.tsx +296 -0
- package/packages/form/src/layouts/ProForm/index.tsx +44 -0
- package/packages/form/src/layouts/QueryFilter/Actions.tsx +104 -0
- package/packages/form/src/layouts/QueryFilter/index.tsx +624 -0
- package/packages/form/src/layouts/QueryFilter/style.ts +61 -0
- package/packages/form/src/layouts/StepsForm/StepForm.tsx +89 -0
- package/packages/form/src/layouts/StepsForm/index.tsx +569 -0
- package/packages/form/src/layouts/StepsForm/style.ts +43 -0
- package/packages/form/src/layouts/index.ts +19 -0
- package/packages/form/src/typing.ts +178 -0
- package/packages/form/tsconfig.json +24 -0
- package/packages/layout/.fatherrc.ts +5 -0
- package/packages/layout/CHANGELOG.md +2188 -0
- package/packages/layout/README.md +64 -0
- package/packages/layout/package.json +71 -0
- package/packages/layout/src/ProLayout.tsx +918 -0
- package/packages/layout/src/WrapContent.tsx +41 -0
- package/packages/layout/src/assert/Logo.tsx +80 -0
- package/packages/layout/src/components/AppsLogoComponents/AppsLogo.tsx +15 -0
- package/packages/layout/src/components/AppsLogoComponents/DefaultContent.tsx +64 -0
- package/packages/layout/src/components/AppsLogoComponents/SimpleContent.tsx +93 -0
- package/packages/layout/src/components/AppsLogoComponents/index.tsx +132 -0
- package/packages/layout/src/components/AppsLogoComponents/style/default.ts +78 -0
- package/packages/layout/src/components/AppsLogoComponents/style/index.ts +71 -0
- package/packages/layout/src/components/AppsLogoComponents/style/simple.ts +93 -0
- package/packages/layout/src/components/AppsLogoComponents/types.d.ts +10 -0
- package/packages/layout/src/components/CollapsedIcon/index.tsx +20 -0
- package/packages/layout/src/components/CollapsedIcon/style.ts +58 -0
- package/packages/layout/src/components/Footer.tsx +47 -0
- package/packages/layout/src/components/FooterToolbar/index.tsx +123 -0
- package/packages/layout/src/components/FooterToolbar/style/index.ts +56 -0
- package/packages/layout/src/components/FooterToolbar/style/stylish.ts +29 -0
- package/packages/layout/src/components/GlobalFooter/index.tsx +70 -0
- package/packages/layout/src/components/GlobalFooter/style.ts +46 -0
- package/packages/layout/src/components/GlobalHeader/ActionsContent.tsx +150 -0
- package/packages/layout/src/components/GlobalHeader/index.tsx +184 -0
- package/packages/layout/src/components/GlobalHeader/rightContentStyle.ts +74 -0
- package/packages/layout/src/components/GlobalHeader/style.ts +75 -0
- package/packages/layout/src/components/GridContent/index.tsx +54 -0
- package/packages/layout/src/components/GridContent/style.ts +29 -0
- package/packages/layout/src/components/Header/index.tsx +170 -0
- package/packages/layout/src/components/Header/style/header.ts +70 -0
- package/packages/layout/src/components/Header/style/stylish.ts +34 -0
- package/packages/layout/src/components/Help/AsyncContentPanel.tsx +62 -0
- package/packages/layout/src/components/Help/HelpProvide.tsx +187 -0
- package/packages/layout/src/components/Help/ProHelpContentPanel.tsx +162 -0
- package/packages/layout/src/components/Help/ProHelpDrawer.tsx +54 -0
- package/packages/layout/src/components/Help/ProHelpModal.tsx +51 -0
- package/packages/layout/src/components/Help/ProHelpPanel.tsx +310 -0
- package/packages/layout/src/components/Help/ProHelpPopover.tsx +78 -0
- package/packages/layout/src/components/Help/RenderContentPanel.tsx +156 -0
- package/packages/layout/src/components/Help/Search.tsx +172 -0
- package/packages/layout/src/components/Help/index.tsx +78 -0
- package/packages/layout/src/components/Help/style.ts +109 -0
- package/packages/layout/src/components/PageContainer/demos/basic.tsx +96 -0
- package/packages/layout/src/components/PageContainer/demos/fixHeader.tsx +59 -0
- package/packages/layout/src/components/PageContainer/demos/hideBreadMenu.tsx +38 -0
- package/packages/layout/src/components/PageContainer/demos/loading.tsx +144 -0
- package/packages/layout/src/components/PageContainer/demos/token.tsx +71 -0
- package/packages/layout/src/components/PageContainer/index.en-US.md +104 -0
- package/packages/layout/src/components/PageContainer/index.md +125 -0
- package/packages/layout/src/components/PageContainer/index.tsx +506 -0
- package/packages/layout/src/components/PageContainer/style/index.ts +137 -0
- package/packages/layout/src/components/PageContainer/style/stylish.ts +29 -0
- package/packages/layout/src/components/PageHeader/demo/actions.en-US.md +78 -0
- package/packages/layout/src/components/PageHeader/demo/actions.md +78 -0
- package/packages/layout/src/components/PageHeader/demo/basic.en-US.md +30 -0
- package/packages/layout/src/components/PageHeader/demo/basic.md +30 -0
- package/packages/layout/src/components/PageHeader/demo/breadcrumb.en-US.md +39 -0
- package/packages/layout/src/components/PageHeader/demo/breadcrumb.md +39 -0
- package/packages/layout/src/components/PageHeader/demo/content.en-US.md +206 -0
- package/packages/layout/src/components/PageHeader/demo/content.md +206 -0
- package/packages/layout/src/components/PageHeader/demo/ghost.en-US.md +52 -0
- package/packages/layout/src/components/PageHeader/demo/ghost.md +52 -0
- package/packages/layout/src/components/PageHeader/demo/responsive.en-US.md +114 -0
- package/packages/layout/src/components/PageHeader/demo/responsive.md +114 -0
- package/packages/layout/src/components/PageHeader/index.en-US.md +39 -0
- package/packages/layout/src/components/PageHeader/index.md +39 -0
- package/packages/layout/src/components/PageHeader/index.tsx +276 -0
- package/packages/layout/src/components/PageHeader/style/index.ts +180 -0
- package/packages/layout/src/components/PageLoading/index.tsx +18 -0
- package/packages/layout/src/components/SettingDrawer/BlockCheckbox.tsx +60 -0
- package/packages/layout/src/components/SettingDrawer/LayoutChange.tsx +122 -0
- package/packages/layout/src/components/SettingDrawer/RegionalChange.tsx +45 -0
- package/packages/layout/src/components/SettingDrawer/ThemeColor.tsx +68 -0
- package/packages/layout/src/components/SettingDrawer/icon/group.tsx +108 -0
- package/packages/layout/src/components/SettingDrawer/icon/sub.tsx +163 -0
- package/packages/layout/src/components/SettingDrawer/index.tsx +602 -0
- package/packages/layout/src/components/SettingDrawer/style/index.ts +149 -0
- package/packages/layout/src/components/SiderMenu/Arrow.tsx +15 -0
- package/packages/layout/src/components/SiderMenu/BaseMenu.tsx +741 -0
- package/packages/layout/src/components/SiderMenu/SiderMenu.tsx +541 -0
- package/packages/layout/src/components/SiderMenu/index.tsx +101 -0
- package/packages/layout/src/components/SiderMenu/style/index.ts +219 -0
- package/packages/layout/src/components/SiderMenu/style/menu.ts +177 -0
- package/packages/layout/src/components/SiderMenu/style/stylish.ts +33 -0
- package/packages/layout/src/components/TopNavHeader/index.tsx +202 -0
- package/packages/layout/src/components/TopNavHeader/style.ts +88 -0
- package/packages/layout/src/components/WaterMark/demos/custom.tsx +133 -0
- package/packages/layout/src/components/WaterMark/demos/frontend.tsx +135 -0
- package/packages/layout/src/components/WaterMark/demos/image.tsx +40 -0
- package/packages/layout/src/components/WaterMark/demos/text.tsx +8 -0
- package/packages/layout/src/components/WaterMark/demos/textRows.tsx +8 -0
- package/packages/layout/src/components/WaterMark/index.en-US.md +80 -0
- package/packages/layout/src/components/WaterMark/index.md +80 -0
- package/packages/layout/src/components/WaterMark/index.tsx +212 -0
- package/packages/layout/src/components/layout.$tab-api.md +120 -0
- package/packages/layout/src/components/layout.en-US.$tab-api.md +76 -0
- package/packages/layout/src/components/layout.en-US.md +465 -0
- package/packages/layout/src/components/layout.md +474 -0
- package/packages/layout/src/context/RouteContext.tsx +36 -0
- package/packages/layout/src/defaultSettings.ts +143 -0
- package/packages/layout/src/demos/AlwaysDefaultOpenAllMenu.tsx +88 -0
- package/packages/layout/src/demos/BreadcrumbsRepeat.tsx +57 -0
- package/packages/layout/src/demos/DefaultOpenAllMenu.tsx +26 -0
- package/packages/layout/src/demos/IconFont.tsx +39 -0
- package/packages/layout/src/demos/MenuGroup.tsx +24 -0
- package/packages/layout/src/demos/MultipleMenuOnePath.tsx +199 -0
- package/packages/layout/src/demos/Nested.tsx +65 -0
- package/packages/layout/src/demos/TopmenuNested.tsx +35 -0
- package/packages/layout/src/demos/_defaultProps.tsx +152 -0
- package/packages/layout/src/demos/antd@4MenuIconFormServe.tsx +67 -0
- package/packages/layout/src/demos/api.tsx +149 -0
- package/packages/layout/src/demos/appList-group-simple.tsx +104 -0
- package/packages/layout/src/demos/appList-group.tsx +131 -0
- package/packages/layout/src/demos/async-load-help.tsx +336 -0
- package/packages/layout/src/demos/background-context.tsx +146 -0
- package/packages/layout/src/demos/base.tsx +456 -0
- package/packages/layout/src/demos/classicMode.tsx +212 -0
- package/packages/layout/src/demos/collapsedShowTitle.tsx +155 -0
- package/packages/layout/src/demos/complexMenu.ts +101 -0
- package/packages/layout/src/demos/config-provider.tsx +153 -0
- package/packages/layout/src/demos/customMenu.ts +23 -0
- package/packages/layout/src/demos/customSider.tsx +140 -0
- package/packages/layout/src/demos/customize-collapsed.tsx +98 -0
- package/packages/layout/src/demos/customizeMenu.tsx +62 -0
- package/packages/layout/src/demos/dark.tsx +127 -0
- package/packages/layout/src/demos/debug-demo.tsx +154 -0
- package/packages/layout/src/demos/designMenuCss.tsx +204 -0
- package/packages/layout/src/demos/designSiderMenu.tsx +105 -0
- package/packages/layout/src/demos/draggableHelp.tsx +349 -0
- package/packages/layout/src/demos/dynamic-settings.tsx +155 -0
- package/packages/layout/src/demos/dynamicMenu.tsx +71 -0
- package/packages/layout/src/demos/error-boundaries.tsx +156 -0
- package/packages/layout/src/demos/footer-global-tools.tsx +211 -0
- package/packages/layout/src/demos/footer.tsx +31 -0
- package/packages/layout/src/demos/ghost.tsx +51 -0
- package/packages/layout/src/demos/help.tsx +683 -0
- package/packages/layout/src/demos/hideMenu.tsx +29 -0
- package/packages/layout/src/demos/immersive-navigation-top.tsx +106 -0
- package/packages/layout/src/demos/immersive-navigation.tsx +139 -0
- package/packages/layout/src/demos/menu-group.tsx +138 -0
- package/packages/layout/src/demos/mixMode.tsx +148 -0
- package/packages/layout/src/demos/morse_debug.tsx +234 -0
- package/packages/layout/src/demos/pageSimplify.tsx +153 -0
- package/packages/layout/src/demos/proHelpModal.tsx +367 -0
- package/packages/layout/src/demos/searchMenu.tsx +90 -0
- package/packages/layout/src/demos/siderMode.tsx +82 -0
- package/packages/layout/src/demos/siteMenu.tsx +148 -0
- package/packages/layout/src/demos/splitMenus.tsx +123 -0
- package/packages/layout/src/demos/theme.tsx +159 -0
- package/packages/layout/src/demos/top-breadcrumb.tsx +68 -0
- package/packages/layout/src/demos/topMode.tsx +351 -0
- package/packages/layout/src/getPageTitle.ts +138 -0
- package/packages/layout/src/index.tsx +93 -0
- package/packages/layout/src/locales/en-US/settingDrawer.ts +45 -0
- package/packages/layout/src/locales/en-US.ts +5 -0
- package/packages/layout/src/locales/index.ts +33 -0
- package/packages/layout/src/locales/it-IT/settingDrawer.ts +37 -0
- package/packages/layout/src/locales/it-IT.ts +5 -0
- package/packages/layout/src/locales/ko-KR/settingDrawer.ts +41 -0
- package/packages/layout/src/locales/ko-KR.ts +5 -0
- package/packages/layout/src/locales/zh-CN/settingDrawer.ts +45 -0
- package/packages/layout/src/locales/zh-CN.ts +5 -0
- package/packages/layout/src/locales/zh-TW/settingDrawer.ts +37 -0
- package/packages/layout/src/locales/zh-TW.ts +5 -0
- package/packages/layout/src/style/index.ts +280 -0
- package/packages/layout/src/typing.ts +77 -0
- package/packages/layout/src/utils/getBreadcrumbProps.tsx +204 -0
- package/packages/layout/src/utils/getMenuData.ts +42 -0
- package/packages/layout/src/utils/pathTools.ts +10 -0
- package/packages/layout/src/utils/useCurrentMenuLayoutProps.ts +36 -0
- package/packages/layout/src/utils/utils.ts +66 -0
- package/packages/layout/tsconfig.json +23 -0
- package/packages/list/.fatherrc.ts +5 -0
- package/packages/list/CHANGELOG.md +1840 -0
- package/packages/list/README.md +49 -0
- package/packages/list/package.json +62 -0
- package/packages/list/src/Item.tsx +389 -0
- package/packages/list/src/ListView.tsx +327 -0
- package/packages/list/src/components/list.en-US.md +147 -0
- package/packages/list/src/components/list.md +149 -0
- package/packages/list/src/constants.ts +17 -0
- package/packages/list/src/demos/ToolBar.tsx +195 -0
- package/packages/list/src/demos/base.tsx +85 -0
- package/packages/list/src/demos/card-list.tsx +117 -0
- package/packages/list/src/demos/editable.tsx +89 -0
- package/packages/list/src/demos/expand.tsx +92 -0
- package/packages/list/src/demos/filter.tsx +125 -0
- package/packages/list/src/demos/layout.tsx +95 -0
- package/packages/list/src/demos/pagination.tsx +64 -0
- package/packages/list/src/demos/search.tsx +123 -0
- package/packages/list/src/demos/selectedRow.tsx +86 -0
- package/packages/list/src/demos/size.tsx +126 -0
- package/packages/list/src/demos/special.tsx +109 -0
- package/packages/list/src/demos/testConfigProvider.tsx +66 -0
- package/packages/list/src/index.tsx +251 -0
- package/packages/list/src/style/index.ts +283 -0
- package/packages/list/tsconfig.json +33 -0
- package/packages/provider/.fatherrc.ts +5 -0
- package/packages/provider/CHANGELOG.md +824 -0
- package/packages/provider/README.md +19 -0
- package/packages/provider/package.json +58 -0
- package/packages/provider/src/index.tsx +484 -0
- package/packages/provider/src/intl.ts +183 -0
- package/packages/provider/src/locale/ar_EG.tsx +71 -0
- package/packages/provider/src/locale/ca_ES.tsx +71 -0
- package/packages/provider/src/locale/cs_CZ.tsx +74 -0
- package/packages/provider/src/locale/de_DE.tsx +71 -0
- package/packages/provider/src/locale/en_GB.tsx +73 -0
- package/packages/provider/src/locale/en_US.tsx +75 -0
- package/packages/provider/src/locale/es_ES.tsx +71 -0
- package/packages/provider/src/locale/fa_IR.tsx +71 -0
- package/packages/provider/src/locale/fr_FR.tsx +71 -0
- package/packages/provider/src/locale/he_IL.tsx +74 -0
- package/packages/provider/src/locale/hr_HR.tsx +71 -0
- package/packages/provider/src/locale/id_ID.tsx +71 -0
- package/packages/provider/src/locale/it_IT.tsx +71 -0
- package/packages/provider/src/locale/ja_JP.tsx +71 -0
- package/packages/provider/src/locale/ko_KR.tsx +71 -0
- package/packages/provider/src/locale/mn_MN.tsx +71 -0
- package/packages/provider/src/locale/ms_MY.tsx +71 -0
- package/packages/provider/src/locale/nl_NL.tsx +74 -0
- package/packages/provider/src/locale/pl_PL.tsx +71 -0
- package/packages/provider/src/locale/pt_BR.tsx +71 -0
- package/packages/provider/src/locale/ro_RO.tsx +74 -0
- package/packages/provider/src/locale/ru_RU.tsx +71 -0
- package/packages/provider/src/locale/sk_SK.tsx +74 -0
- package/packages/provider/src/locale/sr_RS.tsx +71 -0
- package/packages/provider/src/locale/sv_SE.tsx +74 -0
- package/packages/provider/src/locale/th_TH.tsx +74 -0
- package/packages/provider/src/locale/tr_TR.tsx +71 -0
- package/packages/provider/src/locale/uk_UA.tsx +74 -0
- package/packages/provider/src/locale/uz_UZ.tsx +71 -0
- package/packages/provider/src/locale/vi_VN.tsx +71 -0
- package/packages/provider/src/locale/zh_CN.tsx +74 -0
- package/packages/provider/src/locale/zh_TW.tsx +74 -0
- package/packages/provider/src/typing/layoutToken.ts +175 -0
- package/packages/provider/src/useStyle/index.ts +141 -0
- package/packages/provider/src/useStyle/token.ts +412 -0
- package/packages/provider/src/utils/merge.ts +28 -0
- package/packages/provider/tsconfig.json +18 -0
- package/packages/skeleton/.fatherrc.ts +5 -0
- package/packages/skeleton/CHANGELOG.md +253 -0
- package/packages/skeleton/README.md +19 -0
- package/packages/skeleton/package.json +54 -0
- package/packages/skeleton/src/components/Descriptions/index.tsx +328 -0
- package/packages/skeleton/src/components/List/index.tsx +310 -0
- package/packages/skeleton/src/components/Result/index.tsx +54 -0
- package/packages/skeleton/src/components/skeleton.en-US.md +49 -0
- package/packages/skeleton/src/components/skeleton.md +41 -0
- package/packages/skeleton/src/demos/descriptions.tsx +14 -0
- package/packages/skeleton/src/demos/list.static.tsx +12 -0
- package/packages/skeleton/src/demos/list.tsx +12 -0
- package/packages/skeleton/src/demos/result.tsx +12 -0
- package/packages/skeleton/src/index.tsx +48 -0
- package/packages/skeleton/tsconfig.json +18 -0
- package/packages/table/.fatherrc.ts +5 -0
- package/packages/table/CHANGELOG.md +2622 -0
- package/packages/table/README.md +167 -0
- package/packages/table/package.json +75 -0
- package/packages/table/src/Store/Provide.tsx +261 -0
- package/packages/table/src/Table.tsx +1043 -0
- package/packages/table/src/components/Alert/index.tsx +96 -0
- package/packages/table/src/components/Alert/style.ts +45 -0
- package/packages/table/src/components/ColumnSetting/index.tsx +535 -0
- package/packages/table/src/components/ColumnSetting/style.ts +104 -0
- package/packages/table/src/components/DragSortTable/demos/drag-sort-table.tsx +164 -0
- package/packages/table/src/components/DragSortTable/demos/drag.tsx +74 -0
- package/packages/table/src/components/DragSortTable/index.en-US.md +28 -0
- package/packages/table/src/components/DragSortTable/index.md +26 -0
- package/packages/table/src/components/DragSortTable/index.tsx +112 -0
- package/packages/table/src/components/DragSortTable/style.ts +35 -0
- package/packages/table/src/components/Dropdown/index.tsx +86 -0
- package/packages/table/src/components/EditableTable/CellEditorTable.tsx +67 -0
- package/packages/table/src/components/EditableTable/RowEditorTable.tsx +60 -0
- package/packages/table/src/components/EditableTable/demos/basic.tsx +219 -0
- package/packages/table/src/components/EditableTable/demos/cell-editor-table.tsx +101 -0
- package/packages/table/src/components/EditableTable/demos/children.tsx +202 -0
- package/packages/table/src/components/EditableTable/demos/custom.tsx +257 -0
- package/packages/table/src/components/EditableTable/demos/form-item.tsx +254 -0
- package/packages/table/src/components/EditableTable/demos/form-linkage.tsx +259 -0
- package/packages/table/src/components/EditableTable/demos/real-time-editing.tsx +155 -0
- package/packages/table/src/components/EditableTable/demos/row-editor-table.tsx +100 -0
- package/packages/table/src/components/EditableTable/index.en-US.md +303 -0
- package/packages/table/src/components/EditableTable/index.md +303 -0
- package/packages/table/src/components/EditableTable/index.tsx +562 -0
- package/packages/table/src/components/Form/FormRender.tsx +262 -0
- package/packages/table/src/components/Form/index.tsx +194 -0
- package/packages/table/src/components/ListToolBar/HeaderMenu.tsx +132 -0
- package/packages/table/src/components/ListToolBar/index.tsx +420 -0
- package/packages/table/src/components/ListToolBar/style.ts +127 -0
- package/packages/table/src/components/ToolBar/DensityIcon.tsx +47 -0
- package/packages/table/src/components/ToolBar/FullscreenIcon.tsx +29 -0
- package/packages/table/src/components/ToolBar/index.tsx +419 -0
- package/packages/table/src/components/table.$tab-api.md +243 -0
- package/packages/table/src/components/table.en-US.$tab-api.md +210 -0
- package/packages/table/src/components/table.en-US.md +333 -0
- package/packages/table/src/components/table.md +338 -0
- package/packages/table/src/demos/ListToolBar/basic.tsx +124 -0
- package/packages/table/src/demos/ListToolBar/menu.tsx +148 -0
- package/packages/table/src/demos/ListToolBar/multipleLine.tsx +139 -0
- package/packages/table/src/demos/ListToolBar/no-title.tsx +108 -0
- package/packages/table/src/demos/ListToolBar/tabs.tsx +176 -0
- package/packages/table/src/demos/batchOption.tsx +180 -0
- package/packages/table/src/demos/card-title.tsx +93 -0
- package/packages/table/src/demos/columns-setting-custom-icon.tsx +55 -0
- package/packages/table/src/demos/columnsStateMap.tsx +113 -0
- package/packages/table/src/demos/config-provider.tsx +139 -0
- package/packages/table/src/demos/crud.tsx +168 -0
- package/packages/table/src/demos/customization-value-type.tsx +174 -0
- package/packages/table/src/demos/dataSource.tsx +178 -0
- package/packages/table/src/demos/dateFormatter.tsx +130 -0
- package/packages/table/src/demos/dynamic-columns-state.tsx +151 -0
- package/packages/table/src/demos/dynamic-settings.tsx +723 -0
- package/packages/table/src/demos/edittable-rules.tsx +106 -0
- package/packages/table/src/demos/error-boundaries-false.tsx +81 -0
- package/packages/table/src/demos/error-boundaries.tsx +201 -0
- package/packages/table/src/demos/form.tsx +82 -0
- package/packages/table/src/demos/intl.tsx +119 -0
- package/packages/table/src/demos/lightfilter.tsx +81 -0
- package/packages/table/src/demos/linkage_form.tsx +175 -0
- package/packages/table/src/demos/listToolBar.tsx +184 -0
- package/packages/table/src/demos/no-option.tsx +113 -0
- package/packages/table/src/demos/no-title.tsx +167 -0
- package/packages/table/src/demos/normal.tsx +124 -0
- package/packages/table/src/demos/open-rules.tsx +187 -0
- package/packages/table/src/demos/pollinga.tsx +129 -0
- package/packages/table/src/demos/renderTable.tsx +159 -0
- package/packages/table/src/demos/rtl_table.tsx +137 -0
- package/packages/table/src/demos/search.tsx +46 -0
- package/packages/table/src/demos/search_option.tsx +66 -0
- package/packages/table/src/demos/single-test.tsx +254 -0
- package/packages/table/src/demos/single.tsx +242 -0
- package/packages/table/src/demos/split.tsx +200 -0
- package/packages/table/src/demos/table-nested.tsx +162 -0
- package/packages/table/src/demos/theme.tsx +235 -0
- package/packages/table/src/demos/valueType.tsx +136 -0
- package/packages/table/src/demos/valueTypeDate.tsx +138 -0
- package/packages/table/src/demos/valueTypeNumber.tsx +117 -0
- package/packages/table/src/demos/valueType_select.tsx +188 -0
- package/packages/table/src/index.tsx +96 -0
- package/packages/table/src/style/index.ts +178 -0
- package/packages/table/src/typing.ts +585 -0
- package/packages/table/src/useFetchData.tsx +464 -0
- package/packages/table/src/utils/cellRenderToFromItem.tsx +360 -0
- package/packages/table/src/utils/columnRender.tsx +220 -0
- package/packages/table/src/utils/columnSort.ts +26 -0
- package/packages/table/src/utils/genProColumnToColumn.tsx +192 -0
- package/packages/table/src/utils/index.ts +224 -0
- package/packages/table/src/utils/useDragSort.tsx +210 -0
- package/packages/table/tsconfig.json +26 -0
- package/packages/utils/.fatherrc.ts +5 -0
- package/packages/utils/CHANGELOG.md +1747 -0
- package/packages/utils/README.md +19 -0
- package/packages/utils/package.json +65 -0
- package/packages/utils/src/compareVersions/coverToNewToken.ts +44 -0
- package/packages/utils/src/compareVersions/index.ts +84 -0
- package/packages/utils/src/compareVersions/menuOverlayCompatible.tsx +20 -0
- package/packages/utils/src/compareVersions/openVisibleCompatible.ts +25 -0
- package/packages/utils/src/compatible/compatibleBorder.ts +21 -0
- package/packages/utils/src/components/DropdownFooter/index.tsx +79 -0
- package/packages/utils/src/components/DropdownFooter/style.ts +30 -0
- package/packages/utils/src/components/ErrorBoundary/index.tsx +37 -0
- package/packages/utils/src/components/FieldLabel/index.tsx +222 -0
- package/packages/utils/src/components/FieldLabel/style.ts +121 -0
- package/packages/utils/src/components/FilterDropdown/index.tsx +100 -0
- package/packages/utils/src/components/FilterDropdown/style.ts +28 -0
- package/packages/utils/src/components/InlineErrorFormItem/index.tsx +196 -0
- package/packages/utils/src/components/InlineErrorFormItem/style.ts +76 -0
- package/packages/utils/src/components/LabelIconTip/index.tsx +63 -0
- package/packages/utils/src/components/LabelIconTip/style.ts +49 -0
- package/packages/utils/src/components/ProFormContext/index.tsx +45 -0
- package/packages/utils/src/conversionMomentValue/index.ts +203 -0
- package/packages/utils/src/dateArrayFormatter/index.tsx +60 -0
- package/packages/utils/src/genCopyable/index.tsx +71 -0
- package/packages/utils/src/getFieldPropsOrFormItemProps/index.tsx +22 -0
- package/packages/utils/src/hooks/useDebounceFn/index.ts +47 -0
- package/packages/utils/src/hooks/useDebounceValue/index.ts +32 -0
- package/packages/utils/src/hooks/useDeepCompareEffect/index.ts +42 -0
- package/packages/utils/src/hooks/useDeepCompareMemo/index.ts +22 -0
- package/packages/utils/src/hooks/useDocumentTitle/index.ts +19 -0
- package/packages/utils/src/hooks/useFetchData/index.tsx +60 -0
- package/packages/utils/src/hooks/useForceRender/index.ts +9 -0
- package/packages/utils/src/hooks/useLatest/index.ts +10 -0
- package/packages/utils/src/hooks/usePrevious/index.ts +11 -0
- package/packages/utils/src/hooks/useReactiveRef/index.ts +21 -0
- package/packages/utils/src/hooks/useRefCallback/index.ts +42 -0
- package/packages/utils/src/hooks/useRefFunction/index.ts +11 -0
- package/packages/utils/src/index.tsx +158 -0
- package/packages/utils/src/isBrowser/index.ts +24 -0
- package/packages/utils/src/isDeepEqualReact/index.ts +96 -0
- package/packages/utils/src/isDropdownValueType/index.ts +13 -0
- package/packages/utils/src/isImg/index.ts +4 -0
- package/packages/utils/src/isNil/index.ts +2 -0
- package/packages/utils/src/isUrl/index.ts +17 -0
- package/packages/utils/src/merge/index.ts +38 -0
- package/packages/utils/src/nanoid/index.ts +41 -0
- package/packages/utils/src/omitBoolean/index.ts +11 -0
- package/packages/utils/src/omitUndefined/index.ts +18 -0
- package/packages/utils/src/omitUndefinedAndEmptyArr/index.ts +15 -0
- package/packages/utils/src/parseValueToMoment/index.ts +39 -0
- package/packages/utils/src/pickProFormItemProps/index.tsx +44 -0
- package/packages/utils/src/pickProProps/index.tsx +16 -0
- package/packages/utils/src/proFieldParsingText/index.tsx +142 -0
- package/packages/utils/src/runFunction/index.ts +7 -0
- package/packages/utils/src/stringify/index.ts +13 -0
- package/packages/utils/src/transformKeySubmitValue/index.ts +207 -0
- package/packages/utils/src/typing.ts +767 -0
- package/packages/utils/src/useEditableArray/index.tsx +1134 -0
- package/packages/utils/src/useEditableMap/index.tsx +236 -0
- package/packages/utils/src/useMediaQuery/index.ts +109 -0
- package/packages/utils/src/useMediaQuery/query.ts +19 -0
- package/packages/utils/src/useMountMergeState/index.ts +3 -0
- package/packages/utils/tsconfig.json +21 -0
- package/pnpm-workspace.yaml +2 -0
- package/public/CNAME +1 -0
- package/public/favicon.ico +0 -0
- package/public/icon.png +0 -0
- package/public/sitemap.xml +458 -0
- package/scripts/bootstrap.js +108 -0
- package/scripts/changelogs.js +10 -0
- package/scripts/checkDeps.js +166 -0
- package/scripts/checkPublish.js +10 -0
- package/scripts/createRelease.js +125 -0
- package/scripts/gen_version.js +34 -0
- package/scripts/generateSizeLimit.js +38 -0
- package/scripts/issue.js +91 -0
- package/scripts/preDeploy.js +18 -0
- package/scripts/readApi.mjs +145 -0
- package/scripts/release.js +184 -0
- package/scripts/replaceEs.js +22 -0
- package/scripts/replaceLib.js +22 -0
- package/scripts/replaceLodash.js +21 -0
- package/scripts/syncTNPM.js +19 -0
- package/scripts/utils/exec.js +23 -0
- package/scripts/utils/getPackages.js +8 -0
- package/scripts/utils/isNextVersion.js +7 -0
- package/scripts/verifyCommit.js +28 -0
- package/tsconfig.json +39 -9
- package/typings.d.ts +6 -0
- package/vercel.json +7 -0
- package/vitest.config.ts +48 -0
- package/.idea/modules.xml +0 -8
- package/.idea/test-components.iml +0 -12
- package/.idea/vcs.xml +0 -6
- package/build/components/ActionBar/index.d.ts +0 -17
- package/build/components/ActionBar/type.d.ts +0 -82
- package/build/components/DataChart/index.d.ts +0 -7
- package/build/components/DataChart/type.d.ts +0 -50
- package/build/components/DataTable/index.d.ts +0 -9
- package/build/components/DataTable/locales/en-US.d.ts +0 -4
- package/build/components/DataTable/locales/zh-CN.d.ts +0 -4
- package/build/components/DataTable/type.d.ts +0 -117
- package/build/components/DragTable/index.d.ts +0 -9
- package/build/components/DragTable/type.d.ts +0 -22
- package/build/components/FileTag/index.d.ts +0 -9
- package/build/components/FileTag/locales/en-US.d.ts +0 -5
- package/build/components/FileTag/locales/zh-CN.d.ts +0 -5
- package/build/components/FileTag/type.d.ts +0 -35
- package/build/components/HtmlRender/index.d.ts +0 -10
- package/build/components/HtmlRender/type.d.ts +0 -13
- package/build/components/IconRender/index.d.ts +0 -9
- package/build/components/IconRender/type.d.ts +0 -9
- package/build/components/ThemeListener/index.d.ts +0 -10
- package/build/components/ThemeListener/type.d.ts +0 -10
- package/build/components/ThemeSetter/index.d.ts +0 -9
- package/build/components/UserCard/index.d.ts +0 -9
- package/build/components/UserCard/locales/en-US.d.ts +0 -10
- package/build/components/UserCard/locales/zh-CN.d.ts +0 -10
- package/build/components/UserCard/type.d.ts +0 -52
- package/build/components/UserSelector/index.d.ts +0 -8
- package/build/components/UserSelector/locales/en-US.d.ts +0 -5
- package/build/components/UserSelector/locales/zh-CN.d.ts +0 -5
- package/build/components/UserSelector/type.d.ts +0 -60
- package/build/index.d.ts +0 -78
- package/build/index.js +0 -28
- package/build/index.js.LICENSE.txt +0 -1733
- package/build/locales/en-US.d.ts +0 -20
- package/build/locales/zh-CN.d.ts +0 -20
- package/build/services/constants/commonConstant.d.ts +0 -6
- package/build/services/constants/dbConstant.d.ts +0 -4
- package/build/services/constants/iconConstant.d.ts +0 -4
- package/build/services/constants/locales/en-US.d.ts +0 -8
- package/build/services/constants/locales/zh-CN.d.ts +0 -8
- package/build/services/enums/eventEnum.d.ts +0 -10
- package/build/services/enums/storageEnum.d.ts +0 -10
- package/build/services/types/commonType.d.ts +0 -42
- package/build/services/utils/dbUtil.d.ts +0 -5
- package/build/services/utils/eventUtil.d.ts +0 -5
- package/build/services/utils/objectUtil.d.ts +0 -5
- package/build/services/utils/renderUtil.d.ts +0 -6
- package/build/services/utils/resourceUtil.d.ts +0 -12
- package/build/services/utils/storageUtil.d.ts +0 -5
|
@@ -0,0 +1,918 @@
|
|
|
1
|
+
import type { GenerateStyle, ProTokenType } from '@ant-design/pro-provider';
|
|
2
|
+
import {
|
|
3
|
+
ProConfigProvider,
|
|
4
|
+
ProProvider,
|
|
5
|
+
isNeedOpenHash,
|
|
6
|
+
} from '@ant-design/pro-provider';
|
|
7
|
+
import {
|
|
8
|
+
coverToNewToken,
|
|
9
|
+
isBrowser,
|
|
10
|
+
useBreakpoint,
|
|
11
|
+
useDocumentTitle,
|
|
12
|
+
useMountMergeState,
|
|
13
|
+
} from '@ant-design/pro-utils';
|
|
14
|
+
import { getMatchMenu } from '@umijs/route-utils';
|
|
15
|
+
import type { BreadcrumbProps } from 'antd';
|
|
16
|
+
import { ConfigProvider, Layout } from 'antd';
|
|
17
|
+
import type { AnyObject } from 'antd/es/_util/type';
|
|
18
|
+
import type { ItemType } from 'antd/es/breadcrumb/Breadcrumb';
|
|
19
|
+
import classNames from 'classnames';
|
|
20
|
+
import Omit from 'omit.js';
|
|
21
|
+
import useMergedState from 'rc-util/lib/hooks/useMergedState';
|
|
22
|
+
import warning from 'rc-util/lib/warning';
|
|
23
|
+
import type { CSSProperties } from 'react';
|
|
24
|
+
import React, {
|
|
25
|
+
useCallback,
|
|
26
|
+
useContext,
|
|
27
|
+
useEffect,
|
|
28
|
+
useMemo,
|
|
29
|
+
useState,
|
|
30
|
+
} from 'react';
|
|
31
|
+
import useSWR, { useSWRConfig } from 'swr';
|
|
32
|
+
import { WrapContent } from './WrapContent';
|
|
33
|
+
import { Logo } from './assert/Logo';
|
|
34
|
+
import { DefaultFooter as Footer } from './components/Footer';
|
|
35
|
+
import type { HeaderViewProps } from './components/Header';
|
|
36
|
+
import { DefaultHeader as Header } from './components/Header';
|
|
37
|
+
import { PageLoading } from './components/PageLoading';
|
|
38
|
+
import { SiderMenu } from './components/SiderMenu';
|
|
39
|
+
import type { SiderMenuProps } from './components/SiderMenu/SiderMenu';
|
|
40
|
+
import type { SiderMenuToken } from './components/SiderMenu/style';
|
|
41
|
+
import type { WaterMarkProps } from './components/WaterMark';
|
|
42
|
+
import { RouteContext } from './context/RouteContext';
|
|
43
|
+
import type { ProSettings } from './defaultSettings';
|
|
44
|
+
import { defaultSettings } from './defaultSettings';
|
|
45
|
+
import type { GetPageTitleProps } from './getPageTitle';
|
|
46
|
+
import { getPageTitleInfo } from './getPageTitle';
|
|
47
|
+
import type { LocaleType } from './locales';
|
|
48
|
+
import { gLocaleObject } from './locales';
|
|
49
|
+
import { useStyle } from './style';
|
|
50
|
+
import type {
|
|
51
|
+
MenuDataItem,
|
|
52
|
+
MessageDescriptor,
|
|
53
|
+
RouterTypes,
|
|
54
|
+
WithFalse,
|
|
55
|
+
} from './typing';
|
|
56
|
+
import type { BreadcrumbProLayoutProps } from './utils/getBreadcrumbProps';
|
|
57
|
+
import { getBreadcrumbProps } from './utils/getBreadcrumbProps';
|
|
58
|
+
import { getMenuData } from './utils/getMenuData';
|
|
59
|
+
import { useCurrentMenuLayoutProps } from './utils/useCurrentMenuLayoutProps';
|
|
60
|
+
import { clearMenuItem } from './utils/utils';
|
|
61
|
+
|
|
62
|
+
let layoutIndex = 0;
|
|
63
|
+
|
|
64
|
+
type LayoutItemType = ItemType & { linkPath?: string; component?: string };
|
|
65
|
+
|
|
66
|
+
export type LayoutBreadcrumbProps<T extends AnyObject = AnyObject> = {
|
|
67
|
+
minLength?: number;
|
|
68
|
+
itemRender?: (
|
|
69
|
+
route: LayoutItemType,
|
|
70
|
+
params: T,
|
|
71
|
+
routes: LayoutItemType[],
|
|
72
|
+
paths: string[],
|
|
73
|
+
) => React.ReactNode;
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
type GlobalTypes = Omit<
|
|
77
|
+
Partial<RouterTypes> &
|
|
78
|
+
SiderMenuProps &
|
|
79
|
+
HeaderViewProps & {
|
|
80
|
+
token?: ProTokenType['layout'];
|
|
81
|
+
},
|
|
82
|
+
'collapsed'
|
|
83
|
+
>;
|
|
84
|
+
|
|
85
|
+
export type ProLayoutProps = GlobalTypes & {
|
|
86
|
+
stylish?: {
|
|
87
|
+
header?: GenerateStyle<SiderMenuToken>;
|
|
88
|
+
sider?: GenerateStyle<SiderMenuToken>;
|
|
89
|
+
};
|
|
90
|
+
/** Layout 的品牌配置,表现为一张背景图片 */
|
|
91
|
+
bgLayoutImgList?: {
|
|
92
|
+
src?: string;
|
|
93
|
+
width?: string;
|
|
94
|
+
height?: string;
|
|
95
|
+
left?: number;
|
|
96
|
+
top?: number;
|
|
97
|
+
bottom?: number;
|
|
98
|
+
right?: number;
|
|
99
|
+
}[];
|
|
100
|
+
/**
|
|
101
|
+
* @name 简约模式,设置了之后不渲染的任何 layout 的东西,但是会有 context,可以获取到当前菜单。
|
|
102
|
+
*
|
|
103
|
+
* @example pure={true}
|
|
104
|
+
*/
|
|
105
|
+
pure?: boolean;
|
|
106
|
+
/**
|
|
107
|
+
* @name logo 的配置,可以配置url,React 组件 和 false
|
|
108
|
+
*
|
|
109
|
+
* @example 设置 logo 为网络地址 logo="https://avatars1.githubusercontent.com/u/8186664?s=460&v=4"
|
|
110
|
+
* @example 设置 logo 为组件 logo={<img src="https://avatars1.githubusercontent.com/u/8186664?s=460&v=4"/>}
|
|
111
|
+
* @example 设置 logo 为 false 不显示 logo logo={false}
|
|
112
|
+
* @example 设置 logo 为 方法 logo={()=> <img src="https://avatars1.githubusercontent.com/u/8186664?s=460&v=4"/> }
|
|
113
|
+
* */
|
|
114
|
+
logo?:
|
|
115
|
+
| React.ReactNode
|
|
116
|
+
| JSX.Element
|
|
117
|
+
| WithFalse<() => React.ReactNode | JSX.Element>;
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* @name 页面切换的时候触发
|
|
121
|
+
*
|
|
122
|
+
* @example 获取切换的页面地址 onPageChange={(location) => { console.log("切换到:"+location.pathname) }}
|
|
123
|
+
*
|
|
124
|
+
* */
|
|
125
|
+
onPageChange?: (location?: RouterTypes['location']) => void;
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* @name layout 的 loading 效果,设置完成之后只展示一个 loading
|
|
129
|
+
*
|
|
130
|
+
* @example loading={true}
|
|
131
|
+
*/
|
|
132
|
+
loading?: boolean;
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* @name layout
|
|
136
|
+
*
|
|
137
|
+
* @description "zh-CN" | "zh-TW" | "en-US" | "it-IT" | "ko-KR"
|
|
138
|
+
* @example 中文 layout="zh-CN"
|
|
139
|
+
* @example 英文 layout="en-US"
|
|
140
|
+
*/
|
|
141
|
+
locale?: LocaleType;
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* @name 是否收起 layout 是严格受控的,可以 设置为 true,一直收起
|
|
145
|
+
*
|
|
146
|
+
* @example collapsed={true}
|
|
147
|
+
*/
|
|
148
|
+
collapsed?: boolean;
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* @name 收起和展开的时候触发事件
|
|
152
|
+
*
|
|
153
|
+
* @example onCollapse=(collapsed)=>{ setCollapsed(collapsed) };
|
|
154
|
+
*/
|
|
155
|
+
onCollapse?: (collapsed: boolean) => void;
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* @name 页脚的配置
|
|
159
|
+
*
|
|
160
|
+
* @example 不展示dom footerRender={false}
|
|
161
|
+
* @example 使用 layout 的 DefaultFooter footerRender={() => (<DefaultFooter copyright="这是一条测试文案"/>}
|
|
162
|
+
*/
|
|
163
|
+
footerRender?: WithFalse<
|
|
164
|
+
(
|
|
165
|
+
props: ProLayoutProps & {
|
|
166
|
+
hasSiderMenu?: boolean;
|
|
167
|
+
},
|
|
168
|
+
defaultDom: React.ReactNode,
|
|
169
|
+
) => React.ReactNode
|
|
170
|
+
>;
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* @name 设置 PageHeader 的面包屑,只能处理数据
|
|
174
|
+
*
|
|
175
|
+
* @example 手动设置 breadcrumbRender={(routers = []) => [ { path: '/', breadcrumbName: '主页'} ]
|
|
176
|
+
* @example 增加一项 breadcrumbRender={(routers = []) => { return [{ path: '/', breadcrumbName: '主页'} ,...routers ]}
|
|
177
|
+
* @example 删除首页 breadcrumbRender={(routers = []) => { return routers.filter(item => item.path !== '/')}
|
|
178
|
+
* @example 不显示面包屑 breadcrumbRender={false}
|
|
179
|
+
*/
|
|
180
|
+
breadcrumbRender?: WithFalse<
|
|
181
|
+
(routers: BreadcrumbProps['items']) => BreadcrumbProps['items']
|
|
182
|
+
>;
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* @name 设置页面的标题
|
|
186
|
+
* @example 根据页面的路由设置标题 pageTitleRender={(props) => { return props.location.pathname }}
|
|
187
|
+
* @example 不显示标题 pageTitleRender={false}
|
|
188
|
+
* @example 根据默认的标题设置 pageTitleRender={(props,defaultPageTitle) => { return defaultPageTitle + '这是一个测试标题' }}
|
|
189
|
+
* @example 根据 info 来自己组合标题 pageTitleRender={(props,defaultPageTitle,info) => { return info.title + "-" + info.pageName }
|
|
190
|
+
*/
|
|
191
|
+
pageTitleRender?: WithFalse<
|
|
192
|
+
(
|
|
193
|
+
props: GetPageTitleProps,
|
|
194
|
+
defaultPageTitle?: string,
|
|
195
|
+
info?: {
|
|
196
|
+
// 页面标题
|
|
197
|
+
title: string;
|
|
198
|
+
// locale 的 title
|
|
199
|
+
id: string;
|
|
200
|
+
// 页面标题不带默认的 title
|
|
201
|
+
pageName: string;
|
|
202
|
+
},
|
|
203
|
+
) => string
|
|
204
|
+
>;
|
|
205
|
+
/**
|
|
206
|
+
* @name 处理 menuData 的数据,可以动态的控制数据
|
|
207
|
+
* @see 尽量不要用异步数据来处理,否则可能造成更新不及时,如果异步数据推荐使用 menu.request 和 params。
|
|
208
|
+
*
|
|
209
|
+
* @example 删除一些菜单 menuDataRender=((menuData) => { return menuData.filter(item => item.name !== 'test') })
|
|
210
|
+
* @example 增加一些菜单 menuDataRender={(menuData) => { return menuData.concat({ path: '/test', name: '测试', icon: 'smile' }) }}
|
|
211
|
+
* @example 修改菜单 menuDataRender={(menuData) => { return menuData.map(item => { if (item.name === 'test') { item.name = '测试' } return item }) }}
|
|
212
|
+
* @example 打平数据 menuDataRender={(menuData) => { return menuData.reduce((pre, item) => { return pre.concat(item.children || []) }, []) }}
|
|
213
|
+
*/
|
|
214
|
+
menuDataRender?: (menuData: MenuDataItem[]) => MenuDataItem[];
|
|
215
|
+
|
|
216
|
+
/**
|
|
217
|
+
* @name 处理每个面包屑的配置,需要直接返回 dom
|
|
218
|
+
* @description (route: Route, params: any, routes: Array<Route>, paths: Array<string>) => React.ReactNode
|
|
219
|
+
*
|
|
220
|
+
* @example 设置 disabled: itemRender={(route, params, routes, paths) => { return <Button disabled>{route.breadcrumbName}</Button> }}
|
|
221
|
+
* @example 拼接 path: itemRender={(route, params, routes, paths) => { return <a href={paths.join('/')}>{route.breadcrumbName}</a> }}
|
|
222
|
+
*/
|
|
223
|
+
itemRender?: BreadcrumbProps['itemRender'];
|
|
224
|
+
|
|
225
|
+
formatMessage?: (message: MessageDescriptor) => string;
|
|
226
|
+
/** @name 是否禁用移动端模式
|
|
227
|
+
*
|
|
228
|
+
* @see 有的管理系统不需要移动端模式,此属性设置为true即可
|
|
229
|
+
* @example disableMobile={true}
|
|
230
|
+
* */
|
|
231
|
+
disableMobile?: boolean;
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* content 的样式
|
|
235
|
+
*
|
|
236
|
+
* @example 背景颜色为红色 contentStyle={{ backgroundColor: 'red '}}
|
|
237
|
+
*/
|
|
238
|
+
contentStyle?: CSSProperties;
|
|
239
|
+
|
|
240
|
+
className?: string;
|
|
241
|
+
|
|
242
|
+
/** PageHeader 的 BreadcrumbProps 配置,会透传下去 */
|
|
243
|
+
breadcrumbProps?: Omit<BreadcrumbProps, 'itemRender'> & LayoutBreadcrumbProps;
|
|
244
|
+
|
|
245
|
+
/** @name 水印的相关配置 */
|
|
246
|
+
waterMarkProps?: WaterMarkProps;
|
|
247
|
+
|
|
248
|
+
/**
|
|
249
|
+
* @name 操作菜单重新刷新
|
|
250
|
+
*
|
|
251
|
+
* @example 重新获取菜单 actionRef.current.reload();
|
|
252
|
+
* */
|
|
253
|
+
actionRef?: React.MutableRefObject<
|
|
254
|
+
| {
|
|
255
|
+
reload: () => void;
|
|
256
|
+
}
|
|
257
|
+
| undefined
|
|
258
|
+
>;
|
|
259
|
+
|
|
260
|
+
/**
|
|
261
|
+
* @name 错误处理组件
|
|
262
|
+
*
|
|
263
|
+
* @example ErrorBoundary={MyErrorBoundary}
|
|
264
|
+
*/
|
|
265
|
+
ErrorBoundary?: React.ComponentClass<any, any> | boolean;
|
|
266
|
+
|
|
267
|
+
/**
|
|
268
|
+
* @name 侧边菜单的类型, menu.type 的快捷方式
|
|
269
|
+
* @type "sub" | "group"
|
|
270
|
+
* @example group
|
|
271
|
+
*/
|
|
272
|
+
siderMenuType?: 'sub' | 'group';
|
|
273
|
+
|
|
274
|
+
isChildrenLayout?: boolean;
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
const headerRender = (
|
|
278
|
+
props: ProLayoutProps & {
|
|
279
|
+
hasSiderMenu: boolean;
|
|
280
|
+
},
|
|
281
|
+
matchMenuKeys: string[],
|
|
282
|
+
): React.ReactNode => {
|
|
283
|
+
if (props.headerRender === false || props.pure) {
|
|
284
|
+
return null;
|
|
285
|
+
}
|
|
286
|
+
return (
|
|
287
|
+
<Header
|
|
288
|
+
matchMenuKeys={matchMenuKeys}
|
|
289
|
+
{...props}
|
|
290
|
+
stylish={props.stylish?.header}
|
|
291
|
+
/>
|
|
292
|
+
);
|
|
293
|
+
};
|
|
294
|
+
|
|
295
|
+
const footerRender = (props: ProLayoutProps): React.ReactNode => {
|
|
296
|
+
if (props.footerRender === false || props.pure) {
|
|
297
|
+
return null;
|
|
298
|
+
}
|
|
299
|
+
if (props.footerRender) {
|
|
300
|
+
return props.footerRender({ ...props }, <Footer />);
|
|
301
|
+
}
|
|
302
|
+
return null;
|
|
303
|
+
};
|
|
304
|
+
|
|
305
|
+
const renderSiderMenu = (
|
|
306
|
+
props: ProLayoutProps,
|
|
307
|
+
matchMenuKeys: string[],
|
|
308
|
+
): React.ReactNode => {
|
|
309
|
+
const {
|
|
310
|
+
layout,
|
|
311
|
+
isMobile,
|
|
312
|
+
selectedKeys,
|
|
313
|
+
openKeys,
|
|
314
|
+
splitMenus,
|
|
315
|
+
suppressSiderWhenMenuEmpty,
|
|
316
|
+
menuRender,
|
|
317
|
+
} = props;
|
|
318
|
+
if (props.menuRender === false || props.pure) {
|
|
319
|
+
return null;
|
|
320
|
+
}
|
|
321
|
+
let { menuData } = props;
|
|
322
|
+
|
|
323
|
+
/** 如果是分割菜单模式,需要专门实现一下 */
|
|
324
|
+
if (splitMenus && (openKeys !== false || layout === 'mix') && !isMobile) {
|
|
325
|
+
const [key] = selectedKeys || matchMenuKeys;
|
|
326
|
+
if (key) {
|
|
327
|
+
menuData =
|
|
328
|
+
props.menuData?.find((item) => item.key === key)?.children || [];
|
|
329
|
+
} else {
|
|
330
|
+
menuData = [];
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
// 这里走了可以少一次循环
|
|
334
|
+
const clearMenuData = clearMenuItem(menuData || []);
|
|
335
|
+
if (
|
|
336
|
+
clearMenuData &&
|
|
337
|
+
clearMenuData?.length < 1 &&
|
|
338
|
+
(splitMenus || suppressSiderWhenMenuEmpty)
|
|
339
|
+
) {
|
|
340
|
+
return null;
|
|
341
|
+
}
|
|
342
|
+
if (layout === 'top' && !isMobile) {
|
|
343
|
+
return (
|
|
344
|
+
<SiderMenu
|
|
345
|
+
matchMenuKeys={matchMenuKeys}
|
|
346
|
+
{...props}
|
|
347
|
+
hide
|
|
348
|
+
stylish={props.stylish?.sider}
|
|
349
|
+
/>
|
|
350
|
+
);
|
|
351
|
+
}
|
|
352
|
+
|
|
353
|
+
const defaultDom = (
|
|
354
|
+
<SiderMenu
|
|
355
|
+
matchMenuKeys={matchMenuKeys}
|
|
356
|
+
{...props}
|
|
357
|
+
// 这里走了可以少一次循环
|
|
358
|
+
menuData={clearMenuData}
|
|
359
|
+
stylish={props.stylish?.sider}
|
|
360
|
+
/>
|
|
361
|
+
);
|
|
362
|
+
if (menuRender) {
|
|
363
|
+
return menuRender(props, defaultDom);
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
return defaultDom;
|
|
367
|
+
};
|
|
368
|
+
|
|
369
|
+
const defaultPageTitleRender = (
|
|
370
|
+
pageProps: GetPageTitleProps,
|
|
371
|
+
props: ProLayoutProps,
|
|
372
|
+
): {
|
|
373
|
+
title: string;
|
|
374
|
+
id: string;
|
|
375
|
+
pageName: string;
|
|
376
|
+
} => {
|
|
377
|
+
const { pageTitleRender } = props;
|
|
378
|
+
const pageTitleInfo = getPageTitleInfo(pageProps);
|
|
379
|
+
if (pageTitleRender === false) {
|
|
380
|
+
return {
|
|
381
|
+
title: props.title || '',
|
|
382
|
+
id: '',
|
|
383
|
+
pageName: '',
|
|
384
|
+
};
|
|
385
|
+
}
|
|
386
|
+
if (pageTitleRender) {
|
|
387
|
+
const title = pageTitleRender(
|
|
388
|
+
pageProps,
|
|
389
|
+
pageTitleInfo.title,
|
|
390
|
+
pageTitleInfo,
|
|
391
|
+
);
|
|
392
|
+
if (typeof title === 'string') {
|
|
393
|
+
return getPageTitleInfo({
|
|
394
|
+
...pageTitleInfo,
|
|
395
|
+
title,
|
|
396
|
+
});
|
|
397
|
+
}
|
|
398
|
+
warning(
|
|
399
|
+
typeof title === 'string',
|
|
400
|
+
'pro-layout: renderPageTitle return value should be a string',
|
|
401
|
+
);
|
|
402
|
+
}
|
|
403
|
+
return pageTitleInfo;
|
|
404
|
+
};
|
|
405
|
+
|
|
406
|
+
export type BasicLayoutContext = { [K in 'location']: ProLayoutProps[K] } & {
|
|
407
|
+
breadcrumb: Record<string, MenuDataItem>;
|
|
408
|
+
};
|
|
409
|
+
|
|
410
|
+
const getPaddingInlineStart = (
|
|
411
|
+
hasLeftPadding: boolean,
|
|
412
|
+
collapsed: boolean | undefined,
|
|
413
|
+
siderWidth: number,
|
|
414
|
+
): number | undefined => {
|
|
415
|
+
if (hasLeftPadding) {
|
|
416
|
+
return collapsed ? 64 : siderWidth;
|
|
417
|
+
}
|
|
418
|
+
return 0;
|
|
419
|
+
};
|
|
420
|
+
|
|
421
|
+
/**
|
|
422
|
+
* 🌃 Powerful and easy to use beautiful layout 🏄 Support multiple topics and layout types
|
|
423
|
+
*
|
|
424
|
+
* @param props
|
|
425
|
+
*/
|
|
426
|
+
const BaseProLayout: React.FC<ProLayoutProps> = (props) => {
|
|
427
|
+
const {
|
|
428
|
+
children,
|
|
429
|
+
onCollapse: propsOnCollapse,
|
|
430
|
+
location = { pathname: '/' },
|
|
431
|
+
contentStyle,
|
|
432
|
+
route,
|
|
433
|
+
defaultCollapsed,
|
|
434
|
+
style,
|
|
435
|
+
siderWidth: propsSiderWidth,
|
|
436
|
+
menu,
|
|
437
|
+
siderMenuType,
|
|
438
|
+
isChildrenLayout: propsIsChildrenLayout,
|
|
439
|
+
menuDataRender,
|
|
440
|
+
actionRef,
|
|
441
|
+
bgLayoutImgList,
|
|
442
|
+
formatMessage: propsFormatMessage,
|
|
443
|
+
loading,
|
|
444
|
+
} = props || {};
|
|
445
|
+
|
|
446
|
+
const siderWidth = useMemo(() => {
|
|
447
|
+
if (propsSiderWidth) return propsSiderWidth;
|
|
448
|
+
if (props.layout === 'mix') return 215;
|
|
449
|
+
return 256;
|
|
450
|
+
}, [props.layout, propsSiderWidth]);
|
|
451
|
+
|
|
452
|
+
const context = useContext(ConfigProvider.ConfigContext);
|
|
453
|
+
|
|
454
|
+
const prefixCls = props.prefixCls ?? context.getPrefixCls('pro');
|
|
455
|
+
|
|
456
|
+
const [menuLoading, setMenuLoading] = useMountMergeState(false, {
|
|
457
|
+
value: menu?.loading,
|
|
458
|
+
onChange: menu?.onLoadingChange,
|
|
459
|
+
});
|
|
460
|
+
|
|
461
|
+
// give a default key for swr
|
|
462
|
+
const [defaultId] = useState(() => {
|
|
463
|
+
layoutIndex += 1;
|
|
464
|
+
return `pro-layout-${layoutIndex}`;
|
|
465
|
+
});
|
|
466
|
+
|
|
467
|
+
/**
|
|
468
|
+
* 处理国际化相关 formatMessage
|
|
469
|
+
* 如果有用户配置的以用户为主
|
|
470
|
+
* 如果没有用自己实现的
|
|
471
|
+
*/
|
|
472
|
+
const formatMessage = useCallback(
|
|
473
|
+
({
|
|
474
|
+
id,
|
|
475
|
+
defaultMessage,
|
|
476
|
+
...restParams
|
|
477
|
+
}: {
|
|
478
|
+
id: string;
|
|
479
|
+
defaultMessage?: string;
|
|
480
|
+
}): string => {
|
|
481
|
+
if (propsFormatMessage) {
|
|
482
|
+
return propsFormatMessage({
|
|
483
|
+
id,
|
|
484
|
+
defaultMessage,
|
|
485
|
+
...restParams,
|
|
486
|
+
});
|
|
487
|
+
}
|
|
488
|
+
const locales = gLocaleObject();
|
|
489
|
+
return locales[id] ? locales[id] : (defaultMessage as string);
|
|
490
|
+
},
|
|
491
|
+
[propsFormatMessage],
|
|
492
|
+
);
|
|
493
|
+
|
|
494
|
+
const { data, mutate, isLoading } = useSWR(
|
|
495
|
+
[defaultId, menu?.params],
|
|
496
|
+
async ([, params]) => {
|
|
497
|
+
setMenuLoading(true);
|
|
498
|
+
const menuDataItems = await menu?.request?.(
|
|
499
|
+
params || {},
|
|
500
|
+
route?.children || route?.routes || [],
|
|
501
|
+
);
|
|
502
|
+
setMenuLoading(false);
|
|
503
|
+
return menuDataItems;
|
|
504
|
+
},
|
|
505
|
+
{
|
|
506
|
+
revalidateOnFocus: false,
|
|
507
|
+
shouldRetryOnError: false,
|
|
508
|
+
revalidateOnReconnect: false,
|
|
509
|
+
},
|
|
510
|
+
);
|
|
511
|
+
|
|
512
|
+
useEffect(() => {
|
|
513
|
+
setMenuLoading(isLoading);
|
|
514
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
515
|
+
}, [isLoading]);
|
|
516
|
+
|
|
517
|
+
const { cache } = useSWRConfig();
|
|
518
|
+
useEffect(() => {
|
|
519
|
+
return () => {
|
|
520
|
+
if (cache instanceof Map) cache.delete(defaultId);
|
|
521
|
+
};
|
|
522
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
523
|
+
}, []);
|
|
524
|
+
|
|
525
|
+
const menuInfoData = useMemo<{
|
|
526
|
+
breadcrumb?: Record<string, MenuDataItem>;
|
|
527
|
+
breadcrumbMap?: Map<string, MenuDataItem>;
|
|
528
|
+
menuData?: MenuDataItem[];
|
|
529
|
+
}>(
|
|
530
|
+
() =>
|
|
531
|
+
getMenuData(
|
|
532
|
+
data || route?.children || route?.routes || [],
|
|
533
|
+
menu,
|
|
534
|
+
formatMessage,
|
|
535
|
+
menuDataRender,
|
|
536
|
+
),
|
|
537
|
+
[formatMessage, menu, menuDataRender, data, route?.children, route?.routes],
|
|
538
|
+
);
|
|
539
|
+
|
|
540
|
+
const { breadcrumb, breadcrumbMap, menuData = [] } = menuInfoData || {};
|
|
541
|
+
|
|
542
|
+
if (actionRef && menu?.request) {
|
|
543
|
+
actionRef.current = {
|
|
544
|
+
reload: () => {
|
|
545
|
+
mutate();
|
|
546
|
+
},
|
|
547
|
+
};
|
|
548
|
+
}
|
|
549
|
+
const matchMenus = useMemo(() => {
|
|
550
|
+
return getMatchMenu(location.pathname || '/', menuData || [], true);
|
|
551
|
+
}, [location.pathname, menuData]);
|
|
552
|
+
|
|
553
|
+
const matchMenuKeys = useMemo(
|
|
554
|
+
() =>
|
|
555
|
+
Array.from(
|
|
556
|
+
new Set(matchMenus.map((item) => item.key || item.path || '')),
|
|
557
|
+
),
|
|
558
|
+
[matchMenus],
|
|
559
|
+
);
|
|
560
|
+
|
|
561
|
+
// 当前选中的menu,一般不会为空
|
|
562
|
+
const currentMenu = (matchMenus[matchMenus.length - 1] || {}) as ProSettings &
|
|
563
|
+
MenuDataItem;
|
|
564
|
+
|
|
565
|
+
const currentMenuLayoutProps = useCurrentMenuLayoutProps(currentMenu);
|
|
566
|
+
|
|
567
|
+
const {
|
|
568
|
+
fixSiderbar,
|
|
569
|
+
navTheme,
|
|
570
|
+
layout: propsLayout,
|
|
571
|
+
...rest
|
|
572
|
+
} = {
|
|
573
|
+
...props,
|
|
574
|
+
...currentMenuLayoutProps,
|
|
575
|
+
};
|
|
576
|
+
|
|
577
|
+
const colSize = useBreakpoint();
|
|
578
|
+
|
|
579
|
+
const isMobile = useMemo(() => {
|
|
580
|
+
return (colSize === 'sm' || colSize === 'xs') && !props.disableMobile;
|
|
581
|
+
}, [colSize, props.disableMobile]);
|
|
582
|
+
|
|
583
|
+
// If it is a fix menu, calculate padding
|
|
584
|
+
// don't need padding in phone mode
|
|
585
|
+
/* Checking if the menu is loading and if it is, it will return a skeleton loading screen. */
|
|
586
|
+
const hasLeftPadding = propsLayout !== 'top' && !isMobile;
|
|
587
|
+
|
|
588
|
+
const [collapsed, onCollapse] = useMergedState<boolean>(
|
|
589
|
+
() => {
|
|
590
|
+
if (defaultCollapsed !== undefined) return defaultCollapsed;
|
|
591
|
+
if (process.env.NODE_ENV === 'TEST') return false;
|
|
592
|
+
if (isMobile) return true;
|
|
593
|
+
if (colSize === 'md') return true;
|
|
594
|
+
return false;
|
|
595
|
+
},
|
|
596
|
+
{
|
|
597
|
+
value: props.collapsed,
|
|
598
|
+
onChange: propsOnCollapse,
|
|
599
|
+
},
|
|
600
|
+
);
|
|
601
|
+
|
|
602
|
+
// Splicing parameters, adding menuData and formatMessage in props
|
|
603
|
+
const defaultProps = Omit(
|
|
604
|
+
{
|
|
605
|
+
prefixCls,
|
|
606
|
+
...props,
|
|
607
|
+
siderWidth,
|
|
608
|
+
...currentMenuLayoutProps,
|
|
609
|
+
formatMessage,
|
|
610
|
+
breadcrumb,
|
|
611
|
+
menu: {
|
|
612
|
+
...menu,
|
|
613
|
+
type: siderMenuType || menu?.type,
|
|
614
|
+
loading: menuLoading,
|
|
615
|
+
},
|
|
616
|
+
layout: propsLayout as 'side',
|
|
617
|
+
},
|
|
618
|
+
['className', 'style', 'breadcrumbRender'],
|
|
619
|
+
);
|
|
620
|
+
|
|
621
|
+
// gen page title
|
|
622
|
+
const pageTitleInfo = defaultPageTitleRender(
|
|
623
|
+
{
|
|
624
|
+
pathname: location.pathname,
|
|
625
|
+
...defaultProps,
|
|
626
|
+
breadcrumbMap,
|
|
627
|
+
},
|
|
628
|
+
props,
|
|
629
|
+
);
|
|
630
|
+
|
|
631
|
+
// gen breadcrumbProps, parameter for pageHeader
|
|
632
|
+
const breadcrumbProps = getBreadcrumbProps(
|
|
633
|
+
{
|
|
634
|
+
...(defaultProps as BreadcrumbProLayoutProps),
|
|
635
|
+
breadcrumbRender: props.breadcrumbRender,
|
|
636
|
+
breadcrumbMap,
|
|
637
|
+
},
|
|
638
|
+
props,
|
|
639
|
+
);
|
|
640
|
+
|
|
641
|
+
// render sider dom
|
|
642
|
+
const siderMenuDom = renderSiderMenu(
|
|
643
|
+
{
|
|
644
|
+
...defaultProps,
|
|
645
|
+
menuData,
|
|
646
|
+
onCollapse,
|
|
647
|
+
isMobile,
|
|
648
|
+
collapsed,
|
|
649
|
+
},
|
|
650
|
+
matchMenuKeys,
|
|
651
|
+
);
|
|
652
|
+
|
|
653
|
+
// render header dom
|
|
654
|
+
const headerDom = headerRender(
|
|
655
|
+
{
|
|
656
|
+
...defaultProps,
|
|
657
|
+
children: null,
|
|
658
|
+
hasSiderMenu: !!siderMenuDom,
|
|
659
|
+
menuData,
|
|
660
|
+
isMobile,
|
|
661
|
+
collapsed,
|
|
662
|
+
onCollapse,
|
|
663
|
+
},
|
|
664
|
+
matchMenuKeys,
|
|
665
|
+
);
|
|
666
|
+
|
|
667
|
+
// render footer dom
|
|
668
|
+
const footerDom = footerRender({
|
|
669
|
+
isMobile,
|
|
670
|
+
collapsed,
|
|
671
|
+
...defaultProps,
|
|
672
|
+
});
|
|
673
|
+
|
|
674
|
+
const { isChildrenLayout: contextIsChildrenLayout } =
|
|
675
|
+
useContext(RouteContext);
|
|
676
|
+
|
|
677
|
+
// 如果 props 中定义,以 props 为准
|
|
678
|
+
const isChildrenLayout =
|
|
679
|
+
propsIsChildrenLayout !== undefined
|
|
680
|
+
? propsIsChildrenLayout
|
|
681
|
+
: contextIsChildrenLayout;
|
|
682
|
+
|
|
683
|
+
const proLayoutClassName = `${prefixCls}-layout`;
|
|
684
|
+
const { wrapSSR, hashId } = useStyle(proLayoutClassName);
|
|
685
|
+
|
|
686
|
+
// gen className
|
|
687
|
+
const className = classNames(
|
|
688
|
+
props.className,
|
|
689
|
+
hashId,
|
|
690
|
+
'ant-design-pro',
|
|
691
|
+
proLayoutClassName,
|
|
692
|
+
{
|
|
693
|
+
[`screen-${colSize}`]: colSize,
|
|
694
|
+
[`${proLayoutClassName}-top-menu`]: propsLayout === 'top',
|
|
695
|
+
[`${proLayoutClassName}-is-children`]: isChildrenLayout,
|
|
696
|
+
[`${proLayoutClassName}-fix-siderbar`]: fixSiderbar,
|
|
697
|
+
[`${proLayoutClassName}-${propsLayout}`]: propsLayout,
|
|
698
|
+
},
|
|
699
|
+
);
|
|
700
|
+
|
|
701
|
+
/** 计算 slider 的宽度 */
|
|
702
|
+
const leftSiderWidth = getPaddingInlineStart(
|
|
703
|
+
!!hasLeftPadding,
|
|
704
|
+
collapsed,
|
|
705
|
+
siderWidth,
|
|
706
|
+
);
|
|
707
|
+
|
|
708
|
+
// siderMenuDom 为空的时候,不需要 padding
|
|
709
|
+
const genLayoutStyle: CSSProperties = {
|
|
710
|
+
position: 'relative',
|
|
711
|
+
};
|
|
712
|
+
|
|
713
|
+
// if is some layout children, don't need min height
|
|
714
|
+
if (isChildrenLayout || (contentStyle && contentStyle.minHeight)) {
|
|
715
|
+
genLayoutStyle.minHeight = 0;
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
/** 页面切换的时候触发 */
|
|
719
|
+
useEffect(() => {
|
|
720
|
+
props.onPageChange?.(props.location);
|
|
721
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
722
|
+
}, [location.pathname, location.pathname?.search]);
|
|
723
|
+
|
|
724
|
+
const [hasFooterToolbar, setHasFooterToolbar] = useState(false);
|
|
725
|
+
/**
|
|
726
|
+
* 使用number是因为多标签页的时候有多个 PageContainer,只有有任意一个就应该展示这个className
|
|
727
|
+
*/
|
|
728
|
+
const [hasPageContainer, setHasPageContainer] = useState(0);
|
|
729
|
+
|
|
730
|
+
useDocumentTitle(pageTitleInfo, props.title || false);
|
|
731
|
+
|
|
732
|
+
const { token } = useContext(ProProvider);
|
|
733
|
+
|
|
734
|
+
const bgImgStyleList = useMemo(() => {
|
|
735
|
+
if (bgLayoutImgList && bgLayoutImgList.length > 0) {
|
|
736
|
+
return bgLayoutImgList?.map((item, index) => {
|
|
737
|
+
return (
|
|
738
|
+
<img
|
|
739
|
+
key={index}
|
|
740
|
+
src={item.src}
|
|
741
|
+
style={{
|
|
742
|
+
position: 'absolute',
|
|
743
|
+
...item,
|
|
744
|
+
}}
|
|
745
|
+
/>
|
|
746
|
+
);
|
|
747
|
+
});
|
|
748
|
+
}
|
|
749
|
+
return null;
|
|
750
|
+
}, [bgLayoutImgList]);
|
|
751
|
+
|
|
752
|
+
return wrapSSR(
|
|
753
|
+
<RouteContext.Provider
|
|
754
|
+
value={{
|
|
755
|
+
...defaultProps,
|
|
756
|
+
breadcrumb: breadcrumbProps,
|
|
757
|
+
menuData,
|
|
758
|
+
isMobile,
|
|
759
|
+
collapsed,
|
|
760
|
+
hasPageContainer,
|
|
761
|
+
setHasPageContainer,
|
|
762
|
+
isChildrenLayout: true,
|
|
763
|
+
title: pageTitleInfo.pageName,
|
|
764
|
+
hasSiderMenu: !!siderMenuDom,
|
|
765
|
+
hasHeader: !!headerDom,
|
|
766
|
+
siderWidth: leftSiderWidth,
|
|
767
|
+
hasFooter: !!footerDom,
|
|
768
|
+
hasFooterToolbar,
|
|
769
|
+
setHasFooterToolbar,
|
|
770
|
+
pageTitleInfo,
|
|
771
|
+
matchMenus,
|
|
772
|
+
matchMenuKeys,
|
|
773
|
+
currentMenu,
|
|
774
|
+
}}
|
|
775
|
+
>
|
|
776
|
+
{props.pure ? (
|
|
777
|
+
<>{children}</>
|
|
778
|
+
) : (
|
|
779
|
+
<div className={className}>
|
|
780
|
+
{bgImgStyleList || token.layout?.bgLayout ? (
|
|
781
|
+
<div
|
|
782
|
+
className={classNames(`${proLayoutClassName}-bg-list`, hashId)}
|
|
783
|
+
>
|
|
784
|
+
{bgImgStyleList}
|
|
785
|
+
</div>
|
|
786
|
+
) : null}
|
|
787
|
+
<Layout
|
|
788
|
+
style={{
|
|
789
|
+
minHeight: '100%',
|
|
790
|
+
// hack style
|
|
791
|
+
flexDirection: siderMenuDom ? 'row' : undefined,
|
|
792
|
+
...style,
|
|
793
|
+
}}
|
|
794
|
+
>
|
|
795
|
+
<ConfigProvider
|
|
796
|
+
// @ts-ignore
|
|
797
|
+
theme={{
|
|
798
|
+
hashed: isNeedOpenHash(),
|
|
799
|
+
token: {
|
|
800
|
+
controlHeightLG:
|
|
801
|
+
token.layout?.sider?.menuHeight || token?.controlHeightLG,
|
|
802
|
+
},
|
|
803
|
+
components: {
|
|
804
|
+
Menu: coverToNewToken({
|
|
805
|
+
colorItemBg:
|
|
806
|
+
token.layout?.sider?.colorMenuBackground || 'transparent',
|
|
807
|
+
colorSubItemBg:
|
|
808
|
+
token.layout?.sider?.colorMenuBackground || 'transparent',
|
|
809
|
+
radiusItem: token.borderRadius,
|
|
810
|
+
|
|
811
|
+
colorItemBgSelected:
|
|
812
|
+
token.layout?.sider?.colorBgMenuItemSelected ||
|
|
813
|
+
token?.colorBgTextHover,
|
|
814
|
+
colorItemBgHover:
|
|
815
|
+
token.layout?.sider?.colorBgMenuItemHover ||
|
|
816
|
+
token?.colorBgTextHover,
|
|
817
|
+
colorItemBgActive:
|
|
818
|
+
token.layout?.sider?.colorBgMenuItemActive ||
|
|
819
|
+
token?.colorBgTextActive,
|
|
820
|
+
colorItemBgSelectedHorizontal:
|
|
821
|
+
token.layout?.sider?.colorBgMenuItemSelected ||
|
|
822
|
+
token?.colorBgTextHover,
|
|
823
|
+
colorActiveBarWidth: 0,
|
|
824
|
+
colorActiveBarHeight: 0,
|
|
825
|
+
colorActiveBarBorderSize: 0,
|
|
826
|
+
colorItemText:
|
|
827
|
+
token.layout?.sider?.colorTextMenu ||
|
|
828
|
+
token?.colorTextSecondary,
|
|
829
|
+
colorItemTextHover:
|
|
830
|
+
token.layout?.sider?.colorTextMenuItemHover ||
|
|
831
|
+
'rgba(0, 0, 0, 0.85)', // 悬浮态
|
|
832
|
+
colorItemTextSelected:
|
|
833
|
+
token.layout?.sider?.colorTextMenuSelected ||
|
|
834
|
+
'rgba(0, 0, 0, 1)',
|
|
835
|
+
popupBg: token?.colorBgElevated,
|
|
836
|
+
subMenuItemBg: token?.colorBgElevated,
|
|
837
|
+
darkSubMenuItemBg: 'transparent',
|
|
838
|
+
darkPopupBg: token?.colorBgElevated,
|
|
839
|
+
}),
|
|
840
|
+
},
|
|
841
|
+
}}
|
|
842
|
+
>
|
|
843
|
+
{siderMenuDom}
|
|
844
|
+
</ConfigProvider>
|
|
845
|
+
<div
|
|
846
|
+
style={genLayoutStyle}
|
|
847
|
+
className={`${proLayoutClassName}-container ${hashId}`.trim()}
|
|
848
|
+
>
|
|
849
|
+
{headerDom}
|
|
850
|
+
<WrapContent
|
|
851
|
+
hasPageContainer={hasPageContainer}
|
|
852
|
+
isChildrenLayout={isChildrenLayout}
|
|
853
|
+
{...rest}
|
|
854
|
+
hasHeader={!!headerDom}
|
|
855
|
+
prefixCls={proLayoutClassName}
|
|
856
|
+
style={contentStyle}
|
|
857
|
+
>
|
|
858
|
+
{loading ? <PageLoading /> : children}
|
|
859
|
+
</WrapContent>
|
|
860
|
+
{footerDom}
|
|
861
|
+
{hasFooterToolbar && (
|
|
862
|
+
<div
|
|
863
|
+
className={`${proLayoutClassName}-has-footer`}
|
|
864
|
+
style={{
|
|
865
|
+
height: 64,
|
|
866
|
+
marginBlockStart:
|
|
867
|
+
token.layout?.pageContainer
|
|
868
|
+
?.paddingBlockPageContainerContent,
|
|
869
|
+
}}
|
|
870
|
+
/>
|
|
871
|
+
)}
|
|
872
|
+
</div>
|
|
873
|
+
</Layout>
|
|
874
|
+
</div>
|
|
875
|
+
)}
|
|
876
|
+
</RouteContext.Provider>,
|
|
877
|
+
);
|
|
878
|
+
};
|
|
879
|
+
|
|
880
|
+
const ProLayout: React.FC<ProLayoutProps> = (props) => {
|
|
881
|
+
const { colorPrimary } = props;
|
|
882
|
+
|
|
883
|
+
const darkProps =
|
|
884
|
+
props.navTheme !== undefined
|
|
885
|
+
? {
|
|
886
|
+
dark: props.navTheme === 'realDark',
|
|
887
|
+
}
|
|
888
|
+
: {};
|
|
889
|
+
|
|
890
|
+
return (
|
|
891
|
+
<ConfigProvider
|
|
892
|
+
theme={
|
|
893
|
+
colorPrimary
|
|
894
|
+
? {
|
|
895
|
+
token: {
|
|
896
|
+
colorPrimary: colorPrimary,
|
|
897
|
+
},
|
|
898
|
+
}
|
|
899
|
+
: undefined
|
|
900
|
+
}
|
|
901
|
+
>
|
|
902
|
+
<ProConfigProvider
|
|
903
|
+
{...darkProps}
|
|
904
|
+
token={props.token}
|
|
905
|
+
prefixCls={props.prefixCls}
|
|
906
|
+
>
|
|
907
|
+
<BaseProLayout
|
|
908
|
+
logo={<Logo />}
|
|
909
|
+
{...defaultSettings}
|
|
910
|
+
location={isBrowser() ? window.location : undefined}
|
|
911
|
+
{...props}
|
|
912
|
+
/>
|
|
913
|
+
</ProConfigProvider>
|
|
914
|
+
</ConfigProvider>
|
|
915
|
+
);
|
|
916
|
+
};
|
|
917
|
+
|
|
918
|
+
export { ProLayout };
|