amis-core 6.4.1 → 6.6.0
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/Root.js +1 -1
- package/esm/RootRenderer.js +1 -1
- package/esm/SchemaRenderer.js +16 -5
- package/esm/Scoped.d.ts +1 -1
- package/esm/Scoped.js +5 -1
- package/esm/StatusScoped.js +1 -1
- package/esm/WithRootStore.js +1 -1
- package/esm/WithStore.js +10 -4
- package/esm/actions/Action.js +6 -5
- package/esm/actions/AjaxAction.js +3 -3
- package/esm/actions/BreakAction.js +1 -1
- package/esm/actions/BroadcastAction.js +1 -1
- package/esm/actions/CmptAction.js +2 -2
- package/esm/actions/ContinueAction.js +1 -1
- package/esm/actions/CopyAction.js +4 -4
- package/esm/actions/CustomAction.js +2 -1
- package/esm/actions/DialogAction.js +2 -1
- package/esm/actions/DrawerAction.js +2 -1
- package/esm/actions/EmailAction.js +1 -1
- package/esm/actions/EventAction.js +2 -1
- package/esm/actions/LinkAction.js +1 -1
- package/esm/actions/LoopAction.js +2 -1
- package/esm/actions/PageAction.js +1 -1
- package/esm/actions/ParallelAction.js +1 -1
- package/esm/actions/PrintAction.d.ts +1 -1
- package/esm/actions/PrintAction.js +12 -6
- package/esm/actions/StatusAction.js +1 -1
- package/esm/actions/SwitchAction.js +3 -3
- package/esm/actions/ToastAction.js +1 -1
- package/esm/actions/WaitAction.js +1 -1
- package/esm/components/CustomStyle.js +3 -2
- package/esm/components/ErrorBoundary.js +1 -1
- package/esm/components/LazyComponent.js +1 -1
- package/esm/components/Overlay.js +2 -1
- package/esm/components/PopOver.js +2 -1
- package/esm/env.d.ts +2 -4
- package/esm/env.js +1 -1
- package/esm/envOverwrite.js +1 -1
- package/esm/factory.js +1 -1
- package/esm/index.js +4 -4
- package/esm/locale.js +2 -1
- package/esm/polyfills.js +1 -1
- package/esm/renderers/Form.d.ts +1 -1
- package/esm/renderers/Form.js +43 -9
- package/esm/renderers/Item.d.ts +27 -60
- package/esm/renderers/Item.js +75 -6
- package/esm/renderers/Options.js +40 -13
- package/esm/renderers/Placeholder.js +1 -1
- package/esm/renderers/builtin.js +1 -1
- package/esm/renderers/register.js +1 -1
- package/esm/renderers/wrapControl.js +19 -9
- package/esm/store/app.d.ts +2 -0
- package/esm/store/app.js +2 -1
- package/esm/store/combo.d.ts +6 -0
- package/esm/store/combo.js +1 -1
- package/esm/store/crud.d.ts +2 -0
- package/esm/store/crud.js +2 -1
- package/esm/store/form.d.ts +2 -0
- package/esm/store/form.js +2 -1
- package/esm/store/formItem.js +12 -2
- package/esm/store/iRenderer.d.ts +2 -0
- package/esm/store/iRenderer.js +13 -1
- package/esm/store/index.js +1 -1
- package/esm/store/list.d.ts +2 -0
- package/esm/store/list.js +1 -1
- package/esm/store/manager.js +1 -1
- package/esm/store/modal.d.ts +2 -0
- package/esm/store/modal.js +1 -1
- package/esm/store/node.js +1 -1
- package/esm/store/pagination.d.ts +2 -0
- package/esm/store/pagination.js +2 -1
- package/esm/store/root.d.ts +2 -0
- package/esm/store/root.js +2 -1
- package/esm/store/service.d.ts +2 -0
- package/esm/store/service.js +2 -1
- package/esm/store/status.js +1 -1
- package/esm/store/table.d.ts +6 -0
- package/esm/store/table.js +2 -1
- package/esm/store/table2.d.ts +2 -0
- package/esm/store/table2.js +1 -1
- package/esm/theme.js +1 -1
- package/esm/types.d.ts +2 -0
- package/esm/utils/Animation.js +1 -1
- package/esm/utils/ColorScale.js +1 -1
- package/esm/utils/DataSchema.js +1 -1
- package/esm/utils/DataScope.js +2 -1
- package/esm/utils/RootClose.js +1 -1
- package/esm/utils/SimpleMap.js +1 -1
- package/esm/utils/api.js +21 -3
- package/esm/utils/arraySlice.js +1 -1
- package/esm/utils/attachmentAdpator.js +1 -1
- package/esm/utils/autobind.js +1 -1
- package/esm/utils/browser.js +1 -1
- package/esm/utils/columnsSplit.js +1 -1
- package/esm/utils/concatData.js +1 -1
- package/esm/utils/dataMapping.js +1 -1
- package/esm/utils/date.d.ts +3 -1
- package/esm/utils/date.js +11 -5
- package/esm/utils/debug.js +1 -1
- package/esm/utils/decodeEntity.js +1 -1
- package/esm/utils/dom.js +1 -1
- package/esm/utils/errors.js +1 -1
- package/esm/utils/escapeHtml.js +1 -1
- package/esm/utils/filter-schema.js +7 -4
- package/esm/utils/filter.js +1 -1
- package/esm/utils/formatDuration.js +1 -1
- package/esm/utils/formula.js +2 -1
- package/esm/utils/getVariable.js +1 -1
- package/esm/utils/grammar.js +1 -1
- package/esm/utils/handleAction.js +1 -1
- package/esm/utils/helper.d.ts +1 -1
- package/esm/utils/helper.js +10 -6
- package/esm/utils/highlight.js +1 -1
- package/esm/utils/icon.js +1 -1
- package/esm/utils/image.js +1 -1
- package/esm/utils/isPureVariable.js +1 -1
- package/esm/utils/json-schema-2-amis-schema.js +1 -1
- package/esm/utils/keyToPath.js +1 -1
- package/esm/utils/labelToString.js +1 -1
- package/esm/utils/makeSorter.js +1 -1
- package/esm/utils/math.js +1 -1
- package/esm/utils/memoryParse.js +1 -1
- package/esm/utils/normalizeLink.js +1 -1
- package/esm/utils/normalizeOptions.d.ts +1 -1
- package/esm/utils/normalizeOptions.js +3 -2
- package/esm/utils/object.js +1 -1
- package/esm/utils/offset.js +1 -1
- package/esm/utils/offsetParent.js +1 -1
- package/esm/utils/optionValueCompare.js +1 -1
- package/esm/utils/position.js +1 -1
- package/esm/utils/prettyBytes.js +1 -1
- package/esm/utils/printElement.js +1 -1
- package/esm/utils/renderer-event.js +7 -6
- package/esm/utils/replaceText.js +1 -1
- package/esm/utils/resize-sensor.js +1 -1
- package/esm/utils/resolveCondition.d.ts +2 -1
- package/esm/utils/resolveCondition.js +60 -8
- package/esm/utils/resolveVariable.js +1 -1
- package/esm/utils/resolveVariableAndFilter.js +1 -1
- package/esm/utils/resolveVariableAndFilterForAsync.js +1 -1
- package/esm/utils/scrollPosition.js +1 -1
- package/esm/utils/string2regExp.js +1 -1
- package/esm/utils/stripNumber.js +2 -2
- package/esm/utils/style-helper.js +15 -8
- package/esm/utils/style.js +2 -1
- package/esm/utils/toNumber.js +1 -1
- package/esm/utils/tokenize.js +1 -1
- package/esm/utils/tpl-builtin.js +2 -1
- package/esm/utils/tpl-lodash.js +2 -1
- package/esm/utils/tpl.d.ts +8 -1
- package/esm/utils/tpl.js +18 -5
- package/esm/utils/uncontrollable.js +1 -1
- package/esm/utils/validateId.js +1 -1
- package/esm/utils/validations.js +2 -1
- package/lib/Root.js +1 -1
- package/lib/RootRenderer.d.ts +1 -1
- package/lib/RootRenderer.js +1 -1
- package/lib/SchemaRenderer.js +16 -5
- package/lib/Scoped.d.ts +1 -1
- package/lib/Scoped.js +5 -1
- package/lib/StatusScoped.js +1 -1
- package/lib/WithRootStore.js +1 -1
- package/lib/WithStore.js +10 -4
- package/lib/actions/Action.js +5 -4
- package/lib/actions/AjaxAction.js +2 -2
- package/lib/actions/BreakAction.js +1 -1
- package/lib/actions/BroadcastAction.js +1 -1
- package/lib/actions/CmptAction.js +2 -2
- package/lib/actions/ContinueAction.js +1 -1
- package/lib/actions/CopyAction.js +4 -4
- package/lib/actions/CustomAction.js +2 -1
- package/lib/actions/DialogAction.js +2 -1
- package/lib/actions/DrawerAction.js +2 -1
- package/lib/actions/EmailAction.js +1 -1
- package/lib/actions/EventAction.js +2 -1
- package/lib/actions/LinkAction.js +1 -1
- package/lib/actions/LoopAction.js +2 -1
- package/lib/actions/PageAction.js +1 -1
- package/lib/actions/ParallelAction.js +1 -1
- package/lib/actions/PrintAction.d.ts +1 -1
- package/lib/actions/PrintAction.js +12 -6
- package/lib/actions/StatusAction.js +1 -1
- package/lib/actions/SwitchAction.js +2 -2
- package/lib/actions/ToastAction.js +1 -1
- package/lib/actions/WaitAction.js +1 -1
- package/lib/components/CustomStyle.js +3 -2
- package/lib/components/ErrorBoundary.js +1 -1
- package/lib/components/LazyComponent.js +1 -1
- package/lib/components/Overlay.js +2 -1
- package/lib/components/PopOver.js +2 -1
- package/lib/env.d.ts +2 -4
- package/lib/env.js +1 -1
- package/lib/envOverwrite.js +1 -1
- package/lib/factory.js +1 -1
- package/lib/index.js +4 -2
- package/lib/locale.js +2 -1
- package/lib/polyfills.js +1 -1
- package/lib/renderers/Form.d.ts +1 -1
- package/lib/renderers/Form.js +43 -9
- package/lib/renderers/Item.d.ts +27 -60
- package/lib/renderers/Item.js +75 -6
- package/lib/renderers/Options.js +40 -13
- package/lib/renderers/Placeholder.js +1 -1
- package/lib/renderers/builtin.js +1 -1
- package/lib/renderers/register.js +1 -1
- package/lib/renderers/wrapControl.js +19 -9
- package/lib/store/app.d.ts +2 -0
- package/lib/store/app.js +2 -1
- package/lib/store/combo.d.ts +30 -24
- package/lib/store/combo.js +1 -1
- package/lib/store/crud.d.ts +2 -0
- package/lib/store/crud.js +2 -1
- package/lib/store/form.d.ts +12 -10
- package/lib/store/form.js +2 -1
- package/lib/store/formItem.js +12 -2
- package/lib/store/iRenderer.d.ts +2 -0
- package/lib/store/iRenderer.js +13 -1
- package/lib/store/index.js +1 -1
- package/lib/store/list.d.ts +2 -0
- package/lib/store/list.js +1 -1
- package/lib/store/manager.js +1 -1
- package/lib/store/modal.d.ts +2 -0
- package/lib/store/modal.js +1 -1
- package/lib/store/node.js +1 -1
- package/lib/store/pagination.d.ts +2 -0
- package/lib/store/pagination.js +2 -1
- package/lib/store/root.d.ts +2 -0
- package/lib/store/root.js +2 -1
- package/lib/store/service.d.ts +2 -0
- package/lib/store/service.js +2 -1
- package/lib/store/status.js +1 -1
- package/lib/store/table.d.ts +26 -20
- package/lib/store/table.js +2 -1
- package/lib/store/table2.d.ts +2 -0
- package/lib/store/table2.js +1 -1
- package/lib/theme.js +1 -1
- package/lib/types.d.ts +2 -0
- package/lib/utils/Animation.js +1 -1
- package/lib/utils/ColorScale.js +1 -1
- package/lib/utils/DataSchema.js +1 -1
- package/lib/utils/DataScope.js +2 -1
- package/lib/utils/RootClose.js +1 -1
- package/lib/utils/SimpleMap.js +1 -1
- package/lib/utils/api.js +23 -3
- package/lib/utils/arraySlice.js +1 -1
- package/lib/utils/attachmentAdpator.js +1 -1
- package/lib/utils/autobind.js +1 -1
- package/lib/utils/browser.js +1 -1
- package/lib/utils/columnsSplit.js +1 -1
- package/lib/utils/concatData.js +1 -1
- package/lib/utils/dataMapping.js +1 -1
- package/lib/utils/date.d.ts +3 -1
- package/lib/utils/date.js +11 -5
- package/lib/utils/debug.js +1 -1
- package/lib/utils/decodeEntity.js +1 -1
- package/lib/utils/dom.js +1 -1
- package/lib/utils/errors.js +1 -1
- package/lib/utils/escapeHtml.js +1 -1
- package/lib/utils/filter-schema.js +6 -3
- package/lib/utils/filter.js +1 -1
- package/lib/utils/formatDuration.js +1 -1
- package/lib/utils/formula.js +2 -1
- package/lib/utils/getVariable.js +1 -1
- package/lib/utils/grammar.js +1 -1
- package/lib/utils/handleAction.js +1 -1
- package/lib/utils/helper.d.ts +1 -1
- package/lib/utils/helper.js +9 -5
- package/lib/utils/highlight.js +1 -1
- package/lib/utils/icon.js +1 -1
- package/lib/utils/image.js +1 -1
- package/lib/utils/isPureVariable.js +1 -1
- package/lib/utils/json-schema-2-amis-schema.js +1 -1
- package/lib/utils/keyToPath.js +1 -1
- package/lib/utils/labelToString.js +1 -1
- package/lib/utils/makeSorter.js +1 -1
- package/lib/utils/math.js +1 -1
- package/lib/utils/memoryParse.js +1 -1
- package/lib/utils/normalizeLink.js +1 -1
- package/lib/utils/normalizeOptions.d.ts +1 -1
- package/lib/utils/normalizeOptions.js +3 -2
- package/lib/utils/object.js +1 -1
- package/lib/utils/offset.js +1 -1
- package/lib/utils/offsetParent.js +1 -1
- package/lib/utils/optionValueCompare.js +1 -1
- package/lib/utils/position.js +1 -1
- package/lib/utils/prettyBytes.js +1 -1
- package/lib/utils/printElement.js +1 -1
- package/lib/utils/renderer-event.js +6 -5
- package/lib/utils/replaceText.js +1 -1
- package/lib/utils/resize-sensor.js +1 -1
- package/lib/utils/resolveCondition.d.ts +2 -1
- package/lib/utils/resolveCondition.js +60 -7
- package/lib/utils/resolveVariable.js +1 -1
- package/lib/utils/resolveVariableAndFilter.js +1 -1
- package/lib/utils/resolveVariableAndFilterForAsync.js +1 -1
- package/lib/utils/scrollPosition.js +1 -1
- package/lib/utils/string2regExp.js +1 -1
- package/lib/utils/stripNumber.js +3 -3
- package/lib/utils/style-helper.js +15 -8
- package/lib/utils/style.js +2 -1
- package/lib/utils/toNumber.js +1 -1
- package/lib/utils/tokenize.js +1 -1
- package/lib/utils/tpl-builtin.js +2 -1
- package/lib/utils/tpl-lodash.js +2 -1
- package/lib/utils/tpl.d.ts +8 -1
- package/lib/utils/tpl.js +17 -3
- package/lib/utils/uncontrollable.js +1 -1
- package/lib/utils/validateId.js +1 -1
- package/lib/utils/validations.js +2 -1
- package/package.json +3 -2
- package/esm/node_modules/@babel/runtime/helpers/esm/classCallCheck.js +0 -12
- package/esm/node_modules/@babel/runtime/helpers/esm/createClass.js +0 -26
- package/esm/node_modules/@babel/runtime/helpers/esm/defineProperty.js +0 -23
- package/esm/node_modules/@babel/runtime/helpers/esm/toPrimitive.js +0 -19
- package/esm/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js +0 -14
- package/esm/node_modules/@babel/runtime/helpers/esm/typeof.js +0 -16
- package/esm/node_modules/@rc-component/mini-decimal/es/BigIntDecimal.js +0 -184
- package/esm/node_modules/@rc-component/mini-decimal/es/MiniDecimal.js +0 -56
- package/esm/node_modules/@rc-component/mini-decimal/es/NumberDecimal.js +0 -119
- package/esm/node_modules/@rc-component/mini-decimal/es/numberUtil.js +0 -105
- package/esm/node_modules/@rc-component/mini-decimal/es/supportUtil.js +0 -10
- package/lib/node_modules/@babel/runtime/helpers/esm/classCallCheck.js +0 -16
- package/lib/node_modules/@babel/runtime/helpers/esm/createClass.js +0 -30
- package/lib/node_modules/@babel/runtime/helpers/esm/defineProperty.js +0 -27
- package/lib/node_modules/@babel/runtime/helpers/esm/toPrimitive.js +0 -23
- package/lib/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js +0 -18
- package/lib/node_modules/@babel/runtime/helpers/esm/typeof.js +0 -20
- package/lib/node_modules/@rc-component/mini-decimal/es/BigIntDecimal.js +0 -188
- package/lib/node_modules/@rc-component/mini-decimal/es/MiniDecimal.js +0 -61
- package/lib/node_modules/@rc-component/mini-decimal/es/NumberDecimal.js +0 -123
- package/lib/node_modules/@rc-component/mini-decimal/es/numberUtil.js +0 -114
- package/lib/node_modules/@rc-component/mini-decimal/es/supportUtil.js +0 -14
package/esm/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-core v6.
|
|
2
|
+
* amis-core v6.6.0
|
|
3
3
|
* Copyright 2018-2024 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -67,13 +67,13 @@ export { string2regExp } from './utils/string2regExp.js';
|
|
|
67
67
|
export { buildStyle } from './utils/style.js';
|
|
68
68
|
export { memoParse, tokenize } from './utils/tokenize.js';
|
|
69
69
|
export { register } from './utils/tpl-builtin.js';
|
|
70
|
-
export { asyncFilter, evalExpression, evalExpressionWithConditionBuilder, evalJS, filter, registerTplEnginer, setCustomEvalExpression, setCustomEvalJs } from './utils/tpl.js';
|
|
70
|
+
export { asyncFilter, evalExpression, evalExpressionWithConditionBuilder, evalExpressionWithConditionBuilderAsync, evalJS, filter, registerTplEnginer, setCustomEvalExpression, setCustomEvalJs } from './utils/tpl.js';
|
|
71
71
|
export { uncontrollable } from './utils/uncontrollable.js';
|
|
72
72
|
export { addRule, str2rules, validate, validateMessages, validateObject, validations } from './utils/validations.js';
|
|
73
73
|
export { toNumber } from './utils/toNumber.js';
|
|
74
74
|
export { decodeEntity } from './utils/decodeEntity.js';
|
|
75
75
|
export { addStyle, findOrCreateStyle, formatInputThemeCss, formatStyle, getValueByPath, inheritValueMap, insertCustomStyle, insertEditCustomStyle, insertStyle, removeCustomStyle, setThemeClassName, valueMap as styleMap, valueMap } from './utils/style-helper.js';
|
|
76
|
-
export { getConditionComputers, registerConditionComputer, resolveCondition, setConditionComputeErrorHandler } from './utils/resolveCondition.js';
|
|
76
|
+
export { getConditionComputers, registerConditionComputer, resolveCondition, resolveConditionAsync, setConditionComputeErrorHandler } from './utils/resolveCondition.js';
|
|
77
77
|
export { arraySlice } from './utils/arraySlice.js';
|
|
78
78
|
export { isIntegerInRange, numberFormatter, safeAdd, safeSub } from './utils/math.js';
|
|
79
79
|
export { default as animation } from './utils/Animation.js';
|
|
@@ -148,7 +148,7 @@ export { StoreNode } from './store/node.js';
|
|
|
148
148
|
*/
|
|
149
149
|
var classPrefix = getClassPrefix();
|
|
150
150
|
// @ts-ignore
|
|
151
|
-
var version = '6.
|
|
151
|
+
var version = '6.6.0';
|
|
152
152
|
function render(schema, props, options, pathPrefix) {
|
|
153
153
|
if (props === void 0) { props = {}; }
|
|
154
154
|
if (options === void 0) { options = {}; }
|
package/esm/locale.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-core v6.
|
|
2
|
+
* amis-core v6.6.0
|
|
3
3
|
* Copyright 2018-2024 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -10,6 +10,7 @@ import moment from 'moment';
|
|
|
10
10
|
import 'amis-formula';
|
|
11
11
|
import 'lodash/isPlainObject';
|
|
12
12
|
import { resolveVariable } from './utils/resolveVariable.js';
|
|
13
|
+
import '@rc-component/mini-decimal';
|
|
13
14
|
import './utils/filter.js';
|
|
14
15
|
|
|
15
16
|
var defaultLocale = 'zh-CN';
|
package/esm/polyfills.js
CHANGED
package/esm/renderers/Form.d.ts
CHANGED
package/esm/renderers/Form.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-core v6.
|
|
2
|
+
* amis-core v6.6.0
|
|
3
3
|
* Copyright 2018-2024 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -17,6 +17,7 @@ import { filterTarget, ScopedContext } from '../Scoped.js';
|
|
|
17
17
|
import 'amis-formula';
|
|
18
18
|
import 'moment';
|
|
19
19
|
import { isObject, createObject, cloneObject, injectObjectChain } from '../utils/object.js';
|
|
20
|
+
import '@rc-component/mini-decimal';
|
|
20
21
|
import { dataMapping } from '../utils/dataMapping.js';
|
|
21
22
|
import '../utils/filter.js';
|
|
22
23
|
import { isEffectiveApi, isApiOutdated } from '../utils/api.js';
|
|
@@ -536,7 +537,7 @@ var Form = /** @class */ (function (_super) {
|
|
|
536
537
|
return;
|
|
537
538
|
}
|
|
538
539
|
store.changeValue(name, value, changePristine);
|
|
539
|
-
if (!changePristine) {
|
|
540
|
+
if (!changePristine || typeof value !== 'undefined') {
|
|
540
541
|
(formLazyChange === false ? this.emitChange : this.lazyEmitChange)(submit);
|
|
541
542
|
}
|
|
542
543
|
if (store.persistData && store.inited) {
|
|
@@ -550,17 +551,17 @@ var Form = /** @class */ (function (_super) {
|
|
|
550
551
|
Form.prototype.emitChange = function (submit, emitedFromWatch) {
|
|
551
552
|
if (emitedFromWatch === void 0) { emitedFromWatch = false; }
|
|
552
553
|
return __awaiter(this, void 0, void 0, function () {
|
|
553
|
-
var _a, onChange, store, submitOnChange, dispatchEvent_1, data, diff, changeProps, dispatcher;
|
|
554
|
+
var _a, onChange, store, submitOnChange, dispatchEvent_1, data, originData, diff, changeProps, dispatcher;
|
|
554
555
|
return __generator(this, function (_b) {
|
|
555
556
|
switch (_b.label) {
|
|
556
557
|
case 0:
|
|
557
558
|
_b.trys.push([0, , 4, 5]);
|
|
558
559
|
this.emitting = true;
|
|
559
|
-
_a = this.props, onChange = _a.onChange, store = _a.store, submitOnChange = _a.submitOnChange, dispatchEvent_1 = _a.dispatchEvent, data = _a.data;
|
|
560
|
+
_a = this.props, onChange = _a.onChange, store = _a.store, submitOnChange = _a.submitOnChange, dispatchEvent_1 = _a.dispatchEvent, data = _a.data, originData = _a.originData;
|
|
560
561
|
if (!isAlive(store)) {
|
|
561
562
|
return [2 /*return*/];
|
|
562
563
|
}
|
|
563
|
-
diff = difference(store.data, store.
|
|
564
|
+
diff = difference(store.data, originData !== null && originData !== void 0 ? originData : store.upStreamData);
|
|
564
565
|
if (emitedFromWatch &&
|
|
565
566
|
(!Object.keys(diff).length || isEqual(store.data, this.emittedData))) {
|
|
566
567
|
return [2 /*return*/];
|
|
@@ -1100,6 +1101,7 @@ var Form = /** @class */ (function (_super) {
|
|
|
1100
1101
|
var _this = this;
|
|
1101
1102
|
if (otherProps === void 0) { otherProps = {}; }
|
|
1102
1103
|
children = children || [];
|
|
1104
|
+
var cx = this.props.classnames;
|
|
1103
1105
|
if (!Array.isArray(children)) {
|
|
1104
1106
|
children = [children];
|
|
1105
1107
|
}
|
|
@@ -1118,10 +1120,40 @@ var Form = /** @class */ (function (_super) {
|
|
|
1118
1120
|
if (!children.length) {
|
|
1119
1121
|
return null;
|
|
1120
1122
|
}
|
|
1121
|
-
|
|
1122
|
-
return (React.createElement("div", { className: cx_1('Form-row') }, children.map(function (control, key) {
|
|
1123
|
+
return (React.createElement("div", { className: cx('Form-row') }, children.map(function (control, key) {
|
|
1123
1124
|
return ~['hidden', 'formula'].indexOf(control.type) ||
|
|
1124
|
-
control.mode === 'inline' ? (_this.renderChild(control, key, otherProps)) : (React.createElement("div", { key: key, className:
|
|
1125
|
+
control.mode === 'inline' ? (_this.renderChild(control, key, otherProps)) : (React.createElement("div", { key: key, className: cx("Form-col", control.columnClassName) }, _this.renderChild(control, '', __assign(__assign({}, otherProps), { mode: 'row' }))));
|
|
1126
|
+
})));
|
|
1127
|
+
}
|
|
1128
|
+
if (this.props.mode === 'flex') {
|
|
1129
|
+
var rows_1 = [];
|
|
1130
|
+
children.forEach(function (child) {
|
|
1131
|
+
if (typeof child.row === 'number') {
|
|
1132
|
+
if (rows_1[child.row]) {
|
|
1133
|
+
rows_1[child.row].push(child);
|
|
1134
|
+
}
|
|
1135
|
+
else {
|
|
1136
|
+
rows_1[child.row] = [child];
|
|
1137
|
+
}
|
|
1138
|
+
}
|
|
1139
|
+
else {
|
|
1140
|
+
// 没有 row 的,就单启一行
|
|
1141
|
+
rows_1.push([child]);
|
|
1142
|
+
}
|
|
1143
|
+
});
|
|
1144
|
+
return (React.createElement(React.Fragment, null, rows_1.map(function (children, index) {
|
|
1145
|
+
return (React.createElement("div", { className: cx('Form-flex'), role: "flex-row", key: index }, children.map(function (control, key) {
|
|
1146
|
+
var _a;
|
|
1147
|
+
var split = (_a = control.colSize) === null || _a === void 0 ? void 0 : _a.split('/');
|
|
1148
|
+
var colSize = (split === null || split === void 0 ? void 0 : split[0]) && (split === null || split === void 0 ? void 0 : split[1])
|
|
1149
|
+
? (split[0] / split[1]) * 100 + '%'
|
|
1150
|
+
: control.colSize;
|
|
1151
|
+
return ~['hidden', 'formula'].indexOf(control.type) ? (_this.renderChild(control, key, otherProps)) : (React.createElement("div", { key: control.id || key, className: cx("Form-flex-col", control.columnClassName), style: {
|
|
1152
|
+
flex: colSize && !['1', 'auto'].includes(colSize)
|
|
1153
|
+
? "0 0 ".concat(colSize)
|
|
1154
|
+
: ''
|
|
1155
|
+
}, role: "flex-col" }, _this.renderChild(control, '', __assign(__assign({}, otherProps), { mode: 'flex' }))));
|
|
1156
|
+
})));
|
|
1125
1157
|
})));
|
|
1126
1158
|
}
|
|
1127
1159
|
return children.map(function (control, key) {
|
|
@@ -1152,7 +1184,9 @@ var Form = /** @class */ (function (_super) {
|
|
|
1152
1184
|
formSubmited: form.submited,
|
|
1153
1185
|
formMode: mode,
|
|
1154
1186
|
formHorizontal: horizontal,
|
|
1155
|
-
formLabelAlign: labelAlign
|
|
1187
|
+
formLabelAlign: !labelAlign || !['left', 'right', 'top'].includes(labelAlign)
|
|
1188
|
+
? 'right'
|
|
1189
|
+
: labelAlign,
|
|
1156
1190
|
formLabelWidth: labelWidth,
|
|
1157
1191
|
controlWidth: controlWidth,
|
|
1158
1192
|
/**
|
package/esm/renderers/Item.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ import { IFormItemStore, IFormStore } from '../store/form';
|
|
|
5
5
|
import { RendererProps, TestFunc, RendererConfig } from '../factory';
|
|
6
6
|
import { FormHorizontal, FormSchemaBase } from './Form';
|
|
7
7
|
import { ActionObject, BaseApiObject, BaseSchemaWithoutType, ClassName, Schema } from '../types';
|
|
8
|
-
export type LabelAlign = 'right' | 'left';
|
|
8
|
+
export type LabelAlign = 'right' | 'left' | 'top' | 'inherit';
|
|
9
9
|
export interface FormBaseControl extends BaseSchemaWithoutType {
|
|
10
10
|
/**
|
|
11
11
|
* 表单项大小
|
|
@@ -348,6 +348,7 @@ export interface FormBaseControl extends BaseSchemaWithoutType {
|
|
|
348
348
|
* 初始化时是否把其他字段同步到表单内部。
|
|
349
349
|
*/
|
|
350
350
|
initAutoFill?: boolean | 'fillIfNotSet';
|
|
351
|
+
row?: number;
|
|
351
352
|
}
|
|
352
353
|
export interface FormItemBasicConfig extends Partial<RendererConfig> {
|
|
353
354
|
type?: string;
|
|
@@ -556,11 +557,11 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
556
557
|
contextType: React.Context<{
|
|
557
558
|
storeType: string;
|
|
558
559
|
} & import("mobx-state-tree/dist/internal").NonEmptyObject & {
|
|
559
|
-
readonly fetcher: any;
|
|
560
|
-
* 显示一个小图标, 鼠标放上去的时候显示提示内容, 这个小图标跟 label 在一起
|
|
561
|
-
*/
|
|
560
|
+
readonly fetcher: any;
|
|
562
561
|
readonly notify: any;
|
|
563
|
-
readonly isCancel: (value: any) => boolean;
|
|
562
|
+
readonly isCancel: (value: any) => boolean; /**
|
|
563
|
+
* 当修改完的时候是否提交表单。
|
|
564
|
+
*/
|
|
564
565
|
readonly __: import("..").TranslateFn<any>;
|
|
565
566
|
getStoreById(id: string): {
|
|
566
567
|
id: string;
|
|
@@ -575,9 +576,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
575
576
|
readonly hasChildren: boolean;
|
|
576
577
|
readonly children: any[];
|
|
577
578
|
} & {
|
|
578
|
-
onChildStoreDispose(child: any): void;
|
|
579
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
580
|
-
*/
|
|
579
|
+
onChildStoreDispose(child: any): void;
|
|
581
580
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
582
581
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
583
582
|
addChildId: (id: string) => void;
|
|
@@ -595,9 +594,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
595
594
|
readonly hasChildren: boolean;
|
|
596
595
|
readonly children: any[];
|
|
597
596
|
} & {
|
|
598
|
-
onChildStoreDispose(child: any): void;
|
|
599
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
600
|
-
*/
|
|
597
|
+
onChildStoreDispose(child: any): void;
|
|
601
598
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
602
599
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
603
600
|
addChildId: (id: string) => void;
|
|
@@ -617,9 +614,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
617
614
|
readonly hasChildren: boolean;
|
|
618
615
|
readonly children: any[];
|
|
619
616
|
} & {
|
|
620
|
-
onChildStoreDispose(child: any): void;
|
|
621
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
622
|
-
*/
|
|
617
|
+
onChildStoreDispose(child: any): void;
|
|
623
618
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
624
619
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
625
620
|
addChildId: (id: string) => void;
|
|
@@ -637,9 +632,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
637
632
|
readonly hasChildren: boolean;
|
|
638
633
|
readonly children: any[];
|
|
639
634
|
} & {
|
|
640
|
-
onChildStoreDispose(child: any): void;
|
|
641
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
642
|
-
*/
|
|
635
|
+
onChildStoreDispose(child: any): void;
|
|
643
636
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
644
637
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
645
638
|
addChildId: (id: string) => void;
|
|
@@ -666,9 +659,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
666
659
|
readonly hasChildren: boolean;
|
|
667
660
|
readonly children: any[];
|
|
668
661
|
} & {
|
|
669
|
-
onChildStoreDispose(child: any): void;
|
|
670
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
671
|
-
*/
|
|
662
|
+
onChildStoreDispose(child: any): void;
|
|
672
663
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
673
664
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
674
665
|
addChildId: (id: string) => void;
|
|
@@ -686,9 +677,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
686
677
|
readonly hasChildren: boolean;
|
|
687
678
|
readonly children: any[];
|
|
688
679
|
} & {
|
|
689
|
-
onChildStoreDispose(child: any): void;
|
|
690
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
691
|
-
*/
|
|
680
|
+
onChildStoreDispose(child: any): void;
|
|
692
681
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
693
682
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
694
683
|
addChildId: (id: string) => void;
|
|
@@ -707,9 +696,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
707
696
|
readonly hasChildren: boolean;
|
|
708
697
|
readonly children: any[];
|
|
709
698
|
} & {
|
|
710
|
-
onChildStoreDispose(child: any): void;
|
|
711
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
712
|
-
*/
|
|
699
|
+
onChildStoreDispose(child: any): void;
|
|
713
700
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
714
701
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
715
702
|
addChildId: (id: string) => void;
|
|
@@ -727,9 +714,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
727
714
|
readonly hasChildren: boolean;
|
|
728
715
|
readonly children: any[];
|
|
729
716
|
} & {
|
|
730
|
-
onChildStoreDispose(child: any): void;
|
|
731
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
732
|
-
*/
|
|
717
|
+
onChildStoreDispose(child: any): void;
|
|
733
718
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
734
719
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
735
720
|
addChildId: (id: string) => void;
|
|
@@ -738,11 +723,11 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
738
723
|
} & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
|
|
739
724
|
storeType: import("mobx-state-tree").IType<string | undefined, string, string>;
|
|
740
725
|
}, {
|
|
741
|
-
readonly fetcher: any;
|
|
742
|
-
* 显示一个小图标, 鼠标放上去的时候显示提示内容, 这个小图标跟 label 在一起
|
|
743
|
-
*/
|
|
726
|
+
readonly fetcher: any;
|
|
744
727
|
readonly notify: any;
|
|
745
|
-
readonly isCancel: (value: any) => boolean;
|
|
728
|
+
readonly isCancel: (value: any) => boolean; /**
|
|
729
|
+
* 当修改完的时候是否提交表单。
|
|
730
|
+
*/
|
|
746
731
|
readonly __: import("..").TranslateFn<any>;
|
|
747
732
|
getStoreById(id: string): {
|
|
748
733
|
id: string;
|
|
@@ -757,9 +742,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
757
742
|
readonly hasChildren: boolean;
|
|
758
743
|
readonly children: any[];
|
|
759
744
|
} & {
|
|
760
|
-
onChildStoreDispose(child: any): void;
|
|
761
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
762
|
-
*/
|
|
745
|
+
onChildStoreDispose(child: any): void;
|
|
763
746
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
764
747
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
765
748
|
addChildId: (id: string) => void;
|
|
@@ -777,9 +760,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
777
760
|
readonly hasChildren: boolean;
|
|
778
761
|
readonly children: any[];
|
|
779
762
|
} & {
|
|
780
|
-
onChildStoreDispose(child: any): void;
|
|
781
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
782
|
-
*/
|
|
763
|
+
onChildStoreDispose(child: any): void;
|
|
783
764
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
784
765
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
785
766
|
addChildId: (id: string) => void;
|
|
@@ -799,9 +780,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
799
780
|
readonly hasChildren: boolean;
|
|
800
781
|
readonly children: any[];
|
|
801
782
|
} & {
|
|
802
|
-
onChildStoreDispose(child: any): void;
|
|
803
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
804
|
-
*/
|
|
783
|
+
onChildStoreDispose(child: any): void;
|
|
805
784
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
806
785
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
807
786
|
addChildId: (id: string) => void;
|
|
@@ -819,9 +798,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
819
798
|
readonly hasChildren: boolean;
|
|
820
799
|
readonly children: any[];
|
|
821
800
|
} & {
|
|
822
|
-
onChildStoreDispose(child: any): void;
|
|
823
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
824
|
-
*/
|
|
801
|
+
onChildStoreDispose(child: any): void;
|
|
825
802
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
826
803
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
827
804
|
addChildId: (id: string) => void;
|
|
@@ -848,9 +825,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
848
825
|
readonly hasChildren: boolean;
|
|
849
826
|
readonly children: any[];
|
|
850
827
|
} & {
|
|
851
|
-
onChildStoreDispose(child: any): void;
|
|
852
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
853
|
-
*/
|
|
828
|
+
onChildStoreDispose(child: any): void;
|
|
854
829
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
855
830
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
856
831
|
addChildId: (id: string) => void;
|
|
@@ -868,9 +843,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
868
843
|
readonly hasChildren: boolean;
|
|
869
844
|
readonly children: any[];
|
|
870
845
|
} & {
|
|
871
|
-
onChildStoreDispose(child: any): void;
|
|
872
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
873
|
-
*/
|
|
846
|
+
onChildStoreDispose(child: any): void;
|
|
874
847
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
875
848
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
876
849
|
addChildId: (id: string) => void;
|
|
@@ -889,9 +862,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
889
862
|
readonly hasChildren: boolean;
|
|
890
863
|
readonly children: any[];
|
|
891
864
|
} & {
|
|
892
|
-
onChildStoreDispose(child: any): void;
|
|
893
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
894
|
-
*/
|
|
865
|
+
onChildStoreDispose(child: any): void;
|
|
895
866
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
896
867
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
897
868
|
addChildId: (id: string) => void;
|
|
@@ -909,9 +880,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
909
880
|
readonly hasChildren: boolean;
|
|
910
881
|
readonly children: any[];
|
|
911
882
|
} & {
|
|
912
|
-
onChildStoreDispose(child: any): void;
|
|
913
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
914
|
-
*/
|
|
883
|
+
onChildStoreDispose(child: any): void;
|
|
915
884
|
syncProps(props: any, prevProps: any, list?: string[]): void;
|
|
916
885
|
dispose: (callback?: (() => void) | undefined) => void;
|
|
917
886
|
addChildId: (id: string) => void;
|
|
@@ -920,9 +889,7 @@ export declare function asFormItem(config: Omit<FormItemConfig, 'component'>): (
|
|
|
920
889
|
}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>>;
|
|
921
890
|
ComposedComponent: React.ComponentType<any>;
|
|
922
891
|
} & hoistNonReactStatic.NonReactStatics<any, {}> & {
|
|
923
|
-
ComposedComponent: any;
|
|
924
|
-
* 字段名,表单提交时的 key,支持多层级,用.连接,如: a.b.c
|
|
925
|
-
*/
|
|
892
|
+
ComposedComponent: any;
|
|
926
893
|
} & {
|
|
927
894
|
ComposedComponent: any;
|
|
928
895
|
};
|
package/esm/renderers/Item.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-core v6.
|
|
2
|
+
* amis-core v6.6.0
|
|
3
3
|
* Copyright 2018-2024 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -34,6 +34,7 @@ import '../utils/filter.js';
|
|
|
34
34
|
import 'lodash/isObject';
|
|
35
35
|
import 'lodash/isString';
|
|
36
36
|
import 'lodash/isBoolean';
|
|
37
|
+
import '@rc-component/mini-decimal';
|
|
37
38
|
import '../utils/image.js';
|
|
38
39
|
import { keyToPath } from '../utils/keyToPath.js';
|
|
39
40
|
import 'lodash/isEqual';
|
|
@@ -706,8 +707,8 @@ var FormItemWrap = /** @class */ (function (_super) {
|
|
|
706
707
|
row: function (props, renderControl) {
|
|
707
708
|
var _a;
|
|
708
709
|
var className = props.className, style = props.style, cx = props.classnames, desc = props.desc, description = props.description, label = props.label, render = props.render, required = props.required, caption = props.caption, remark = props.remark, labelRemark = props.labelRemark, env = props.env, descriptionClassName = props.descriptionClassName, captionClassName = props.captionClassName, model = props.formItem, renderLabel = props.renderLabel, renderDescription = props.renderDescription, hint = props.hint; props.data; var showErrorMsg = props.showErrorMsg, mobileUI = props.mobileUI; props.translate; var isStatic = props.static, staticClassName = props.staticClassName, wrapperCustomStyle = props.wrapperCustomStyle, themeCss = props.themeCss, id = props.id;
|
|
709
|
-
var labelWidth = props.labelWidth || props.formLabelWidth;
|
|
710
710
|
description = description || desc;
|
|
711
|
+
var labelWidth = props.labelWidth || props.formLabelWidth;
|
|
711
712
|
return (React.createElement("div", { "data-role": "form-item", className: cx("Form-item Form-item--row", isStatic && staticClassName ? staticClassName : className, (_a = {
|
|
712
713
|
'is-error': model && !model.valid
|
|
713
714
|
},
|
|
@@ -757,6 +758,66 @@ var FormItemWrap = /** @class */ (function (_super) {
|
|
|
757
758
|
className: cx("Form-description", descriptionClassName, setThemeClassName(__assign(__assign({}, props), { name: 'descriptionClassName', id: id, themeCss: themeCss, extra: 'item' })))
|
|
758
759
|
})
|
|
759
760
|
: null));
|
|
761
|
+
},
|
|
762
|
+
flex: function (props, renderControl) {
|
|
763
|
+
var _a;
|
|
764
|
+
var className = props.className, style = props.style, cx = props.classnames, desc = props.desc, description = props.description, label = props.label, render = props.render, required = props.required, caption = props.caption, remark = props.remark, labelRemark = props.labelRemark, env = props.env, descriptionClassName = props.descriptionClassName, captionClassName = props.captionClassName, model = props.formItem, renderLabel = props.renderLabel, renderDescription = props.renderDescription, hint = props.hint; props.data; var showErrorMsg = props.showErrorMsg, mobileUI = props.mobileUI; props.translate; var isStatic = props.static, staticClassName = props.staticClassName, wrapperCustomStyle = props.wrapperCustomStyle, themeCss = props.themeCss, id = props.id;
|
|
765
|
+
var labelAlign = (props.labelAlign !== 'inherit' && props.labelAlign) ||
|
|
766
|
+
props.formLabelAlign;
|
|
767
|
+
var labelWidth = props.labelWidth || props.formLabelWidth;
|
|
768
|
+
description = description || desc;
|
|
769
|
+
return (React.createElement("div", { "data-role": "form-item", className: cx("Form-item Form-item--flex", isStatic && staticClassName ? staticClassName : className, (_a = {
|
|
770
|
+
'is-error': model && !model.valid
|
|
771
|
+
},
|
|
772
|
+
_a["is-required"] = required,
|
|
773
|
+
_a), model === null || model === void 0 ? void 0 : model.errClassNames, setThemeClassName(__assign(__assign({}, props), { name: 'wrapperCustomStyle', id: id, themeCss: wrapperCustomStyle, extra: 'item' }))), style: style },
|
|
774
|
+
React.createElement("div", { className: cx('Form-flexInner', labelAlign && "Form-flexInner--label-".concat(labelAlign)) },
|
|
775
|
+
label && renderLabel !== false ? (React.createElement("label", { className: cx("Form-label", getItemLabelClassName(props)), style: labelWidth != null
|
|
776
|
+
? { width: labelAlign === 'top' ? '100%' : labelWidth }
|
|
777
|
+
: undefined },
|
|
778
|
+
React.createElement("span", null,
|
|
779
|
+
render('label', label),
|
|
780
|
+
required && (label || labelRemark) ? (React.createElement("span", { className: cx("Form-star") }, "*")) : null,
|
|
781
|
+
labelRemark
|
|
782
|
+
? render('label-remark', {
|
|
783
|
+
type: 'remark',
|
|
784
|
+
icon: labelRemark.icon || 'warning-mark',
|
|
785
|
+
tooltip: labelRemark,
|
|
786
|
+
className: cx("Form-lableRemark"),
|
|
787
|
+
mobileUI: mobileUI,
|
|
788
|
+
container: props.popOverContainer || env.getModalContainer
|
|
789
|
+
})
|
|
790
|
+
: null))) : null,
|
|
791
|
+
React.createElement("div", { className: cx("Form-value") },
|
|
792
|
+
renderControl(),
|
|
793
|
+
caption
|
|
794
|
+
? render('caption', caption, {
|
|
795
|
+
className: cx("Form-caption", captionClassName)
|
|
796
|
+
})
|
|
797
|
+
: null,
|
|
798
|
+
remark
|
|
799
|
+
? render('remark', {
|
|
800
|
+
type: 'remark',
|
|
801
|
+
icon: remark.icon || 'warning-mark',
|
|
802
|
+
className: cx("Form-remark"),
|
|
803
|
+
tooltip: remark,
|
|
804
|
+
container: props.popOverContainer || env.getModalContainer
|
|
805
|
+
})
|
|
806
|
+
: null,
|
|
807
|
+
hint && model && model.isFocused
|
|
808
|
+
? render('hint', hint, {
|
|
809
|
+
className: cx("Form-hint")
|
|
810
|
+
})
|
|
811
|
+
: null,
|
|
812
|
+
model &&
|
|
813
|
+
!model.valid &&
|
|
814
|
+
showErrorMsg !== false &&
|
|
815
|
+
Array.isArray(model.errors) ? (React.createElement("ul", { className: cx('Form-feedback') }, model.errors.map(function (msg, key) { return (React.createElement("li", { key: key }, msg)); }))) : null,
|
|
816
|
+
description && renderDescription !== false
|
|
817
|
+
? render('description', description, {
|
|
818
|
+
className: cx("Form-description", descriptionClassName, setThemeClassName(__assign(__assign({}, props), { name: 'descriptionClassName', id: id, themeCss: themeCss, extra: 'item' })))
|
|
819
|
+
})
|
|
820
|
+
: null))));
|
|
760
821
|
}
|
|
761
822
|
};
|
|
762
823
|
__decorate([
|
|
@@ -879,12 +940,18 @@ var detectProps = [
|
|
|
879
940
|
'displayMode',
|
|
880
941
|
'revealPassword',
|
|
881
942
|
'loading',
|
|
882
|
-
'themeCss'
|
|
943
|
+
'themeCss',
|
|
944
|
+
'formLabelAlign',
|
|
945
|
+
'formLabelWidth',
|
|
946
|
+
'formHorizontal',
|
|
947
|
+
'labelAlign',
|
|
948
|
+
'colSize'
|
|
883
949
|
];
|
|
884
950
|
function asFormItem(config) {
|
|
885
951
|
return function (Control) {
|
|
886
952
|
var _a;
|
|
887
|
-
var
|
|
953
|
+
var supportRef = Control.prototype instanceof React.Component ||
|
|
954
|
+
Control.$$typeof === Symbol.for('react.forward_ref');
|
|
888
955
|
// 兼容老的 FormItem 用法。
|
|
889
956
|
if (config.validate && !Control.prototype.validate) {
|
|
890
957
|
var fn_1 = config.validate;
|
|
@@ -943,11 +1010,13 @@ function asFormItem(config) {
|
|
|
943
1010
|
var _b = this.props;
|
|
944
1011
|
// 这里解构,不可轻易删除,避免被rest传到子组件
|
|
945
1012
|
_b.inputClassName; var model = _b.formItem, cx = _b.classnames; _b.children; var type = _b.type, size = _b.size, defaultSize = _b.defaultSize, mobileUI = _b.mobileUI, rest = __rest(_b, ["inputClassName", "formItem", "classnames", "children", "type", "size", "defaultSize", "mobileUI"]);
|
|
946
|
-
var controlSize = size
|
|
1013
|
+
var controlSize = size && ['xs', 'sm', 'md', 'lg', 'full'].includes(size)
|
|
1014
|
+
? size
|
|
1015
|
+
: defaultSize;
|
|
947
1016
|
//@ts-ignore
|
|
948
1017
|
var isOpened = this.state.isOpened;
|
|
949
1018
|
return (React.createElement(React.Fragment, null,
|
|
950
|
-
React.createElement(Control, __assign({}, rest, { mobileUI: mobileUI, onOpenDialog: this.handleOpenDialog, size: config.sizeMutable !== false ? undefined : size, onFocus: this.handleFocus, onBlur: this.handleBlur, type: type, classnames: cx, ref:
|
|
1019
|
+
React.createElement(Control, __assign({}, rest, { mobileUI: mobileUI, onOpenDialog: this.handleOpenDialog, size: config.sizeMutable !== false ? undefined : size, onFocus: this.handleFocus, onBlur: this.handleBlur, type: type, classnames: cx, ref: supportRef ? this.refFn : undefined, forwardedRef: supportRef ? undefined : this.refFn, formItem: model, className: cx("Form-control", (_a = {
|
|
951
1020
|
'is-inline': !!rest.inline && !mobileUI,
|
|
952
1021
|
'is-error': model && !model.valid,
|
|
953
1022
|
'is-full': size === 'full'
|
package/esm/renderers/Options.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-core v6.
|
|
2
|
+
* amis-core v6.6.0
|
|
3
3
|
* Copyright 2018-2024 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -14,6 +14,7 @@ import 'amis-formula';
|
|
|
14
14
|
import 'moment';
|
|
15
15
|
import { createObject, setVariable } from '../utils/object.js';
|
|
16
16
|
import { isPureVariable } from '../utils/isPureVariable.js';
|
|
17
|
+
import '@rc-component/mini-decimal';
|
|
17
18
|
import { resolveVariableAndFilter } from '../utils/resolveVariableAndFilter.js';
|
|
18
19
|
import 'lodash/isPlainObject';
|
|
19
20
|
import '../utils/filter.js';
|
|
@@ -91,21 +92,47 @@ function registerOptionsControl(config) {
|
|
|
91
92
|
_this.defaultCheckAll();
|
|
92
93
|
}
|
|
93
94
|
var loadOptions = initFetch !== false;
|
|
95
|
+
var setInitValue = null;
|
|
94
96
|
if (joinValues === false && defaultValue) {
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
97
|
+
setInitValue = function () {
|
|
98
|
+
var selectedOptions = extractValue
|
|
99
|
+
? formItem
|
|
100
|
+
.getSelectedOptions(value)
|
|
101
|
+
.map(function (selectedOption) {
|
|
102
|
+
return selectedOption[valueField || 'value'];
|
|
103
|
+
})
|
|
104
|
+
: formItem.getSelectedOptions(value);
|
|
105
|
+
setPrinstineValue(multiple ? selectedOptions.concat() : selectedOptions[0]);
|
|
106
|
+
};
|
|
103
107
|
}
|
|
104
|
-
loadOptions &&
|
|
105
|
-
config.autoLoadOptionsFromSource !== false &&
|
|
108
|
+
if (loadOptions && config.autoLoadOptionsFromSource !== false) {
|
|
106
109
|
_this.toDispose.push(formInited || !addHook
|
|
107
|
-
? formItem.addInitHook(_this
|
|
108
|
-
|
|
110
|
+
? formItem.addInitHook(function () { return __awaiter(_this, void 0, void 0, function () {
|
|
111
|
+
return __generator(this, function (_a) {
|
|
112
|
+
switch (_a.label) {
|
|
113
|
+
case 0: return [4 /*yield*/, this.reload()];
|
|
114
|
+
case 1:
|
|
115
|
+
_a.sent();
|
|
116
|
+
setInitValue === null || setInitValue === void 0 ? void 0 : setInitValue();
|
|
117
|
+
return [2 /*return*/];
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
}); })
|
|
121
|
+
: addHook(function (data) { return __awaiter(_this, void 0, void 0, function () {
|
|
122
|
+
return __generator(this, function (_a) {
|
|
123
|
+
switch (_a.label) {
|
|
124
|
+
case 0: return [4 /*yield*/, this.initOptions(data)];
|
|
125
|
+
case 1:
|
|
126
|
+
_a.sent();
|
|
127
|
+
setInitValue === null || setInitValue === void 0 ? void 0 : setInitValue();
|
|
128
|
+
return [2 /*return*/];
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
}); }, 'init'));
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
setInitValue === null || setInitValue === void 0 ? void 0 : setInitValue();
|
|
135
|
+
}
|
|
109
136
|
return _this;
|
|
110
137
|
}
|
|
111
138
|
FormOptionsItem.prototype.componentDidMount = function () {
|
package/esm/renderers/builtin.js
CHANGED