@flatbiz/antd 4.2.35 → 4.2.37
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/esm/button-operate/index.js +1 -1
- package/esm/button-operate-6add2cbf.js +3 -0
- package/esm/button-operate-6add2cbf.js.map +1 -0
- package/esm/cascader-wrapper/index.js +1 -1
- package/esm/cascader-wrapper/index.js.map +1 -1
- package/esm/cascader-wrapper-7f1eed71.js +3 -0
- package/esm/cascader-wrapper-7f1eed71.js.map +1 -0
- package/esm/cell-render-03055c65.js +3 -0
- package/esm/cell-render-03055c65.js.map +1 -0
- package/esm/center-a4dfda6f.js +3 -0
- package/esm/center-a4dfda6f.js.map +1 -0
- package/esm/checkbox-wrapper/index.js +1 -1
- package/esm/checkbox-wrapper/index.js.map +1 -1
- package/esm/checkbox-wrapper-018a5c59.js +3 -0
- package/esm/checkbox-wrapper-018a5c59.js.map +1 -0
- package/esm/css-node-hover/index.js +1 -1
- package/esm/css-node-hover/index.js.map +1 -1
- package/esm/css-node-hover-ed7b9860.js +3 -0
- package/esm/css-node-hover-ed7b9860.js.map +1 -0
- package/esm/date-range-picker-wrapper-form-item/index.js +1 -1
- package/esm/date-range-picker-wrapper-form-item/index.js.map +1 -1
- package/esm/date-range-picker-wrapper-form-item-688cf465.js +3 -0
- package/esm/date-range-picker-wrapper-form-item-688cf465.js.map +1 -0
- package/esm/dialog-alert/index.js +1 -1
- package/esm/dialog-alert/index.js.map +1 -1
- package/esm/dialog-alert-0ca83448.js +3 -0
- package/esm/dialog-alert-0ca83448.js.map +1 -0
- package/esm/dialog-drawer/index.js +1 -1
- package/esm/dialog-drawer/index.js.map +1 -1
- package/esm/dialog-drawer-525a0bc3.js +3 -0
- package/esm/dialog-drawer-525a0bc3.js.map +1 -0
- package/esm/dialog-loading/index.js +1 -1
- package/esm/dialog-loading/index.js.map +1 -1
- package/esm/dialog-loading-16bd1baa.js +3 -0
- package/esm/dialog-loading-16bd1baa.js.map +1 -0
- package/esm/drawer-wrapper/index.js +1 -1
- package/esm/drawer-wrapper/index.js.map +1 -1
- package/esm/drawer-wrapper-9af2f178.js +3 -0
- package/esm/drawer-wrapper-9af2f178.js.map +1 -0
- package/esm/easy-table/index.js +1 -1
- package/esm/easy-table/index.js.map +1 -1
- package/esm/editable-field/index.js +1 -1
- package/esm/editable-field/index.js.map +1 -1
- package/esm/editable-field-7f30db8e.js +3 -0
- package/esm/editable-field-7f30db8e.js.map +1 -0
- package/esm/editable-field-provider/index.js +1 -1
- package/esm/editable-field-provider/index.js.map +1 -1
- package/esm/editable-field-provider-20963c3e.js +3 -0
- package/esm/editable-field-provider-20963c3e.js.map +1 -0
- package/esm/editable-table/index.js +1 -1
- package/esm/editable-table/index.js.map +1 -1
- package/esm/editable-table-6bd8df15.js +3 -0
- package/esm/editable-table-6bd8df15.js.map +1 -0
- package/esm/editor-wrapper/index.js +1 -1
- package/esm/editor-wrapper/index.js.map +1 -1
- package/esm/editor-wrapper-ff6e75b7.js +3 -0
- package/esm/editor-wrapper-ff6e75b7.js.map +1 -0
- package/esm/file-import/index.js +1 -1
- package/esm/file-import/index.js.map +1 -1
- package/esm/file-import-890a1df9.js +3 -0
- package/esm/file-import-890a1df9.js.map +1 -0
- package/esm/form-item-hidden/index.js +1 -1
- package/esm/form-item-hidden/index.js.map +1 -1
- package/esm/form-item-hidden-45541774.js +3 -0
- package/esm/form-item-hidden-45541774.js.map +1 -0
- package/esm/form-item-wrapper/index.js +1 -1
- package/esm/form-item-wrapper/index.js.map +1 -1
- package/esm/form-item-wrapper-dfe2ebd9.js +3 -0
- package/esm/form-item-wrapper-dfe2ebd9.js.map +1 -0
- package/esm/gap/index.js +1 -1
- package/esm/gap/index.js.map +1 -1
- package/esm/gap-284e1f59.js +3 -0
- package/esm/gap-284e1f59.js.map +1 -0
- package/esm/in-view-448ba714.js +3 -0
- package/esm/in-view-448ba714.js.map +1 -0
- package/esm/index.css +0 -0
- package/esm/index.js +80 -0
- package/esm/index.js.map +1 -0
- package/esm/label-value-layout/index.js +1 -1
- package/esm/label-value-layout/index.js.map +1 -1
- package/esm/label-value-layout-beb35b0d.js +3 -0
- package/esm/label-value-layout-beb35b0d.js.map +1 -0
- package/esm/modal-action/index.js +1 -1
- package/esm/modal-action/index.js.map +1 -1
- package/esm/modal-action-5c5ca8a7.js +3 -0
- package/esm/modal-action-5c5ca8a7.js.map +1 -0
- package/esm/modal-wrapper/index.js +1 -1
- package/esm/modal-wrapper/index.js.map +1 -1
- package/esm/modal-wrapper-ff8df98b.js +3 -0
- package/esm/modal-wrapper-ff8df98b.js.map +1 -0
- package/esm/page-fixed-footer/index.js +1 -1
- package/esm/page-fixed-footer/index.js.map +1 -1
- package/esm/page-fixed-footer-5fa10112.js +3 -0
- package/esm/page-fixed-footer-5fa10112.js.map +1 -0
- package/esm/page404/index.js +1 -1
- package/esm/page404/index.js.map +1 -1
- package/esm/page404-f087129a.js +3 -0
- package/esm/page404-f087129a.js.map +1 -0
- package/esm/permission/index.js +1 -1
- package/esm/permission/index.js.map +1 -1
- package/esm/permission-a1c99455.js +3 -0
- package/esm/permission-a1c99455.js.map +1 -0
- package/esm/radio-group-wrapper/index.js +1 -1
- package/esm/radio-group-wrapper/index.js.map +1 -1
- package/esm/radio-group-wrapper-b34746d1.js +3 -0
- package/esm/radio-group-wrapper-b34746d1.js.map +1 -0
- package/esm/relation-tree/index.js +1 -1
- package/esm/relation-tree/index.js.map +1 -1
- package/esm/relation-tree-7bec12bd.js +3 -0
- package/esm/relation-tree-7bec12bd.js.map +1 -0
- package/esm/rich-text-viewer/index.js +1 -1
- package/esm/rich-text-viewer/index.js.map +1 -1
- package/esm/rich-text-viewer-5cbe01e9.js +3 -0
- package/esm/rich-text-viewer-5cbe01e9.js.map +1 -0
- package/esm/roll-location-center/index.js +1 -1
- package/esm/roll-location-center/index.js.map +1 -1
- package/esm/roll-location-in-view/index.js +1 -1
- package/esm/roll-location-in-view/index.js.map +1 -1
- package/esm/rule-describe/index.js +1 -1
- package/esm/rule-describe/index.js.map +1 -1
- package/esm/rule-describe-b4a8e831.js +3 -0
- package/esm/rule-describe-b4a8e831.js.map +1 -0
- package/esm/selector-wrapper-search/index.js +1 -1
- package/esm/selector-wrapper-search/index.js.map +1 -1
- package/esm/selector-wrapper-search-aad145b5.js +3 -0
- package/esm/selector-wrapper-search-aad145b5.js.map +1 -0
- package/esm/selector-wrapper-simple/index.js +1 -1
- package/esm/selector-wrapper-simple/index.js.map +1 -1
- package/esm/selector-wrapper-simple-49384d37.js +3 -0
- package/esm/selector-wrapper-simple-49384d37.js.map +1 -0
- package/esm/simple-layout/index.css +1 -1
- package/esm/simple-layout/index.js +1 -1
- package/esm/simple-layout-08f90dab.js +3 -0
- package/esm/simple-layout-08f90dab.js.map +1 -0
- package/esm/sms-count-down/index.js +1 -1
- package/esm/sms-count-down/index.js.map +1 -1
- package/esm/sms-count-down-c2609386.js +3 -0
- package/esm/sms-count-down-c2609386.js.map +1 -0
- package/esm/switch-wrapper/index.js +1 -1
- package/esm/switch-wrapper/index.js.map +1 -1
- package/esm/switch-wrapper-f20b9a58.js +3 -0
- package/esm/switch-wrapper-f20b9a58.js.map +1 -0
- package/esm/table-cell-render/index.js +1 -1
- package/esm/table-cell-render/index.js.map +1 -1
- package/esm/table-title-tooltip/index.js +1 -1
- package/esm/table-title-tooltip/index.js.map +1 -1
- package/esm/tabs-wrapper/index.css +1 -1
- package/esm/tabs-wrapper/index.js +1 -1
- package/esm/tabs-wrapper/index.js.map +1 -1
- package/esm/tabs-wrapper-0a2da713.js +3 -0
- package/esm/tabs-wrapper-0a2da713.js.map +1 -0
- package/esm/tag-group/index.js +1 -1
- package/esm/tag-group/index.js.map +1 -1
- package/esm/tag-group-4fbcaa14.js +3 -0
- package/esm/tag-group-4fbcaa14.js.map +1 -0
- package/esm/tag-wrapper/index.js +1 -1
- package/esm/tag-wrapper/index.js.map +1 -1
- package/esm/tag-wrapper-6d8b505e.js +3 -0
- package/esm/tag-wrapper-6d8b505e.js.map +1 -0
- package/esm/time-picker-wrapper/index.js +1 -1
- package/esm/time-picker-wrapper/index.js.map +1 -1
- package/esm/time-picker-wrapper-f1d26d96.js +3 -0
- package/esm/time-picker-wrapper-f1d26d96.js.map +1 -0
- package/esm/time-range-picker-wrapper-form-item/index.js +1 -1
- package/esm/time-range-picker-wrapper-form-item/index.js.map +1 -1
- package/esm/time-range-picker-wrapper-form-item-9df6c0f4.js +3 -0
- package/esm/time-range-picker-wrapper-form-item-9df6c0f4.js.map +1 -0
- package/esm/title-render-2874a932.js +3 -0
- package/esm/title-render-2874a932.js.map +1 -0
- package/esm/tree-selector-wrapper/index.js +1 -1
- package/esm/tree-selector-wrapper/index.js.map +1 -1
- package/esm/tree-selector-wrapper-9cd9da23.js +3 -0
- package/esm/tree-selector-wrapper-9cd9da23.js.map +1 -0
- package/esm/tree-wrapper/index.css +1 -1
- package/esm/tree-wrapper/index.js +1 -1
- package/esm/tree-wrapper/index.js.map +1 -1
- package/esm/tree-wrapper-85aa72d7.js +3 -0
- package/esm/tree-wrapper-85aa72d7.js.map +1 -0
- package/index.d.ts +36 -0
- package/package.json +8 -8
- package/esm/button-operate-04d9185b.js +0 -3
- package/esm/button-operate-04d9185b.js.map +0 -1
- package/esm/simple-layout-1676e586.js +0 -3
- package/esm/simple-layout-1676e586.js.map +0 -1
package/esm/tag-group/index.js
CHANGED
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
import './../fba-hooks/index.css';
|
|
3
3
|
import './index.css';
|
|
4
4
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
5
|
-
|
|
5
|
+
export{T as TagGroup}from"../tag-group-4fbcaa14.js";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"antd";import"../fba-hooks/index.js";import"@dimjs/lang/cjs/is-array";import"@wove/react/cjs/hooks";import"react";import"../use-responsive-point-21b8c601.js";import"react/jsx-runtime";
|
|
6
6
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import{a as r}from"./_rollupPluginBabelHelpers-1f4d8910.js";import{Space as o,Tag as a}from"antd";import{fbaHooks as e}from"./fba-hooks/index.js";import{jsx as l}from"react/jsx-runtime";var i=function i(t){var n=e.useThemeToken();return l(o,r({wrap:true,size:5},t.spaceProps,{children:t.dataList.map((function(r,o){var e;var i=r.color||((e=t.colorMap)==null?void 0:e[r.value])||n.colorPrimary;return l(a,{color:i,children:r.label},o)}))}))};export{i as T};
|
|
3
|
+
//# sourceMappingURL=tag-group-4fbcaa14.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-group-4fbcaa14.js","sources":["@flatbiz/antd/src/tag-group/tag-group.tsx"],"sourcesContent":["import { Space, SpaceProps, Tag } from 'antd';\nimport { FC } from 'react';\nimport { fbaHooks } from '../fba-hooks';\n\ntype TagGroupDataItem = { label: string; value: string | number; color?: string };\n\nexport type TagGroupProps = {\n dataList: TagGroupDataItem[];\n /**\n * 颜色配置数据,例如:{ 1:'red', 2: 'blue'} key值与 dataList中value相同\n */\n colorMap?: Record<string, string>;\n spaceProps?: SpaceProps;\n};\n\n/**\n * Tag 列表显示\n */\nexport const TagGroup: FC<TagGroupProps> = (props) => {\n const theme = fbaHooks.useThemeToken();\n return (\n <Space wrap size={5} {...props.spaceProps}>\n {props.dataList.map((item, index) => {\n const color = item.color || props.colorMap?.[item.value] || theme.colorPrimary;\n return (\n <Tag color={color} key={index}>\n {item.label}\n </Tag>\n );\n })}\n </Space>\n );\n};\n"],"names":["TagGroup","props","theme","fbaHooks","useThemeToken","_jsx","Space","_extends","wrap","size","spaceProps","children","dataList","map","item","index","_props$colorMap","color","colorMap","value","colorPrimary","Tag","label"],"mappings":";8LAkBaA,EAA8B,SAA9BA,EAA+BC,GAC1C,IAAMC,EAAQC,EAASC,gBACvB,OACEC,EAACC,EAAKC,EAAA,CAACC,KAAI,KAACC,KAAM,GAAOR,EAAMS,WAAU,CAAAC,SACtCV,EAAMW,SAASC,KAAI,SAACC,EAAMC,GAAU,IAAAC,EACnC,IAAMC,EAAQH,EAAKG,SAAKD,EAAIf,EAAMiB,WAANF,UAAAA,EAAAA,EAAiBF,EAAKK,SAAUjB,EAAMkB,aAClE,OACEf,EAACgB,EAAG,CAACJ,MAAOA,EAAMN,SACfG,EAAKQ,OADgBP,QAOlC"}
|
package/esm/tag-wrapper/index.js
CHANGED
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
import './../fba-hooks/index.css';
|
|
3
3
|
import './index.css';
|
|
4
4
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
5
|
-
|
|
5
|
+
export{T as TagWrapper}from"../tag-wrapper-6d8b505e.js";import"@ant-design/icons/es/icons/LoadingOutlined";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"@dimjs/lang/cjs/is-promise";import"@wove/react/cjs/hooks";import"@flatbiz/utils";import"antd";import"react";import"../fba-hooks/index.js";import"@dimjs/lang/cjs/is-array";import"../use-responsive-point-21b8c601.js";import"react/jsx-runtime";
|
|
6
6
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import r from"@ant-design/icons/es/icons/LoadingOutlined";import{_ as o,a as i}from"./_rollupPluginBabelHelpers-1f4d8910.js";import{isPromise as e}from"@dimjs/lang/cjs/is-promise";import{hooks as n}from"@wove/react/cjs/hooks";import{isUndefinedOrNull as t}from"@flatbiz/utils";import{Tag as a}from"antd";import{useState as l}from"react";import{fbaHooks as s}from"./fba-hooks/index.js";import{jsxs as c,jsx as f}from"react/jsx-runtime";var m=["loading","children","debounceDuration","style"];var u=function u(d){var p=d.loading,v=d.children,h=d.debounceDuration,g=d.style,b=o(d,m);var j=l(false),k=j[0],y=j[1];var C=t(h)?500:h;s.useEffectCustom((function(){if(!t(p)){y(p||false)}}),[p]);var x=n.useDebounceClick((function(r){var o=d.onClick;if(!o){return}var i=o(r);if(i&&e(i)){y(true);i.catch((function(r){console.error(r)})).finally((function(){y(false)}))}}),C);return c(a,i({},b,{onClick:x,style:i({cursor:d.onClick?"pointer":"default"},g),children:[k&&f("div",{className:"tw-center-loading",children:f(r,{})}),k?f("div",{style:{opacity:.5},children:v}):v]}))};export{u as T};
|
|
3
|
+
//# sourceMappingURL=tag-wrapper-6d8b505e.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-wrapper-6d8b505e.js","sources":["@flatbiz/antd/src/tag-wrapper/tag-wrapper.tsx"],"sourcesContent":["import { LoadingOutlined } from '@ant-design/icons';\nimport { isPromise } from '@dimjs/lang';\nimport { isUndefinedOrNull, TAny } from '@flatbiz/utils';\nimport { hooks } from '@wove/react';\nimport { Tag, TagProps } from 'antd';\nimport { useState } from 'react';\nimport { fbaHooks } from '../fba-hooks';\nimport './style.less';\n\nexport type TagWrapperProps = Omit<TagProps, 'onClick'> & {\n onClick?: (e: React.MouseEvent<HTMLElement>) => Promise<TAny> | void;\n loading?: boolean;\n // 重复点击间隙,单位毫秒 默认值:500\n debounceDuration?: number;\n};\n\n/**\n * 为 Tag 添加 loading 效果\n */\nexport const TagWrapper = (props: TagWrapperProps) => {\n const { loading, children, debounceDuration, style, ...otherProps } = props;\n\n const [innerLoading, setLoading] = useState(false);\n const debounceDurationMew = isUndefinedOrNull(debounceDuration) ? 500 : debounceDuration;\n\n fbaHooks.useEffectCustom(() => {\n if (!isUndefinedOrNull(loading)) {\n setLoading(loading || false);\n }\n }, [loading]);\n\n const onClick = hooks.useDebounceClick((e) => {\n const onClick = props.onClick;\n if (!onClick) {\n return;\n }\n const result = onClick(e);\n if (result && isPromise(result)) {\n setLoading(true);\n result\n .catch((error) => {\n console.error(error);\n })\n .finally(() => {\n setLoading(false);\n });\n }\n }, debounceDurationMew);\n\n return (\n <Tag\n {...otherProps}\n onClick={onClick}\n style={{ cursor: props.onClick ? 'pointer' : 'default', ...style }}\n >\n {innerLoading && (\n <div className=\"tw-center-loading\">\n <LoadingOutlined />\n </div>\n )}\n {innerLoading ? <div style={{ opacity: 0.5 }}>{children}</div> : children}\n </Tag>\n );\n};\n"],"names":["TagWrapper","props","loading","children","debounceDuration","style","otherProps","_objectWithoutPropertiesLoose","_excluded","_useState","useState","innerLoading","setLoading","debounceDurationMew","isUndefinedOrNull","fbaHooks","useEffectCustom","onClick","_hooks","useDebounceClick","e","result","_isPromise","catch","error","console","finally","_jsxs","Tag","_extends","cursor","_jsx","className","_LoadingOutlined","opacity"],"mappings":";+eAmBaA,EAAa,SAAbA,EAAcC,GACzB,IAAQC,EAA8DD,EAA9DC,QAASC,EAAqDF,EAArDE,SAAUC,EAA2CH,EAA3CG,iBAAkBC,EAAyBJ,EAAzBI,MAAUC,EAAUC,EAAKN,EAAKO,GAE3E,IAAAC,EAAmCC,EAAS,OAArCC,EAAYF,EAAA,GAAEG,EAAUH,EAAA,GAC/B,IAAMI,EAAsBC,EAAkBV,GAAoB,IAAMA,EAExEW,EAASC,iBAAgB,WACvB,IAAKF,EAAkBZ,GAAU,CAC/BU,EAAWV,GAAW,MACxB,CACF,GAAG,CAACA,IAEJ,IAAMe,EAAUC,EAAMC,kBAAiB,SAACC,GACtC,IAAMH,EAAUhB,EAAMgB,QACtB,IAAKA,EAAS,CACZ,MACF,CACA,IAAMI,EAASJ,EAAQG,GACvB,GAAIC,GAAUC,EAAUD,GAAS,CAC/BT,EAAW,MACXS,EACGE,OAAM,SAACC,GACNC,QAAQD,MAAMA,EAChB,IACCE,SAAQ,WACPd,EAAW,MACb,GACJ,CACD,GAAEC,GAEH,OACEc,EAACC,EAAGC,KACEvB,EAAU,CACdW,QAASA,EACTZ,MAAKwB,EAAA,CAAIC,OAAQ7B,EAAMgB,QAAU,UAAY,WAAcZ,GAAQF,SAAA,CAElEQ,GACCoB,EAAA,MAAA,CAAKC,UAAU,oBAAmB7B,SAChC4B,EAAAE,EAAA,MAGHtB,EAAeoB,EAAA,MAAA,CAAK1B,MAAO,CAAE6B,QAAS,IAAM/B,SAAEA,IAAkBA,KAGvE"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* eslint-disable */
|
|
2
2
|
import './index.css';
|
|
3
3
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
4
|
-
|
|
4
|
+
export{T as TimePickerWrapper}from"../time-picker-wrapper-f1d26d96.js";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"@wove/react/cjs/hooks";import"antd";import"dayjs";import"dayjs/plugin/isSameOrAfter";import"dayjs/plugin/isSameOrBefore";import"react";import"../time-53b3f55f.js";import"react/jsx-runtime";
|
|
5
5
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import{_ as e,a as r}from"./_rollupPluginBabelHelpers-1f4d8910.js";import{hooks as i}from"@wove/react/cjs/hooks";import{TimePicker as a}from"antd";import n from"dayjs";import o from"dayjs/plugin/isSameOrAfter";import t from"dayjs/plugin/isSameOrBefore";import{useMemo as s}from"react";import{c as d,D as m,g as u,a as f,b as l}from"./time-53b3f55f.js";import{jsx as v}from"react/jsx-runtime";var c=["onChange","disabledTimeConfig","format"];n.extend(t);n.extend(o);var b=function o(t){var b=t.onChange,p=t.disabledTimeConfig,g=t.format,T=e(t,c);var j=p||{},S=j.minTime,x=j.maxTime,C=j.disabledHourList,L=j.disabledMinuteList,h=j.disabledSecondList;var H=g||d.Hms;var D=i.useCallbackRef((function(e,r){if(e){b==null?void 0:b(r)}else{b==null?void 0:b(undefined)}}));var M=s((function(){var e=t.value;if(e){return n(e,H)}return undefined}),[H,t.value]);var O=function e(){var r=n().format(m.YMD);var i={minDateTime:S?n(r+" "+S):undefined,maxDateTime:x?n(r+" "+x):undefined,disabledHourList:C,disabledMinuteList:L,disabledSecondList:h};return{disabledHours:function e(){return u(n(),i)},disabledMinutes:function e(a){return f(n(r+" "+a),i)},disabledSeconds:function e(a,o){return l(n(r+" "+a+":"+o),i)}}};var w=s((function(){var e=n();return e.isSameOrAfter(n(S||"00:00:00",H))&&e.isSameOrBefore(n(x||"23:59:59",H))}),[H,x,S]);return v(a,r({showNow:w,disabledTime:O},T,{value:M,onChange:D,format:H}))};export{b as T};
|
|
3
|
+
//# sourceMappingURL=time-picker-wrapper-f1d26d96.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"time-picker-wrapper-f1d26d96.js","sources":["@flatbiz/antd/src/time-picker-wrapper/time-picker-wrapper.tsx"],"sourcesContent":["import { hooks } from '@wove/react';\nimport { TimePicker, TimePickerProps } from 'antd';\nimport dayjs from 'dayjs';\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter';\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore';\nimport { useMemo } from 'react';\nimport { DayjsDateTypeEnum, DayjsTimeTypeEnum, TDayjsTimeType } from '../_utils/constants';\nimport { getDisabledHour, getDisabledMinute, getDisabledSecond } from '../_utils/time';\ndayjs.extend(isSameOrBefore);\ndayjs.extend(isSameOrAfter);\n\nexport type TimePickerWrapperProps = Omit<TimePickerProps, 'value' | 'onChange' | 'format'> & {\n value?: string;\n onChange?: (value?: string) => void;\n /**\n * 1. minTime、maxTime设置为 DayjsTimeTypeEnum,默认格式:HH:mm:ss\n * 2. minTime、maxTime格式必须与 format 相同\n */\n disabledTimeConfig?: {\n minTime?: TDayjsTimeType;\n maxTime?: TDayjsTimeType;\n /** 禁用 小时 刻度列表,与日期无关 */\n disabledHourList?: number[];\n /** 禁用 分钟 刻度列表,与日期无关 */\n disabledMinuteList?: number[];\n /** 禁用 秒钟 刻度列表,与日期无关 */\n disabledSecondList?: number[];\n };\n format?: TDayjsTimeType;\n};\n/**\n * TimePicker组件包装\n * ```\n * 1. value类型为 string\n * 2. onChange返回类型 string\n * 3. 默认格式化类型 HH:mm:ss\n * 4. 其他格式化类型自定义format\n * 5. 设置disabledTime后,disabledTimeConfig配置将失效\n * ```\n */\nexport const TimePickerWrapper = (props: TimePickerWrapperProps) => {\n const { onChange, disabledTimeConfig, format, ...otherProps } = props;\n const { minTime, maxTime, disabledHourList, disabledMinuteList, disabledSecondList } =\n disabledTimeConfig || {};\n\n const customFormat = format || DayjsTimeTypeEnum.Hms;\n\n const onChangeTime = hooks.useCallbackRef((time: dayjs.Dayjs | null, timeString: string) => {\n if (time) {\n onChange?.(timeString);\n } else {\n onChange?.(undefined);\n }\n });\n\n const timePickerValue = useMemo(() => {\n const value = props.value;\n if (value) {\n return dayjs(value, customFormat);\n }\n return undefined;\n }, [customFormat, props.value]);\n\n const getDisabledTime: TimePickerProps['disabledTime'] = () => {\n const date = dayjs().format(DayjsDateTypeEnum.YMD);\n const options = {\n minDateTime: minTime ? dayjs(`${date} ${minTime}`) : undefined,\n maxDateTime: maxTime ? dayjs(`${date} ${maxTime}`) : undefined,\n disabledHourList,\n disabledMinuteList,\n disabledSecondList,\n };\n return {\n disabledHours: () => {\n return getDisabledHour(dayjs(), options);\n },\n disabledMinutes: (hour: number) => {\n return getDisabledMinute(dayjs(`${date} ${hour}`), options);\n },\n disabledSeconds: (hour: number, minute: number) => {\n return getDisabledSecond(dayjs(`${date} ${hour}:${minute}`), options);\n },\n };\n };\n\n const showNow = useMemo(() => {\n const now = dayjs();\n return (\n now.isSameOrAfter(dayjs(minTime || '00:00:00', customFormat)) &&\n now.isSameOrBefore(dayjs(maxTime || '23:59:59', customFormat))\n );\n }, [customFormat, maxTime, minTime]);\n\n return (\n <TimePicker\n showNow={showNow}\n disabledTime={getDisabledTime}\n {...otherProps}\n value={timePickerValue}\n onChange={onChangeTime}\n format={customFormat}\n />\n );\n};\n"],"names":["dayjs","extend","isSameOrBefore","isSameOrAfter","TimePickerWrapper","props","onChange","disabledTimeConfig","format","otherProps","_objectWithoutPropertiesLoose","_excluded","_ref","minTime","maxTime","disabledHourList","disabledMinuteList","disabledSecondList","customFormat","DayjsTimeTypeEnum","Hms","onChangeTime","_hooks","useCallbackRef","time","timeString","undefined","timePickerValue","useMemo","value","getDisabledTime","date","DayjsDateTypeEnum","YMD","options","minDateTime","maxDateTime","disabledHours","getDisabledHour","disabledMinutes","hour","getDisabledMinute","disabledSeconds","minute","getDisabledSecond","showNow","now","_jsx","TimePicker","_extends","disabledTime"],"mappings":";ybAQAA,EAAMC,OAAOC,GACbF,EAAMC,OAAOE,OA+BAC,EAAoB,SAApBA,EAAqBC,GAChC,IAAQC,EAAwDD,EAAxDC,SAAUC,EAA8CF,EAA9CE,mBAAoBC,EAA0BH,EAA1BG,OAAWC,EAAUC,EAAKL,EAAKM,GACrE,IAAAC,EACEL,GAAsB,CAAE,EADlBM,EAAOD,EAAPC,QAASC,EAAOF,EAAPE,QAASC,EAAgBH,EAAhBG,iBAAkBC,EAAkBJ,EAAlBI,mBAAoBC,EAAkBL,EAAlBK,mBAGhE,IAAMC,EAAeV,GAAUW,EAAkBC,IAEjD,IAAMC,EAAeC,EAAMC,gBAAe,SAACC,EAA0BC,GACnE,GAAID,EAAM,CACRlB,GAAAA,UAAAA,EAAAA,EAAWmB,EACb,KAAO,CACLnB,GAAAA,UAAAA,EAAAA,EAAWoB,UACb,CACF,IAEA,IAAMC,EAAkBC,GAAQ,WAC9B,IAAMC,EAAQxB,EAAMwB,MACpB,GAAIA,EAAO,CACT,OAAO7B,EAAM6B,EAAOX,EACtB,CACA,OAAOQ,SACR,GAAE,CAACR,EAAcb,EAAMwB,QAExB,IAAMC,EAAmD,SAAnDA,IACJ,IAAMC,EAAO/B,IAAQQ,OAAOwB,EAAkBC,KAC9C,IAAMC,EAAU,CACdC,YAAatB,EAAUb,EAAS+B,EAAQlB,IAAAA,GAAaa,UACrDU,YAAatB,EAAUd,EAAS+B,EAAQjB,IAAAA,GAAaY,UACrDX,iBAAAA,EACAC,mBAAAA,EACAC,mBAAAA,GAEF,MAAO,CACLoB,cAAe,SAAAA,IACb,OAAOC,EAAgBtC,IAASkC,EACjC,EACDK,gBAAiB,SAAAA,EAACC,GAChB,OAAOC,EAAkBzC,EAAS+B,MAAQS,GAASN,EACpD,EACDQ,gBAAiB,SAAAA,EAACF,EAAcG,GAC9B,OAAOC,EAAkB5C,EAAS+B,EAAI,IAAIS,EAAI,IAAIG,GAAWT,EAC/D,IAIJ,IAAMW,EAAUjB,GAAQ,WACtB,IAAMkB,EAAM9C,IACZ,OACE8C,EAAI3C,cAAcH,EAAMa,GAAW,WAAYK,KAC/C4B,EAAI5C,eAAeF,EAAMc,GAAW,WAAYI,GAEnD,GAAE,CAACA,EAAcJ,EAASD,IAE3B,OACEkC,EAACC,EAAUC,EAAA,CACTJ,QAASA,EACTK,aAAcpB,GACVrB,EAAU,CACdoB,MAAOF,EACPrB,SAAUe,EACVb,OAAQU,IAGd"}
|
|
@@ -4,5 +4,5 @@ import './../time-range-picker-wrapper/index.css';
|
|
|
4
4
|
import './../types/index.css';
|
|
5
5
|
import './index.css';
|
|
6
6
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
7
|
-
|
|
7
|
+
export{T as TimeRangePickerWrapperFormItem}from"../time-range-picker-wrapper-form-item-9df6c0f4.js";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"@wove/react/cjs/hooks";import"@dimjs/lang/cjs/is-array";import"antd";import"react";import"../fba-hooks/index.js";import"../use-responsive-point-21b8c601.js";import"../time-range-picker-wrapper-be9850b5.js";import"dayjs";import"../time-53b3f55f.js";import"react/jsx-runtime";
|
|
8
8
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import{_ as e,a as n}from"./_rollupPluginBabelHelpers-1f4d8910.js";import{hooks as r}from"@wove/react/cjs/hooks";import{isArray as a}from"@dimjs/lang/cjs/is-array";import{Form as t,Input as i}from"antd";import{useMemo as o,useRef as u,forwardRef as l,useImperativeHandle as m}from"react";import{fbaHooks as s}from"./fba-hooks/index.js";import{T as c}from"./time-range-picker-wrapper-be9850b5.js";import{jsxs as v,Fragment as d,jsx as f}from"react/jsx-runtime";var h=["startName","endName","formListName","timeRangePickerWrapperProps"];var p=function i(l){var m=l.startName,p=l.endName,_=l.formListName,C=l.timeRangePickerWrapperProps,j=e(l,h);var P=t.useFormInstance();var k=o((function(){if(a(m)&&a(p)){return m.slice(0,m.length-1).concat("__#invalid_time_"+m[m.length-1]+"_"+p[p.length-1])}return"__#invalid_time_"+m+"_"+p}),[m,p]);var N=o((function(){return _?[].concat(_,m):m}),[m,_]);var F=o((function(){return _?[].concat(_,p):p}),[p,_]);var I=t.useWatch(N,P);var W=t.useWatch(F,P);var b=s.usePrevious(I);var x=s.usePrevious(W);s.useEffectCustom((function(){var e=_?[].concat(_,k):k;if(I&&W){P.setFields([{name:e,value:[I,W]}])}if(b&&x&&!I&&!W){P.setFields([{name:e,value:undefined}])}}),[I,W]);var R=u(null);var w=u(null);var L=r.useCallbackRef((function(e){var n,r;P.setFields([{name:N,value:e==null?void 0:e[0]},{name:F,value:e==null?void 0:e[1]}]);(n=R.current)==null?void 0:n.onChange==null?void 0:n.onChange(e==null?void 0:e[0]);(r=w.current)==null?void 0:r.onChange==null?void 0:r.onChange(e==null?void 0:e[1])}));return v(d,{children:[f(t.Item,{name:m,hidden:true,children:f(g,{ref:R})}),f(t.Item,{name:p,hidden:true,children:f(g,{ref:w})}),f(t.Item,n({},j,{name:k,children:f(c,n({},C,{onChange:L}))}))]})};var g=l((function(e,n){m(n,(function(){return{onChange:function n(r){e.onChange==null?void 0:e.onChange(r)}}}));return f(i,{value:e.value})}));export{p as T};
|
|
3
|
+
//# sourceMappingURL=time-range-picker-wrapper-form-item-9df6c0f4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"time-range-picker-wrapper-form-item-9df6c0f4.js","sources":["@flatbiz/antd/src/time-range-picker-wrapper-form-item/time-range-picker-wrapper-form-item.tsx"],"sourcesContent":["import { isArray } from '@dimjs/lang';\nimport { TAny } from '@flatbiz/utils';\nimport { hooks } from '@wove/react';\nimport { Form, FormItemProps, Input } from 'antd';\nimport { forwardRef, useImperativeHandle, useMemo, useRef } from 'react';\nimport { fbaHooks } from '../fba-hooks';\nimport { TimeRangePickerWrapper, TimeRangePickerWrapperProps } from '../time-range-picker-wrapper';\nimport { FormItemNamePath } from '../types';\n\nexport type TimeRangePickerWrapperFormItemProps = Omit<FormItemProps, 'name'> & {\n /**\n * 开始的时间name\n */\n startName: FormItemNamePath;\n /**\n * 结束的时间name\n */\n endName: FormItemNamePath;\n /**\n * 如果 TimeRangePickerWrapperFormItem 在Form.List场景下 必传\n */\n formListName?: FormItemNamePath;\n timeRangePickerWrapperProps?: Omit<TimeRangePickerWrapperProps, 'onChange'>;\n};\n/**\n * 包含了Form.Item组件的时间区间选择组件\n * ```\n * 1. 时间区间组件可以定义成两个字段操作,不用再通过数组处理\n * 2. 会在form中产生一个 `__#invalid_time_xxxx_xxxx` 的无效字段,可以直接忽略\n * ```\n */\nexport const TimeRangePickerWrapperFormItem = (props: TimeRangePickerWrapperFormItemProps) => {\n const { startName, endName, formListName, timeRangePickerWrapperProps, ...otherProps } = props;\n const form = Form.useFormInstance();\n const bodyName = useMemo(() => {\n if (isArray(startName) && isArray(endName)) {\n return startName\n .slice(0, startName.length - 1)\n .concat(`__#invalid_time_${startName[startName.length - 1]}_${endName[endName.length - 1]}`);\n }\n return `__#invalid_time_${startName}_${endName}`;\n }, [startName, endName]);\n\n const startNameMerge = useMemo(() => {\n return formListName ? ([] as (string | number)[]).concat(formListName, startName) : startName;\n }, [startName, formListName]);\n\n const endNameMerge = useMemo(() => {\n return formListName ? ([] as (string | number)[]).concat(formListName, endName) : endName;\n }, [endName, formListName]);\n\n const startVal = Form.useWatch(startNameMerge, form);\n const endVal = Form.useWatch(endNameMerge, form);\n // const bodyVal = Form.useWatch(bodyName, form);\n\n const preValue1 = fbaHooks.usePrevious(startVal);\n const preValue2 = fbaHooks.usePrevious(endVal);\n\n fbaHooks.useEffectCustom(() => {\n const name = formListName ? ([] as (string | number)[]).concat(formListName, bodyName) : bodyName;\n if (startVal && endVal) {\n form.setFields([{ name, value: [startVal, endVal] }]);\n }\n if (preValue1 && preValue2 && !startVal && !endVal) {\n form.setFields([{ name, value: undefined }]);\n }\n }, [startVal, endVal]);\n\n const reftest = useRef<InputContentRef>(null);\n const reftest2 = useRef<InputContentRef>(null);\n\n const onChange = hooks.useCallbackRef((data) => {\n form.setFields([\n { name: startNameMerge, value: data?.[0] },\n { name: endNameMerge, value: data?.[1] },\n ]);\n // 为了解决 外部Form onValuesChange获取到操作值\n reftest.current?.onChange?.(data?.[0]);\n reftest2.current?.onChange?.(data?.[1]);\n });\n\n return (\n <>\n <Form.Item name={startName} hidden>\n <InputContent ref={reftest} />\n </Form.Item>\n <Form.Item name={endName} hidden>\n <InputContent ref={reftest2} />\n </Form.Item>\n <Form.Item {...otherProps} name={bodyName}>\n <TimeRangePickerWrapper {...timeRangePickerWrapperProps} onChange={onChange} />\n </Form.Item>\n </>\n );\n};\n\ntype InputContentProps = {\n onChange?: (data: TAny) => void;\n value?: string;\n};\n\ntype InputContentRef = {\n onChange?: (data: TAny) => void;\n};\n\nconst InputContent = forwardRef<InputContentRef, InputContentProps>((props, ref) => {\n useImperativeHandle(ref, () => {\n return {\n onChange: (startVal) => {\n props.onChange?.(startVal);\n },\n };\n });\n\n return <Input value={props.value} />;\n});\n"],"names":["TimeRangePickerWrapperFormItem","props","startName","endName","formListName","timeRangePickerWrapperProps","otherProps","_objectWithoutPropertiesLoose","_excluded","form","Form","useFormInstance","bodyName","useMemo","_isArray","slice","length","concat","startNameMerge","endNameMerge","startVal","useWatch","endVal","preValue1","fbaHooks","usePrevious","preValue2","useEffectCustom","name","setFields","value","undefined","reftest","useRef","reftest2","onChange","_hooks","useCallbackRef","data","_reftest$current","_reftest2$current","current","_jsxs","_Fragment","children","_jsx","Item","hidden","InputContent","ref","_extends","TimeRangePickerWrapper","forwardRef","useImperativeHandle","Input"],"mappings":";2hBA+BaA,EAAiC,SAAjCA,EAAkCC,GAC7C,IAAQC,EAAiFD,EAAjFC,UAAWC,EAAsEF,EAAtEE,QAASC,EAA6DH,EAA7DG,aAAcC,EAA+CJ,EAA/CI,4BAAgCC,EAAUC,EAAKN,EAAKO,GAC9F,IAAMC,EAAOC,EAAKC,kBAClB,IAAMC,EAAWC,GAAQ,WACvB,GAAIC,EAAQZ,IAAcY,EAAQX,GAAU,CAC1C,OAAOD,EACJa,MAAM,EAAGb,EAAUc,OAAS,GAC5BC,OAA0Bf,mBAAAA,EAAUA,EAAUc,OAAS,GAAMb,IAAAA,EAAQA,EAAQa,OAAS,GAC3F,CACA,MAA0Bd,mBAAAA,MAAaC,CACzC,GAAG,CAACD,EAAWC,IAEf,IAAMe,EAAiBL,GAAQ,WAC7B,OAAOT,EAAgB,GAA2Ba,OAAOb,EAAcF,GAAaA,CACtF,GAAG,CAACA,EAAWE,IAEf,IAAMe,EAAeN,GAAQ,WAC3B,OAAOT,EAAgB,GAA2Ba,OAAOb,EAAcD,GAAWA,CACpF,GAAG,CAACA,EAASC,IAEb,IAAMgB,EAAWV,EAAKW,SAASH,EAAgBT,GAC/C,IAAMa,EAASZ,EAAKW,SAASF,EAAcV,GAG3C,IAAMc,EAAYC,EAASC,YAAYL,GACvC,IAAMM,EAAYF,EAASC,YAAYH,GAEvCE,EAASG,iBAAgB,WACvB,IAAMC,EAAOxB,EAAgB,GAA2Ba,OAAOb,EAAcQ,GAAYA,EACzF,GAAIQ,GAAYE,EAAQ,CACtBb,EAAKoB,UAAU,CAAC,CAAED,KAAAA,EAAME,MAAO,CAACV,EAAUE,KAC5C,CACA,GAAIC,GAAaG,IAAcN,IAAaE,EAAQ,CAClDb,EAAKoB,UAAU,CAAC,CAAED,KAAAA,EAAME,MAAOC,YACjC,CACF,GAAG,CAACX,EAAUE,IAEd,IAAMU,EAAUC,EAAwB,MACxC,IAAMC,EAAWD,EAAwB,MAEzC,IAAME,EAAWC,EAAMC,gBAAe,SAACC,GAAS,IAAAC,EAAAC,EAC9C/B,EAAKoB,UAAU,CACb,CAAED,KAAMV,EAAgBY,MAAOQ,GAAAA,UAAAA,EAAAA,EAAO,IACtC,CAAEV,KAAMT,EAAcW,MAAOQ,GAAAA,UAAAA,EAAAA,EAAO,OAGtCC,EAAAP,EAAQS,UAARF,UAAAA,EAAAA,EAAiBJ,UAAQ,UAAA,EAAzBI,EAAiBJ,SAAWG,GAAI,UAAA,EAAJA,EAAO,KACnCE,EAAAN,EAASO,UAATD,UAAAA,EAAAA,EAAkBL,UAAQ,UAAA,EAA1BK,EAAkBL,SAAWG,GAAI,UAAA,EAAJA,EAAO,GACtC,IAEA,OACEI,EAAAC,EAAA,CAAAC,SACEC,CAAAA,EAACnC,EAAKoC,KAAI,CAAClB,KAAM1B,EAAW6C,OAAM,KAAAH,SAChCC,EAACG,EAAY,CAACC,IAAKjB,MAErBa,EAACnC,EAAKoC,KAAI,CAAClB,KAAMzB,EAAS4C,OAAM,KAAAH,SAC9BC,EAACG,EAAY,CAACC,IAAKf,MAErBW,EAACnC,EAAKoC,KAAII,EAAA,CAAA,EAAK5C,EAAU,CAAEsB,KAAMhB,EAASgC,SACxCC,EAACM,EAAsBD,KAAK7C,EAA2B,CAAE8B,SAAUA,UAI3E,EAWA,IAAMa,EAAeI,GAA+C,SAACnD,EAAOgD,GAC1EI,EAAoBJ,GAAK,WACvB,MAAO,CACLd,SAAU,SAAAA,EAACf,GACTnB,EAAMkC,UAANlC,UAAAA,EAAAA,EAAMkC,SAAWf,EACnB,EAEJ,IAEA,OAAOyB,EAACS,EAAK,CAACxB,MAAO7B,EAAM6B,OAC7B"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import t from"@ant-design/icons/es/icons/QuestionCircleOutlined";import{isUndefinedOrNull as e}from"@flatbiz/utils";import{Tooltip as i,Space as n}from"antd";import{jsx as r,jsxs as s}from"react/jsx-runtime";var l=function l(a){var c=a.tooltip;var o=e(a.gap)?3:a.gap;if(typeof c==="string"){return r(i,{title:c,children:s(n,{size:o,className:a.className,style:a.style,children:[r("span",{children:a.title}),r("span",{style:{opacity:.7},children:r(t,{})})]})})}return r(i,{title:c.content,children:s(n,{size:o,className:a.className,style:a.style,children:[r("span",{children:a.title}),r("span",{children:c.icon})]})})};export{l as T};
|
|
3
|
+
//# sourceMappingURL=title-render-2874a932.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"title-render-2874a932.js","sources":["@flatbiz/antd/src/table-title-tooltip/title-render.tsx"],"sourcesContent":["import { QuestionCircleOutlined } from '@ant-design/icons';\nimport { isUndefinedOrNull } from '@flatbiz/utils';\nimport { Space, Tooltip } from 'antd';\nimport { CSSProperties, ReactElement } from 'react';\n\nexport type TableTitleTooltipProps = {\n title: string;\n tooltip: string | { icon: ReactElement; content?: string };\n // 间隙,默认值:3\n gap?: number;\n className?: string;\n style?: CSSProperties;\n};\n\nexport const TableTitleTooltip = (props: TableTitleTooltipProps) => {\n const tooltip = props.tooltip;\n const gap = isUndefinedOrNull(props.gap) ? 3 : props.gap;\n if (typeof tooltip === 'string') {\n return (\n <Tooltip title={tooltip}>\n <Space size={gap} className={props.className} style={props.style}>\n <span>{props.title}</span>\n <span style={{ opacity: 0.7 }}>\n <QuestionCircleOutlined />\n </span>\n </Space>\n </Tooltip>\n );\n }\n return (\n <Tooltip title={tooltip.content}>\n <Space size={gap} className={props.className} style={props.style}>\n <span>{props.title}</span>\n <span>{tooltip.icon}</span>\n </Space>\n </Tooltip>\n );\n};\n"],"names":["TableTitleTooltip","props","tooltip","gap","isUndefinedOrNull","_jsx","Tooltip","title","children","_jsxs","Space","size","className","style","opacity","_QuestionCircleOutlined","content","icon"],"mappings":";oNAcaA,EAAoB,SAApBA,EAAqBC,GAChC,IAAMC,EAAUD,EAAMC,QACtB,IAAMC,EAAMC,EAAkBH,EAAME,KAAO,EAAIF,EAAME,IACrD,UAAWD,IAAY,SAAU,CAC/B,OACEG,EAACC,EAAO,CAACC,MAAOL,EAAQM,SACtBC,EAACC,EAAK,CAACC,KAAMR,EAAKS,UAAWX,EAAMW,UAAWC,MAAOZ,EAAMY,MAAML,UAC/DH,EAAA,OAAA,CAAAG,SAAOP,EAAMM,QACbF,EAAA,OAAA,CAAMQ,MAAO,CAAEC,QAAS,IAAMN,SAC5BH,EAAAU,EAAA,UAKV,CACA,OACEV,EAACC,EAAO,CAACC,MAAOL,EAAQc,QAAQR,SAC9BC,EAACC,EAAK,CAACC,KAAMR,EAAKS,UAAWX,EAAMW,UAAWC,MAAOZ,EAAMY,MAAML,UAC/DH,EAAA,OAAA,CAAAG,SAAOP,EAAMM,QACbF,EAAA,OAAA,CAAAG,SAAON,EAAQe,WAIvB"}
|
|
@@ -3,5 +3,5 @@ import './../request-status/index.css';
|
|
|
3
3
|
import './../fba-hooks/index.css';
|
|
4
4
|
import './index.css';
|
|
5
5
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
6
|
-
|
|
6
|
+
export{T as TreeSelectorWrapper}from"../tree-selector-wrapper-9cd9da23.js";import"@ant-design/icons/es/icons/RedoOutlined";import"@dimjs/utils/cjs/class-names";import"@ant-design/icons/es/icons/CaretDownFilled";import"@dimjs/lang/cjs/is-string";import"@dimjs/lang/cjs/is-array";import"@dimjs/utils/cjs/extend";import"@wove/react/cjs/hooks";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"@flatbiz/utils";import"antd";import"react";import"@dimjs/model-react";import"dequal";import"../fba-hooks/index.js";import"../use-responsive-point-21b8c601.js";import"../request-status-03fc60e2.js";import"react/jsx-runtime";import"@dimjs/lang/cjs/is-object";
|
|
7
7
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["@flatbiz/antd/src/tree-selector-wrapper/model.ts","@flatbiz/antd/src/tree-selector-wrapper/utils.ts","@flatbiz/antd/src/tree-selector-wrapper/tree-selector-wrapper.tsx"],"sourcesContent":["import { API, ModelType } from '@dimjs/model';\nimport { Model } from '@dimjs/model-react';\nimport { TAny, TPlainObject, TSetDefaultDefined } from '@flatbiz/utils';\nimport { TreeSelectProps } from 'antd';\nimport { TRequestStatus } from '../request-status';\n\nexport type ModelState = {\n treeSelectorList: TSetDefaultDefined<TreeSelectProps['treeData'], []>;\n treeSelectorTiledArray: TPlainObject[];\n queryIsEmpty: boolean;\n requestStatus?: TRequestStatus;\n};\n\ntype ModelActionParams = {\n setSelectBoxList: {\n treeSelectorList: ModelState['treeSelectorList'];\n treeSelectorTiledArray: ModelState['treeSelectorTiledArray'];\n };\n resetSelectBoxList: void;\n changeRequestStatus: TRequestStatus;\n};\n\nconst defaultState: ModelState = {\n treeSelectorList: [],\n treeSelectorTiledArray: [],\n queryIsEmpty: false,\n};\n\nconst TreeSelectorWrapperModel: ModelType<ModelState, ModelActionParams> = {\n actions: {\n setSelectBoxList: (params) => {\n return (state) => {\n state.treeSelectorList = params.treeSelectorList || [];\n state.treeSelectorTiledArray = params.treeSelectorTiledArray || [];\n state.requestStatus = 'request-success';\n };\n },\n resetSelectBoxList: () => {\n return (state) => {\n state.treeSelectorList = [];\n };\n },\n changeRequestStatus: (params) => {\n return (state) => {\n state.requestStatus = params;\n };\n },\n },\n state: defaultState,\n};\n\nconst treeSelectorWrapperModels: Record<string, API<ModelType<ModelState, ModelActionParams, TAny>>> = {};\n\n/**\n * ```\n * 使用方式\n * const [state, actions] = useTreeSelectorWrapperModel('key值').useStore();\n * ```\n */\nexport const treeSelectorWrapperModel = (key: string) => {\n if (!treeSelectorWrapperModels[key]) {\n treeSelectorWrapperModels[key] = Model(TreeSelectorWrapperModel);\n }\n return treeSelectorWrapperModels[key];\n};\n","import { isArray, isObject } from '@dimjs/lang';\nimport {\n isUndefinedOrNull,\n LabelValueItem,\n toArray,\n TPlainObject,\n treeLeafParentsArray,\n treeToTiledArray,\n} from '@flatbiz/utils';\nimport { TreeSelectProps } from 'antd';\nimport { dequal } from 'dequal';\n\nexport const getExpandedKeys = (\n value: string | number,\n treeList: TPlainObject[],\n fieldNames?: TreeSelectProps['fieldNames'],\n) => {\n if (!isArray(treeList) || treeList.length === 0) return [];\n const tiledArray = treeToTiledArray(treeList, fieldNames);\n return treeLeafParentsArray(value, tiledArray, true, { value: 'value', parentValue: 'parentValue' });\n};\n\nexport const getVauleList = (data, fieldNames: LabelValueItem<string>) => {\n let tempList = toArray<TPlainObject | string | number>(data);\n tempList = tempList.map((item) => {\n if (isObject(item)) return item[fieldNames.value];\n return item;\n });\n return tempList as Array<string | number>;\n};\n\nexport const array2map = (data, fieldNames: LabelValueItem<string>) => {\n const list = getVauleList(data, fieldNames);\n const map = {};\n list.forEach((item) => {\n map[item] = true;\n });\n return map;\n};\n\n/**\n * value的类型包括 string、number、Array<string | number>、{ label: string, value: string | nuber }\n * 将数组转成对象,深度比较时不用考虑顺序问题\n * @param value1\n * @param value2\n * @returns\n */\nexport const treeSelectorWrapperValueDeepEqual = (\n value1: any,\n value2: any,\n fieldNames: LabelValueItem<string>,\n) => {\n if (isUndefinedOrNull(value1) && isUndefinedOrNull(value2)) return true;\n const object1 = array2map(value1, fieldNames);\n const object2 = array2map(value2, fieldNames);\n const diff = dequal(object1, object2);\n return diff;\n};\n","import { CaretDownFilled, RedoOutlined } from '@ant-design/icons';\nimport { isArray, isString } from '@dimjs/lang';\nimport { classNames, extend } from '@dimjs/utils';\nimport {\n isNumber,\n isUndefinedOrNull,\n TAny,\n toArray,\n TPlainObject,\n treeToArray,\n valueIsEqual,\n} from '@flatbiz/utils';\nimport { hooks } from '@wove/react';\nimport { Button, TreeSelect, TreeSelectProps } from 'antd';\nimport { DependencyList, useMemo, useRef, useState } from 'react';\nimport { treeSelectorWrapperModel } from './model';\nimport './style.less';\n\nimport { arrayFind, getValueOrDefault } from '@flatbiz/utils';\nimport { dequal } from 'dequal';\nimport { fbaHooks } from '../fba-hooks';\nimport { RequestStatus, TRequestStatusProps } from '../request-status';\nimport { getExpandedKeys, getVauleList, treeSelectorWrapperValueDeepEqual } from './utils';\n\ntype TreeSelectorWrapperValue =\n | string\n | number\n | Array<string | number>\n | TPlainObject<string | number>\n | Array<TPlainObject<string | number>>;\n\ntype TreeSelectorServiceConfig = {\n params?: TPlainObject;\n requiredParamsKeys?: string[];\n onRequest?: (params?: TAny) => TAny;\n /**\n * 响应数据适配器\n */\n onRequestResultAdapter?: (respData: TAny) => TPlainObject[];\n};\n\nexport type TreeSelectorWrapperProps = Omit<\n TreeSelectProps,\n 'treeExpandedKeys' | 'treeData' | 'loading' | 'onTreeExpand' | 'onChange' | 'value' | 'fieldNames'\n> & {\n modelKey: string;\n fieldNames?: { label?: string; value?: string; children?: string; disabled?: string };\n /**\n * useEffect依赖项数组,用于重新发起获取接口数据\n */\n effectDependencyList?: DependencyList;\n /**\n * 请求服务需求的数据,当设置`treeSelectorList`后无效果\n */\n serviceConfig?: TreeSelectorServiceConfig;\n /**\n * 当设置treeSelectorList后,serviceConfig 将失效\n */\n treeSelectorList?: TreeSelectProps['treeData'];\n /**\n * treeSelectorList发生变更时触发\n */\n onTreeSelectorListChange?: (treeSelectorList?: TreeSelectProps['treeData']) => void;\n /**\n * 通过服务获取数据异常回调,当设置`treeSelectorList`后无效果\n */\n onTreeSelectorRequestError?: (error: Error) => void;\n /**\n * 添加全部选项\n * ```\n * 1. showAllOption = true,添加默认全部选项(value值为空字符串)\n * 2. 可自定义全部选项,例如:{ label: '全部', value: 'all' }\n * 3. 自定义字段会通过fieldNames转换后使用\n * 4. 多选操作时,最好不要设置全部选项\n * ```\n */\n showAllOption?: true | TPlainObject<string | number>;\n /**\n * 1. 当 treeCheckable = true && treeCheckStrictly = true,如果选择的数据中含有父节点,selectedValue、selectedList返回数据包含父节点\n * 2. 当 treeCheckable = true && treeCheckStrictly = false,selectedValue、selectedList返回的数据不包含父节点\n * 3. 当 treeCheckable = false,节点选择没有级联关系,selectedValue、selectedList返回的数据就是实际选择\n * 4. selectAllDataList 返回的数据都包含父节点\n * 5. 使用 onTreeItemAdapter 拼接label数据后,选中回填数据也是拼接后的\n * 6. triggerInfo 当前操作节点数据\n */\n onChangeHandle?: (\n selectedValue?: TreeSelectorWrapperValue,\n selectedData?: TPlainObject[] | TPlainObject,\n triggerInfo?: TPlainObject,\n ) => void;\n // // label渲染适配器\n // onLabelRenderAdapter?: (dataItem: TPlainObject) => string;\n /**\n * tree item 数据适配器\n */\n onTreeItemDataAdapter?: (dataItem: TPlainObject) => TPlainObject;\n // icon 无法实现、treeIcon不起作用4.20.0\n // showIcon?: boolean;\n // icon?: (data: TPlainObject) => ReactElement;\n\n requestMessageConfig?: TRequestStatusProps['messageConfig'];\n\n /**\n * value格式\n *```\n * 1. string 、number\n * 2. Array<string | number>\n * 3. lableInValue = true,根据labelInValueFieldNames配置格式\n * 4. lableInValue = true,Array<labelInValueFieldNames配置>\n * ```\n */\n value?: TreeSelectorWrapperValue;\n\n /**\n * treeCheckStrictly \tcheckable 状态下节点选择完全受控(父子节点选中状态不再关联),\n * 会使得 labelInValue 强制为 true\n */\n labelInValue?: boolean;\n /**\n * ```\n * lableInValue = true,onChange输出数据字段名称,默认:{ label: string; value: string|number }\n * ```\n */\n labelInValueFieldNames?: { label: string; value: string };\n /**\n * treeCheckStrictly = true模式下有效,点击父节点是否选中所有子节点,默认值:true\n */\n selectedParentCheckedAllChildrenList?: boolean;\n};\n\ntype TreeSelectorWrapperPropsInner = TreeSelectorWrapperProps & {\n onChange?: (selectedValue?: TreeSelectorWrapperValue) => void;\n};\n\n/**\n * 树选择器包装组件\n * @param props\n * @returns\n * ```\n * 1. 当设置treeSelectorList属性后,serviceConfig、onTreeSelectorListChange将失效\n * 2. 父节点默认不返回,需要返回请设置showCheckedStrategy\n * ```\n */\nexport const TreeSelectorWrapper = (props: TreeSelectorWrapperProps) => {\n const {\n serviceConfig,\n effectDependencyList,\n onTreeSelectorListChange,\n onTreeSelectorRequestError,\n // onLabelRenderAdapter,\n treeSelectorList,\n requestMessageConfig,\n modelKey,\n value,\n labelInValue: _labelInValue,\n labelInValueFieldNames,\n onTreeItemDataAdapter,\n selectedParentCheckedAllChildrenList = true,\n fieldNames,\n onChange,\n onChangeHandle,\n showAllOption,\n ...otherProps\n } = props as TreeSelectorWrapperPropsInner;\n /**\n * 不能使用key、defaultValue模式\n * 1. 勾选的和回填选中不相同情况,勾选后会渲染defaultValue模式后,弹框被关闭,操作体验存在问题\n */\n const hasTreeSelectorList = props.hasOwnProperty('treeSelectorList');\n const newServiceConfig = serviceConfig || {};\n const newEffectDependencyList = effectDependencyList || [];\n const [loading, setLoading] = fbaHooks.useSafeState(false);\n const [treeExpandedKeys, setTreeExpandedKeys] = useState<React.Key[]>();\n const [state, actions] = treeSelectorWrapperModel(modelKey).useStore();\n const requestPreKey = `request-progress-${modelKey}`;\n const isMultiple = otherProps.treeCheckable;\n /**\n * treeCheckStrictly \tcheckable 状态下节点选择完全受控(父子节点选中状态不再关联),\n * 会使得 labelInValue 强制为 true\n */\n const labelInValue = useMemo(() => {\n if (otherProps.treeCheckStrictly) return true;\n return _labelInValue;\n }, [_labelInValue, otherProps.treeCheckStrictly]);\n\n const fieldNamesMerge = useMemo(() => {\n return { label: 'label', value: 'value', children: 'children', disabled: 'disabled', ...fieldNames };\n }, [fieldNames]);\n\n const labelInValueFieldNamesMerge = useMemo(() => {\n return { label: 'label', value: 'value', ...labelInValueFieldNames };\n }, [labelInValueFieldNames]);\n\n const allOptionConfig = useMemo(() => {\n if (showAllOption) {\n const isTrue = showAllOption === true;\n return {\n label: isTrue ? '全部' : showAllOption.label,\n value: isTrue ? '' : showAllOption.value,\n };\n }\n return null;\n }, [showAllOption]);\n\n const [innerOperateValue, setInnerOperateValue] = useState<\n Array<TPlainObject> | string | number | Array<string | number> | TPlainObject\n >();\n const isFirstUseValueRef = useRef(true);\n\n fbaHooks.useEffectCustom(() => {\n if (isUndefinedOrNull(value) && isFirstUseValueRef.current) return;\n isFirstUseValueRef.current = false;\n if (state.treeSelectorList.length > 0) {\n if (!treeSelectorWrapperValueDeepEqual(value, innerOperateValue, labelInValueFieldNamesMerge)) {\n console.log(`modelKey:${modelKey} TreeSelectorWrapper key refresh`, value, innerOperateValue);\n const valueList = getVauleList(value, labelInValueFieldNamesMerge);\n setInnerOperateValue(valueList);\n // 重新计算 expandedKeys\n const expandedKeys = getTreeExpandedKeys(valueList, true);\n setTreeExpandedKeys(Array.from(new Set(expandedKeys)));\n }\n }\n }, [value, state.treeSelectorList]);\n\n const valueIsEmpty = (value: string | number) => {\n return value === '' || isUndefinedOrNull(value);\n };\n\n const serviceResponseHandle = (respData) => {\n const respDataList = newServiceConfig.onRequestResultAdapter\n ? newServiceConfig.onRequestResultAdapter(respData as unknown as TPlainObject)\n : respData;\n return respDataList as TPlainObject[];\n };\n\n const startDataSourceRequest = hooks.useCallbackRef(async () => {\n if (!newServiceConfig.onRequest) {\n throw new Error('onRequest 调用接口服务不能为空');\n }\n const requiredParamsKeys = newServiceConfig.requiredParamsKeys || [];\n const params = extend({}, newServiceConfig.params);\n const isEmpty = requiredParamsKeys.find((key) => {\n return valueIsEmpty(params[key] as string | number);\n });\n if (isEmpty) {\n console.warn(`TreeSelectorWrapper组件:参数:${requiredParamsKeys.join('、')}不能为空`);\n return;\n }\n try {\n setLoading(true);\n window[requestPreKey] = true;\n void actions.changeRequestStatus('request-progress');\n const _respData = await newServiceConfig.onRequest?.(params);\n const respData = serviceResponseHandle(_respData) as TreeSelectProps['treeData'];\n setLoading(false);\n window[requestPreKey] = false;\n onChangeSelectorList(respData || []);\n } catch (error) {\n setLoading(false);\n window[requestPreKey] = false;\n void actions.changeRequestStatus('request-error');\n onTreeSelectorRequestError?.(error);\n }\n });\n\n hooks.useCustomCompareEffect(\n () => {\n if (hasTreeSelectorList) return;\n // 当无依赖项时,如果存在缓存数据,就不在调用接口\n if (Boolean(newEffectDependencyList.length)) {\n // 内部主动清楚数据,被依赖的数据发生变更时,依赖组件数据清空\n onChangeSelectorList([]);\n void startDataSourceRequest();\n return;\n }\n const allState = treeSelectorWrapperModel(modelKey).getState();\n if (allState.requestStatus === 'request-success') {\n return;\n }\n // 判断相同的modelKey是否已经在请求数据中,避免重复请求\n if (!window[requestPreKey]) {\n void startDataSourceRequest();\n return;\n }\n },\n newEffectDependencyList,\n dequal,\n );\n\n const onChangeSelectorList = hooks.useCallbackRef((dataList: TAny[]) => {\n if (dataList?.length === 0 && state.treeSelectorList.length === 0) {\n void actions.setSelectBoxList({\n treeSelectorList: [],\n treeSelectorTiledArray: [],\n });\n onTreeSelectorListChange?.([]);\n return;\n }\n // 全部选项\n const tempItem = allOptionConfig\n ? {\n [fieldNamesMerge.label]: allOptionConfig.label,\n [fieldNamesMerge.value]: allOptionConfig.value,\n }\n : undefined;\n const newdataList = showAllOption ? [tempItem, ...dataList] : dataList;\n void actions.setSelectBoxList({\n treeSelectorList: newdataList,\n treeSelectorTiledArray: treeToArray(newdataList || [], fieldNamesMerge.children),\n });\n onTreeSelectorListChange?.(dataList);\n });\n\n fbaHooks.useEffectCustom(() => {\n if (hasTreeSelectorList) {\n onChangeSelectorList(treeSelectorList || []);\n }\n }, [treeSelectorList]);\n\n const onTreeExpand = hooks.useCallbackRef((expandedKeys) => {\n setTreeExpandedKeys(expandedKeys as string[]);\n });\n\n const onAgainRequest = hooks.useCallbackRef(() => {\n void startDataSourceRequest();\n });\n\n const getTreeExpandedKeys = hooks.useCallbackRef((valueList: Array<string | number>, refresh?: boolean) => {\n let newTreeExpandedKeys = [] as Array<string | number>;\n valueList.forEach((value) => {\n if (!refresh && treeExpandedKeys?.includes(value)) return;\n const targetList = getExpandedKeys(value, state.treeSelectorList, fieldNamesMerge);\n newTreeExpandedKeys = newTreeExpandedKeys.concat(targetList.map((item) => item.value));\n });\n return newTreeExpandedKeys;\n });\n\n /**\n * 数据源Item解析\n */\n const parseDataSourceItem = hooks.useCallbackRef((item?: TPlainObject | null) => {\n if (!item) return undefined;\n return {\n label: item?.[fieldNamesMerge.label],\n value: item?.[fieldNamesMerge.value],\n children: item?.[fieldNamesMerge.children],\n disabled: item?.['disabled'],\n };\n });\n /**\n * labelInValue模式入参value item解析\n */\n const parseLabelInValueItem = hooks.useCallbackRef((item?: TPlainObject | null) => {\n if (!item) return undefined;\n return {\n label: item?.[labelInValueFieldNamesMerge.label],\n value: item?.[labelInValueFieldNamesMerge.value],\n disabled: item?.['disabled'],\n };\n });\n\n const getResponseTreeNodeList = hooks.useCallbackRef((changeValue: TAny, triggerInfo: TPlainObject) => {\n const valueList = getVauleList(changeValue, { value: 'value', label: 'label' });\n let selectedTreeNodeList = [] as TPlainObject[];\n valueList.forEach((item) => {\n const target = arrayFind(state.treeSelectorTiledArray, item, fieldNamesMerge.value) as TPlainObject;\n if (!target) return;\n selectedTreeNodeList.push(target);\n });\n if (otherProps.treeCheckStrictly && selectedParentCheckedAllChildrenList) {\n const triggerNode = parseDataSourceItem(\n triggerInfo.checked\n ? arrayFind(state.treeSelectorTiledArray, triggerInfo.triggerValue, fieldNamesMerge.value)\n : null,\n );\n if (triggerNode && isArray(triggerNode.children) && triggerNode.children.length > 0) {\n // 判断为父节点\n const allChildrenList = treeToArray(triggerNode.children, fieldNamesMerge.children);\n const selectedChildrenList = allChildrenList.filter((item) => {\n const parseItem = parseDataSourceItem(item);\n if (parseItem?.disabled) return false;\n // 去重\n if (arrayFind(selectedTreeNodeList, parseItem?.value, fieldNamesMerge.value)) return false;\n return true;\n });\n selectedTreeNodeList = selectedTreeNodeList.concat(selectedChildrenList);\n }\n }\n let realTreeNodeList = [] as TPlainObject[];\n if (otherProps.treeCheckable) {\n if (\n otherProps.treeCheckStrictly === true ||\n valueIsEqual(otherProps.showCheckedStrategy, ['SHOW_ALL', 'SHOW_PARENT'])\n ) {\n // 返回包含父节点\n realTreeNodeList = selectedTreeNodeList;\n } else {\n // 返回不包含父节点\n realTreeNodeList = selectedTreeNodeList.filter((item) => {\n const children = item[fieldNamesMerge.children];\n return !(isArray(children) && children.length > 0);\n });\n }\n } else {\n realTreeNodeList = selectedTreeNodeList;\n }\n return {\n realTreeNodeList,\n realTreeNodeValueList: getVauleList(realTreeNodeList, fieldNamesMerge),\n };\n });\n\n const onRespChange = hooks.useCallbackRef((values, selectedValues, triggerInfo) => {\n setInnerOperateValue(values);\n onChange?.(values);\n onChangeHandle?.(values, selectedValues, triggerInfo);\n });\n\n /**\n * 根据treeCheckable、treeCheckStrictly、showCheckedStrategy等设置情况,判断返回数据是否包含父节点\n * 1. 当 treeCheckable = true,changeValue 数据格式为 { label,value }[]\n */\n const onInnerChange = hooks.useCallbackRef((changeValue: TAny, _data, triggerInfo: TPlainObject) => {\n const { realTreeNodeList, realTreeNodeValueList } = getResponseTreeNodeList(changeValue, triggerInfo);\n if (otherProps.treeCheckable) {\n setTreeExpandedKeys((prev) => {\n const mergeList = getTreeExpandedKeys(realTreeNodeValueList).concat(prev || []);\n return Array.from(new Set(mergeList));\n });\n }\n\n if (labelInValue) {\n const labelInValueList = realTreeNodeList.map((item) => {\n const parseItem = parseDataSourceItem(item);\n return {\n [labelInValueFieldNamesMerge.label]: parseItem?.label,\n [labelInValueFieldNamesMerge.value]: parseItem?.value,\n };\n });\n\n if (isMultiple) {\n onRespChange?.(labelInValueList, realTreeNodeList, triggerInfo);\n } else {\n onRespChange?.(labelInValueList[0], realTreeNodeList[0], triggerInfo);\n }\n } else {\n if (isMultiple) {\n onRespChange?.(realTreeNodeValueList, realTreeNodeList, triggerInfo);\n } else {\n onRespChange?.(realTreeNodeValueList[0], realTreeNodeList[0], triggerInfo);\n }\n }\n });\n\n const mapTree = hooks.useCallbackRef((data) => {\n if (!data) return null;\n return data.map((item) => {\n const itemAdapterData = onTreeItemDataAdapter?.({ ...item }) || item;\n const children = itemAdapterData[fieldNamesMerge.children];\n const value = itemAdapterData[fieldNamesMerge.value];\n const label = itemAdapterData[fieldNamesMerge.label];\n const disabled = itemAdapterData[fieldNamesMerge.disabled]\n ? itemAdapterData[fieldNamesMerge.disabled]\n : itemAdapterData.disabled;\n return (\n <TreeSelect.TreeNode\n {...itemAdapterData}\n disabled={disabled}\n value={value}\n title={label}\n key={`${value}`}\n >\n {children && children.length > 0 && mapTree(children)}\n </TreeSelect.TreeNode>\n );\n });\n });\n\n /**\n * 1. 当 treeCheckable = true,value 数据格式为 labelInValueFieldNames[]\n * 2. 其他情况 value 数据格式为 value[]\n */\n const renderValueList = useMemo(() => {\n const innerOperateValueList = toArray(innerOperateValue);\n if (innerOperateValueList.length == 0) return [];\n if (otherProps.treeCheckStrictly) {\n if (state.treeSelectorTiledArray.length === 0) {\n return innerOperateValueList.map((item) => ({ label: item, value: item }));\n }\n return innerOperateValueList.map((item) => {\n let targetParseItem: TPlainObject;\n let defualtValue;\n if (isString(item) || isNumber(item as TAny)) {\n const target = arrayFind(state.treeSelectorTiledArray, item as string, fieldNamesMerge.value);\n targetParseItem = parseDataSourceItem(target) as TPlainObject;\n defualtValue = item;\n } else {\n targetParseItem = parseLabelInValueItem(item as TPlainObject) as TPlainObject;\n }\n return {\n label: getValueOrDefault(targetParseItem?.label, defualtValue),\n value: getValueOrDefault(targetParseItem?.value, defualtValue),\n };\n });\n }\n return getVauleList(innerOperateValue, labelInValueFieldNamesMerge);\n }, [\n innerOperateValue,\n otherProps.treeCheckStrictly,\n labelInValueFieldNamesMerge,\n state.treeSelectorTiledArray,\n fieldNamesMerge.value,\n parseDataSourceItem,\n parseLabelInValueItem,\n ]);\n\n const treeSelectValue = useMemo(() => {\n if (isArray(renderValueList) && renderValueList.length === 0) {\n return undefined;\n }\n return isMultiple ? renderValueList : renderValueList[0];\n }, [isMultiple, renderValueList]);\n\n /**\n * 1. 使用 TreeNode 渲染节点,不能重写 fieldNames 配置\n * 2. 使用 TreeNode 是为了实现 TreeNode ICON\n */\n return (\n <TreeSelect\n dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}\n showSearch={true}\n treeLine={{ showLeafIcon: false }}\n treeNodeFilterProp=\"title\"\n switcherIcon={<CaretDownFilled />}\n showArrow\n {...otherProps}\n className={classNames('v-tree-select-wrapper', otherProps.className)}\n popupClassName={classNames('v-tree-select-wrapper-dropdown', otherProps.popupClassName)}\n onChange={onInnerChange}\n treeExpandedKeys={treeExpandedKeys}\n value={treeSelectValue}\n loading={loading}\n dropdownMatchSelectWidth={false}\n onTreeExpand={onTreeExpand}\n style={{ width: '100%', ...otherProps.style }}\n suffixIcon={\n state.requestStatus === 'request-error' ? (\n <RedoOutlined spin={loading} onClick={onAgainRequest} />\n ) : undefined\n }\n notFoundContent={\n <RequestStatus\n status={state.requestStatus}\n messageConfig={requestMessageConfig}\n loading={loading}\n errorButton={\n <Button type=\"primary\" onClick={onAgainRequest}>\n 重新获取数据\n </Button>\n }\n />\n }\n >\n {mapTree(state.treeSelectorList)}\n </TreeSelect>\n );\n};\n"],"names":["defaultState","treeSelectorList","treeSelectorTiledArray","queryIsEmpty","TreeSelectorWrapperModel","actions","setSelectBoxList","params","state","requestStatus","resetSelectBoxList","changeRequestStatus","treeSelectorWrapperModels","treeSelectorWrapperModel","key","Model","getExpandedKeys","value","treeList","fieldNames","_isArray","length","tiledArray","treeToTiledArray","treeLeafParentsArray","parentValue","getVauleList","data","tempList","toArray","map","item","_isObject","array2map","list","forEach","treeSelectorWrapperValueDeepEqual","value1","value2","isUndefinedOrNull","object1","object2","diff","dequal","TreeSelectorWrapper","props","_ref","serviceConfig","effectDependencyList","onTreeSelectorListChange","onTreeSelectorRequestError","requestMessageConfig","modelKey","_labelInValue","labelInValue","labelInValueFieldNames","onTreeItemDataAdapter","_ref$selectedParentCh","selectedParentCheckedAllChildrenList","onChange","onChangeHandle","showAllOption","otherProps","_objectWithoutPropertiesLoose","_excluded","hasTreeSelectorList","hasOwnProperty","newServiceConfig","newEffectDependencyList","_fbaHooks$useSafeStat","fbaHooks","useSafeState","loading","setLoading","_useState","useState","treeExpandedKeys","setTreeExpandedKeys","_treeSelectorWrapperM","useStore","requestPreKey","isMultiple","treeCheckable","useMemo","treeCheckStrictly","fieldNamesMerge","_extends","label","children","disabled","labelInValueFieldNamesMerge","allOptionConfig","isTrue","_useState2","innerOperateValue","setInnerOperateValue","isFirstUseValueRef","useRef","useEffectCustom","current","console","log","valueList","expandedKeys","getTreeExpandedKeys","Array","from","Set","valueIsEmpty","serviceResponseHandle","respData","respDataList","onRequestResultAdapter","startDataSourceRequest","_hooks","useCallbackRef","Promise","$return","$error","requiredParamsKeys","isEmpty","_respData","_respData2","onRequest","Error","_extend","find","warn","join","$Try_1_Post","$boundEx","$Try_1_Catch","error","window","resolve","then","$await_2","onChangeSelectorList","useCustomCompareEffect","Boolean","allState","getState","dataList","_ref2","tempItem","undefined","newdataList","concat","treeToArray","onTreeExpand","onAgainRequest","refresh","newTreeExpandedKeys","includes","targetList","parseDataSourceItem","parseLabelInValueItem","getResponseTreeNodeList","changeValue","triggerInfo","selectedTreeNodeList","target","arrayFind","push","triggerNode","checked","triggerValue","allChildrenList","selectedChildrenList","filter","parseItem","realTreeNodeList","valueIsEqual","showCheckedStrategy","realTreeNodeValueList","onRespChange","values","selectedValues","onInnerChange","_data","_getResponseTreeNodeL","prev","mergeList","labelInValueList","_ref3","mapTree","itemAdapterData","_createElement","TreeSelect","TreeNode","title","renderValueList","innerOperateValueList","_targetParseItem","_targetParseItem2","targetParseItem","defualtValue","_isString","isNumber","getValueOrDefault","treeSelectValue","_jsx","dropdownStyle","maxHeight","overflow","showSearch","treeLine","showLeafIcon","treeNodeFilterProp","switcherIcon","_CaretDownFilled","showArrow","className","_classNames","popupClassName","dropdownMatchSelectWidth","style","width","suffixIcon","_RedoOutlined","spin","onClick","notFoundContent","RequestStatus","status","messageConfig","errorButton","Button","type"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
+
import e from"@ant-design/icons/es/icons/RedoOutlined";import{classNames as r}from"@dimjs/utils/cjs/class-names";import t from"@ant-design/icons/es/icons/CaretDownFilled";import{isString as l}from"@dimjs/lang/cjs/is-string";import{isArray as n}from"@dimjs/lang/cjs/is-array";import{extend as a}from"@dimjs/utils/cjs/extend";import{hooks as u}from"@wove/react/cjs/hooks";import{_ as i,a as o}from"./_rollupPluginBabelHelpers-1f4d8910.js";import{treeToTiledArray as s,treeLeafParentsArray as c,toArray as f,isUndefinedOrNull as v,treeToArray as d,arrayFind as m,valueIsEqual as h,isNumber as p,getValueOrDefault as S}from"@flatbiz/utils";import{TreeSelect as b,Button as C}from"antd";import{useState as g,useMemo as y,useRef as L,createElement as w}from"react";import{Model as k}from"@dimjs/model-react";import{dequal as q}from"dequal";import{fbaHooks as R}from"./fba-hooks/index.js";import{R as T}from"./request-status-03fc60e2.js";import{isObject as A}from"@dimjs/lang/cjs/is-object";import{jsx as j}from"react/jsx-runtime";var N={treeSelectorList:[],treeSelectorTiledArray:[],queryIsEmpty:false};var E={actions:{setSelectBoxList:function e(r){return function(e){e.treeSelectorList=r.treeSelectorList||[];e.treeSelectorTiledArray=r.treeSelectorTiledArray||[];e.requestStatus="request-success"}},resetSelectBoxList:function e(){return function(e){e.treeSelectorList=[]}},changeRequestStatus:function e(r){return function(e){e.requestStatus=r}}},state:N};var x={};var I=function e(r){if(!x[r]){x[r]=k(E)}return x[r]};var P=function e(r,t,l){if(!n(t)||t.length===0)return[];var a=s(t,l);return c(r,a,true,{value:"value",parentValue:"parentValue"})};var V=function e(r,t){var l=f(r);l=l.map((function(e){if(A(e))return e[t.value];return e}));return l};var B=function e(r,t){var l=V(r,t);var n={};l.forEach((function(e){n[e]=true}));return n};var H=function e(r,t,l){if(v(r)&&v(t))return true;var n=B(r,l);var a=B(t,l);var u=q(n,a);return u};var O=["serviceConfig","effectDependencyList","onTreeSelectorListChange","onTreeSelectorRequestError","treeSelectorList","requestMessageConfig","modelKey","value","labelInValue","labelInValueFieldNames","onTreeItemDataAdapter","selectedParentCheckedAllChildrenList","fieldNames","onChange","onChangeHandle","showAllOption"];var D=function s(c){var k=c,A=k.serviceConfig,N=k.effectDependencyList,E=k.onTreeSelectorListChange,x=k.onTreeSelectorRequestError,B=k.treeSelectorList,D=k.requestMessageConfig,F=k.modelKey,K=k.value,W=k.labelInValue,_=k.labelInValueFieldNames,M=k.onTreeItemDataAdapter,z=k.selectedParentCheckedAllChildrenList,G=z===void 0?true:z,J=k.fieldNames,Q=k.onChange,U=k.onChangeHandle,X=k.showAllOption,Y=i(k,O);var Z=c.hasOwnProperty("treeSelectorList");var $=A||{};var ee=N||[];var re=R.useSafeState(false),te=re[0],le=re[1];var ne=g(),ae=ne[0],ue=ne[1];var ie=I(F).useStore(),oe=ie[0],se=ie[1];var ce="request-progress-"+F;var fe=Y.treeCheckable;var ve=y((function(){if(Y.treeCheckStrictly)return true;return W}),[W,Y.treeCheckStrictly]);var de=y((function(){return o({label:"label",value:"value",children:"children",disabled:"disabled"},J)}),[J]);var me=y((function(){return o({label:"label",value:"value"},_)}),[_]);var he=y((function(){if(X){var e=X===true;return{label:e?"全部":X.label,value:e?"":X.value}}return null}),[X]);var pe=g(),Se=pe[0],be=pe[1];var Ce=L(true);R.useEffectCustom((function(){if(v(K)&&Ce.current)return;Ce.current=false;if(oe.treeSelectorList.length>0){if(!H(K,Se,me)){console.log("modelKey:"+F+" TreeSelectorWrapper key refresh",K,Se);var e=V(K,me);be(e);var r=Re(e,true);ue(Array.from(new Set(r)))}}}),[K,oe.treeSelectorList]);var ge=function e(r){return r===""||v(r)};var ye=function e(r){var t=$.onRequestResultAdapter?$.onRequestResultAdapter(r):r;return t};var Le=u.useCallbackRef((function(){return new Promise((function(e,r){var t,l,n,u,i;if(!$.onRequest){return r(new Error("onRequest 调用接口服务不能为空"))}t=$.requiredParamsKeys||[];l=a({},$.params);n=t.find((function(e){return ge(l[e])}));if(n){console.warn("TreeSelectorWrapper组件:参数:"+t.join("、")+"不能为空");return e()}var o=function(){try{return e()}catch(e){return r(e)}};var s=function(e){try{le(false);window[ce]=false;void se.changeRequestStatus("request-error");x==null?void 0:x(e);return o()}catch(e){return r(e)}};try{le(true);window[ce]=true;void se.changeRequestStatus("request-progress");return Promise.resolve($.onRequest==null?void 0:$.onRequest(l)).then((function(e){try{u=e;i=ye(u);le(false);window[ce]=false;we(i||[]);return o()}catch(e){return s(e)}}),s)}catch(e){s(e)}}))}));u.useCustomCompareEffect((function(){if(Z)return;if(Boolean(ee.length)){we([]);void Le();return}var e=I(F).getState();if(e.requestStatus==="request-success"){return}if(!window[ce]){void Le();return}}),ee,q);var we=u.useCallbackRef((function(e){var r;if((e==null?void 0:e.length)===0&&oe.treeSelectorList.length===0){void se.setSelectBoxList({treeSelectorList:[],treeSelectorTiledArray:[]});E==null?void 0:E([]);return}var t=he?(r={},r[de.label]=he.label,r[de.value]=he.value,r):undefined;var l=X?[t].concat(e):e;void se.setSelectBoxList({treeSelectorList:l,treeSelectorTiledArray:d(l||[],de.children)});E==null?void 0:E(e)}));R.useEffectCustom((function(){if(Z){we(B||[])}}),[B]);var ke=u.useCallbackRef((function(e){ue(e)}));var qe=u.useCallbackRef((function(){void Le()}));var Re=u.useCallbackRef((function(e,r){var t=[];e.forEach((function(e){if(!r&&ae!=null&&ae.includes(e))return;var l=P(e,oe.treeSelectorList,de);t=t.concat(l.map((function(e){return e.value})))}));return t}));var Te=u.useCallbackRef((function(e){if(!e)return undefined;return{label:e==null?void 0:e[de.label],value:e==null?void 0:e[de.value],children:e==null?void 0:e[de.children],disabled:e==null?void 0:e["disabled"]}}));var Ae=u.useCallbackRef((function(e){if(!e)return undefined;return{label:e==null?void 0:e[me.label],value:e==null?void 0:e[me.value],disabled:e==null?void 0:e["disabled"]}}));var je=u.useCallbackRef((function(e,r){var t=V(e,{value:"value",label:"label"});var l=[];t.forEach((function(e){var r=m(oe.treeSelectorTiledArray,e,de.value);if(!r)return;l.push(r)}));if(Y.treeCheckStrictly&&G){var a=Te(r.checked?m(oe.treeSelectorTiledArray,r.triggerValue,de.value):null);if(a&&n(a.children)&&a.children.length>0){var u=d(a.children,de.children);var i=u.filter((function(e){var r=Te(e);if(r!=null&&r.disabled)return false;if(m(l,r==null?void 0:r.value,de.value))return false;return true}));l=l.concat(i)}}var o=[];if(Y.treeCheckable){if(Y.treeCheckStrictly===true||h(Y.showCheckedStrategy,["SHOW_ALL","SHOW_PARENT"])){o=l}else{o=l.filter((function(e){var r=e[de.children];return!(n(r)&&r.length>0)}))}}else{o=l}return{realTreeNodeList:o,realTreeNodeValueList:V(o,de)}}));var Ne=u.useCallbackRef((function(e,r,t){be(e);Q==null?void 0:Q(e);U==null?void 0:U(e,r,t)}));var Ee=u.useCallbackRef((function(e,r,t){var l=je(e,t),n=l.realTreeNodeList,a=l.realTreeNodeValueList;if(Y.treeCheckable){ue((function(e){var r=Re(a).concat(e||[]);return Array.from(new Set(r))}))}if(ve){var u=n.map((function(e){var r;var t=Te(e);return r={},r[me.label]=t==null?void 0:t.label,r[me.value]=t==null?void 0:t.value,r}));if(fe){Ne==null?void 0:Ne(u,n,t)}else{Ne==null?void 0:Ne(u[0],n[0],t)}}else{if(fe){Ne==null?void 0:Ne(a,n,t)}else{Ne==null?void 0:Ne(a[0],n[0],t)}}}));var xe=u.useCallbackRef((function(e){if(!e)return null;return e.map((function(e){var r=(M==null?void 0:M(o({},e)))||e;var t=r[de.children];var l=r[de.value];var n=r[de.label];var a=r[de.disabled]?r[de.disabled]:r.disabled;return w(b.TreeNode,o({},r,{disabled:a,value:l,title:n,key:""+l}),t&&t.length>0&&xe(t))}))}));var Ie=y((function(){var e=f(Se);if(e.length==0)return[];if(Y.treeCheckStrictly){if(oe.treeSelectorTiledArray.length===0){return e.map((function(e){return{label:e,value:e}}))}return e.map((function(e){var r,t;var n;var a;if(l(e)||p(e)){var u=m(oe.treeSelectorTiledArray,e,de.value);n=Te(u);a=e}else{n=Ae(e)}return{label:S((r=n)==null?void 0:r.label,a),value:S((t=n)==null?void 0:t.value,a)}}))}return V(Se,me)}),[Se,Y.treeCheckStrictly,me,oe.treeSelectorTiledArray,de.value,Te,Ae]);var Pe=y((function(){if(n(Ie)&&Ie.length===0){return undefined}return fe?Ie:Ie[0]}),[fe,Ie]);return j(b,o({dropdownStyle:{maxHeight:400,overflow:"auto"},showSearch:true,treeLine:{showLeafIcon:false},treeNodeFilterProp:"title",switcherIcon:j(t,{}),showArrow:true},Y,{className:r("v-tree-select-wrapper",Y.className),popupClassName:r("v-tree-select-wrapper-dropdown",Y.popupClassName),onChange:Ee,treeExpandedKeys:ae,value:Pe,loading:te,dropdownMatchSelectWidth:false,onTreeExpand:ke,style:o({width:"100%"},Y.style),suffixIcon:oe.requestStatus==="request-error"?j(e,{spin:te,onClick:qe}):undefined,notFoundContent:j(T,{status:oe.requestStatus,messageConfig:D,loading:te,errorButton:j(C,{type:"primary",onClick:qe,children:"重新获取数据"})}),children:xe(oe.treeSelectorList)}))};export{D as T};
|
|
3
|
+
//# sourceMappingURL=tree-selector-wrapper-9cd9da23.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tree-selector-wrapper-9cd9da23.js","sources":["@flatbiz/antd/src/tree-selector-wrapper/model.ts","@flatbiz/antd/src/tree-selector-wrapper/utils.ts","@flatbiz/antd/src/tree-selector-wrapper/tree-selector-wrapper.tsx"],"sourcesContent":["import { API, ModelType } from '@dimjs/model';\nimport { Model } from '@dimjs/model-react';\nimport { TAny, TPlainObject, TSetDefaultDefined } from '@flatbiz/utils';\nimport { TreeSelectProps } from 'antd';\nimport { TRequestStatus } from '../request-status';\n\nexport type ModelState = {\n treeSelectorList: TSetDefaultDefined<TreeSelectProps['treeData'], []>;\n treeSelectorTiledArray: TPlainObject[];\n queryIsEmpty: boolean;\n requestStatus?: TRequestStatus;\n};\n\ntype ModelActionParams = {\n setSelectBoxList: {\n treeSelectorList: ModelState['treeSelectorList'];\n treeSelectorTiledArray: ModelState['treeSelectorTiledArray'];\n };\n resetSelectBoxList: void;\n changeRequestStatus: TRequestStatus;\n};\n\nconst defaultState: ModelState = {\n treeSelectorList: [],\n treeSelectorTiledArray: [],\n queryIsEmpty: false,\n};\n\nconst TreeSelectorWrapperModel: ModelType<ModelState, ModelActionParams> = {\n actions: {\n setSelectBoxList: (params) => {\n return (state) => {\n state.treeSelectorList = params.treeSelectorList || [];\n state.treeSelectorTiledArray = params.treeSelectorTiledArray || [];\n state.requestStatus = 'request-success';\n };\n },\n resetSelectBoxList: () => {\n return (state) => {\n state.treeSelectorList = [];\n };\n },\n changeRequestStatus: (params) => {\n return (state) => {\n state.requestStatus = params;\n };\n },\n },\n state: defaultState,\n};\n\nconst treeSelectorWrapperModels: Record<string, API<ModelType<ModelState, ModelActionParams, TAny>>> = {};\n\n/**\n * ```\n * 使用方式\n * const [state, actions] = useTreeSelectorWrapperModel('key值').useStore();\n * ```\n */\nexport const treeSelectorWrapperModel = (key: string) => {\n if (!treeSelectorWrapperModels[key]) {\n treeSelectorWrapperModels[key] = Model(TreeSelectorWrapperModel);\n }\n return treeSelectorWrapperModels[key];\n};\n","import { isArray, isObject } from '@dimjs/lang';\nimport {\n isUndefinedOrNull,\n LabelValueItem,\n toArray,\n TPlainObject,\n treeLeafParentsArray,\n treeToTiledArray,\n} from '@flatbiz/utils';\nimport { TreeSelectProps } from 'antd';\nimport { dequal } from 'dequal';\n\nexport const getExpandedKeys = (\n value: string | number,\n treeList: TPlainObject[],\n fieldNames?: TreeSelectProps['fieldNames'],\n) => {\n if (!isArray(treeList) || treeList.length === 0) return [];\n const tiledArray = treeToTiledArray(treeList, fieldNames);\n return treeLeafParentsArray(value, tiledArray, true, { value: 'value', parentValue: 'parentValue' });\n};\n\nexport const getVauleList = (data, fieldNames: LabelValueItem<string>) => {\n let tempList = toArray<TPlainObject | string | number>(data);\n tempList = tempList.map((item) => {\n if (isObject(item)) return item[fieldNames.value];\n return item;\n });\n return tempList as Array<string | number>;\n};\n\nexport const array2map = (data, fieldNames: LabelValueItem<string>) => {\n const list = getVauleList(data, fieldNames);\n const map = {};\n list.forEach((item) => {\n map[item] = true;\n });\n return map;\n};\n\n/**\n * value的类型包括 string、number、Array<string | number>、{ label: string, value: string | nuber }\n * 将数组转成对象,深度比较时不用考虑顺序问题\n * @param value1\n * @param value2\n * @returns\n */\nexport const treeSelectorWrapperValueDeepEqual = (\n value1: any,\n value2: any,\n fieldNames: LabelValueItem<string>,\n) => {\n if (isUndefinedOrNull(value1) && isUndefinedOrNull(value2)) return true;\n const object1 = array2map(value1, fieldNames);\n const object2 = array2map(value2, fieldNames);\n const diff = dequal(object1, object2);\n return diff;\n};\n","import { CaretDownFilled, RedoOutlined } from '@ant-design/icons';\nimport { isArray, isString } from '@dimjs/lang';\nimport { classNames, extend } from '@dimjs/utils';\nimport {\n isNumber,\n isUndefinedOrNull,\n TAny,\n toArray,\n TPlainObject,\n treeToArray,\n valueIsEqual,\n} from '@flatbiz/utils';\nimport { hooks } from '@wove/react';\nimport { Button, TreeSelect, TreeSelectProps } from 'antd';\nimport { DependencyList, useMemo, useRef, useState } from 'react';\nimport { treeSelectorWrapperModel } from './model';\nimport './style.less';\n\nimport { arrayFind, getValueOrDefault } from '@flatbiz/utils';\nimport { dequal } from 'dequal';\nimport { fbaHooks } from '../fba-hooks';\nimport { RequestStatus, TRequestStatusProps } from '../request-status';\nimport { getExpandedKeys, getVauleList, treeSelectorWrapperValueDeepEqual } from './utils';\n\ntype TreeSelectorWrapperValue =\n | string\n | number\n | Array<string | number>\n | TPlainObject<string | number>\n | Array<TPlainObject<string | number>>;\n\ntype TreeSelectorServiceConfig = {\n params?: TPlainObject;\n requiredParamsKeys?: string[];\n onRequest?: (params?: TAny) => TAny;\n /**\n * 响应数据适配器\n */\n onRequestResultAdapter?: (respData: TAny) => TPlainObject[];\n};\n\nexport type TreeSelectorWrapperProps = Omit<\n TreeSelectProps,\n 'treeExpandedKeys' | 'treeData' | 'loading' | 'onTreeExpand' | 'onChange' | 'value' | 'fieldNames'\n> & {\n modelKey: string;\n fieldNames?: { label?: string; value?: string; children?: string; disabled?: string };\n /**\n * useEffect依赖项数组,用于重新发起获取接口数据\n */\n effectDependencyList?: DependencyList;\n /**\n * 请求服务需求的数据,当设置`treeSelectorList`后无效果\n */\n serviceConfig?: TreeSelectorServiceConfig;\n /**\n * 当设置treeSelectorList后,serviceConfig 将失效\n */\n treeSelectorList?: TreeSelectProps['treeData'];\n /**\n * treeSelectorList发生变更时触发\n */\n onTreeSelectorListChange?: (treeSelectorList?: TreeSelectProps['treeData']) => void;\n /**\n * 通过服务获取数据异常回调,当设置`treeSelectorList`后无效果\n */\n onTreeSelectorRequestError?: (error: Error) => void;\n /**\n * 添加全部选项\n * ```\n * 1. showAllOption = true,添加默认全部选项(value值为空字符串)\n * 2. 可自定义全部选项,例如:{ label: '全部', value: 'all' }\n * 3. 自定义字段会通过fieldNames转换后使用\n * 4. 多选操作时,最好不要设置全部选项\n * ```\n */\n showAllOption?: true | TPlainObject<string | number>;\n /**\n * 1. 当 treeCheckable = true && treeCheckStrictly = true,如果选择的数据中含有父节点,selectedValue、selectedList返回数据包含父节点\n * 2. 当 treeCheckable = true && treeCheckStrictly = false,selectedValue、selectedList返回的数据不包含父节点\n * 3. 当 treeCheckable = false,节点选择没有级联关系,selectedValue、selectedList返回的数据就是实际选择\n * 4. selectAllDataList 返回的数据都包含父节点\n * 5. 使用 onTreeItemAdapter 拼接label数据后,选中回填数据也是拼接后的\n * 6. triggerInfo 当前操作节点数据\n */\n onChangeHandle?: (\n selectedValue?: TreeSelectorWrapperValue,\n selectedData?: TPlainObject[] | TPlainObject,\n triggerInfo?: TPlainObject,\n ) => void;\n // // label渲染适配器\n // onLabelRenderAdapter?: (dataItem: TPlainObject) => string;\n /**\n * tree item 数据适配器\n */\n onTreeItemDataAdapter?: (dataItem: TPlainObject) => TPlainObject;\n // icon 无法实现、treeIcon不起作用4.20.0\n // showIcon?: boolean;\n // icon?: (data: TPlainObject) => ReactElement;\n\n requestMessageConfig?: TRequestStatusProps['messageConfig'];\n\n /**\n * value格式\n *```\n * 1. string 、number\n * 2. Array<string | number>\n * 3. lableInValue = true,根据labelInValueFieldNames配置格式\n * 4. lableInValue = true,Array<labelInValueFieldNames配置>\n * ```\n */\n value?: TreeSelectorWrapperValue;\n\n /**\n * treeCheckStrictly \tcheckable 状态下节点选择完全受控(父子节点选中状态不再关联),\n * 会使得 labelInValue 强制为 true\n */\n labelInValue?: boolean;\n /**\n * ```\n * lableInValue = true,onChange输出数据字段名称,默认:{ label: string; value: string|number }\n * ```\n */\n labelInValueFieldNames?: { label: string; value: string };\n /**\n * treeCheckStrictly = true模式下有效,点击父节点是否选中所有子节点,默认值:true\n */\n selectedParentCheckedAllChildrenList?: boolean;\n};\n\ntype TreeSelectorWrapperPropsInner = TreeSelectorWrapperProps & {\n onChange?: (selectedValue?: TreeSelectorWrapperValue) => void;\n};\n\n/**\n * 树选择器包装组件\n * @param props\n * @returns\n * ```\n * 1. 当设置treeSelectorList属性后,serviceConfig、onTreeSelectorListChange将失效\n * 2. 父节点默认不返回,需要返回请设置showCheckedStrategy\n * ```\n */\nexport const TreeSelectorWrapper = (props: TreeSelectorWrapperProps) => {\n const {\n serviceConfig,\n effectDependencyList,\n onTreeSelectorListChange,\n onTreeSelectorRequestError,\n // onLabelRenderAdapter,\n treeSelectorList,\n requestMessageConfig,\n modelKey,\n value,\n labelInValue: _labelInValue,\n labelInValueFieldNames,\n onTreeItemDataAdapter,\n selectedParentCheckedAllChildrenList = true,\n fieldNames,\n onChange,\n onChangeHandle,\n showAllOption,\n ...otherProps\n } = props as TreeSelectorWrapperPropsInner;\n /**\n * 不能使用key、defaultValue模式\n * 1. 勾选的和回填选中不相同情况,勾选后会渲染defaultValue模式后,弹框被关闭,操作体验存在问题\n */\n const hasTreeSelectorList = props.hasOwnProperty('treeSelectorList');\n const newServiceConfig = serviceConfig || {};\n const newEffectDependencyList = effectDependencyList || [];\n const [loading, setLoading] = fbaHooks.useSafeState(false);\n const [treeExpandedKeys, setTreeExpandedKeys] = useState<React.Key[]>();\n const [state, actions] = treeSelectorWrapperModel(modelKey).useStore();\n const requestPreKey = `request-progress-${modelKey}`;\n const isMultiple = otherProps.treeCheckable;\n /**\n * treeCheckStrictly \tcheckable 状态下节点选择完全受控(父子节点选中状态不再关联),\n * 会使得 labelInValue 强制为 true\n */\n const labelInValue = useMemo(() => {\n if (otherProps.treeCheckStrictly) return true;\n return _labelInValue;\n }, [_labelInValue, otherProps.treeCheckStrictly]);\n\n const fieldNamesMerge = useMemo(() => {\n return { label: 'label', value: 'value', children: 'children', disabled: 'disabled', ...fieldNames };\n }, [fieldNames]);\n\n const labelInValueFieldNamesMerge = useMemo(() => {\n return { label: 'label', value: 'value', ...labelInValueFieldNames };\n }, [labelInValueFieldNames]);\n\n const allOptionConfig = useMemo(() => {\n if (showAllOption) {\n const isTrue = showAllOption === true;\n return {\n label: isTrue ? '全部' : showAllOption.label,\n value: isTrue ? '' : showAllOption.value,\n };\n }\n return null;\n }, [showAllOption]);\n\n const [innerOperateValue, setInnerOperateValue] = useState<\n Array<TPlainObject> | string | number | Array<string | number> | TPlainObject\n >();\n const isFirstUseValueRef = useRef(true);\n\n fbaHooks.useEffectCustom(() => {\n if (isUndefinedOrNull(value) && isFirstUseValueRef.current) return;\n isFirstUseValueRef.current = false;\n if (state.treeSelectorList.length > 0) {\n if (!treeSelectorWrapperValueDeepEqual(value, innerOperateValue, labelInValueFieldNamesMerge)) {\n console.log(`modelKey:${modelKey} TreeSelectorWrapper key refresh`, value, innerOperateValue);\n const valueList = getVauleList(value, labelInValueFieldNamesMerge);\n setInnerOperateValue(valueList);\n // 重新计算 expandedKeys\n const expandedKeys = getTreeExpandedKeys(valueList, true);\n setTreeExpandedKeys(Array.from(new Set(expandedKeys)));\n }\n }\n }, [value, state.treeSelectorList]);\n\n const valueIsEmpty = (value: string | number) => {\n return value === '' || isUndefinedOrNull(value);\n };\n\n const serviceResponseHandle = (respData) => {\n const respDataList = newServiceConfig.onRequestResultAdapter\n ? newServiceConfig.onRequestResultAdapter(respData as unknown as TPlainObject)\n : respData;\n return respDataList as TPlainObject[];\n };\n\n const startDataSourceRequest = hooks.useCallbackRef(async () => {\n if (!newServiceConfig.onRequest) {\n throw new Error('onRequest 调用接口服务不能为空');\n }\n const requiredParamsKeys = newServiceConfig.requiredParamsKeys || [];\n const params = extend({}, newServiceConfig.params);\n const isEmpty = requiredParamsKeys.find((key) => {\n return valueIsEmpty(params[key] as string | number);\n });\n if (isEmpty) {\n console.warn(`TreeSelectorWrapper组件:参数:${requiredParamsKeys.join('、')}不能为空`);\n return;\n }\n try {\n setLoading(true);\n window[requestPreKey] = true;\n void actions.changeRequestStatus('request-progress');\n const _respData = await newServiceConfig.onRequest?.(params);\n const respData = serviceResponseHandle(_respData) as TreeSelectProps['treeData'];\n setLoading(false);\n window[requestPreKey] = false;\n onChangeSelectorList(respData || []);\n } catch (error) {\n setLoading(false);\n window[requestPreKey] = false;\n void actions.changeRequestStatus('request-error');\n onTreeSelectorRequestError?.(error);\n }\n });\n\n hooks.useCustomCompareEffect(\n () => {\n if (hasTreeSelectorList) return;\n // 当无依赖项时,如果存在缓存数据,就不在调用接口\n if (Boolean(newEffectDependencyList.length)) {\n // 内部主动清楚数据,被依赖的数据发生变更时,依赖组件数据清空\n onChangeSelectorList([]);\n void startDataSourceRequest();\n return;\n }\n const allState = treeSelectorWrapperModel(modelKey).getState();\n if (allState.requestStatus === 'request-success') {\n return;\n }\n // 判断相同的modelKey是否已经在请求数据中,避免重复请求\n if (!window[requestPreKey]) {\n void startDataSourceRequest();\n return;\n }\n },\n newEffectDependencyList,\n dequal,\n );\n\n const onChangeSelectorList = hooks.useCallbackRef((dataList: TAny[]) => {\n if (dataList?.length === 0 && state.treeSelectorList.length === 0) {\n void actions.setSelectBoxList({\n treeSelectorList: [],\n treeSelectorTiledArray: [],\n });\n onTreeSelectorListChange?.([]);\n return;\n }\n // 全部选项\n const tempItem = allOptionConfig\n ? {\n [fieldNamesMerge.label]: allOptionConfig.label,\n [fieldNamesMerge.value]: allOptionConfig.value,\n }\n : undefined;\n const newdataList = showAllOption ? [tempItem, ...dataList] : dataList;\n void actions.setSelectBoxList({\n treeSelectorList: newdataList,\n treeSelectorTiledArray: treeToArray(newdataList || [], fieldNamesMerge.children),\n });\n onTreeSelectorListChange?.(dataList);\n });\n\n fbaHooks.useEffectCustom(() => {\n if (hasTreeSelectorList) {\n onChangeSelectorList(treeSelectorList || []);\n }\n }, [treeSelectorList]);\n\n const onTreeExpand = hooks.useCallbackRef((expandedKeys) => {\n setTreeExpandedKeys(expandedKeys as string[]);\n });\n\n const onAgainRequest = hooks.useCallbackRef(() => {\n void startDataSourceRequest();\n });\n\n const getTreeExpandedKeys = hooks.useCallbackRef((valueList: Array<string | number>, refresh?: boolean) => {\n let newTreeExpandedKeys = [] as Array<string | number>;\n valueList.forEach((value) => {\n if (!refresh && treeExpandedKeys?.includes(value)) return;\n const targetList = getExpandedKeys(value, state.treeSelectorList, fieldNamesMerge);\n newTreeExpandedKeys = newTreeExpandedKeys.concat(targetList.map((item) => item.value));\n });\n return newTreeExpandedKeys;\n });\n\n /**\n * 数据源Item解析\n */\n const parseDataSourceItem = hooks.useCallbackRef((item?: TPlainObject | null) => {\n if (!item) return undefined;\n return {\n label: item?.[fieldNamesMerge.label],\n value: item?.[fieldNamesMerge.value],\n children: item?.[fieldNamesMerge.children],\n disabled: item?.['disabled'],\n };\n });\n /**\n * labelInValue模式入参value item解析\n */\n const parseLabelInValueItem = hooks.useCallbackRef((item?: TPlainObject | null) => {\n if (!item) return undefined;\n return {\n label: item?.[labelInValueFieldNamesMerge.label],\n value: item?.[labelInValueFieldNamesMerge.value],\n disabled: item?.['disabled'],\n };\n });\n\n const getResponseTreeNodeList = hooks.useCallbackRef((changeValue: TAny, triggerInfo: TPlainObject) => {\n const valueList = getVauleList(changeValue, { value: 'value', label: 'label' });\n let selectedTreeNodeList = [] as TPlainObject[];\n valueList.forEach((item) => {\n const target = arrayFind(state.treeSelectorTiledArray, item, fieldNamesMerge.value) as TPlainObject;\n if (!target) return;\n selectedTreeNodeList.push(target);\n });\n if (otherProps.treeCheckStrictly && selectedParentCheckedAllChildrenList) {\n const triggerNode = parseDataSourceItem(\n triggerInfo.checked\n ? arrayFind(state.treeSelectorTiledArray, triggerInfo.triggerValue, fieldNamesMerge.value)\n : null,\n );\n if (triggerNode && isArray(triggerNode.children) && triggerNode.children.length > 0) {\n // 判断为父节点\n const allChildrenList = treeToArray(triggerNode.children, fieldNamesMerge.children);\n const selectedChildrenList = allChildrenList.filter((item) => {\n const parseItem = parseDataSourceItem(item);\n if (parseItem?.disabled) return false;\n // 去重\n if (arrayFind(selectedTreeNodeList, parseItem?.value, fieldNamesMerge.value)) return false;\n return true;\n });\n selectedTreeNodeList = selectedTreeNodeList.concat(selectedChildrenList);\n }\n }\n let realTreeNodeList = [] as TPlainObject[];\n if (otherProps.treeCheckable) {\n if (\n otherProps.treeCheckStrictly === true ||\n valueIsEqual(otherProps.showCheckedStrategy, ['SHOW_ALL', 'SHOW_PARENT'])\n ) {\n // 返回包含父节点\n realTreeNodeList = selectedTreeNodeList;\n } else {\n // 返回不包含父节点\n realTreeNodeList = selectedTreeNodeList.filter((item) => {\n const children = item[fieldNamesMerge.children];\n return !(isArray(children) && children.length > 0);\n });\n }\n } else {\n realTreeNodeList = selectedTreeNodeList;\n }\n return {\n realTreeNodeList,\n realTreeNodeValueList: getVauleList(realTreeNodeList, fieldNamesMerge),\n };\n });\n\n const onRespChange = hooks.useCallbackRef((values, selectedValues, triggerInfo) => {\n setInnerOperateValue(values);\n onChange?.(values);\n onChangeHandle?.(values, selectedValues, triggerInfo);\n });\n\n /**\n * 根据treeCheckable、treeCheckStrictly、showCheckedStrategy等设置情况,判断返回数据是否包含父节点\n * 1. 当 treeCheckable = true,changeValue 数据格式为 { label,value }[]\n */\n const onInnerChange = hooks.useCallbackRef((changeValue: TAny, _data, triggerInfo: TPlainObject) => {\n const { realTreeNodeList, realTreeNodeValueList } = getResponseTreeNodeList(changeValue, triggerInfo);\n if (otherProps.treeCheckable) {\n setTreeExpandedKeys((prev) => {\n const mergeList = getTreeExpandedKeys(realTreeNodeValueList).concat(prev || []);\n return Array.from(new Set(mergeList));\n });\n }\n\n if (labelInValue) {\n const labelInValueList = realTreeNodeList.map((item) => {\n const parseItem = parseDataSourceItem(item);\n return {\n [labelInValueFieldNamesMerge.label]: parseItem?.label,\n [labelInValueFieldNamesMerge.value]: parseItem?.value,\n };\n });\n\n if (isMultiple) {\n onRespChange?.(labelInValueList, realTreeNodeList, triggerInfo);\n } else {\n onRespChange?.(labelInValueList[0], realTreeNodeList[0], triggerInfo);\n }\n } else {\n if (isMultiple) {\n onRespChange?.(realTreeNodeValueList, realTreeNodeList, triggerInfo);\n } else {\n onRespChange?.(realTreeNodeValueList[0], realTreeNodeList[0], triggerInfo);\n }\n }\n });\n\n const mapTree = hooks.useCallbackRef((data) => {\n if (!data) return null;\n return data.map((item) => {\n const itemAdapterData = onTreeItemDataAdapter?.({ ...item }) || item;\n const children = itemAdapterData[fieldNamesMerge.children];\n const value = itemAdapterData[fieldNamesMerge.value];\n const label = itemAdapterData[fieldNamesMerge.label];\n const disabled = itemAdapterData[fieldNamesMerge.disabled]\n ? itemAdapterData[fieldNamesMerge.disabled]\n : itemAdapterData.disabled;\n return (\n <TreeSelect.TreeNode\n {...itemAdapterData}\n disabled={disabled}\n value={value}\n title={label}\n key={`${value}`}\n >\n {children && children.length > 0 && mapTree(children)}\n </TreeSelect.TreeNode>\n );\n });\n });\n\n /**\n * 1. 当 treeCheckable = true,value 数据格式为 labelInValueFieldNames[]\n * 2. 其他情况 value 数据格式为 value[]\n */\n const renderValueList = useMemo(() => {\n const innerOperateValueList = toArray(innerOperateValue);\n if (innerOperateValueList.length == 0) return [];\n if (otherProps.treeCheckStrictly) {\n if (state.treeSelectorTiledArray.length === 0) {\n return innerOperateValueList.map((item) => ({ label: item, value: item }));\n }\n return innerOperateValueList.map((item) => {\n let targetParseItem: TPlainObject;\n let defualtValue;\n if (isString(item) || isNumber(item as TAny)) {\n const target = arrayFind(state.treeSelectorTiledArray, item as string, fieldNamesMerge.value);\n targetParseItem = parseDataSourceItem(target) as TPlainObject;\n defualtValue = item;\n } else {\n targetParseItem = parseLabelInValueItem(item as TPlainObject) as TPlainObject;\n }\n return {\n label: getValueOrDefault(targetParseItem?.label, defualtValue),\n value: getValueOrDefault(targetParseItem?.value, defualtValue),\n };\n });\n }\n return getVauleList(innerOperateValue, labelInValueFieldNamesMerge);\n }, [\n innerOperateValue,\n otherProps.treeCheckStrictly,\n labelInValueFieldNamesMerge,\n state.treeSelectorTiledArray,\n fieldNamesMerge.value,\n parseDataSourceItem,\n parseLabelInValueItem,\n ]);\n\n const treeSelectValue = useMemo(() => {\n if (isArray(renderValueList) && renderValueList.length === 0) {\n return undefined;\n }\n return isMultiple ? renderValueList : renderValueList[0];\n }, [isMultiple, renderValueList]);\n\n /**\n * 1. 使用 TreeNode 渲染节点,不能重写 fieldNames 配置\n * 2. 使用 TreeNode 是为了实现 TreeNode ICON\n */\n return (\n <TreeSelect\n dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}\n showSearch={true}\n treeLine={{ showLeafIcon: false }}\n treeNodeFilterProp=\"title\"\n switcherIcon={<CaretDownFilled />}\n showArrow\n {...otherProps}\n className={classNames('v-tree-select-wrapper', otherProps.className)}\n popupClassName={classNames('v-tree-select-wrapper-dropdown', otherProps.popupClassName)}\n onChange={onInnerChange}\n treeExpandedKeys={treeExpandedKeys}\n value={treeSelectValue}\n loading={loading}\n dropdownMatchSelectWidth={false}\n onTreeExpand={onTreeExpand}\n style={{ width: '100%', ...otherProps.style }}\n suffixIcon={\n state.requestStatus === 'request-error' ? (\n <RedoOutlined spin={loading} onClick={onAgainRequest} />\n ) : undefined\n }\n notFoundContent={\n <RequestStatus\n status={state.requestStatus}\n messageConfig={requestMessageConfig}\n loading={loading}\n errorButton={\n <Button type=\"primary\" onClick={onAgainRequest}>\n 重新获取数据\n </Button>\n }\n />\n }\n >\n {mapTree(state.treeSelectorList)}\n </TreeSelect>\n );\n};\n"],"names":["defaultState","treeSelectorList","treeSelectorTiledArray","queryIsEmpty","TreeSelectorWrapperModel","actions","setSelectBoxList","params","state","requestStatus","resetSelectBoxList","changeRequestStatus","treeSelectorWrapperModels","treeSelectorWrapperModel","key","Model","getExpandedKeys","value","treeList","fieldNames","_isArray","length","tiledArray","treeToTiledArray","treeLeafParentsArray","parentValue","getVauleList","data","tempList","toArray","map","item","_isObject","array2map","list","forEach","treeSelectorWrapperValueDeepEqual","value1","value2","isUndefinedOrNull","object1","object2","diff","dequal","TreeSelectorWrapper","props","_ref","serviceConfig","effectDependencyList","onTreeSelectorListChange","onTreeSelectorRequestError","requestMessageConfig","modelKey","_labelInValue","labelInValue","labelInValueFieldNames","onTreeItemDataAdapter","_ref$selectedParentCh","selectedParentCheckedAllChildrenList","onChange","onChangeHandle","showAllOption","otherProps","_objectWithoutPropertiesLoose","_excluded","hasTreeSelectorList","hasOwnProperty","newServiceConfig","newEffectDependencyList","_fbaHooks$useSafeStat","fbaHooks","useSafeState","loading","setLoading","_useState","useState","treeExpandedKeys","setTreeExpandedKeys","_treeSelectorWrapperM","useStore","requestPreKey","isMultiple","treeCheckable","useMemo","treeCheckStrictly","fieldNamesMerge","_extends","label","children","disabled","labelInValueFieldNamesMerge","allOptionConfig","isTrue","_useState2","innerOperateValue","setInnerOperateValue","isFirstUseValueRef","useRef","useEffectCustom","current","console","log","valueList","expandedKeys","getTreeExpandedKeys","Array","from","Set","valueIsEmpty","serviceResponseHandle","respData","respDataList","onRequestResultAdapter","startDataSourceRequest","_hooks","useCallbackRef","Promise","$return","$error","requiredParamsKeys","isEmpty","_respData","_respData2","onRequest","Error","_extend","find","warn","join","$Try_1_Post","$boundEx","$Try_1_Catch","error","window","resolve","then","$await_2","onChangeSelectorList","useCustomCompareEffect","Boolean","allState","getState","dataList","_ref2","tempItem","undefined","newdataList","concat","treeToArray","onTreeExpand","onAgainRequest","refresh","newTreeExpandedKeys","includes","targetList","parseDataSourceItem","parseLabelInValueItem","getResponseTreeNodeList","changeValue","triggerInfo","selectedTreeNodeList","target","arrayFind","push","triggerNode","checked","triggerValue","allChildrenList","selectedChildrenList","filter","parseItem","realTreeNodeList","valueIsEqual","showCheckedStrategy","realTreeNodeValueList","onRespChange","values","selectedValues","onInnerChange","_data","_getResponseTreeNodeL","prev","mergeList","labelInValueList","_ref3","mapTree","itemAdapterData","_createElement","TreeSelect","TreeNode","title","renderValueList","innerOperateValueList","_targetParseItem","_targetParseItem2","targetParseItem","defualtValue","_isString","isNumber","getValueOrDefault","treeSelectValue","_jsx","dropdownStyle","maxHeight","overflow","showSearch","treeLine","showLeafIcon","treeNodeFilterProp","switcherIcon","_CaretDownFilled","showArrow","className","_classNames","popupClassName","dropdownMatchSelectWidth","style","width","suffixIcon","_RedoOutlined","spin","onClick","notFoundContent","RequestStatus","status","messageConfig","errorButton","Button","type"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.v-tree-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.v-tree-wrapper .ant-tree-list-holder-inner{overflow:hidden}.v-tree-wrapper-loading{left:50%;position:absolute;top:50%;z-index:9}.v-tree-wrapper-search{flex:1}.v-tree-wrapper-tree{flex:1;
|
|
1
|
+
.v-tree-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.v-tree-wrapper .ant-tree-list-holder-inner{overflow:hidden}.v-tree-wrapper-loading{left:50%;position:absolute;top:50%;z-index:9}.v-tree-wrapper-search{flex:1}.v-tree-wrapper-tree-wrapper{flex:1;overflow:hidden;position:relative}.v-tree-wrapper-tree-wrapper>.ant-spin{left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:9}.v-tree-wrapper-tree{height:100%;overflow:scroll;position:relative}.v-tree-wrapper-tree .ant-tree-title{align-items:center;display:flex;flex:1;position:relative}.v-tree-wrapper-tree .tree-item-title{flex:1;margin-right:5px}.v-tree-wrapper-tree .anticon-more{display:none;font-weight:700}.v-tree-wrapper-tree .tree-item-title-operate{display:none}.v-tree-wrapper-tree .ant-tree-node-selected .anticon-more,.v-tree-wrapper-tree .ant-tree-node-selected .tree-item-title-operate{display:block}.v-tree-wrapper-tree .ant-tree-node-content-wrapper{display:flex}.tree-wrapper-empty{position:relative}.tree-wrapper-empty .ant-empty{margin:8px 0}.tree-wrapper-empty .ant-spin{left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.site-tree-search-value{color:red}.v-tree-item-disabled{opacity:.5}.tree-item-title-operate .ant-btn{height:auto;padding:0 3px;width:auto}.v-tree-wrapper-menu-hover .ant-tree-node-content-wrapper:hover .anticon-more,.v-tree-wrapper-menu-hover .ant-tree-node-content-wrapper:hover .tree-item-title-operate{display:block}.v-tree-wrapper-search-area{align-items:center;display:flex;margin-bottom:12px}.v-tree-wrapper-search-extra{margin-left:12px}
|
|
@@ -9,5 +9,5 @@ import './../input-search-wrapper/index.css';
|
|
|
9
9
|
import './../request-status/index.css';
|
|
10
10
|
import './index.css';
|
|
11
11
|
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
12
|
-
import e from"@ant-design/icons/es/icons/CaretDownFilled";import r from"@ant-design/icons/es/icons/MoreOutlined";import{classNames as t}from"@dimjs/utils/cjs/class-names";import{isArray as a}from"@dimjs/lang/cjs/is-array";import{extend as n}from"@dimjs/utils/cjs/extend";import{hooks as i}from"@wove/react/cjs/hooks";import{_ as l,a as u}from"../_rollupPluginBabelHelpers-1f4d8910.js";import{cloneState as s}from"@dimjs/model";import{treeToArray as o,treeToTiledArray as c,treeLeafParentsArray as d,isUndefinedOrNull as f,toArray as v,treeFilter as m}from"@flatbiz/utils";import{Tree as p,Button as h,message as g}from"antd";import{forwardRef as b,useState as y,useMemo as L,useRef as C,useImperativeHandle as w,Fragment as j,isValidElement as R}from"react";import{a as q}from"../button-operate-04d9185b.js";import{D as k}from"../dropdown-menu-wrapper-2c4b6cad.js";import{fbaHooks as N}from"../fba-hooks/index.js";import{I as S}from"../input-search-wrapper-10d4a9b9.js";import{R as T}from"../request-status-03fc60e2.js";import{Model as P}from"@dimjs/model-react";import{isObject as E}from"@dimjs/lang/cjs/is-object";import{dequal as A}from"dequal";import{jsxs as D,jsx as x}from"react/jsx-runtime";import"@dimjs/lang/cjs/is-undefined";import"@dimjs/lang/cjs/is-plain-object";import"@dimjs/lang/cjs/is-string";import"@dimjs/lang/cjs/is-promise";import"../button-wrapper-c63ea6fc.js";import"@ant-design/icons/es/icons/LoadingOutlined";import"../config-provider-wrapper-dfe8f592.js";import"antd/es/locale/en_US";import"antd/es/locale/zh_CN";import"dayjs";import"dayjs/locale/en";import"dayjs/locale/zh-cn";import"dayjs/plugin/advancedFormat";import"dayjs/plugin/customParseFormat";import"dayjs/plugin/localeData";import"dayjs/plugin/utc";import"dayjs/plugin/weekday";import"dayjs/plugin/weekOfYear";import"dayjs/plugin/weekYear";import"../fba-utils-1e895394.js";import"../use-responsive-point-21b8c601.js";var I={treeList:[],treeTiledArray:[],queryIsEmpty:false};var O={actions:{setTreeList:function e(r){return function(e){e.treeList=r.treeList||[];e.treeTiledArray=o(e.treeList,r.childrenName);e.requestStatus="request-success"}},resetTreeList:function e(){return function(e){e.treeList=[]}},changeRequestStatus:function e(r){return function(e){e.requestStatus=r;if(r==="request-error"){e.treeList=[]}}},treeListAppendChildren:function e(r){return function(e){var t=o(e.treeList,r.childrenName);var n=t.find((function(e){return e[r.valueName]===r.value}));if(n){if(a(r.appendList)&&r.appendList.length>0){n[r.childrenName]=r.appendList}else{n.isLeaf=true}}e.treeTiledArray=o(e.treeList,r.childrenName)}}},state:I};var V={};var K=function e(r){if(!V[r]){V[r]=P(O)}return V[r]};var F=function e(r,t,a){var n=c(t,a);return d(r,n,true,{value:"value",parentValue:"parentValue"})};var _=function e(r,t){var n=f(r)?[]:r;n=a(n)?n:[n];n=n.map((function(e){if(E(e))return e[t.value];return e}));return n};var M=function e(r,t){var a=_(r,t);var n={};a.forEach((function(e){n[e]=true}));return n};var U=function e(r,t,a){if(f(r)&&f(t))return true;var n=M(r,a);var i=M(t,a);var l=A(n,i);return l};var z=["serviceConfig","effectDependencyList","selectorTreeList","value","onChange","modelKey","checkableResponseParentNode","checkable","onSelectorTreeListChange","treeItemDataAdapter","searchValue","showSearch","searchPlaceholder","requestMessageConfig","labelInValueFieldNames","labelInValue","disabledCanUse","menuLayoutType","menuTriggerType","initRootExpand"];var B=b((function(o,d){var b=o.serviceConfig,P=o.effectDependencyList,E=o.selectorTreeList,A=o.value,I=o.onChange,O=o.modelKey,V=o.checkableResponseParentNode,M=V===void 0?true:V,B=o.checkable,W=o.onSelectorTreeListChange,Y=o.treeItemDataAdapter,H=o.searchValue,G=o.showSearch,J=o.searchPlaceholder,Q=o.requestMessageConfig,X=o.labelInValueFieldNames,Z=o.labelInValue,$=o.disabledCanUse,ee=o.menuLayoutType,re=o.menuTriggerType,te=o.initRootExpand,ae=l(o,z);var ne=o.hasOwnProperty("selectorTreeList");var ie=b||{};var le=P||[];var ue=y(),se=ue[0],oe=ue[1];var ce=K(O).useStore(),de=ce[0],fe=ce[1];var ve=N.useSafeState(false),me=ve[0],pe=ve[1];var he="request-progress-"+o.modelKey;var ge=L((function(){return u({label:"label",value:"value",children:"children"},o.fieldNames)}),[o.fieldNames]);var be=C();var ye=ee===undefined?"fold":ee;var Le=re===undefined?"click":re;var Ce=B===true;var we=L((function(){return u({label:"label",value:"value"},X)}),[X]);var je=y(),Re=je[0],qe=je[1];var ke=C(true);var Ne=y(0),Se=Ne[0],Te=Ne[1];var Pe=C();var Ee=L((function(){var e=_(A,we);return e}),[we,A]);N.useEffectCustom((function(){if(f(A)&&ke.current||de.treeList.length==0)return;ke.current=false;if(!U(A,Pe.current,we)){console.log("modelKey:"+O+" TreeWrapper key refresh",A,Pe.current);Pe.current=Ce?Ee:Ee[0];var e=Oe(Ee,true);oe(Array.from(new Set(e)));be.current=Ee;Te(Date.now())}}),[A,de.treeList]);var Ae=function e(r){return r===""||f(r)};var De=function e(r){var t=ie.onRequestResultAdapter?ie.onRequestResultAdapter(r):r;return t};N.useEffectCustom((function(){qe(H)}),[H]);var xe=i.useCallbackRef((function(){return new Promise((function(e,r){var t,a,i,l,u;var s=function(){try{return e()}catch(e){return r(e)}};var o=function(e){try{pe(false);void g.error(e.message||"数据查询异常...");return s()}catch(e){return r(e)}};try{if(!ie.onRequest){throw new Error("onRequest 调用接口服务不能为空")}t=ie.requiredParamsKeys;a=n({},ie.params);if(t){i=t.find((function(e){return Ae(a[e])}));if(i){console.warn("TreeWrapper组件:参数:"+t.join("、")+"不能为空");return e()}}var c=function(){try{return s()}catch(e){return o(e)}};var d=function(e){try{window[he]=false;pe(false);void fe.changeRequestStatus("request-error");return c()}catch(e){return o(e)}};try{pe(true);return Promise.resolve(fe.changeRequestStatus("request-progress")).then((function(e){try{window[he]=true;return Promise.resolve(ie.onRequest==null?void 0:ie.onRequest(a)).then((function(e){try{l=e;u=De(l);Ie(u||[]);pe(false);if(te&&v(u).length){oe([u==null?void 0:u[0][ge.value]])}window[he]=false;return c()}catch(e){return d(e)}}),d)}catch(e){return d(e)}}),d)}catch(e){d(e)}}catch(e){o(e)}}))}));N.useEffectCustom((function(){if(ne)return;if(Boolean(le.length)){void xe();return}var e=K(O).getState();if(e.requestStatus==="request-success"){return}if(!window[he]){void xe();return}}),le);N.useEffectCustom((function(){if(ne){Ie(E||[])}}),[E]);var Ie=i.useCallbackRef((function(e){if((e==null?void 0:e.length)===0&&de.treeList.length===0){void fe.changeRequestStatus("request-success");return}void fe.setTreeList({treeList:e||[],childrenName:ge.children});W==null?void 0:W(e)}));var Oe=i.useCallbackRef((function(e,r){var t=[];e.forEach((function(e){if(!r&&se!=null&&se.includes(e))return;var a=F(e,de.treeList,ge);t=t.concat(a.map((function(e){return e.value})))}));return t}));i.useUpdateEffect((function(){if(Re){var e=c(de.treeList||[],ge);var r=e.filter((function(e){var r;return(r=e.label)==null?void 0:r.includes(Re||"")}));oe((function(e){var t=Oe(r.map((function(e){return e.value}))).concat(e||[]);return Array.from(new Set(t))}))}else{oe([])}}),[Re]);w(d,(function(){return{onClearSelectorList:function e(){void fe.resetTreeList()},getTreeDataList:function e(){return de.treeList}}}));var Ve=i.useCallbackRef((function(e){oe(e)}));var Ke=i.useCallbackRef((function(e,r,t){Pe.current=e;var n=f(r)?[]:a(r)?r:[r];if(f(e)){I==null?void 0:I(e,r,t);return}if(Z){var i=we.label;var l=we.value;var u=n.map((function(e){var r;return r={},r[i]=e[ge.label],r[l]=e[ge.value],r}));if(a(e)){I==null?void 0:I(u,n,t)}else{I==null?void 0:I(u[0],n[0],t)}}else{if(a(e)){I==null?void 0:I(e,n,t)}else{I==null?void 0:I(e,n[0],t)}}}));var Fe=i.useCallbackRef((function(e,r){var t=o.checkStrictly?e.checked:e;t=f(e)?[]:e;t=a(t)?t:[t];var n=[];var i=[];var l=[];var u=[];t.forEach((function(e){var r=de.treeTiledArray.find((function(r){return r[ge.value]===e}));if(!r)return;var t=r==null?void 0:r[ge.children];if(!a(t)||t.length===0){n.push(r);i.push(r[ge.value])}l.push(r);u.push(r[ge.value])}));if(B){oe((function(e){var r=Oe(i).concat(e||[]);return Array.from(new Set(r))}));if(!M&&!o.checkStrictly){Ke(i,n,l)}else{Ke(u,l,l)}}else{if(t[0]){var s=l.find((function(e){return e[ge.value]===t[0]}));Ke(t[0],s,[s])}else{var c=r.node[ge.value];var d=de.treeTiledArray.find((function(e){return e[ge.value]===c}));Ke(undefined,d,[d])}}}));var _e=i.useCallbackRef((function(e){return Y==null?void 0:Y(e)}));var Me=L((function(){var e=function e(r){return r==null?void 0:r.map((function(r){var n;var i=(_e==null?void 0:_e(r))||r;var l=$?undefined:i.disabled;var s=i[ge.label];var o;if(Re){var c=s.indexOf(Re);var d=s.substring(0,c);var f=s.slice(c+Re.length);o=c>-1?D("span",{className:t({"v-tree-item-disabled":i.disabled}),children:[d,x("span",{className:"site-tree-search-value",children:Re}),f]}):null}if(!o){o=x("span",{className:t({"v-tree-item-disabled":i.disabled}),children:s})}var v=i[ge.children];return u({},i,(n={disabled:l},n[ge.label]=o,n._treeItemName=s,n._disabled=i.disabled,n[ge.children]=a(v)&&v.length>0?e(v):undefined,n))}))};var r=s(de.treeList||[]);if(Re){return e(m(s(de.treeList||[]),(function(e){var r;var t=(r=e[ge.label])==null?void 0:r.toLowerCase();return t.indexOf(Re.toLowerCase())>=0})))}return e(r)}),[de.treeList,_e,$,ge.label,ge.children,Re]);var Ue=i.useCallbackRef((function(e){return new Promise((function(r,t){return new Promise((function(a,n){var i,l,u,s;if(e[ge.children]){r();return a()}var c=function(){try{return a()}catch(e){return n(e)}};var d=function(e){try{void g.error(e.message||"数据加载异常...");t();return c()}catch(e){return n(e)}};try{return Promise.resolve((i=o.loadDataServiceConfig)==null?void 0:i.onRequest==null?void 0:i.onRequest((l=o.loadDataServiceConfig)==null?void 0:l.getParams==null?void 0:l.getParams(e))).then((function(t){try{u=t;s=ie.onRequestResultAdapter?ie.onRequestResultAdapter(u):u;void fe.treeListAppendChildren({value:e[ge.value],appendList:s,childrenName:ge.children,valueName:ge.value}).then((function(e){Ie(e.treeList);r()}));return c()}catch(e){return d(e)}}),d)}catch(e){d(e)}}))}))}));var ze=i.useCallbackRef((function(e){var r=e==null?void 0:e[ge.children];var t=o.loadDataFlag;var a=t?!e.isLeaf:false;var n=r&&r.length>0||a;return!n}));var Be=i.useCallbackRef((function(e){var a,n;var i=e._treeItemName||e[ge.label];if(ye==="fold"){var l;var s=[];if((l=o.menuOptions)!=null&&l.fold){var c,d,f;s=((c=o.menuOptions)==null?void 0:(d=c[ye])==null?void 0:d.call(c,u({},e,(f={},f[ge.label]=i,f))))||[]}else{var v;s=(o.getMenuOptions==null?void 0:o.getMenuOptions(u({},e,(v={},v[ge.label]=i,v))))||[]}return D(j,{children:[x("span",{className:"tree-item-title",children:e==null?void 0:e[ge.label]}),s.length>0&&x(k,{menuList:s,children:x(r,{})})]})}var m=(a=o.menuOptions)==null?void 0:a.tile==null?void 0:a.tile(u({},e,(n={},n[ge.label]=i,n)));return D(j,{children:[x("span",{className:"tree-item-title",children:e==null?void 0:e[ge.label]}),m?x(q,u({},m,{gap:5,className:t("tree-item-title-operate",m.className)})):null]})}));var We=i.useDebounceCallback((function(e){qe(e);o.onSearchValueChange==null?void 0:o.onSearchValueChange(e)}),300);var Ye=i.useCallbackRef((function(e){We(e.target.value)}));var He=i.useCallbackRef((function(e){if(!o.icon)return null;if(R(o.icon))return o.icon;var r=ze(e.data);return o.icon(u({},e,{isParent:!r,isLeaf:r}))}));var Ge=L((function(){return{title:ge.label,key:ge.value,children:ge.children}}),[ge]);var Je=Me.length>0&&de.requestStatus!=="request-error";var Qe=u({showLine:{showLeafIcon:false},titleRender:Be,blockNode:true,switcherIcon:x(e,{})},ae,{fieldNames:Ge,expandedKeys:se,treeData:Me,onExpand:Ve,loadData:o.loadDataFlag?Ue:undefined,style:u({width:"100%"},ae.style),icon:He});var Xe={onCheck:Fe,checkable:B,defaultCheckedKeys:be.current};var Ze={onSelect:Fe,multiple:false,defaultSelectedKeys:be.current};var $e=B?Xe:Ze;var er=t("v-tree-wrapper","v-tree-wrapper-menu-"+Le);var rr=de.treeList.length>0&&!Je&ℜreturn D("div",{className:er,children:[!!G&&D("div",{className:"v-tree-wrapper-search-area",children:[x(S,{className:"v-tree-wrapper-search",placeholder:J,onChange:Ye,value:H,allowClear:true}),!!o.searchExtraElement&&x("span",{className:"v-tree-wrapper-search-extra",children:o.searchExtraElement})]}),Je?x(p,u({},$e,Qe,{className:"v-tree-wrapper-tree"}),Se):x(T,{status:de.requestStatus,loading:me,messageConfig:u({"request-success":rr?"搜索结果为空":"暂无数据"},Q),errorButton:x(h,{type:"primary",onClick:xe,children:"重新获取数据"})})]})}));B.defaultProps={disabledCanUse:true};export{B as TreeWrapper};
|
|
12
|
+
export{T as TreeWrapper}from"../tree-wrapper-85aa72d7.js";import"@ant-design/icons/es/icons/CaretDownFilled";import"@ant-design/icons/es/icons/MoreOutlined";import"@dimjs/utils/cjs/class-names";import"@dimjs/lang/cjs/is-array";import"@dimjs/utils/cjs/extend";import"@wove/react/cjs/hooks";import"../_rollupPluginBabelHelpers-1f4d8910.js";import"@dimjs/model";import"antd";import"react";import"@flatbiz/utils";import"../button-operate-6add2cbf.js";import"@dimjs/lang/cjs/is-undefined";import"@dimjs/lang/cjs/is-plain-object";import"@dimjs/lang/cjs/is-string";import"@dimjs/lang/cjs/is-promise";import"../button-wrapper-c63ea6fc.js";import"@ant-design/icons/es/icons/LoadingOutlined";import"../config-provider-wrapper-dfe8f592.js";import"antd/es/locale/en_US";import"antd/es/locale/zh_CN";import"dayjs";import"dayjs/locale/en";import"dayjs/locale/zh-cn";import"dayjs/plugin/advancedFormat";import"dayjs/plugin/customParseFormat";import"dayjs/plugin/localeData";import"dayjs/plugin/utc";import"dayjs/plugin/weekday";import"dayjs/plugin/weekOfYear";import"dayjs/plugin/weekYear";import"../fba-hooks/index.js";import"../use-responsive-point-21b8c601.js";import"react/jsx-runtime";import"../fba-utils-1e895394.js";import"../dropdown-menu-wrapper-2c4b6cad.js";import"../input-search-wrapper-10d4a9b9.js";import"../request-status-03fc60e2.js";import"@dimjs/model-react";import"@dimjs/utils/cjs/tree";import"@dimjs/lang/cjs/is-object";import"dequal";
|
|
13
13
|
//# sourceMappingURL=index.js.map
|