@cloudbase/weda-ui 3.22.0 → 3.22.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/style/weda-ui.min.css +1 -1
- package/dist/web/components/chart/statisticsCard/index.js +9 -6
- package/dist/web/components/form/uploader/util.js +1 -1
- package/dist/web/components/jsx/index.js +18 -5
- package/dist/web/components/wd-cascader/cascader.js +8 -5
- package/dist/web/components/wd-date/wd-date.js +6 -3
- package/dist/web/components/wd-date-range/wd-date-range.js +10 -12
- package/dist/web/components/wd-form/form-utils.d.ts +1 -0
- package/dist/web/components/wd-form/form-utils.js +17 -0
- package/dist/web/components/wd-form/hooks/use-remote-value.js +1 -1
- package/dist/web/components/wd-form/index.js +14 -39
- package/dist/web/components/wd-select/wd-select.js +9 -5
- package/dist/web/components/wd-select-multiple/wd-select-multiple.js +9 -5
- package/dist/web/components/wd-time/wd-time.js +6 -3
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
@cloudbase/weda-ui v3.22.
|
|
2
|
+
@cloudbase/weda-ui v3.22.2
|
|
3
3
|
*/
|
|
4
4
|
@charset "UTF-8";@media (min-width:1024px){.weda-ui .weui-cells{font-size:1em}.weui .weui-cell_active:active{background-color:unset!important}}@font-face{font-family:lcap-icon;font-weight:400;font-style:normal;src:url(data:application/font-woff2;charset=utf-8;base64,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) format('woff2')}.wd-form--vertical-left .wedatea2td-form .weda-formcells__pc.horizontal,.wd-form--vertical-right .wedatea2td-form .weda-formcells__pc.horizontal,.wedatea2td-form--vertical .wd-form--horizontal-left .wd-form-item-wrap,.wedatea2td-form--vertical .wd-form--horizontal-right .wd-form-item-wrap,.wedatea2td-form--vertical .wd-form-item.wd-form-item--horizontal-left .wd-form-item-wrap,.wedatea2td-form--vertical .wd-form-item.wd-form-item--horizontal-right .wd-form-item-wrap,.wedatea2td-form--vertical .wedatea2td-form .weda-formcells__pc.horizontal{flex-direction:column}.g-swiper-item>div>*{max-width:100%;max-height:100%;object-fit:cover;max-width:100%;object-fit:cover;max-width:100%;max-height:100%;object-fit:cover;width:100%;height:auto;max-width:100%;object-fit:cover}.form-detail-wrap .form-detail-content-wrap .form-detail-group-header-container{display:flex;align-items:center;justify-content:space-between}.weda-graphic-card .weda-graphic-card__col .weda-graphic-card__title{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.weda-graphic-card .weda-graphic-card__col .weda-graphic-card__desc{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.weda-menu .wedatea2td-menu--light .wedatea2td-menu__list li.is-selected>.wedatea2td-menu__item:hover,.wedatea2td-drawer .wedatea2td-menu--light .wedatea2td-menu__list li .wedatea2td-menu__item:hover{background-color:var(--weda-navigation-menu-hover-color)}.weda-menu-mobile .weda-menu__wrapper{display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 2px rgba(0,0,0,.05)}.weda-menu .wedatea2td-menu__text .menu-text,.weda-menu__drawer .wedatea2td-menu__text .menu-text{display:flex;justify-content:center;align-items:center}.ExEditor-basic{box-sizing:border-box;min-height:var(--exeditor-editor-min-height,100px);background:var(--exeditor-editor-background,#fff);padding:var(--exeditor-editor-padding,20px);white-space:pre-wrap;--exeditor-hr-color:var(--exeditor-basic-hr-color, #e7e7e7);--exeditor-link-color:var(--exeditor-basic-link-color, #0052ff);--exeditor-selected-outline:var(--exeditor-basic-selected-outline, 2px solid #68cef8);--exeditor-selected-background:var(--exeditor-basic-selected-background, rgba(24, 144, 255, 0.3));--exeditor-selected-cell-background:var(--exeditor-basic-selected-cell-background, rgba(24, 144, 255, 0.15));--exeditor-formula-vertical-align:var(--exeditor-basic-formula-vertical-align, middle)}@media (max-width:1024px){.g-swiper .g-swiper__turn-next,.g-swiper .g-swiper__turn-pre{display:none}.modal-table-delete .wedatea2td-dialog__inner,.model-relation-selector-modal .wedatea2td-dialog__inner,.wedatea2td-dialog__inner{min-width:0;width:90%;margin:10px 0}.wedatea2td-form.model-form{width:100%}}.markdown-body .octicon{fill:currentColor}.markdown-body pre{word-wrap:normal}.wd-form-item.wd-pc-rich-text-root .ExEditor-basic,.wd-form-item.wd-pc-rich-text-root .exeditor-toolbar{background-color:inherit}.wd-add-relation-button-wrap{display:flex;align-items:center;color:var(--wd-color-brand,#0052d9);white-space:pre-wrap}.weda-import-csv-file-modal .file-json-map-wrap{display:flex;flex-direction:column;box-sizing:border-box}.weda-import-csv-file-modal .import-file-result-wrap .error-container{display:flex;flex-direction:column}.weda-import-csv-file-modal .import-file-result-wrap .error-content{flex:1}.wd-table-wrap-filter .wedatea2td-input:focus,.wd-table-wrap-filter .wedatea2td-input:hover,.wd-table-wrap-filter .wedatea2td-textarea-group:focus,.wd-table-wrap-filter .wedatea2td-textarea-group:hover,.wd-table-wrap-filter .wedatea2td-textarea:focus,.wd-table-wrap-filter .wedatea2td-textarea:hover,.wedatea2td-overlay .wedatea2td-checkbox:focus,.wedatea2td-overlay .wedatea2td-checkbox:hover,.wedatea2td-overlay input[type=checkbox]:focus,.wedatea2td-overlay input[type=checkbox]:hover{border-color:var(--wd-color-brand,#0052d9)}.weda-ui_mapChoose_search_input_clear{display:flex;justify-content:center}.form-select-map .wedatea2td-dialog__inner{box-shadow:none;min-width:100vw!important}.weda-ui-custom-calendar-op__end,.weda-ui-custom-calendar-op__start{display:flex;align-items:center}.weui-tag span{word-wrap:break-word;word-break:break-word}.weda-ui-user-select-container-list__start .depart-tree .wedatea2td-tree__node.is-selected>.wedatea2td-tree__node-content,.weda-ui-user-select-container-list__start .depart-tree .wedatea2td-tree__node.is-selected>.wedatea2td-tree__node-content .wedatea2td-tree__label,.weda-ui-user-select-container-list__start .wedatea2td-tree.wedatea2td-tree--checkbox-separate .wedatea2td-tree__node.is-selected>.wedatea2td-tree__node-content .wedatea2td-tree__label .wedatea2td-tree__label-title{background-color:var(--wd-color-brand-light,#d4e3fc)}.weda-select-user-dept-breadcrumb{display:flex;align-items:center}.form-location-con_disabled{opacity:.4}body{font-size:var(--wd-font-base)}@font-face{font-family:wd-lcap-icon;font-weight:400;font-style:normal;src:url(data:application/font-woff2;charset=utf-8;base64,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) format("woff2")}.t-icon{speak:none;text-transform:none;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.wd-space-align-items--flex-start{align-items:flex-start;align-items:center;align-items:flex-end}.wd-space-justify-content--flex-start{justify-content:flex-start;justify-content:center;justify-content:flex-end}.wd-btn{--wd-btn-sm-padding:0.0625rem calc(var(--wd-space-base) * 2);--wd-btn-md-padding:0.25rem calc(var(--wd-space-base) * 4);--wd-btn-lg-padding:0.4375rem calc(var(--wd-space-base) * 6);--wd-btn-margin-top:0;--wd-btn-margin-top:0;--wd-btn-font-size-sm:var(--wd-font-size-2);--wd-btn-line-height-sm:1.5;--wd-btn-min-height-sm:24px;--wd-btn-font-size-md:var(--wd-font-size-3);--wd-btn-line-height-md:1.5;--wd-btn-min-height-md:32px;--wd-btn-font-size-lg:var(--wd-font-size-4);--wd-btn-line-height-lg:1.5;--wd-btn-min-height-lg:40px;--wd-btn-icon-space-sm:var(--wd-space-base);--wd-btn-icon-space-md:calc(var(--wd-space-base) * 2);--wd-btn-icon-space-lg:calc(var(--wd-space-base) * 3);--wd-btn-icon-size-sm:calc(var(--wd-btn-font-size-sm) + 0.125rem);--wd-btn-icon-size-md:calc(var(--wd-btn-font-size-md) + 0.125rem);--wd-btn-icon-size-lg:calc(var(--wd-btn-font-size-lg) + 0.25rem);--wd-btn-border-radius:var(--wd-border-radius);--wd-btn-color-text:var(--wd-color-text-default);--wd-btn-color-text-inverse:var(--wd-color-text-inverse);--wd-btn-color-text-hover:var(--wd-color-text-default);--wd-btn-color-text-active:var(--wd-color-text-default);--wd-btn-color-text-focus:var(--wd-color-text-default);--wd-btn-color-text-disabled:var(--wd-color-text-disabled);--wd-btn-color-brand:var(--wd-color-brand);--wd-btn-color-brand-hover:var(--wd-color-brand-hover);--wd-btn-color-brand-active:var(--wd-color-brand-active);--wd-btn-color-brand-focus:var(--wd-color-brand-focus);--wd-btn-color-brand-disabled:var(--wd-color-brand-disabled);--wd-btn-color-warning:var(--wd-color-warning);--wd-btn-color-warning-hover:var(--wd-color-warning-hover);--wd-btn-color-warning-active:var(--wd-color-warning-active);--wd-btn-color-warning-focus:var(--wd-color-warning-focus);--wd-btn-color-warning-disabled:var(--wd-color-warning-disabled);--wd-btn-color-error:var(--wd-color-error);--wd-btn-color-error-hover:var(--wd-color-error-hover);--wd-btn-color-error-active:var(--wd-color-error-active);--wd-btn-color-error-focus:var(--wd-color-error-focus);--wd-btn-color-error-disabled:var(--wd-color-error-disabled);--wd-btn-color-gray:var(
|
|
5
5
|
--wd-color-gray-1
|
|
@@ -148,16 +148,19 @@ export default function StatisticsCard({ dataSource, filterData, field, operatio
|
|
|
148
148
|
],
|
|
149
149
|
};
|
|
150
150
|
try {
|
|
151
|
-
if ((dataSource === null || dataSource === void 0 ? void 0 : dataSource.type) === 'database') {
|
|
151
|
+
if ((dataSource === null || dataSource === void 0 ? void 0 : dataSource.type) === 'database' && (dataSource === null || dataSource === void 0 ? void 0 : dataSource.name)) {
|
|
152
152
|
return await (appCloud === null || appCloud === void 0 ? void 0 : appCloud.callWedaApi({
|
|
153
153
|
action: 'DescribeChartCardData',
|
|
154
154
|
data: params,
|
|
155
155
|
}));
|
|
156
156
|
}
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
157
|
+
if ((dataSource === null || dataSource === void 0 ? void 0 : dataSource.name) && (dataSource === null || dataSource === void 0 ? void 0 : dataSource.methodName)) {
|
|
158
|
+
return await (appCloud === null || appCloud === void 0 ? void 0 : appCloud.callDataSource({
|
|
159
|
+
dataSourceName: dataSource === null || dataSource === void 0 ? void 0 : dataSource.name,
|
|
160
|
+
methodName: dataSource === null || dataSource === void 0 ? void 0 : dataSource.methodName,
|
|
161
|
+
}));
|
|
162
|
+
}
|
|
163
|
+
return [];
|
|
161
164
|
}
|
|
162
165
|
catch (e) {
|
|
163
166
|
errorHandler({
|
|
@@ -205,5 +208,5 @@ export default function StatisticsCard({ dataSource, filterData, field, operatio
|
|
|
205
208
|
[`${CLASS_PREFIX}-mobile`]: platform === 'h5',
|
|
206
209
|
[`${CLASS_PREFIX}-pc`]: platform !== 'h5',
|
|
207
210
|
});
|
|
208
|
-
return (_jsx(ConfigProvider, { classPrefix: "wedatea2td", children: _jsx("div", { id: id, role: role, className: cls, style: style, onClick: (e) => events.tap({}, { originEvent: e }), children: _jsxs("div", { className: `${CLASS_PREFIX}__wrapper`, children: [_jsx("div", { className: `${CLASS_PREFIX}__title`, children: label }), _jsx("div", { className: `${CLASS_PREFIX}__detail`, children: _jsxs("div", { className: `${CLASS_PREFIX}__count`, children: [isShowUnit ? formatNumber(val / unit, decimalDigits) : val, isShowUnit &&
|
|
211
|
+
return (_jsx(ConfigProvider, { classPrefix: "wedatea2td", children: _jsx("div", { id: id, role: role, className: cls, style: style, onClick: (e) => events.tap({}, { originEvent: e }), children: _jsxs("div", { className: `${CLASS_PREFIX}__wrapper`, children: [_jsx("div", { className: `${CLASS_PREFIX}__title`, children: label }), _jsx("div", { className: `${CLASS_PREFIX}__detail`, children: _jsxs("div", { className: `${CLASS_PREFIX}__count`, children: [isShowUnit ? formatNumber(val / unit, decimalDigits) : val, isShowUnit && _jsx("label", { className: `${CLASS_PREFIX}__unit`, children: suffix })] }) })] }) }) }));
|
|
209
212
|
}
|
|
@@ -58,7 +58,7 @@ const uploadToTcb = async (item, props) => {
|
|
|
58
58
|
const tcb = await getCloudInstance();
|
|
59
59
|
let _uploadPath = getDefaultUploadPath(uploadPath);
|
|
60
60
|
if (customUploadPath) {
|
|
61
|
-
_uploadPath = `${_uploadPath}/${sanitizeFilename(customUploadPath, '')}
|
|
61
|
+
_uploadPath = `${_uploadPath}/${sanitizeFilename(customUploadPath, '')}`;
|
|
62
62
|
}
|
|
63
63
|
const cloudPath = `${_uploadPath}/${randomStr()}-${(_a = file === null || file === void 0 ? void 0 : file.name) === null || _a === void 0 ? void 0 : _a.replace(filenameRegex, '-')}`;
|
|
64
64
|
const res = await tcb.uploadFile({
|
|
@@ -8,7 +8,8 @@ import * as PropTypes from 'prop-types';
|
|
|
8
8
|
// // eslint-disable-next-line tree-shaking/no-side-effects-in-initialization
|
|
9
9
|
// window['Tea'] = teaComponent;
|
|
10
10
|
export default function JSX(props) {
|
|
11
|
-
|
|
11
|
+
const [ready, setReady] = React.useState(false);
|
|
12
|
+
let { jsCode, $node } = props;
|
|
12
13
|
if (!jsCode) {
|
|
13
14
|
jsCode = `
|
|
14
15
|
return function JSX(props) {
|
|
@@ -16,10 +17,22 @@ export default function JSX(props) {
|
|
|
16
17
|
}
|
|
17
18
|
`;
|
|
18
19
|
}
|
|
19
|
-
const MyComponent = React.useMemo(() => new Function(window['__POWERED_BY_QIANKUN__']
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
20
|
+
const MyComponent = React.useMemo(() => new Function(window['__POWERED_BY_QIANKUN__'] ? `with(window.proxy || window){${jsCode}}` : jsCode)(), [jsCode]);
|
|
21
|
+
const cachedProxy = React.useMemo(() => new Proxy(window.$w, {
|
|
22
|
+
get(target, prop) {
|
|
23
|
+
try {
|
|
24
|
+
const $w = $node._getWidgetAPIContext();
|
|
25
|
+
return $w[prop];
|
|
26
|
+
}
|
|
27
|
+
catch (e) {
|
|
28
|
+
return target[prop];
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
}), [$node]);
|
|
32
|
+
React.useEffect(() => {
|
|
33
|
+
setReady(true);
|
|
34
|
+
}, []);
|
|
35
|
+
return (_jsx("div", { className: props.className, style: props.style, children: ready && _jsx(MyComponent, { ...props, "$w": cachedProxy }) }));
|
|
23
36
|
}
|
|
24
37
|
JSX.propTypes = {
|
|
25
38
|
/**
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import React, { forwardRef, useState, useCallback, useMemo, useEffect
|
|
2
|
+
import React, { forwardRef, useState, useCallback, useMemo, useEffect } from 'react';
|
|
3
3
|
import { Cascader, ConfigProvider } from 'tea-component';
|
|
4
|
-
import { useHandleClear, useFixedIcon, SELECT_ICON_H5, SELECT_ICON_PC
|
|
4
|
+
import { useHandleClear, useFixedIcon, SELECT_ICON_H5, SELECT_ICON_PC } from '../../utils/hooks/useFormLegacy';
|
|
5
5
|
import { useFormInputTrait } from '../../components/form-input-hooks';
|
|
6
6
|
import { WdFormItem, WdInputGroup, WdInputWrap } from '../wd-form-item';
|
|
7
7
|
import { emptyObject } from '../../utils/constant';
|
|
@@ -14,6 +14,7 @@ import { useDelayEvents } from '../../utils/hooks/use-delay-events';
|
|
|
14
14
|
import { X_RUNTIME_DEFAULT } from '../../../configs/type-utils/x-runtime-default';
|
|
15
15
|
import { CascaderH5 } from './cascader.h5';
|
|
16
16
|
import { getSelectedOptions } from './utils';
|
|
17
|
+
import isObjectEqual from '../../utils/isObjectEqual';
|
|
17
18
|
/**
|
|
18
19
|
* 级联选择-标准化
|
|
19
20
|
*/
|
|
@@ -92,9 +93,11 @@ export const WdCascader = forwardRef(function WdCascader(props, ref) {
|
|
|
92
93
|
}, [debouncedTriggerSearchEvent]);
|
|
93
94
|
const handleChange = (v, { options }) => {
|
|
94
95
|
var _a;
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
96
|
+
if (!isObjectEqual(v, value)) {
|
|
97
|
+
setSelectedOptions(options);
|
|
98
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
99
|
+
(_a = delayEvents === null || delayEvents === void 0 ? void 0 : delayEvents.change) === null || _a === void 0 ? void 0 : _a.call(delayEvents, { value: v });
|
|
100
|
+
}
|
|
98
101
|
};
|
|
99
102
|
if (!visible)
|
|
100
103
|
return null;
|
|
@@ -10,6 +10,7 @@ import { DateH5 } from './h5';
|
|
|
10
10
|
import { usePlatform } from '../../utils/platform';
|
|
11
11
|
import '../form/select/moment-locale';
|
|
12
12
|
import { X_RUNTIME_DEFAULT } from '../../../configs/type-utils/x-runtime-default';
|
|
13
|
+
import isObjectEqual from '../../utils/isObjectEqual';
|
|
13
14
|
const isDateNil = (v) => v === '' || v == null;
|
|
14
15
|
/**
|
|
15
16
|
* 标准化:日期组件
|
|
@@ -31,9 +32,11 @@ export const WdDate = React.forwardRef(function WdDate(props, ref) {
|
|
|
31
32
|
const readValue = useMemo(() => { var _a; return (_a = convertMoment(value)) === null || _a === void 0 ? void 0 : _a.format(format); }, [value, format]);
|
|
32
33
|
const pureChange = useCallback((v) => {
|
|
33
34
|
var _a;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
35
|
+
if (!isObjectEqual(v, value)) {
|
|
36
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
37
|
+
(_a = events === null || events === void 0 ? void 0 : events.change) === null || _a === void 0 ? void 0 : _a.call(events, { value: v });
|
|
38
|
+
}
|
|
39
|
+
}, [onChange, events, value]);
|
|
37
40
|
const clearProps = useHandleClear({
|
|
38
41
|
onChange: pureChange,
|
|
39
42
|
clearable,
|
|
@@ -7,9 +7,10 @@ import { DateRangePc } from './pc';
|
|
|
7
7
|
import { DateRangeH5 } from './h5';
|
|
8
8
|
import { usePlatform } from '../../utils/platform';
|
|
9
9
|
import { useDeepCompareMemo } from '@react-hookz/web';
|
|
10
|
-
import { convertDateRangToNumber, convertDateRangeToString, YEAR_START, YEAR_END
|
|
10
|
+
import { convertDateRangToNumber, convertDateRangeToString, YEAR_START, YEAR_END } from '../../utils/date';
|
|
11
11
|
import '../form/select/moment-locale';
|
|
12
12
|
import { X_RUNTIME_DEFAULT } from '../../../configs/type-utils/x-runtime-default';
|
|
13
|
+
import isObjectEqual from '../../utils/isObjectEqual';
|
|
13
14
|
const isDateNil = (v) => v === '' || v == null;
|
|
14
15
|
/**
|
|
15
16
|
* 标准化:日期区间组件
|
|
@@ -19,14 +20,9 @@ export const WdDateRange = React.forwardRef(function WdDateRangeInner(props, ref
|
|
|
19
20
|
const isH5 = usePlatform() === 'h5';
|
|
20
21
|
// 最早、最晚日期
|
|
21
22
|
const [start, end] = useMemo(() => {
|
|
22
|
-
const startDefault = isDateNil(_start)
|
|
23
|
-
? getValueByAddYear(YEAR_START)
|
|
24
|
-
: _start;
|
|
23
|
+
const startDefault = isDateNil(_start) ? getValueByAddYear(YEAR_START) : _start;
|
|
25
24
|
const endDefault = isDateNil(_end) ? getValueByAddYear(YEAR_END) : _end;
|
|
26
|
-
return [
|
|
27
|
-
getStartMoment(mode, startDefault),
|
|
28
|
-
getEndMoment(mode, endDefault),
|
|
29
|
-
];
|
|
25
|
+
return [getStartMoment(mode, startDefault), getEndMoment(mode, endDefault)];
|
|
30
26
|
}, [mode, _start, _end]);
|
|
31
27
|
// 初始值 value
|
|
32
28
|
const formValue = useDeepCompareMemo(() => convertDateRangToNumber(props.value), [props.value]);
|
|
@@ -39,9 +35,11 @@ export const WdDateRange = React.forwardRef(function WdDateRangeInner(props, ref
|
|
|
39
35
|
const readValue = useDeepCompareMemo(() => { var _a; return (_a = convertDateRangeToString(value, format)) === null || _a === void 0 ? void 0 : _a.join(' - '); }, [value, format]);
|
|
40
36
|
const pureChange = useCallback((v) => {
|
|
41
37
|
var _a;
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
38
|
+
if (!isObjectEqual(v, value)) {
|
|
39
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
40
|
+
(_a = events === null || events === void 0 ? void 0 : events.change) === null || _a === void 0 ? void 0 : _a.call(events, { value: v });
|
|
41
|
+
}
|
|
42
|
+
}, [onChange, events, value]);
|
|
45
43
|
const clearProps = useHandleClear({
|
|
46
44
|
onChange: pureChange,
|
|
47
45
|
clearable,
|
|
@@ -62,5 +60,5 @@ export const WdDateRange = React.forwardRef(function WdDateRangeInner(props, ref
|
|
|
62
60
|
};
|
|
63
61
|
if (!visible)
|
|
64
62
|
return null;
|
|
65
|
-
return (_jsx(WdFormItem, { ...formItemProps, children: _jsx(WdInputGroup, { ...inputGroupProps, children: _jsx(WdInputWrap, { ...inputWrapProps, children: isH5 ?
|
|
63
|
+
return (_jsx(WdFormItem, { ...formItemProps, children: _jsx(WdInputGroup, { ...inputGroupProps, children: _jsx(WdInputWrap, { ...inputWrapProps, children: isH5 ? _jsx(DateRangeH5, { ...dateProps }) : _jsx(DateRangePc, { ...dateProps }) }) }) }));
|
|
66
64
|
});
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import lodashSet from 'lodash.set';
|
|
2
|
+
import lodashGet from 'lodash.get';
|
|
3
|
+
import { deepClone } from '../../utils/tool';
|
|
4
|
+
import { NOT_EXISTED_VALUE } from '../../utils/constant';
|
|
2
5
|
function getFormDetailValueIsNull({ formData, formItemMap, }) {
|
|
3
6
|
const formDetailList = [];
|
|
4
7
|
formItemMap.forEach((items, name) => {
|
|
@@ -40,3 +43,17 @@ export function getErrorObjectFromValidateResult(errObj) {
|
|
|
40
43
|
return acc;
|
|
41
44
|
}, {});
|
|
42
45
|
}
|
|
46
|
+
// 表单容器上挂载的表单项的值
|
|
47
|
+
export const convertFormData = (formData, formItemMapList, fieldInitValueCache) => {
|
|
48
|
+
const data = {};
|
|
49
|
+
formItemMapList.forEach((i) => {
|
|
50
|
+
const namePath = i;
|
|
51
|
+
const value = lodashGet(formData, namePath, NOT_EXISTED_VALUE);
|
|
52
|
+
// 表单容器内不包含的表单项,不赋值
|
|
53
|
+
if (value !== NOT_EXISTED_VALUE) {
|
|
54
|
+
lodashSet(data, namePath, value);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
const _fieldInitValueCache = deepClone(fieldInitValueCache);
|
|
58
|
+
return Object.assign(_fieldInitValueCache, data);
|
|
59
|
+
};
|
|
@@ -227,7 +227,7 @@ export function useRemoteParamsFromValue({ dataSourceProfile, formData, formType
|
|
|
227
227
|
const format = (_c = (_b = (_a = dataSourceProfile.schema) === null || _a === void 0 ? void 0 : _a.properties) === null || _b === void 0 ? void 0 : _b[cur]) === null || _c === void 0 ? void 0 : _c.format;
|
|
228
228
|
acc[cur] = formData[cur];
|
|
229
229
|
if (SINGLE_SELECT_FORMATS.includes(format)) {
|
|
230
|
-
acc[cur] = { _id: formData[cur] };
|
|
230
|
+
acc[cur] = { _id: formData[cur] || '' };
|
|
231
231
|
}
|
|
232
232
|
if (MULTI_SELECT_FORMATS.includes(format)) {
|
|
233
233
|
acc[cur] = (_d = acc[cur]) === null || _d === void 0 ? void 0 : _d.map((_id) => ({ _id }));
|
|
@@ -17,12 +17,12 @@ import lodashGet from 'lodash.get';
|
|
|
17
17
|
import lodashSet from 'lodash.set';
|
|
18
18
|
import { useDataSource } from '../../utils/hooks/useDataSource';
|
|
19
19
|
import { WdForm as FormUi } from './wd-form';
|
|
20
|
-
import
|
|
20
|
+
import StatusContent from '../statusContent';
|
|
21
21
|
import { deepClone } from '../../utils/tool';
|
|
22
22
|
import isObjectEqual from '../../utils/isObjectEqual';
|
|
23
23
|
import { convertMethodParam } from '../../utils/hooks/useFormLegacy';
|
|
24
24
|
import '../style';
|
|
25
|
-
import { getErrorObjectFromValidateResult } from './form-utils';
|
|
25
|
+
import { getErrorObjectFromValidateResult, convertFormData } from './form-utils';
|
|
26
26
|
import { isNil } from '../../utils/lodash';
|
|
27
27
|
import { FormTypeProvider } from './contexts/form-type-context';
|
|
28
28
|
import { FormLayoutProvider } from './contexts/form-layout-context';
|
|
@@ -33,7 +33,7 @@ import useDebouncedCallback from '../../utils/hooks/use-debounced-callback';
|
|
|
33
33
|
const SET_VALUE_DEBOUNCE_TIMEOUT = 250;
|
|
34
34
|
const logger = debug('wd-form');
|
|
35
35
|
const WdForm = React.forwardRef(function WdForm(props, ref) {
|
|
36
|
-
var _a, _b, _c
|
|
36
|
+
var _a, _b, _c;
|
|
37
37
|
const { className, id, style, contentSlot: contentSlotEl, layout = 'horizontal', formType = 'create', _id, datasourceType = 'model', dataSourceName, methodGetItem, methodCreate, methodUpdate, paramGetItem, appCloud = tcbAppCloud, lgWidth, labelAlign = 'left', initialValues: _initialValues,
|
|
38
38
|
// 兼容流程setValue调用,其他地方别用
|
|
39
39
|
$node, $widget, } = props;
|
|
@@ -76,32 +76,14 @@ const WdForm = React.forwardRef(function WdForm(props, ref) {
|
|
|
76
76
|
// 表单值
|
|
77
77
|
const [formData, setFormData] = useState((_c = deepClone(_initialValues)) !== null && _c !== void 0 ? _c : emptyObject);
|
|
78
78
|
// 转换后表单值,仅保留已挂载表单项的值
|
|
79
|
-
const
|
|
79
|
+
const formFieldsValue = useMemo(() => {
|
|
80
|
+
return convertFormData(formData, formItemMapList, fieldInitValueCache);
|
|
81
|
+
}, [formData, formItemMapList, fieldInitValueCache]);
|
|
80
82
|
useDebouncedEffect(() => {
|
|
81
83
|
var _a, _b;
|
|
82
|
-
//
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
formItemMapList.forEach((i) => {
|
|
86
|
-
const namePath = i;
|
|
87
|
-
const value = lodashGet(formData, namePath, NOT_EXISTED_VALUE);
|
|
88
|
-
// 表单容器内不包含的表单项,不赋值
|
|
89
|
-
if (value !== NOT_EXISTED_VALUE) {
|
|
90
|
-
lodashSet(data, namePath, value);
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
if (setNull) {
|
|
94
|
-
lodashSet(data, namePath, null);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
const _fieldInitValueCache = deepClone(fieldInitValueCache);
|
|
99
|
-
return Object.assign(_fieldInitValueCache, data);
|
|
100
|
-
};
|
|
101
|
-
const _data = convertFormData(formData);
|
|
102
|
-
setFormFieldsValue(_data);
|
|
103
|
-
(_b = (_a = eventsRef === null || eventsRef === void 0 ? void 0 : eventsRef.current) === null || _a === void 0 ? void 0 : _a.onDataChange) === null || _b === void 0 ? void 0 : _b.call(_a, { data: _data });
|
|
104
|
-
}, [formData, fieldInitValueCache],
|
|
84
|
+
// 表单容器上挂载的表单项的值
|
|
85
|
+
(_b = (_a = eventsRef === null || eventsRef === void 0 ? void 0 : eventsRef.current) === null || _a === void 0 ? void 0 : _a.onDataChange) === null || _b === void 0 ? void 0 : _b.call(_a, { data: formFieldsValue });
|
|
86
|
+
}, [formFieldsValue],
|
|
105
87
|
// eslint-disable-next-line @typescript-eslint/no-magic-numbers
|
|
106
88
|
SET_VALUE_DEBOUNCE_TIMEOUT);
|
|
107
89
|
const eventsRef = useSyncedRef(props.events);
|
|
@@ -508,7 +490,7 @@ const WdForm = React.forwardRef(function WdForm(props, ref) {
|
|
|
508
490
|
return `${layout}-${labelAlign}`;
|
|
509
491
|
}, [layout, labelAlign]);
|
|
510
492
|
const getFieldValue = useCallback(({ namePath, initialValue }) => {
|
|
511
|
-
const value = lodashGet(
|
|
493
|
+
const value = lodashGet(formData, namePath, NOT_EXISTED_VALUE);
|
|
512
494
|
if (value !== NOT_EXISTED_VALUE) {
|
|
513
495
|
return value;
|
|
514
496
|
}
|
|
@@ -520,7 +502,7 @@ const WdForm = React.forwardRef(function WdForm(props, ref) {
|
|
|
520
502
|
}
|
|
521
503
|
return null;
|
|
522
504
|
}
|
|
523
|
-
}, [
|
|
505
|
+
}, [formData]);
|
|
524
506
|
const setFieldValue = useCallback(({ namePath, value }) => {
|
|
525
507
|
setFormData((formData) => {
|
|
526
508
|
const _formData = deepClone(formData);
|
|
@@ -536,16 +518,9 @@ const WdForm = React.forwardRef(function WdForm(props, ref) {
|
|
|
536
518
|
return _formData;
|
|
537
519
|
});
|
|
538
520
|
}, []);
|
|
539
|
-
if (initValueLoadingStatus === '
|
|
540
|
-
return
|
|
521
|
+
if (initValueLoadingStatus === 'loading' && !fetchedInitialValues) {
|
|
522
|
+
return _jsx(StatusContent, { emptyText: '数据加载中,请稍候...', component: "table", icon: "loading" });
|
|
541
523
|
}
|
|
542
|
-
|
|
543
|
-
// return (
|
|
544
|
-
// <ConfigProvider classPrefix="wedatea2td">
|
|
545
|
-
// <StatusTip status="loading" loadingText="数据加载中..." />
|
|
546
|
-
// </ConfigProvider>
|
|
547
|
-
// );
|
|
548
|
-
// }
|
|
549
|
-
return (_jsx(FormWidgetProvider, { "$widget": $widget, children: _jsx(FormLayoutProvider, { layout: layout, children: _jsx(FormTypeProvider, { formType: formType, children: _jsx(FormFieldProvider, { setFieldValue: setFieldValue, isInformContainer: isInformContainer, getFieldValue: getFieldValue, children: _jsx(FormUi, { layout: layout, className: cls, style: style, id: id, lgWidth: lgWidth, labelPosition: labelPosition, children: initValueFetchError ? (_jsx(EmptyContent, { emptyText: '数据加载失败', errorObj: initValueFetchError, icon: 'error', isH5: isH5 })) : (contentSlot) }) }) }) }) }));
|
|
524
|
+
return (_jsx(FormWidgetProvider, { "$widget": $widget, children: _jsx(FormLayoutProvider, { layout: layout, children: _jsx(FormTypeProvider, { formType: formType, children: _jsx(FormFieldProvider, { setFieldValue: setFieldValue, isInformContainer: isInformContainer, getFieldValue: getFieldValue, children: _jsx(FormUi, { layout: layout, className: cls, style: style, id: id, lgWidth: lgWidth, labelPosition: labelPosition, children: initValueFetchError ? (_jsx(StatusContent, { emptyText: '数据加载失败', errorObj: initValueFetchError, icon: 'error', isH5: isH5 })) : (contentSlot) }) }) }) }) }));
|
|
550
525
|
});
|
|
551
526
|
export default React.memo(WdForm);
|
|
@@ -42,13 +42,17 @@ export const WdSelect = forwardRef(function WsSelect(props, ref) {
|
|
|
42
42
|
});
|
|
43
43
|
const onClearChange = useCallback((v) => {
|
|
44
44
|
var _a;
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
if (!isObjectEqual(v, value)) {
|
|
46
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
47
|
+
(_a = delayEvents === null || delayEvents === void 0 ? void 0 : delayEvents.change) === null || _a === void 0 ? void 0 : _a.call(delayEvents, { value: v });
|
|
48
|
+
}
|
|
49
|
+
}, [onChange, delayEvents, value]);
|
|
48
50
|
const handleChange = (v, context) => {
|
|
49
51
|
var _a;
|
|
50
|
-
|
|
51
|
-
|
|
52
|
+
if (!isObjectEqual(v, value)) {
|
|
53
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
54
|
+
(_a = delayEvents === null || delayEvents === void 0 ? void 0 : delayEvents.change) === null || _a === void 0 ? void 0 : _a.call(delayEvents, { value: v, context });
|
|
55
|
+
}
|
|
52
56
|
};
|
|
53
57
|
const clearProps = useHandleClear({
|
|
54
58
|
onChange: onClearChange,
|
|
@@ -44,9 +44,11 @@ export const WdSelectMultiple = forwardRef(function WdSelectMultiple(props, ref)
|
|
|
44
44
|
const delayEvents = useDelayEvents(events);
|
|
45
45
|
const onClearChange = useCallback((v) => {
|
|
46
46
|
var _a;
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
47
|
+
if (!isObjectEqual(v, value)) {
|
|
48
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
49
|
+
(_a = delayEvents === null || delayEvents === void 0 ? void 0 : delayEvents.change) === null || _a === void 0 ? void 0 : _a.call(delayEvents, { value: v });
|
|
50
|
+
}
|
|
51
|
+
}, [onChange, delayEvents, value]);
|
|
50
52
|
const clearProps = useHandleClear({
|
|
51
53
|
onChange: onClearChange,
|
|
52
54
|
clearable,
|
|
@@ -55,8 +57,10 @@ export const WdSelectMultiple = forwardRef(function WdSelectMultiple(props, ref)
|
|
|
55
57
|
});
|
|
56
58
|
const handleChange = (v, context) => {
|
|
57
59
|
var _a;
|
|
58
|
-
|
|
59
|
-
|
|
60
|
+
if (!isObjectEqual(v, value)) {
|
|
61
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
62
|
+
(_a = delayEvents === null || delayEvents === void 0 ? void 0 : delayEvents.change) === null || _a === void 0 ? void 0 : _a.call(delayEvents, { value: v, context });
|
|
63
|
+
}
|
|
60
64
|
};
|
|
61
65
|
const onFocus = (e) => {
|
|
62
66
|
(events === null || events === void 0 ? void 0 : events.focus) && events.focus(null, { originEvent: e });
|
|
@@ -9,6 +9,7 @@ import { convertTimeValue, convertTimeToMoment, useDateFormat, MAX_TIME, useHand
|
|
|
9
9
|
import { useFormInputTrait } from '../../components/form-input-hooks';
|
|
10
10
|
import '../form/select/moment-locale';
|
|
11
11
|
import { X_RUNTIME_DEFAULT } from '../../../configs/type-utils/x-runtime-default';
|
|
12
|
+
import isObjectEqual from '../../utils/isObjectEqual';
|
|
12
13
|
/**
|
|
13
14
|
* 标准化:时间组件
|
|
14
15
|
*/
|
|
@@ -26,9 +27,11 @@ export const WdTime = React.forwardRef(function WdTime(props, ref) {
|
|
|
26
27
|
const readValue = useMemo(() => { var _a; return (_a = convertTimeToMoment(value)) === null || _a === void 0 ? void 0 : _a.format(format); }, [value, format]);
|
|
27
28
|
const pureChange = useCallback((v) => {
|
|
28
29
|
var _a;
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
if (!isObjectEqual(v, value)) {
|
|
31
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(v);
|
|
32
|
+
(_a = events === null || events === void 0 ? void 0 : events.change) === null || _a === void 0 ? void 0 : _a.call(events, { value: v });
|
|
33
|
+
}
|
|
34
|
+
}, [onChange, events, value]);
|
|
32
35
|
const clearProps = useHandleClear({
|
|
33
36
|
onChange: pureChange,
|
|
34
37
|
clearable,
|