feat: V3 form (#4678)
* chore: update husky * perf: update formItem * perf: useInjectFormItemContextv2.3
parent
989d1d4202
commit
ca6ce42819
|
@ -63,7 +63,6 @@ _site
|
||||||
yarn.lock
|
yarn.lock
|
||||||
package-lock.json
|
package-lock.json
|
||||||
/coverage
|
/coverage
|
||||||
.husky
|
|
||||||
|
|
||||||
# 备份文件
|
# 备份文件
|
||||||
/components/test/*
|
/components/test/*
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
_
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/bin/sh
|
||||||
|
. "$(dirname "$0")/_/husky.sh"
|
||||||
|
|
||||||
|
npx --no-install pretty-quick --staged
|
|
@ -4,7 +4,7 @@ exports[`renders ./components/auto-complete/demo/basic.vue correctly 1`] = `
|
||||||
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><input type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><input id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
||||||
<!----><span class="ant-select-selection-placeholder">input here</span>
|
<!----><span class="ant-select-selection-placeholder">input here</span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -17,7 +17,7 @@ exports[`renders ./components/auto-complete/demo/certain-category.vue correctly
|
||||||
<div class="ant-select ant-select-lg certain-category-search ant-select-lg ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search" style="width: 100%;">
|
<div class="ant-select ant-select-lg certain-category-search ant-select-lg ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search" style="width: 100%;">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><span class="ant-select-selection-search-input ant-input-affix-wrapper"><!----><input placeholder="input here" type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" class="ant-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"><span class="ant-input-suffix"><!----><span role="img" aria-label="search" class="anticon anticon-search certain-category-icon"><svg focusable="false" class="" data-icon="search" width="1em" height="1em" fill="currentColor" aria-hidden="true" viewBox="64 64 896 896"><path d="M909.6 854.5L649.9 594.8C690.2 542.7 712 479 712 412c0-80.2-31.3-155.4-87.9-212.1-56.6-56.7-132-87.9-212.1-87.9s-155.5 31.3-212.1 87.9C143.2 256.5 112 331.8 112 412c0 80.1 31.3 155.5 87.9 212.1C256.5 680.8 331.8 712 412 712c67 0 130.6-21.8 182.7-62l259.7 259.6a8.2 8.2 0 0011.6 0l43.6-43.5a8.2 8.2 0 000-11.6zM570.4 570.4C528 612.7 471.8 636 412 636s-116-23.3-158.4-65.6C211.3 528 188 471.8 188 412s23.3-116.1 65.6-158.4C296 211.3 352.2 188 412 188s116.1 23.2 158.4 65.6S636 352.2 636 412s-23.3 116.1-65.6 158.4z"></path></svg></span></span></span></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><span class="ant-select-selection-search-input ant-input-affix-wrapper"><!----><input placeholder="input here" id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" class="ant-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"><span class="ant-input-suffix"><!----><span role="img" aria-label="search" class="anticon anticon-search certain-category-icon"><svg focusable="false" class="" data-icon="search" width="1em" height="1em" fill="currentColor" aria-hidden="true" viewBox="64 64 896 896"><path d="M909.6 854.5L649.9 594.8C690.2 542.7 712 479 712 412c0-80.2-31.3-155.4-87.9-212.1-56.6-56.7-132-87.9-212.1-87.9s-155.5 31.3-212.1 87.9C143.2 256.5 112 331.8 112 412c0 80.1 31.3 155.5 87.9 212.1C256.5 680.8 331.8 712 412 712c67 0 130.6-21.8 182.7-62l259.7 259.6a8.2 8.2 0 0011.6 0l43.6-43.5a8.2 8.2 0 000-11.6zM570.4 570.4C528 612.7 471.8 636 412 636s-116-23.3-158.4-65.6C211.3 528 188 471.8 188 412s23.3-116.1 65.6-158.4C296 211.3 352.2 188 412 188s116.1 23.2 158.4 65.6S636 352.2 636 412s-23.3 116.1-65.6 158.4z"></path></svg></span></span></span></span>
|
||||||
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -30,7 +30,7 @@ exports[`renders ./components/auto-complete/demo/custom.vue correctly 1`] = `
|
||||||
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><textarea placeholder="input here" class="ant-input ant-select-selection-search-input" style="height: 50px;" id="rc_select_TEST_OR_SSR" autocomplete="off" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></textarea></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><textarea placeholder="input here" id="rc_select_TEST_OR_SSR" class="ant-input ant-select-selection-search-input" style="height: 50px;" autocomplete="off" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></textarea></span>
|
||||||
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -42,7 +42,7 @@ exports[`renders ./components/auto-complete/demo/non-case-sensitive.vue correctl
|
||||||
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><input type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><input id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
||||||
<!----><span class="ant-select-selection-placeholder">input here</span>
|
<!----><span class="ant-select-selection-placeholder">input here</span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -54,7 +54,7 @@ exports[`renders ./components/auto-complete/demo/options.vue correctly 1`] = `
|
||||||
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><input type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><input id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
||||||
<!----><span class="ant-select-selection-placeholder">input here</span>
|
<!----><span class="ant-select-selection-placeholder">input here</span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -67,7 +67,7 @@ exports[`renders ./components/auto-complete/demo/uncertain-category.vue correctl
|
||||||
<div class="ant-select ant-select-lg global-search ant-select-lg ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search" style="width: 100%;">
|
<div class="ant-select ant-select-lg global-search ant-select-lg ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search" style="width: 100%;">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><span class="ant-input-search ant-select-selection-search-input ant-input-search-enter-button ant-input-search-large ant-input-group-wrapper ant-input-group-wrapper-lg"><span class="ant-input-wrapper ant-input-group"><!----><input placeholder="input here" type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0" class="ant-input ant-input-lg"><span class="ant-input-group-addon"><button class="ant-btn ant-btn-primary ant-btn-lg ant-input-search-button" type="button"><!----><span role="img" aria-label="search" class="anticon anticon-search"><svg focusable="false" class="" data-icon="search" width="1em" height="1em" fill="currentColor" aria-hidden="true" viewBox="64 64 896 896"><path d="M909.6 854.5L649.9 594.8C690.2 542.7 712 479 712 412c0-80.2-31.3-155.4-87.9-212.1-56.6-56.7-132-87.9-212.1-87.9s-155.5 31.3-212.1 87.9C143.2 256.5 112 331.8 112 412c0 80.1 31.3 155.5 87.9 212.1C256.5 680.8 331.8 712 412 712c67 0 130.6-21.8 182.7-62l259.7 259.6a8.2 8.2 0 0011.6 0l43.6-43.5a8.2 8.2 0 000-11.6zM570.4 570.4C528 612.7 471.8 636 412 636s-116-23.3-158.4-65.6C211.3 528 188 471.8 188 412s23.3-116.1 65.6-158.4C296 211.3 352.2 188 412 188s116.1 23.2 158.4 65.6S636 352.2 636 412s-23.3 116.1-65.6 158.4z"></path></svg></span></button></span></span></span></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><span class="ant-input-search ant-select-selection-search-input ant-input-search-enter-button ant-input-search-large ant-input-group-wrapper ant-input-group-wrapper-lg"><span class="ant-input-wrapper ant-input-group"><!----><input placeholder="input here" id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0" class="ant-input ant-input-lg"><span class="ant-input-group-addon"><button class="ant-btn ant-btn-primary ant-btn-lg ant-input-search-button" type="button"><!----><span role="img" aria-label="search" class="anticon anticon-search"><svg focusable="false" class="" data-icon="search" width="1em" height="1em" fill="currentColor" aria-hidden="true" viewBox="64 64 896 896"><path d="M909.6 854.5L649.9 594.8C690.2 542.7 712 479 712 412c0-80.2-31.3-155.4-87.9-212.1-56.6-56.7-132-87.9-212.1-87.9s-155.5 31.3-212.1 87.9C143.2 256.5 112 331.8 112 412c0 80.1 31.3 155.5 87.9 212.1C256.5 680.8 331.8 712 412 712c67 0 130.6-21.8 182.7-62l259.7 259.6a8.2 8.2 0 0011.6 0l43.6-43.5a8.2 8.2 0 000-11.6zM570.4 570.4C528 612.7 471.8 636 412 636s-116-23.3-158.4-65.6C211.3 528 188 471.8 188 412s23.3-116.1 65.6-158.4C296 211.3 352.2 188 412 188s116.1 23.2 158.4 65.6S636 352.2 636 412s-23.3 116.1-65.6 158.4z"></path></svg></span></button></span></span></span></span>
|
||||||
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
<!----><span class="ant-select-selection-placeholder"><!----></span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
|
|
@ -27,6 +27,7 @@ import { defaultConfigProvider } from '../config-provider';
|
||||||
import type { VueNode } from '../_util/type';
|
import type { VueNode } from '../_util/type';
|
||||||
import { tuple, withInstall } from '../_util/type';
|
import { tuple, withInstall } from '../_util/type';
|
||||||
import type { RenderEmptyHandler } from '../config-provider/renderEmpty';
|
import type { RenderEmptyHandler } from '../config-provider/renderEmpty';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export interface CascaderOptionType {
|
export interface CascaderOptionType {
|
||||||
value?: string | number;
|
value?: string | number;
|
||||||
|
@ -220,12 +221,14 @@ const Cascader = defineComponent({
|
||||||
inheritAttrs: false,
|
inheritAttrs: false,
|
||||||
props: cascaderProps,
|
props: cascaderProps,
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
localeData: inject('localeData', {} as any),
|
localeData: inject('localeData', {} as any),
|
||||||
cachedOptions: [],
|
cachedOptions: [],
|
||||||
popupRef: undefined,
|
popupRef: undefined,
|
||||||
input: undefined,
|
input: undefined,
|
||||||
|
formItemContext,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
@ -323,6 +326,7 @@ const Cascader = defineComponent({
|
||||||
inputFocused: false,
|
inputFocused: false,
|
||||||
});
|
});
|
||||||
this.$emit('blur', e);
|
this.$emit('blur', e);
|
||||||
|
this.formItemContext.onFieldBlur();
|
||||||
},
|
},
|
||||||
|
|
||||||
handleInputClick(e: MouseEvent & { nativeEvent?: any }) {
|
handleInputClick(e: MouseEvent & { nativeEvent?: any }) {
|
||||||
|
@ -354,6 +358,7 @@ const Cascader = defineComponent({
|
||||||
}
|
}
|
||||||
this.$emit('update:value', value);
|
this.$emit('update:value', value);
|
||||||
this.$emit('change', value, selectedOptions);
|
this.$emit('change', value, selectedOptions);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
|
|
||||||
getLabel() {
|
getLabel() {
|
||||||
|
@ -474,7 +479,12 @@ const Cascader = defineComponent({
|
||||||
...otherProps
|
...otherProps
|
||||||
} = props as any;
|
} = props as any;
|
||||||
const { onEvents, extraAttrs } = splitAttrs(this.$attrs);
|
const { onEvents, extraAttrs } = splitAttrs(this.$attrs);
|
||||||
const { class: className, style, ...restAttrs } = extraAttrs;
|
const {
|
||||||
|
class: className,
|
||||||
|
style,
|
||||||
|
id = this.formItemContext.id.value,
|
||||||
|
...restAttrs
|
||||||
|
} = extraAttrs;
|
||||||
const getPrefixCls = this.configProvider.getPrefixCls;
|
const getPrefixCls = this.configProvider.getPrefixCls;
|
||||||
const renderEmpty = this.configProvider.renderEmpty;
|
const renderEmpty = this.configProvider.renderEmpty;
|
||||||
const prefixCls = getPrefixCls('cascader', customizePrefixCls);
|
const prefixCls = getPrefixCls('cascader', customizePrefixCls);
|
||||||
|
@ -570,6 +580,7 @@ const Cascader = defineComponent({
|
||||||
const inputProps = {
|
const inputProps = {
|
||||||
...restAttrs,
|
...restAttrs,
|
||||||
...tempInputProps,
|
...tempInputProps,
|
||||||
|
id,
|
||||||
prefixCls: inputPrefixCls,
|
prefixCls: inputPrefixCls,
|
||||||
placeholder: value && value.length > 0 ? undefined : placeholder,
|
placeholder: value && value.length > 0 ? undefined : placeholder,
|
||||||
value: inputValue,
|
value: inputValue,
|
||||||
|
|
|
@ -8,6 +8,7 @@ import { defaultConfigProvider } from '../config-provider';
|
||||||
import warning from '../_util/warning';
|
import warning from '../_util/warning';
|
||||||
import type { RadioChangeEvent } from '../radio/interface';
|
import type { RadioChangeEvent } from '../radio/interface';
|
||||||
import type { EventHandler } from '../_util/EventInterface';
|
import type { EventHandler } from '../_util/EventInterface';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
function noop() {}
|
function noop() {}
|
||||||
|
|
||||||
export const checkboxProps = () => {
|
export const checkboxProps = () => {
|
||||||
|
@ -38,7 +39,9 @@ export default defineComponent({
|
||||||
props: checkboxProps(),
|
props: checkboxProps(),
|
||||||
emits: ['change', 'update:checked'],
|
emits: ['change', 'update:checked'],
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
|
formItemContext,
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
checkboxGroupContext: inject('checkboxGroupContext', undefined),
|
checkboxGroupContext: inject('checkboxGroupContext', undefined),
|
||||||
};
|
};
|
||||||
|
@ -96,7 +99,13 @@ export default defineComponent({
|
||||||
const props = getOptionProps(this);
|
const props = getOptionProps(this);
|
||||||
const { checkboxGroupContext: checkboxGroup, $attrs } = this;
|
const { checkboxGroupContext: checkboxGroup, $attrs } = this;
|
||||||
const children = getSlot(this);
|
const children = getSlot(this);
|
||||||
const { indeterminate, prefixCls: customizePrefixCls, skipGroup, ...restProps } = props;
|
const {
|
||||||
|
indeterminate,
|
||||||
|
prefixCls: customizePrefixCls,
|
||||||
|
skipGroup,
|
||||||
|
id = this.formItemContext.id.value,
|
||||||
|
...restProps
|
||||||
|
} = props;
|
||||||
const getPrefixCls = this.configProvider.getPrefixCls;
|
const getPrefixCls = this.configProvider.getPrefixCls;
|
||||||
const prefixCls = getPrefixCls('checkbox', customizePrefixCls);
|
const prefixCls = getPrefixCls('checkbox', customizePrefixCls);
|
||||||
const {
|
const {
|
||||||
|
@ -109,12 +118,14 @@ export default defineComponent({
|
||||||
} = $attrs;
|
} = $attrs;
|
||||||
const checkboxProps: any = {
|
const checkboxProps: any = {
|
||||||
...restProps,
|
...restProps,
|
||||||
|
id,
|
||||||
prefixCls,
|
prefixCls,
|
||||||
...restAttrs,
|
...restAttrs,
|
||||||
};
|
};
|
||||||
if (checkboxGroup && !skipGroup) {
|
if (checkboxGroup && !skipGroup) {
|
||||||
checkboxProps.onChange = (...args) => {
|
checkboxProps.onChange = (...args) => {
|
||||||
this.$emit('change', ...args);
|
this.$emit('change', ...args);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
checkboxGroup.toggleOption({ label: children, value: props.value });
|
checkboxGroup.toggleOption({ label: children, value: props.value });
|
||||||
};
|
};
|
||||||
checkboxProps.name = checkboxGroup.name;
|
checkboxProps.name = checkboxGroup.name;
|
||||||
|
|
|
@ -5,6 +5,7 @@ import Checkbox from './Checkbox';
|
||||||
import hasProp, { getSlot } from '../_util/props-util';
|
import hasProp, { getSlot } from '../_util/props-util';
|
||||||
import { defaultConfigProvider } from '../config-provider';
|
import { defaultConfigProvider } from '../config-provider';
|
||||||
import type { VueNode } from '../_util/type';
|
import type { VueNode } from '../_util/type';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export type CheckboxValueType = string | number | boolean;
|
export type CheckboxValueType = string | number | boolean;
|
||||||
export interface CheckboxOptionType {
|
export interface CheckboxOptionType {
|
||||||
|
@ -25,10 +26,13 @@ export default defineComponent({
|
||||||
options: { type: Array as PropType<Array<CheckboxOptionType | string>> },
|
options: { type: Array as PropType<Array<CheckboxOptionType | string>> },
|
||||||
disabled: PropTypes.looseBool,
|
disabled: PropTypes.looseBool,
|
||||||
onChange: PropTypes.func,
|
onChange: PropTypes.func,
|
||||||
|
id: PropTypes.string,
|
||||||
},
|
},
|
||||||
emits: ['change', 'update:value'],
|
emits: ['change', 'update:value'],
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
|
formItemContext,
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
@ -95,11 +99,12 @@ export default defineComponent({
|
||||||
// this.$emit('input', val);
|
// this.$emit('input', val);
|
||||||
this.$emit('update:value', val);
|
this.$emit('update:value', val);
|
||||||
this.$emit('change', val);
|
this.$emit('change', val);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
const { $props: props, $data: state } = this;
|
const { $props: props, $data: state } = this;
|
||||||
const { prefixCls: customizePrefixCls, options } = props;
|
const { prefixCls: customizePrefixCls, options, id = this.formItemContext.id.value } = props;
|
||||||
const getPrefixCls = this.configProvider.getPrefixCls;
|
const getPrefixCls = this.configProvider.getPrefixCls;
|
||||||
const prefixCls = getPrefixCls('checkbox', customizePrefixCls);
|
const prefixCls = getPrefixCls('checkbox', customizePrefixCls);
|
||||||
let children = getSlot(this);
|
let children = getSlot(this);
|
||||||
|
@ -120,6 +125,10 @@ export default defineComponent({
|
||||||
</Checkbox>
|
</Checkbox>
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
return <div class={groupPrefixCls}>{children}</div>;
|
return (
|
||||||
|
<div class={groupPrefixCls} id={id}>
|
||||||
|
{children}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -15,6 +15,7 @@ import { commonProps, rangePickerProps } from './props';
|
||||||
import type { PanelMode, RangeValue } from '../../vc-picker/interface';
|
import type { PanelMode, RangeValue } from '../../vc-picker/interface';
|
||||||
import type { RangePickerSharedProps } from '../../vc-picker/RangePicker';
|
import type { RangePickerSharedProps } from '../../vc-picker/RangePicker';
|
||||||
import devWarning from '../../vc-util/devWarning';
|
import devWarning from '../../vc-util/devWarning';
|
||||||
|
import { useInjectFormItemContext } from '../../form/FormItemContext';
|
||||||
|
|
||||||
export default function generateRangePicker<DateType, ExtraProps = {}>(
|
export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
generateConfig: GenerateConfig<DateType>,
|
generateConfig: GenerateConfig<DateType>,
|
||||||
|
@ -52,6 +53,7 @@ export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
'blur',
|
'blur',
|
||||||
],
|
],
|
||||||
setup(props, { expose, slots, attrs, emit }) {
|
setup(props, { expose, slots, attrs, emit }) {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
devWarning(
|
devWarning(
|
||||||
!attrs.getCalendarContainer,
|
!attrs.getCalendarContainer,
|
||||||
'DatePicker',
|
'DatePicker',
|
||||||
|
@ -86,6 +88,7 @@ export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
const values = maybeToStrings(dates);
|
const values = maybeToStrings(dates);
|
||||||
emit('update:value', values);
|
emit('update:value', values);
|
||||||
emit('change', values, dateStrings);
|
emit('change', values, dateStrings);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
const onOpenChange = (open: boolean) => {
|
const onOpenChange = (open: boolean) => {
|
||||||
emit('update:open', open);
|
emit('update:open', open);
|
||||||
|
@ -96,6 +99,7 @@ export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
};
|
};
|
||||||
const onBlur = () => {
|
const onBlur = () => {
|
||||||
emit('blur');
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
const onPanelChange = (dates: RangeValue<DateType>, modes: [PanelMode, PanelMode]) => {
|
const onPanelChange = (dates: RangeValue<DateType>, modes: [PanelMode, PanelMode]) => {
|
||||||
const values = maybeToStrings(dates);
|
const values = maybeToStrings(dates);
|
||||||
|
@ -154,6 +158,7 @@ export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
renderExtraFooter = slots.renderExtraFooter,
|
renderExtraFooter = slots.renderExtraFooter,
|
||||||
separator = slots.separator?.(),
|
separator = slots.separator?.(),
|
||||||
clearIcon = slots.clearIcon?.(),
|
clearIcon = slots.clearIcon?.(),
|
||||||
|
id = formItemContext.id.value,
|
||||||
...restProps
|
...restProps
|
||||||
} = p;
|
} = p;
|
||||||
const { format, showTime } = p as any;
|
const { format, showTime } = p as any;
|
||||||
|
@ -187,6 +192,7 @@ export default function generateRangePicker<DateType, ExtraProps = {}>(
|
||||||
transitionName={transitionName || `${rootPrefixCls.value}-slide-up`}
|
transitionName={transitionName || `${rootPrefixCls.value}-slide-up`}
|
||||||
{...restProps}
|
{...restProps}
|
||||||
{...additionalOverrideProps}
|
{...additionalOverrideProps}
|
||||||
|
id={id}
|
||||||
value={value.value}
|
value={value.value}
|
||||||
defaultValue={defaultValue.value}
|
defaultValue={defaultValue.value}
|
||||||
defaultPickerValue={defaultPickerValue.value}
|
defaultPickerValue={defaultPickerValue.value}
|
||||||
|
|
|
@ -14,6 +14,7 @@ import classNames from '../../_util/classNames';
|
||||||
import { commonProps, datePickerProps } from './props';
|
import { commonProps, datePickerProps } from './props';
|
||||||
|
|
||||||
import devWarning from '../../vc-util/devWarning';
|
import devWarning from '../../vc-util/devWarning';
|
||||||
|
import { useInjectFormItemContext } from '../../form/FormItemContext';
|
||||||
|
|
||||||
export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
generateConfig: GenerateConfig<DateType>,
|
generateConfig: GenerateConfig<DateType>,
|
||||||
|
@ -51,6 +52,7 @@ export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
'update:open',
|
'update:open',
|
||||||
],
|
],
|
||||||
setup(props, { slots, expose, attrs, emit }) {
|
setup(props, { slots, expose, attrs, emit }) {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
devWarning(
|
devWarning(
|
||||||
!(props.monthCellContentRender || slots.monthCellContentRender),
|
!(props.monthCellContentRender || slots.monthCellContentRender),
|
||||||
'DatePicker',
|
'DatePicker',
|
||||||
|
@ -91,6 +93,7 @@ export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
const value = maybeToString(date);
|
const value = maybeToString(date);
|
||||||
emit('update:value', value);
|
emit('update:value', value);
|
||||||
emit('change', value, dateString);
|
emit('change', value, dateString);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
const onOpenChange = (open: boolean) => {
|
const onOpenChange = (open: boolean) => {
|
||||||
emit('update:open', open);
|
emit('update:open', open);
|
||||||
|
@ -101,6 +104,7 @@ export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
};
|
};
|
||||||
const onBlur = () => {
|
const onBlur = () => {
|
||||||
emit('blur');
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
const onPanelChange = (date: DateType, mode: PanelMode | null) => {
|
const onPanelChange = (date: DateType, mode: PanelMode | null) => {
|
||||||
const value = maybeToString(date);
|
const value = maybeToString(date);
|
||||||
|
@ -157,6 +161,7 @@ export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
(props as any).monthCellContentRender ||
|
(props as any).monthCellContentRender ||
|
||||||
slots.monthCellContentRender,
|
slots.monthCellContentRender,
|
||||||
clearIcon = slots.clearIcon?.(),
|
clearIcon = slots.clearIcon?.(),
|
||||||
|
id = formItemContext.id.value,
|
||||||
...restProps
|
...restProps
|
||||||
} = p;
|
} = p;
|
||||||
const showTime = p.showTime === '' ? true : p.showTime;
|
const showTime = p.showTime === '' ? true : p.showTime;
|
||||||
|
@ -198,6 +203,7 @@ export default function generateSinglePicker<DateType, ExtraProps = {}>(
|
||||||
transitionName={transitionName || `${rootPrefixCls.value}-slide-up`}
|
transitionName={transitionName || `${rootPrefixCls.value}-slide-up`}
|
||||||
{...restProps}
|
{...restProps}
|
||||||
{...additionalOverrideProps}
|
{...additionalOverrideProps}
|
||||||
|
id={id}
|
||||||
picker={mergedPicker}
|
picker={mergedPicker}
|
||||||
value={value.value}
|
value={value.value}
|
||||||
defaultValue={defaultValue.value}
|
defaultValue={defaultValue.value}
|
||||||
|
|
|
@ -19,6 +19,7 @@ import type { VueNode } from '../../_util/type';
|
||||||
|
|
||||||
function commonProps<DateType>() {
|
function commonProps<DateType>() {
|
||||||
return {
|
return {
|
||||||
|
id: String,
|
||||||
dropdownClassName: String,
|
dropdownClassName: String,
|
||||||
dropdownAlign: { type: Object as PropType<AlignType> },
|
dropdownAlign: { type: Object as PropType<AlignType> },
|
||||||
popupStyle: { type: Object as PropType<CSSProperties> },
|
popupStyle: { type: Object as PropType<CSSProperties> },
|
||||||
|
@ -77,6 +78,7 @@ function commonProps<DateType>() {
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface CommonProps<DateType> {
|
export interface CommonProps<DateType> {
|
||||||
|
id?: string;
|
||||||
prefixCls?: string;
|
prefixCls?: string;
|
||||||
dropdownClassName?: string;
|
dropdownClassName?: string;
|
||||||
dropdownAlign?: AlignType;
|
dropdownAlign?: AlignType;
|
||||||
|
|
|
@ -4,9 +4,8 @@ import cloneDeep from 'lodash-es/cloneDeep';
|
||||||
import PropTypes from '../_util/vue-types';
|
import PropTypes from '../_util/vue-types';
|
||||||
import Row from '../grid/Row';
|
import Row from '../grid/Row';
|
||||||
import type { ColProps } from '../grid/Col';
|
import type { ColProps } from '../grid/Col';
|
||||||
import { isValidElement, flattenChildren, filterEmpty } from '../_util/props-util';
|
import { filterEmpty } from '../_util/props-util';
|
||||||
import BaseMixin from '../_util/BaseMixin';
|
import BaseMixin from '../_util/BaseMixin';
|
||||||
import { cloneElement } from '../_util/vnode';
|
|
||||||
import { validateRules as validateRulesUtil } from './utils/validateUtil';
|
import { validateRules as validateRulesUtil } from './utils/validateUtil';
|
||||||
import { getNamePath } from './utils/valueUtil';
|
import { getNamePath } from './utils/valueUtil';
|
||||||
import { toArray } from './utils/typeUtil';
|
import { toArray } from './utils/typeUtil';
|
||||||
|
@ -19,6 +18,7 @@ import { useInjectForm } from './context';
|
||||||
import FormItemLabel from './FormItemLabel';
|
import FormItemLabel from './FormItemLabel';
|
||||||
import FormItemInput from './FormItemInput';
|
import FormItemInput from './FormItemInput';
|
||||||
import type { ValidationRule } from './Form';
|
import type { ValidationRule } from './Form';
|
||||||
|
import { useProvideFormItemContext } from './FormItemContext';
|
||||||
|
|
||||||
const ValidateStatuses = tuple('success', 'warning', 'error', 'validating', '');
|
const ValidateStatuses = tuple('success', 'warning', 'error', 'validating', '');
|
||||||
export type ValidateStatus = typeof ValidateStatuses[number];
|
export type ValidateStatus = typeof ValidateStatuses[number];
|
||||||
|
@ -271,6 +271,13 @@ export default defineComponent({
|
||||||
clearValidate,
|
clearValidate,
|
||||||
resetField,
|
resetField,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
useProvideFormItemContext({
|
||||||
|
id: fieldId,
|
||||||
|
onFieldBlur,
|
||||||
|
onFieldChange,
|
||||||
|
clearValidate,
|
||||||
|
});
|
||||||
let registered = false;
|
let registered = false;
|
||||||
watch(
|
watch(
|
||||||
fieldName,
|
fieldName,
|
||||||
|
@ -299,12 +306,6 @@ export default defineComponent({
|
||||||
onBeforeUnmount(() => {
|
onBeforeUnmount(() => {
|
||||||
formContext.removeField(eventKey);
|
formContext.removeField(eventKey);
|
||||||
});
|
});
|
||||||
// const onHelpAnimEnd = (_key: string, helpShow: boolean) => {
|
|
||||||
// this.helpShow = helpShow;
|
|
||||||
// if (!helpShow) {
|
|
||||||
// this.$forceUpdate();
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
const itemClassName = computed(() => ({
|
const itemClassName = computed(() => ({
|
||||||
[`${prefixCls.value}-item`]: true,
|
[`${prefixCls.value}-item`]: true,
|
||||||
|
|
||||||
|
@ -318,36 +319,6 @@ export default defineComponent({
|
||||||
}));
|
}));
|
||||||
return () => {
|
return () => {
|
||||||
const help = props.help ?? (slots.help ? filterEmpty(slots.help()) : null);
|
const help = props.help ?? (slots.help ? filterEmpty(slots.help()) : null);
|
||||||
const children = flattenChildren(slots.default?.());
|
|
||||||
let firstChildren = children[0];
|
|
||||||
if (fieldName.value && props.autoLink && isValidElement(firstChildren)) {
|
|
||||||
const originalEvents = firstChildren.props || {};
|
|
||||||
const originalBlur = originalEvents.onBlur;
|
|
||||||
const originalChange = originalEvents.onChange;
|
|
||||||
firstChildren = cloneElement(firstChildren, {
|
|
||||||
...(fieldId.value ? { id: fieldId.value } : undefined),
|
|
||||||
onBlur: (...args: any[]) => {
|
|
||||||
if (Array.isArray(originalChange)) {
|
|
||||||
for (let i = 0, l = originalChange.length; i < l; i++) {
|
|
||||||
originalBlur[i](...args);
|
|
||||||
}
|
|
||||||
} else if (originalBlur) {
|
|
||||||
originalBlur(...args);
|
|
||||||
}
|
|
||||||
onFieldBlur();
|
|
||||||
},
|
|
||||||
onChange: (...args: any[]) => {
|
|
||||||
if (Array.isArray(originalChange)) {
|
|
||||||
for (let i = 0, l = originalChange.length; i < l; i++) {
|
|
||||||
originalChange[i](...args);
|
|
||||||
}
|
|
||||||
} else if (originalChange) {
|
|
||||||
originalChange(...args);
|
|
||||||
}
|
|
||||||
onFieldChange();
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return (
|
return (
|
||||||
<Row
|
<Row
|
||||||
{...attrs}
|
{...attrs}
|
||||||
|
@ -357,32 +328,37 @@ export default defineComponent({
|
||||||
attrs.class,
|
attrs.class,
|
||||||
]}
|
]}
|
||||||
key="row"
|
key="row"
|
||||||
>
|
v-slots={{
|
||||||
{/* Label */}
|
default: () => (
|
||||||
<FormItemLabel
|
<>
|
||||||
{...props}
|
{/* Label */}
|
||||||
htmlFor={fieldId.value}
|
<FormItemLabel
|
||||||
required={isRequired.value}
|
{...props}
|
||||||
requiredMark={formContext.requiredMark.value}
|
htmlFor={fieldId.value}
|
||||||
prefixCls={prefixCls.value}
|
required={isRequired.value}
|
||||||
onClick={onLabelClick}
|
requiredMark={formContext.requiredMark.value}
|
||||||
label={props.label ?? slots.label?.()}
|
prefixCls={prefixCls.value}
|
||||||
/>
|
onClick={onLabelClick}
|
||||||
{/* Input Group */}
|
label={props.label ?? slots.label?.()}
|
||||||
<FormItemInput
|
/>
|
||||||
{...props}
|
{/* Input Group */}
|
||||||
errors={help !== undefined && help !== null ? toArray(help) : errors.value}
|
<FormItemInput
|
||||||
prefixCls={prefixCls.value}
|
{...props}
|
||||||
status={validateState.value}
|
errors={help !== undefined && help !== null ? toArray(help) : errors.value}
|
||||||
onDomErrorVisibleChange={(v: boolean) => (domErrorVisible.value = v)}
|
prefixCls={prefixCls.value}
|
||||||
validateStatus={validateState.value}
|
status={validateState.value}
|
||||||
ref={inputRef}
|
onDomErrorVisibleChange={(v: boolean) => (domErrorVisible.value = v)}
|
||||||
help={help}
|
validateStatus={validateState.value}
|
||||||
extra={props.extra ?? slots.extra?.()}
|
ref={inputRef}
|
||||||
>
|
help={help}
|
||||||
{[firstChildren, children.slice(1)]}
|
extra={props.extra ?? slots.extra?.()}
|
||||||
</FormItemInput>
|
v-slots={{ default: slots.default }}
|
||||||
</Row>
|
// v-slots={{ default: () => [firstChildren, children.slice(1)] }}
|
||||||
|
></FormItemInput>
|
||||||
|
</>
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
></Row>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
import type { ComputedRef, InjectionKey } from 'vue';
|
||||||
|
import { computed, inject, provide } from 'vue';
|
||||||
|
|
||||||
|
export type FormItemContext = {
|
||||||
|
id: ComputedRef<string>;
|
||||||
|
onFieldBlur: () => void;
|
||||||
|
onFieldChange: () => void;
|
||||||
|
clearValidate: () => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
type ContextProps = FormItemContext;
|
||||||
|
|
||||||
|
const ContextKey: InjectionKey<ContextProps> = Symbol('ContextProps');
|
||||||
|
|
||||||
|
export const useProvideFormItemContext = (props: ContextProps) => {
|
||||||
|
provide(ContextKey, props);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const useInjectFormItemContext = () => {
|
||||||
|
const defaultContext: ContextProps = {
|
||||||
|
id: computed(() => undefined),
|
||||||
|
onFieldBlur: () => {},
|
||||||
|
onFieldChange: () => {},
|
||||||
|
clearValidate: () => {},
|
||||||
|
};
|
||||||
|
|
||||||
|
// We should prevent the passing of context for children
|
||||||
|
|
||||||
|
provide(ContextKey, defaultContext);
|
||||||
|
return inject(ContextKey, defaultContext);
|
||||||
|
};
|
|
@ -86,33 +86,32 @@ const FormItemInput = defineComponent({
|
||||||
|
|
||||||
// Should provides additional icon if `hasFeedback`
|
// Should provides additional icon if `hasFeedback`
|
||||||
const IconNode = validateStatus && iconMap[validateStatus];
|
const IconNode = validateStatus && iconMap[validateStatus];
|
||||||
const icon =
|
|
||||||
hasFeedback && IconNode ? (
|
|
||||||
<span class={`${baseClassName}-children-icon`}>
|
|
||||||
<IconNode />
|
|
||||||
</span>
|
|
||||||
) : null;
|
|
||||||
|
|
||||||
const inputDom = (
|
|
||||||
<div class={`${baseClassName}-control-input`}>
|
|
||||||
<div class={`${baseClassName}-control-input-content`}>{slots.default?.()}</div>
|
|
||||||
{icon}
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
const errorListDom = (
|
|
||||||
<ErrorList errors={errors} help={help} onDomErrorVisibleChange={onDomErrorVisibleChange} />
|
|
||||||
);
|
|
||||||
|
|
||||||
// If extra = 0, && will goes wrong
|
|
||||||
// 0&&error -> 0
|
|
||||||
const extraDom = extra ? <div class={`${baseClassName}-extra`}>{extra}</div> : null;
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Col {...mergedWrapperCol} class={className}>
|
<Col
|
||||||
{inputDom}
|
{...mergedWrapperCol}
|
||||||
{errorListDom}
|
class={className}
|
||||||
{extraDom}
|
v-slots={{
|
||||||
</Col>
|
default: () => (
|
||||||
|
<>
|
||||||
|
<div class={`${baseClassName}-control-input`}>
|
||||||
|
<div class={`${baseClassName}-control-input-content`}>{slots.default?.()}</div>
|
||||||
|
{hasFeedback && IconNode ? (
|
||||||
|
<span class={`${baseClassName}-children-icon`}>
|
||||||
|
<IconNode />
|
||||||
|
</span>
|
||||||
|
) : null}
|
||||||
|
</div>
|
||||||
|
<ErrorList
|
||||||
|
errors={errors}
|
||||||
|
help={help}
|
||||||
|
onDomErrorVisibleChange={onDomErrorVisibleChange}
|
||||||
|
/>
|
||||||
|
{extra ? <div class={`${baseClassName}-extra`}>{extra}</div> : null}
|
||||||
|
</>
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
></Col>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
|
@ -141,7 +141,7 @@ exports[`renders ./components/form/demo/custom-validation.vue correctly 1`] = `
|
||||||
</label></div>
|
</label></div>
|
||||||
<div class="ant-col ant-col-14 ant-form-item-control">
|
<div class="ant-col ant-col-14 ant-form-item-control">
|
||||||
<div class="ant-form-item-control-input">
|
<div class="ant-form-item-control-input">
|
||||||
<div class="ant-form-item-control-input-content"><input type="password" autocomplete="off" id="custom-validation_pass" class="ant-input"></div>
|
<div class="ant-form-item-control-input-content"><input type="password" id="custom-validation_pass" autocomplete="off" class="ant-input"></div>
|
||||||
<!---->
|
<!---->
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
@ -154,7 +154,7 @@ exports[`renders ./components/form/demo/custom-validation.vue correctly 1`] = `
|
||||||
</label></div>
|
</label></div>
|
||||||
<div class="ant-col ant-col-14 ant-form-item-control">
|
<div class="ant-col ant-col-14 ant-form-item-control">
|
||||||
<div class="ant-form-item-control-input">
|
<div class="ant-form-item-control-input">
|
||||||
<div class="ant-form-item-control-input-content"><input type="password" autocomplete="off" id="custom-validation_checkPass" class="ant-input"></div>
|
<div class="ant-form-item-control-input-content"><input type="password" id="custom-validation_checkPass" autocomplete="off" class="ant-input"></div>
|
||||||
<!---->
|
<!---->
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
</demo-sort>
|
</demo-sort>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
|
import { defineComponent } from 'vue';
|
||||||
import Basic from './basic.vue';
|
import Basic from './basic.vue';
|
||||||
import CustomValidation from './custom-validation.vue';
|
import CustomValidation from './custom-validation.vue';
|
||||||
import DynamicFormItem from './dynamic-form-item.vue';
|
import DynamicFormItem from './dynamic-form-item.vue';
|
||||||
|
@ -27,11 +28,10 @@ import UseFormNested from './useForm-nested.vue';
|
||||||
import UseFormTrigger from './useForm-trigger.vue';
|
import UseFormTrigger from './useForm-trigger.vue';
|
||||||
import UseFormMerge from './useForm-merge.vue';
|
import UseFormMerge from './useForm-merge.vue';
|
||||||
import LableWidth from './lable-width.vue';
|
import LableWidth from './lable-width.vue';
|
||||||
|
|
||||||
import CN from '../index.zh-CN.md';
|
import CN from '../index.zh-CN.md';
|
||||||
import US from '../index.en-US.md';
|
import US from '../index.en-US.md';
|
||||||
|
|
||||||
export default {
|
export default defineComponent({
|
||||||
US,
|
US,
|
||||||
CN,
|
CN,
|
||||||
components: {
|
components: {
|
||||||
|
@ -48,7 +48,7 @@ export default {
|
||||||
UseFormMerge,
|
UseFormMerge,
|
||||||
LableWidth,
|
LableWidth,
|
||||||
},
|
},
|
||||||
};
|
});
|
||||||
</script>
|
</script>
|
||||||
<style>
|
<style>
|
||||||
.code-box-demo .ant-form:not(.ant-form-inline):not(.ant-form-vertical) {
|
.code-box-demo .ant-form:not(.ant-form-inline):not(.ant-form-vertical) {
|
||||||
|
|
|
@ -2,6 +2,7 @@ import type { App, Plugin } from 'vue';
|
||||||
import Form, { formProps } from './Form';
|
import Form, { formProps } from './Form';
|
||||||
import FormItem, { formItemProps } from './FormItem';
|
import FormItem, { formItemProps } from './FormItem';
|
||||||
import useForm from './useForm';
|
import useForm from './useForm';
|
||||||
|
import { useInjectFormItemContext } from './FormItemContext';
|
||||||
|
|
||||||
export type { FormProps } from './Form';
|
export type { FormProps } from './Form';
|
||||||
export type { FormItemProps } from './FormItem';
|
export type { FormItemProps } from './FormItem';
|
||||||
|
@ -13,10 +14,11 @@ Form.install = function (app: App) {
|
||||||
return app;
|
return app;
|
||||||
};
|
};
|
||||||
|
|
||||||
export { FormItem, formItemProps, formProps, useForm };
|
export { FormItem, formItemProps, formProps, useForm, useInjectFormItemContext };
|
||||||
|
|
||||||
export default Form as typeof Form &
|
export default Form as typeof Form &
|
||||||
Plugin & {
|
Plugin & {
|
||||||
readonly Item: typeof Form.Item;
|
readonly Item: typeof Form.Item;
|
||||||
readonly useForm: typeof useForm;
|
readonly useForm: typeof useForm;
|
||||||
|
readonly useInjectFormItemContext: typeof useInjectFormItemContext;
|
||||||
};
|
};
|
||||||
|
|
|
@ -9,6 +9,7 @@ import VcInputNumber from '../vc-input-number/src';
|
||||||
import { defaultConfigProvider } from '../config-provider';
|
import { defaultConfigProvider } from '../config-provider';
|
||||||
import { tuple, withInstall } from '../_util/type';
|
import { tuple, withInstall } from '../_util/type';
|
||||||
import type { EventHandler } from '../_util/EventInterface';
|
import type { EventHandler } from '../_util/EventInterface';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
const inputNumberProps = {
|
const inputNumberProps = {
|
||||||
prefixCls: PropTypes.string,
|
prefixCls: PropTypes.string,
|
||||||
|
@ -40,7 +41,9 @@ const InputNumber = defineComponent({
|
||||||
name: 'AInputNumber',
|
name: 'AInputNumber',
|
||||||
inheritAttrs: false,
|
inheritAttrs: false,
|
||||||
props: inputNumberProps,
|
props: inputNumberProps,
|
||||||
setup(props) {
|
emits: ['input', 'change', 'blur', 'update:value'],
|
||||||
|
setup(props, { emit }) {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
const inputNumberRef = ref(null);
|
const inputNumberRef = ref(null);
|
||||||
const focus = () => {
|
const focus = () => {
|
||||||
inputNumberRef.value.focus();
|
inputNumberRef.value.focus();
|
||||||
|
@ -48,6 +51,13 @@ const InputNumber = defineComponent({
|
||||||
const blur = () => {
|
const blur = () => {
|
||||||
inputNumberRef.value.blur();
|
inputNumberRef.value.blur();
|
||||||
};
|
};
|
||||||
|
const handleChange = (val: number) => {
|
||||||
|
emit('update:value', val);
|
||||||
|
emit('change', val);
|
||||||
|
};
|
||||||
|
const handleBlur = () => {
|
||||||
|
emit('blur');
|
||||||
|
};
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
if (process.env.NODE_ENV === 'test') {
|
if (process.env.NODE_ENV === 'test') {
|
||||||
|
@ -62,6 +72,9 @@ const InputNumber = defineComponent({
|
||||||
inputNumberRef,
|
inputNumberRef,
|
||||||
focus,
|
focus,
|
||||||
blur,
|
blur,
|
||||||
|
formItemContext,
|
||||||
|
handleBlur,
|
||||||
|
handleChange,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -70,6 +83,7 @@ const InputNumber = defineComponent({
|
||||||
prefixCls: customizePrefixCls,
|
prefixCls: customizePrefixCls,
|
||||||
size,
|
size,
|
||||||
class: className,
|
class: className,
|
||||||
|
id = this.formItemContext.id.value,
|
||||||
...others
|
...others
|
||||||
} = {
|
} = {
|
||||||
...getOptionProps(this),
|
...getOptionProps(this),
|
||||||
|
@ -94,6 +108,9 @@ const InputNumber = defineComponent({
|
||||||
downHandler: downIcon,
|
downHandler: downIcon,
|
||||||
...others,
|
...others,
|
||||||
class: inputNumberClass,
|
class: inputNumberClass,
|
||||||
|
onChange: this.handleChange,
|
||||||
|
onBlur: this.handleBlur,
|
||||||
|
id,
|
||||||
};
|
};
|
||||||
return <VcInputNumber {...vcInputNumberProps} ref="inputNumberRef" />;
|
return <VcInputNumber {...vcInputNumberProps} ref="inputNumberRef" />;
|
||||||
},
|
},
|
||||||
|
|
|
@ -7,6 +7,7 @@ import inputProps from './inputProps';
|
||||||
import { hasProp, getComponent, getOptionProps } from '../_util/props-util';
|
import { hasProp, getComponent, getOptionProps } from '../_util/props-util';
|
||||||
import { defaultConfigProvider } from '../config-provider';
|
import { defaultConfigProvider } from '../config-provider';
|
||||||
import ClearableLabeledInput from './ClearableLabeledInput';
|
import ClearableLabeledInput from './ClearableLabeledInput';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export function fixControlledValue(value: string | number) {
|
export function fixControlledValue(value: string | number) {
|
||||||
if (typeof value === 'undefined' || value === null) {
|
if (typeof value === 'undefined' || value === null) {
|
||||||
|
@ -56,11 +57,13 @@ export default defineComponent({
|
||||||
...inputProps,
|
...inputProps,
|
||||||
},
|
},
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
removePasswordTimeout: undefined,
|
removePasswordTimeout: undefined,
|
||||||
input: null,
|
input: null,
|
||||||
clearableInput: null,
|
clearableInput: null,
|
||||||
|
formItemContext,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
@ -100,6 +103,7 @@ export default defineComponent({
|
||||||
handleInputBlur(e: Event) {
|
handleInputBlur(e: Event) {
|
||||||
this.isFocused = false;
|
this.isFocused = false;
|
||||||
this.onBlur && this.onBlur(e);
|
this.onBlur && this.onBlur(e);
|
||||||
|
this.formItemContext.onFieldBlur();
|
||||||
},
|
},
|
||||||
|
|
||||||
focus() {
|
focus() {
|
||||||
|
@ -138,6 +142,7 @@ export default defineComponent({
|
||||||
this.$emit('update:value', (e.target as HTMLInputElement).value);
|
this.$emit('update:value', (e.target as HTMLInputElement).value);
|
||||||
this.$emit('change', e);
|
this.$emit('change', e);
|
||||||
this.$emit('input', e);
|
this.$emit('input', e);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
handleReset(e: Event) {
|
handleReset(e: Event) {
|
||||||
this.setValue('', () => {
|
this.setValue('', () => {
|
||||||
|
@ -173,6 +178,7 @@ export default defineComponent({
|
||||||
const inputProps: any = {
|
const inputProps: any = {
|
||||||
...otherProps,
|
...otherProps,
|
||||||
...$attrs,
|
...$attrs,
|
||||||
|
id: otherProps.id ?? this.formItemContext.id.value,
|
||||||
onKeydown: handleKeyDown,
|
onKeydown: handleKeyDown,
|
||||||
class: classNames(getInputClassName(prefixCls, size, disabled), {
|
class: classNames(getInputClassName(prefixCls, size, disabled), {
|
||||||
[$attrs.class as string]: $attrs.class && !addonBefore && !addonAfter,
|
[$attrs.class as string]: $attrs.class && !addonBefore && !addonAfter,
|
||||||
|
@ -240,6 +246,7 @@ export default defineComponent({
|
||||||
prefix,
|
prefix,
|
||||||
isFocused,
|
isFocused,
|
||||||
};
|
};
|
||||||
|
|
||||||
return <ClearableLabeledInput {...props} ref={this.saveClearableInput} />;
|
return <ClearableLabeledInput {...props} ref={this.saveClearableInput} />;
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -7,6 +7,7 @@ import { defaultConfigProvider } from '../config-provider';
|
||||||
import { fixControlledValue, resolveOnChange } from './Input';
|
import { fixControlledValue, resolveOnChange } from './Input';
|
||||||
import classNames from '../_util/classNames';
|
import classNames from '../_util/classNames';
|
||||||
import PropTypes, { withUndefined } from '../_util/vue-types';
|
import PropTypes, { withUndefined } from '../_util/vue-types';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
const TextAreaProps = {
|
const TextAreaProps = {
|
||||||
...inputProps,
|
...inputProps,
|
||||||
|
@ -24,10 +25,12 @@ export default defineComponent({
|
||||||
...TextAreaProps,
|
...TextAreaProps,
|
||||||
},
|
},
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
resizableTextArea: null,
|
resizableTextArea: null,
|
||||||
clearableInput: null,
|
clearableInput: null,
|
||||||
|
formItemContext,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
|
@ -71,6 +74,7 @@ export default defineComponent({
|
||||||
this.$emit('update:value', (e.target as any).value);
|
this.$emit('update:value', (e.target as any).value);
|
||||||
this.$emit('change', e);
|
this.$emit('change', e);
|
||||||
this.$emit('input', e);
|
this.$emit('input', e);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
handleChange(e: Event) {
|
handleChange(e: Event) {
|
||||||
const { value, composing, isComposing } = e.target as any;
|
const { value, composing, isComposing } = e.target as any;
|
||||||
|
@ -103,6 +107,10 @@ export default defineComponent({
|
||||||
});
|
});
|
||||||
resolveOnChange(this.resizableTextArea.textArea, e, this.triggerChange);
|
resolveOnChange(this.resizableTextArea.textArea, e, this.triggerChange);
|
||||||
},
|
},
|
||||||
|
handleBlur(e: Event) {
|
||||||
|
this.$emit('blur', e);
|
||||||
|
this.formItemContext.onFieldBlur();
|
||||||
|
},
|
||||||
|
|
||||||
renderTextArea(prefixCls: string) {
|
renderTextArea(prefixCls: string) {
|
||||||
const props = getOptionProps(this);
|
const props = getOptionProps(this);
|
||||||
|
@ -118,7 +126,13 @@ export default defineComponent({
|
||||||
onChange: this.handleChange,
|
onChange: this.handleChange,
|
||||||
onKeydown: this.handleKeyDown,
|
onKeydown: this.handleKeyDown,
|
||||||
};
|
};
|
||||||
return <ResizableTextArea {...resizeProps} ref={this.saveTextArea} />;
|
return (
|
||||||
|
<ResizableTextArea
|
||||||
|
{...resizeProps}
|
||||||
|
id={resizeProps.id ?? this.formItemContext.id.value}
|
||||||
|
ref={this.saveTextArea}
|
||||||
|
/>
|
||||||
|
);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
|
|
|
@ -66,7 +66,7 @@ exports[`renders ./components/input/demo/group.vue correctly 1`] = `
|
||||||
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
<div style="width: 200px;" class="ant-select ant-select-show-search ant-select-auto-complete ant-select-single ant-select-customize-input ant-select-show-search">
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
<div class="ant-select-selector"><span class="ant-select-selection-search"><input type="search" id="rc_select_TEST_OR_SSR" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
<div class="ant-select-selector"><span class="ant-select-selection-search"><input id="rc_select_TEST_OR_SSR" type="search" autocomplete="off" class="ant-input ant-select-selection-search-input" role="combobox" aria-haspopup="listbox" aria-owns="rc_select_TEST_OR_SSR_list" aria-autocomplete="list" aria-controls="rc_select_TEST_OR_SSR_list" aria-activedescendant="rc_select_TEST_OR_SSR_list_0"></span>
|
||||||
<!----><span class="ant-select-selection-placeholder">Email</span>
|
<!----><span class="ant-select-selection-placeholder">Email</span>
|
||||||
</div>
|
</div>
|
||||||
<!---->
|
<!---->
|
||||||
|
|
|
@ -2,6 +2,7 @@ import type { PropType } from 'vue';
|
||||||
import PropTypes from '../_util/vue-types';
|
import PropTypes from '../_util/vue-types';
|
||||||
import type { SizeType } from '../config-provider';
|
import type { SizeType } from '../config-provider';
|
||||||
export default {
|
export default {
|
||||||
|
id: PropTypes.string,
|
||||||
prefixCls: PropTypes.string,
|
prefixCls: PropTypes.string,
|
||||||
inputPrefixCls: PropTypes.string,
|
inputPrefixCls: PropTypes.string,
|
||||||
defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
||||||
|
|
|
@ -21,7 +21,7 @@ exports[`renders ./components/mentions/demo/form.vue correctly 1`] = `
|
||||||
<div class="ant-col ant-col-18 ant-form-item-control">
|
<div class="ant-col ant-col-18 ant-form-item-control">
|
||||||
<div class="ant-form-item-control-input">
|
<div class="ant-form-item-control-input">
|
||||||
<div class="ant-form-item-control-input-content">
|
<div class="ant-form-item-control-input-content">
|
||||||
<div class="ant-mentions"><textarea rows="1"></textarea>
|
<div class="ant-mentions"><textarea rows="1" id="coders"></textarea>
|
||||||
<!---->
|
<!---->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -38,7 +38,7 @@ exports[`renders ./components/mentions/demo/form.vue correctly 1`] = `
|
||||||
<div class="ant-col ant-col-18 ant-form-item-control">
|
<div class="ant-col ant-col-18 ant-form-item-control">
|
||||||
<div class="ant-form-item-control-input">
|
<div class="ant-form-item-control-input">
|
||||||
<div class="ant-form-item-control-input-content">
|
<div class="ant-form-item-control-input-content">
|
||||||
<div class="ant-mentions"><textarea rows="3" placeholder="You can use @ to ref user here"></textarea>
|
<div class="ant-mentions"><textarea rows="3" placeholder="You can use @ to ref user here" id="bio"></textarea>
|
||||||
<!---->
|
<!---->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -7,6 +7,7 @@ import VcMentions from '../vc-mentions';
|
||||||
import { mentionsProps as baseMentionsProps } from '../vc-mentions/src/mentionsProps';
|
import { mentionsProps as baseMentionsProps } from '../vc-mentions/src/mentionsProps';
|
||||||
import useConfigInject from '../_util/hooks/useConfigInject';
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
import { flattenChildren, getOptionProps } from '../_util/props-util';
|
import { flattenChildren, getOptionProps } from '../_util/props-util';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
const { Option } = VcMentions;
|
const { Option } = VcMentions;
|
||||||
|
|
||||||
|
@ -75,6 +76,7 @@ const mentionsProps = {
|
||||||
},
|
},
|
||||||
notFoundContent: PropTypes.any,
|
notFoundContent: PropTypes.any,
|
||||||
defaultValue: String,
|
defaultValue: String,
|
||||||
|
id: String,
|
||||||
};
|
};
|
||||||
|
|
||||||
export type MentionsProps = Partial<ExtractPropTypes<typeof mentionsProps>>;
|
export type MentionsProps = Partial<ExtractPropTypes<typeof mentionsProps>>;
|
||||||
|
@ -92,6 +94,7 @@ const Mentions = defineComponent({
|
||||||
const focused = ref(false);
|
const focused = ref(false);
|
||||||
const vcMentions = ref(null);
|
const vcMentions = ref(null);
|
||||||
const value = ref(props.value ?? props.defaultValue ?? '');
|
const value = ref(props.value ?? props.defaultValue ?? '');
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
watch(
|
watch(
|
||||||
() => props.value,
|
() => props.value,
|
||||||
val => {
|
val => {
|
||||||
|
@ -106,6 +109,7 @@ const Mentions = defineComponent({
|
||||||
const handleBlur = (e: FocusEvent) => {
|
const handleBlur = (e: FocusEvent) => {
|
||||||
focused.value = false;
|
focused.value = false;
|
||||||
emit('blur', e);
|
emit('blur', e);
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleSelect = (...args: [MentionsOptionProps, string]) => {
|
const handleSelect = (...args: [MentionsOptionProps, string]) => {
|
||||||
|
@ -119,6 +123,7 @@ const Mentions = defineComponent({
|
||||||
}
|
}
|
||||||
emit('update:value', val);
|
emit('update:value', val);
|
||||||
emit('change', val);
|
emit('change', val);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
|
|
||||||
const getNotFoundContent = () => {
|
const getNotFoundContent = () => {
|
||||||
|
@ -159,7 +164,13 @@ const Mentions = defineComponent({
|
||||||
});
|
});
|
||||||
|
|
||||||
return () => {
|
return () => {
|
||||||
const { disabled, getPopupContainer, rows = 1, ...restProps } = props;
|
const {
|
||||||
|
disabled,
|
||||||
|
getPopupContainer,
|
||||||
|
rows = 1,
|
||||||
|
id = formItemContext.id.value,
|
||||||
|
...restProps
|
||||||
|
} = props;
|
||||||
const { class: className, ...otherAttrs } = attrs;
|
const { class: className, ...otherAttrs } = attrs;
|
||||||
const otherProps = omit(restProps, ['defaultValue', 'onUpdate:value', 'prefixCls']);
|
const otherProps = omit(restProps, ['defaultValue', 'onUpdate:value', 'prefixCls']);
|
||||||
|
|
||||||
|
@ -186,6 +197,7 @@ const Mentions = defineComponent({
|
||||||
onBlur: handleBlur,
|
onBlur: handleBlur,
|
||||||
ref: vcMentions,
|
ref: vcMentions,
|
||||||
value: value.value,
|
value: value.value,
|
||||||
|
id,
|
||||||
};
|
};
|
||||||
return (
|
return (
|
||||||
<VcMentions
|
<VcMentions
|
||||||
|
|
|
@ -6,6 +6,7 @@ import { getOptionProps, filterEmpty, hasProp, getSlot } from '../_util/props-ut
|
||||||
import { defaultConfigProvider } from '../config-provider';
|
import { defaultConfigProvider } from '../config-provider';
|
||||||
import { tuple } from '../_util/type';
|
import { tuple } from '../_util/type';
|
||||||
import type { RadioChangeEvent } from './interface';
|
import type { RadioChangeEvent } from './interface';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'ARadioGroup',
|
name: 'ARadioGroup',
|
||||||
|
@ -19,10 +20,13 @@ export default defineComponent({
|
||||||
name: PropTypes.string,
|
name: PropTypes.string,
|
||||||
buttonStyle: PropTypes.string.def('outline'),
|
buttonStyle: PropTypes.string.def('outline'),
|
||||||
onChange: PropTypes.func,
|
onChange: PropTypes.func,
|
||||||
|
id: PropTypes.string,
|
||||||
},
|
},
|
||||||
emits: ['update:value', 'change'],
|
emits: ['update:value', 'change'],
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
|
formItemContext,
|
||||||
updatingValue: false,
|
updatingValue: false,
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
radioGroupContext: null,
|
radioGroupContext: null,
|
||||||
|
@ -65,6 +69,7 @@ export default defineComponent({
|
||||||
this.updatingValue = true;
|
this.updatingValue = true;
|
||||||
this.$emit('update:value', value);
|
this.$emit('update:value', value);
|
||||||
this.$emit('change', ev);
|
this.$emit('change', ev);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
}
|
}
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
this.updatingValue = false;
|
this.updatingValue = false;
|
||||||
|
@ -73,7 +78,12 @@ export default defineComponent({
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
const props = getOptionProps(this);
|
const props = getOptionProps(this);
|
||||||
const { prefixCls: customizePrefixCls, options, buttonStyle } = props;
|
const {
|
||||||
|
prefixCls: customizePrefixCls,
|
||||||
|
options,
|
||||||
|
buttonStyle,
|
||||||
|
id = this.formItemContext.id.value,
|
||||||
|
} = props;
|
||||||
const { getPrefixCls } = this.configProvider;
|
const { getPrefixCls } = this.configProvider;
|
||||||
const prefixCls = getPrefixCls('radio', customizePrefixCls);
|
const prefixCls = getPrefixCls('radio', customizePrefixCls);
|
||||||
|
|
||||||
|
@ -114,6 +124,10 @@ export default defineComponent({
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return <div class={classString}>{children}</div>;
|
return (
|
||||||
|
<div class={classString} id={id}>
|
||||||
|
{children}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -6,6 +6,7 @@ import classNames from '../_util/classNames';
|
||||||
import { getOptionProps } from '../_util/props-util';
|
import { getOptionProps } from '../_util/props-util';
|
||||||
import { defaultConfigProvider } from '../config-provider';
|
import { defaultConfigProvider } from '../config-provider';
|
||||||
import type { RadioChangeEvent } from './interface';
|
import type { RadioChangeEvent } from './interface';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export const radioProps = {
|
export const radioProps = {
|
||||||
prefixCls: PropTypes.string,
|
prefixCls: PropTypes.string,
|
||||||
|
@ -30,9 +31,11 @@ export default defineComponent({
|
||||||
props: radioProps,
|
props: radioProps,
|
||||||
emits: ['update:checked', 'update:value', 'change', 'blur', 'focus'],
|
emits: ['update:checked', 'update:value', 'change', 'blur', 'focus'],
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
radioGroupContext: inject('radioGroupContext', null),
|
radioGroupContext: inject('radioGroupContext', null),
|
||||||
|
formItemContext,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
@ -47,6 +50,7 @@ export default defineComponent({
|
||||||
this.$emit('update:checked', targetChecked);
|
this.$emit('update:checked', targetChecked);
|
||||||
this.$emit('update:value', targetChecked);
|
this.$emit('update:value', targetChecked);
|
||||||
this.$emit('change', event);
|
this.$emit('change', event);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
onChange2(e: RadioChangeEvent) {
|
onChange2(e: RadioChangeEvent) {
|
||||||
this.$emit('change', e);
|
this.$emit('change', e);
|
||||||
|
@ -59,12 +63,17 @@ export default defineComponent({
|
||||||
render() {
|
render() {
|
||||||
const { $slots, radioGroupContext: radioGroup } = this;
|
const { $slots, radioGroupContext: radioGroup } = this;
|
||||||
const props = getOptionProps(this);
|
const props = getOptionProps(this);
|
||||||
const { prefixCls: customizePrefixCls, ...restProps } = props;
|
const {
|
||||||
|
prefixCls: customizePrefixCls,
|
||||||
|
id = this.formItemContext.id.value,
|
||||||
|
...restProps
|
||||||
|
} = props;
|
||||||
const { getPrefixCls } = this.configProvider;
|
const { getPrefixCls } = this.configProvider;
|
||||||
const prefixCls = getPrefixCls('radio', customizePrefixCls);
|
const prefixCls = getPrefixCls('radio', customizePrefixCls);
|
||||||
|
|
||||||
const rProps: RadioProps = {
|
const rProps: RadioProps = {
|
||||||
prefixCls,
|
prefixCls,
|
||||||
|
id,
|
||||||
...restProps,
|
...restProps,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@ import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
|
|
||||||
import Star from './Star';
|
import Star from './Star';
|
||||||
import { useRef } from '../_util/hooks/useRef';
|
import { useRef } from '../_util/hooks/useRef';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export const rateProps = {
|
export const rateProps = {
|
||||||
prefixCls: PropTypes.string,
|
prefixCls: PropTypes.string,
|
||||||
|
@ -25,6 +26,7 @@ export const rateProps = {
|
||||||
autofocus: PropTypes.looseBool,
|
autofocus: PropTypes.looseBool,
|
||||||
tabindex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
tabindex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
||||||
direction: PropTypes.string,
|
direction: PropTypes.string,
|
||||||
|
id: PropTypes.string,
|
||||||
};
|
};
|
||||||
|
|
||||||
export type RateProps = Partial<ExtractPropTypes<typeof rateProps>>;
|
export type RateProps = Partial<ExtractPropTypes<typeof rateProps>>;
|
||||||
|
@ -44,6 +46,7 @@ const Rate = defineComponent({
|
||||||
emits: ['hoverChange', 'update:value', 'change', 'focus', 'blur', 'keydown'],
|
emits: ['hoverChange', 'update:value', 'change', 'focus', 'blur', 'keydown'],
|
||||||
setup(props, { slots, attrs, emit, expose }) {
|
setup(props, { slots, attrs, emit, expose }) {
|
||||||
const { prefixCls, direction } = useConfigInject('rate', props);
|
const { prefixCls, direction } = useConfigInject('rate', props);
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
const rateRef = ref();
|
const rateRef = ref();
|
||||||
const [setRef, starRefs] = useRef();
|
const [setRef, starRefs] = useRef();
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
|
@ -82,6 +85,7 @@ const Rate = defineComponent({
|
||||||
}
|
}
|
||||||
emit('update:value', value);
|
emit('update:value', value);
|
||||||
emit('change', value);
|
emit('change', value);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
|
|
||||||
const onHover = (e: MouseEvent, index: number) => {
|
const onHover = (e: MouseEvent, index: number) => {
|
||||||
|
@ -115,6 +119,7 @@ const Rate = defineComponent({
|
||||||
const onBlur = () => {
|
const onBlur = () => {
|
||||||
state.focused = false;
|
state.focused = false;
|
||||||
emit('blur');
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
const onKeyDown = (event: KeyboardEvent) => {
|
const onKeyDown = (event: KeyboardEvent) => {
|
||||||
const { keyCode } = event;
|
const { keyCode } = event;
|
||||||
|
@ -187,7 +192,7 @@ const Rate = defineComponent({
|
||||||
const character = getPropsSlot(slots, props, 'character') || <StarFilled />;
|
const character = getPropsSlot(slots, props, 'character') || <StarFilled />;
|
||||||
|
|
||||||
return () => {
|
return () => {
|
||||||
const { count, allowHalf, disabled, tabindex } = props;
|
const { count, allowHalf, disabled, tabindex, id = formItemContext.id.value } = props;
|
||||||
const { class: className, style } = attrs;
|
const { class: className, style } = attrs;
|
||||||
const stars = [];
|
const stars = [];
|
||||||
const disabledClass = disabled ? `${prefixCls.value}-disabled` : '';
|
const disabledClass = disabled ? `${prefixCls.value}-disabled` : '';
|
||||||
|
@ -216,6 +221,7 @@ const Rate = defineComponent({
|
||||||
return (
|
return (
|
||||||
<ul
|
<ul
|
||||||
{...attrs}
|
{...attrs}
|
||||||
|
id={id}
|
||||||
class={rateClassName}
|
class={rateClassName}
|
||||||
style={style}
|
style={style}
|
||||||
onMouseleave={disabled ? null : onMouseLeave}
|
onMouseleave={disabled ? null : onMouseLeave}
|
||||||
|
|
|
@ -8,6 +8,7 @@ import PropTypes from '../_util/vue-types';
|
||||||
import { tuple } from '../_util/type';
|
import { tuple } from '../_util/type';
|
||||||
import useConfigInject from '../_util/hooks/useConfigInject';
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
import omit from '../_util/omit';
|
import omit from '../_util/omit';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
type RawValue = string | number;
|
type RawValue = string | number;
|
||||||
|
|
||||||
|
@ -49,7 +50,7 @@ const Select = defineComponent({
|
||||||
inheritAttrs: false,
|
inheritAttrs: false,
|
||||||
props: selectProps(),
|
props: selectProps(),
|
||||||
SECRET_COMBOBOX_MODE_DO_NOT_USE: 'SECRET_COMBOBOX_MODE_DO_NOT_USE',
|
SECRET_COMBOBOX_MODE_DO_NOT_USE: 'SECRET_COMBOBOX_MODE_DO_NOT_USE',
|
||||||
emits: ['change', 'update:value'],
|
emits: ['change', 'update:value', 'blur'],
|
||||||
slots: [
|
slots: [
|
||||||
'notFoundContent',
|
'notFoundContent',
|
||||||
'suffixIcon',
|
'suffixIcon',
|
||||||
|
@ -61,7 +62,7 @@ const Select = defineComponent({
|
||||||
],
|
],
|
||||||
setup(props, { attrs, emit, slots, expose }) {
|
setup(props, { attrs, emit, slots, expose }) {
|
||||||
const selectRef = ref();
|
const selectRef = ref();
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
const focus = () => {
|
const focus = () => {
|
||||||
if (selectRef.value) {
|
if (selectRef.value) {
|
||||||
selectRef.value.focus();
|
selectRef.value.focus();
|
||||||
|
@ -99,6 +100,11 @@ const Select = defineComponent({
|
||||||
const triggerChange = (...args: any[]) => {
|
const triggerChange = (...args: any[]) => {
|
||||||
emit('update:value', args[0]);
|
emit('update:value', args[0]);
|
||||||
emit('change', ...args);
|
emit('change', ...args);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
|
};
|
||||||
|
const handleBlur = (e: InputEvent) => {
|
||||||
|
emit('blur', e);
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
expose({
|
expose({
|
||||||
blur,
|
blur,
|
||||||
|
@ -113,6 +119,7 @@ const Select = defineComponent({
|
||||||
dropdownClassName,
|
dropdownClassName,
|
||||||
virtual,
|
virtual,
|
||||||
dropdownMatchSelectWidth,
|
dropdownMatchSelectWidth,
|
||||||
|
id = formItemContext.id.value,
|
||||||
} = props;
|
} = props;
|
||||||
|
|
||||||
const { renderEmpty, getPopupContainer: getContextPopupContainer } = configProvider;
|
const { renderEmpty, getPopupContainer: getContextPopupContainer } = configProvider;
|
||||||
|
@ -175,6 +182,8 @@ const Select = defineComponent({
|
||||||
getPopupContainer={getPopupContainer || getContextPopupContainer}
|
getPopupContainer={getPopupContainer || getContextPopupContainer}
|
||||||
dropdownClassName={rcSelectRtlDropDownClassName}
|
dropdownClassName={rcSelectRtlDropDownClassName}
|
||||||
onChange={triggerChange}
|
onChange={triggerChange}
|
||||||
|
onBlur={handleBlur}
|
||||||
|
id={id}
|
||||||
dropdownRender={selectProps.dropdownRender || slots.dropdownRender}
|
dropdownRender={selectProps.dropdownRender || slots.dropdownRender}
|
||||||
v-slots={{ option: slots.option }}
|
v-slots={{ option: slots.option }}
|
||||||
>
|
>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
exports[`renders ./components/slider/demo/basic.vue correctly 1`] = `
|
exports[`renders ./components/slider/demo/basic.vue correctly 1`] = `
|
||||||
<div>
|
<div>
|
||||||
<div tabindex="-1" class="ant-slider">
|
<div id="test" tabindex="-1" class="ant-slider">
|
||||||
<div class="ant-slider-rail"></div>
|
<div class="ant-slider-rail"></div>
|
||||||
<div class="ant-slider-track" style="left: 0%; width: 0%;"></div>
|
<div class="ant-slider-track" style="left: 0%; width: 0%;"></div>
|
||||||
<div class="ant-slider-step"></div>
|
<div class="ant-slider-step"></div>
|
||||||
|
|
|
@ -10,6 +10,7 @@ import type { TooltipPlacement } from '../tooltip/Tooltip';
|
||||||
import useConfigInject from '../_util/hooks/useConfigInject';
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
import SliderTooltip from './SliderTooltip';
|
import SliderTooltip from './SliderTooltip';
|
||||||
import classNames from '../_util/classNames';
|
import classNames from '../_util/classNames';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export type SliderValue = number | [number, number];
|
export type SliderValue = number | [number, number];
|
||||||
|
|
||||||
|
@ -39,6 +40,7 @@ type Value = [number, number] | number;
|
||||||
|
|
||||||
const defaultTipFormatter = (value: number) => (typeof value === 'number' ? value.toString() : '');
|
const defaultTipFormatter = (value: number) => (typeof value === 'number' ? value.toString() : '');
|
||||||
export const sliderProps = () => ({
|
export const sliderProps = () => ({
|
||||||
|
id: String,
|
||||||
prefixCls: String,
|
prefixCls: String,
|
||||||
tooltipPrefixCls: String,
|
tooltipPrefixCls: String,
|
||||||
range: { type: [Boolean, Object] as PropType<boolean | SliderRange>, default: undefined },
|
range: { type: [Boolean, Object] as PropType<boolean | SliderRange>, default: undefined },
|
||||||
|
@ -78,11 +80,12 @@ const Slider = defineComponent({
|
||||||
props: {
|
props: {
|
||||||
...sliderProps(),
|
...sliderProps(),
|
||||||
},
|
},
|
||||||
emits: ['update:value', 'change', 'afterChange'],
|
emits: ['update:value', 'change', 'afterChange', 'blur'],
|
||||||
slots: ['mark'],
|
slots: ['mark'],
|
||||||
setup(props, { attrs, slots, emit, expose }) {
|
setup(props, { attrs, slots, emit, expose }) {
|
||||||
const { prefixCls, rootPrefixCls, direction, getPopupContainer, configProvider } =
|
const { prefixCls, rootPrefixCls, direction, getPopupContainer, configProvider } =
|
||||||
useConfigInject('slider', props);
|
useConfigInject('slider', props);
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
const sliderRef = ref();
|
const sliderRef = ref();
|
||||||
const visibles = ref<Visibles>({});
|
const visibles = ref<Visibles>({});
|
||||||
const toggleTooltipVisible = (index: number, visible: boolean) => {
|
const toggleTooltipVisible = (index: number, visible: boolean) => {
|
||||||
|
@ -107,6 +110,10 @@ const Slider = defineComponent({
|
||||||
const handleChange = (val: SliderValue) => {
|
const handleChange = (val: SliderValue) => {
|
||||||
emit('update:value', val);
|
emit('update:value', val);
|
||||||
emit('change', val);
|
emit('change', val);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
|
};
|
||||||
|
const handleBlur = () => {
|
||||||
|
emit('blur');
|
||||||
};
|
};
|
||||||
expose({
|
expose({
|
||||||
focus,
|
focus,
|
||||||
|
@ -140,7 +147,12 @@ const Slider = defineComponent({
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
return () => {
|
return () => {
|
||||||
const { tooltipPrefixCls: customizeTooltipPrefixCls, range, ...restProps } = props;
|
const {
|
||||||
|
tooltipPrefixCls: customizeTooltipPrefixCls,
|
||||||
|
range,
|
||||||
|
id = formItemContext.id.value,
|
||||||
|
...restProps
|
||||||
|
} = props;
|
||||||
const tooltipPrefixCls = configProvider.getPrefixCls('tooltip', customizeTooltipPrefixCls);
|
const tooltipPrefixCls = configProvider.getPrefixCls('tooltip', customizeTooltipPrefixCls);
|
||||||
const cls = classNames(attrs.class, {
|
const cls = classNames(attrs.class, {
|
||||||
[`${prefixCls.value}-rtl`]: direction.value === 'rtl',
|
[`${prefixCls.value}-rtl`]: direction.value === 'rtl',
|
||||||
|
@ -181,6 +193,7 @@ const Slider = defineComponent({
|
||||||
return (
|
return (
|
||||||
<VcSlider
|
<VcSlider
|
||||||
{...restProps}
|
{...restProps}
|
||||||
|
id={id}
|
||||||
step={restProps.step!}
|
step={restProps.step!}
|
||||||
class={cls}
|
class={cls}
|
||||||
ref={ref}
|
ref={ref}
|
||||||
|
@ -193,6 +206,7 @@ const Slider = defineComponent({
|
||||||
}
|
}
|
||||||
prefixCls={prefixCls.value}
|
prefixCls={prefixCls.value}
|
||||||
onChange={handleChange}
|
onChange={handleChange}
|
||||||
|
onBlur={handleBlur}
|
||||||
v-slots={{ mark: slots.mark }}
|
v-slots={{ mark: slots.mark }}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
|
|
@ -9,10 +9,12 @@ import { tuple, withInstall } from '../_util/type';
|
||||||
import { getPropsSlot } from '../_util/props-util';
|
import { getPropsSlot } from '../_util/props-util';
|
||||||
import Omit from 'omit.js';
|
import Omit from 'omit.js';
|
||||||
import useConfigInject from '../_util/hooks/useConfigInject';
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export const SwitchSizes = tuple('small', 'default');
|
export const SwitchSizes = tuple('small', 'default');
|
||||||
type CheckedType = boolean | string | number;
|
type CheckedType = boolean | string | number;
|
||||||
const switchProps = {
|
const switchProps = {
|
||||||
|
id: PropTypes.string,
|
||||||
prefixCls: PropTypes.string,
|
prefixCls: PropTypes.string,
|
||||||
size: PropTypes.oneOf(SwitchSizes),
|
size: PropTypes.oneOf(SwitchSizes),
|
||||||
disabled: PropTypes.looseBool,
|
disabled: PropTypes.looseBool,
|
||||||
|
@ -55,8 +57,9 @@ const Switch = defineComponent({
|
||||||
inheritAttrs: false,
|
inheritAttrs: false,
|
||||||
props: switchProps,
|
props: switchProps,
|
||||||
slots: ['checkedChildren', 'unCheckedChildren'],
|
slots: ['checkedChildren', 'unCheckedChildren'],
|
||||||
emits: ['update:checked', 'mouseup', 'change', 'click', 'keydown'],
|
emits: ['update:checked', 'mouseup', 'change', 'click', 'keydown', 'blur'],
|
||||||
setup(props, { attrs, slots, expose, emit }) {
|
setup(props, { attrs, slots, expose, emit }) {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
onBeforeMount(() => {
|
onBeforeMount(() => {
|
||||||
warning(
|
warning(
|
||||||
!('defaultChecked' in attrs),
|
!('defaultChecked' in attrs),
|
||||||
|
@ -104,6 +107,11 @@ const Switch = defineComponent({
|
||||||
}
|
}
|
||||||
emit('update:checked', check);
|
emit('update:checked', check);
|
||||||
emit('change', check, e);
|
emit('change', check, e);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleBlur = () => {
|
||||||
|
emit('blur');
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleClick = (e: MouseEvent) => {
|
const handleClick = (e: MouseEvent) => {
|
||||||
|
@ -147,10 +155,13 @@ const Switch = defineComponent({
|
||||||
'defaultChecked',
|
'defaultChecked',
|
||||||
'checkedValue',
|
'checkedValue',
|
||||||
'unCheckedValue',
|
'unCheckedValue',
|
||||||
|
'id',
|
||||||
])}
|
])}
|
||||||
{...attrs}
|
{...attrs}
|
||||||
|
id={props.id ?? formItemContext.id.value}
|
||||||
onKeydown={handleKeyDown}
|
onKeydown={handleKeyDown}
|
||||||
onClick={handleClick}
|
onClick={handleClick}
|
||||||
|
onBlur={handleBlur}
|
||||||
onMouseup={handleMouseUp}
|
onMouseup={handleMouseUp}
|
||||||
type="button"
|
type="button"
|
||||||
role="switch"
|
role="switch"
|
||||||
|
|
|
@ -11,6 +11,7 @@ import type { GenerateConfig } from '../vc-picker/generate';
|
||||||
import type { PanelMode, RangeValue } from '../vc-picker/interface';
|
import type { PanelMode, RangeValue } from '../vc-picker/interface';
|
||||||
import type { RangePickerSharedProps } from '../vc-picker/RangePicker';
|
import type { RangePickerSharedProps } from '../vc-picker/RangePicker';
|
||||||
import devWarning from '../vc-util/devWarning';
|
import devWarning from '../vc-util/devWarning';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export interface TimePickerLocale {
|
export interface TimePickerLocale {
|
||||||
placeholder?: string;
|
placeholder?: string;
|
||||||
|
@ -74,6 +75,7 @@ function createTimePicker<
|
||||||
slot: ['addon', 'renderExtraFooter', 'suffixIcon', 'clearIcon'],
|
slot: ['addon', 'renderExtraFooter', 'suffixIcon', 'clearIcon'],
|
||||||
emits: ['change', 'openChange', 'focus', 'blur', 'ok', 'update:value', 'update:open'],
|
emits: ['change', 'openChange', 'focus', 'blur', 'ok', 'update:value', 'update:open'],
|
||||||
setup(props, { slots, expose, emit, attrs }) {
|
setup(props, { slots, expose, emit, attrs }) {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
devWarning(
|
devWarning(
|
||||||
!(slots.addon || props.addon),
|
!(slots.addon || props.addon),
|
||||||
'TimePicker',
|
'TimePicker',
|
||||||
|
@ -91,6 +93,7 @@ function createTimePicker<
|
||||||
const onChange = (value: DateType | string, dateString: string) => {
|
const onChange = (value: DateType | string, dateString: string) => {
|
||||||
emit('update:value', value);
|
emit('update:value', value);
|
||||||
emit('change', value, dateString);
|
emit('change', value, dateString);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
const onOpenChange = (open: boolean) => {
|
const onOpenChange = (open: boolean) => {
|
||||||
emit('update:open', open);
|
emit('update:open', open);
|
||||||
|
@ -101,15 +104,18 @@ function createTimePicker<
|
||||||
};
|
};
|
||||||
const onBlur = () => {
|
const onBlur = () => {
|
||||||
emit('blur');
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
const onOk = (value: DateType) => {
|
const onOk = (value: DateType) => {
|
||||||
emit('ok', value);
|
emit('ok', value);
|
||||||
};
|
};
|
||||||
return () => {
|
return () => {
|
||||||
|
const { id = formItemContext.id.value, ...restProps } = props;
|
||||||
return (
|
return (
|
||||||
<InternalTimePicker
|
<InternalTimePicker
|
||||||
{...attrs}
|
{...attrs}
|
||||||
{...props}
|
{...restProps}
|
||||||
|
id={id}
|
||||||
dropdownClassName={props.popupClassName}
|
dropdownClassName={props.popupClassName}
|
||||||
mode={undefined}
|
mode={undefined}
|
||||||
ref={pickerRef}
|
ref={pickerRef}
|
||||||
|
@ -152,6 +158,9 @@ function createTimePicker<
|
||||||
],
|
],
|
||||||
setup(props, { slots, expose, emit, attrs }) {
|
setup(props, { slots, expose, emit, attrs }) {
|
||||||
const pickerRef = ref();
|
const pickerRef = ref();
|
||||||
|
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
|
|
||||||
expose({
|
expose({
|
||||||
focus: () => {
|
focus: () => {
|
||||||
pickerRef.value?.focus();
|
pickerRef.value?.focus();
|
||||||
|
@ -166,6 +175,7 @@ function createTimePicker<
|
||||||
) => {
|
) => {
|
||||||
emit('update:value', values);
|
emit('update:value', values);
|
||||||
emit('change', values, dateStrings);
|
emit('change', values, dateStrings);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
const onOpenChange = (open: boolean) => {
|
const onOpenChange = (open: boolean) => {
|
||||||
emit('update:open', open);
|
emit('update:open', open);
|
||||||
|
@ -176,6 +186,7 @@ function createTimePicker<
|
||||||
};
|
};
|
||||||
const onBlur = () => {
|
const onBlur = () => {
|
||||||
emit('blur');
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
};
|
};
|
||||||
const onPanelChange = (
|
const onPanelChange = (
|
||||||
values: RangeValue<string> | RangeValue<DateType>,
|
values: RangeValue<string> | RangeValue<DateType>,
|
||||||
|
@ -194,10 +205,12 @@ function createTimePicker<
|
||||||
emit('calendarChange', values, dateStrings, info);
|
emit('calendarChange', values, dateStrings, info);
|
||||||
};
|
};
|
||||||
return () => {
|
return () => {
|
||||||
|
const { id = formItemContext.id.value, ...restProps } = props;
|
||||||
return (
|
return (
|
||||||
<InternalRangePicker
|
<InternalRangePicker
|
||||||
{...attrs}
|
{...attrs}
|
||||||
{...props}
|
{...restProps}
|
||||||
|
id={id}
|
||||||
dropdownClassName={props.popupClassName}
|
dropdownClassName={props.popupClassName}
|
||||||
picker="time"
|
picker="time"
|
||||||
mode={undefined}
|
mode={undefined}
|
||||||
|
|
|
@ -13,6 +13,7 @@ import { withInstall } from '../_util/type';
|
||||||
import useConfigInject from '../_util/hooks/useConfigInject';
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
||||||
import type { TransferListBodyProps } from './ListBody';
|
import type { TransferListBodyProps } from './ListBody';
|
||||||
import type { PaginationType } from './interface';
|
import type { PaginationType } from './interface';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export type { TransferListProps } from './list';
|
export type { TransferListProps } from './list';
|
||||||
export type { TransferOperationProps } from './operation';
|
export type { TransferOperationProps } from './operation';
|
||||||
|
@ -64,6 +65,7 @@ export interface TransferLocale {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const transferProps = {
|
export const transferProps = {
|
||||||
|
id: String,
|
||||||
prefixCls: String,
|
prefixCls: String,
|
||||||
dataSource: { type: Array as PropType<TransferItem[]>, default: [] },
|
dataSource: { type: Array as PropType<TransferItem[]>, default: [] },
|
||||||
disabled: { type: Boolean, default: undefined },
|
disabled: { type: Boolean, default: undefined },
|
||||||
|
@ -118,6 +120,7 @@ const Transfer = defineComponent({
|
||||||
const sourceSelectedKeys = ref([]);
|
const sourceSelectedKeys = ref([]);
|
||||||
const targetSelectedKeys = ref([]);
|
const targetSelectedKeys = ref([]);
|
||||||
|
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
watch(
|
watch(
|
||||||
() => props.selectedKeys,
|
() => props.selectedKeys,
|
||||||
() => {
|
() => {
|
||||||
|
@ -164,6 +167,7 @@ const Transfer = defineComponent({
|
||||||
emit('update:targetKeys', newTargetKeys);
|
emit('update:targetKeys', newTargetKeys);
|
||||||
handleSelectChange(oppositeDirection, []);
|
handleSelectChange(oppositeDirection, []);
|
||||||
emit('change', newTargetKeys, direction, newMoveKeys);
|
emit('change', newTargetKeys, direction, newMoveKeys);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
|
|
||||||
const moveToLeft = () => {
|
const moveToLeft = () => {
|
||||||
|
@ -312,6 +316,7 @@ const Transfer = defineComponent({
|
||||||
selectAllLabels = [],
|
selectAllLabels = [],
|
||||||
oneWay,
|
oneWay,
|
||||||
pagination,
|
pagination,
|
||||||
|
id = formItemContext.id.value,
|
||||||
} = props;
|
} = props;
|
||||||
const { class: className, style } = attrs;
|
const { class: className, style } = attrs;
|
||||||
|
|
||||||
|
@ -335,7 +340,7 @@ const Transfer = defineComponent({
|
||||||
const rightTitle =
|
const rightTitle =
|
||||||
(titles && titles[1]) ?? slots.rightTitle?.() ?? (locale.titles || ['', ''])[1];
|
(titles && titles[1]) ?? slots.rightTitle?.() ?? (locale.titles || ['', ''])[1];
|
||||||
return (
|
return (
|
||||||
<div class={cls} style={style}>
|
<div class={cls} style={style} id={id}>
|
||||||
<List
|
<List
|
||||||
key="leftList"
|
key="leftList"
|
||||||
prefixCls={`${prefixCls.value}-list`}
|
prefixCls={`${prefixCls.value}-list`}
|
||||||
|
|
|
@ -20,6 +20,7 @@ import renderSwitcherIcon from '../tree/utils/iconUtil';
|
||||||
import type { AntTreeNodeProps } from '../tree/Tree';
|
import type { AntTreeNodeProps } from '../tree/Tree';
|
||||||
import { warning } from '../vc-util/warning';
|
import { warning } from '../vc-util/warning';
|
||||||
import { flattenChildren } from '../_util/props-util';
|
import { flattenChildren } from '../_util/props-util';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
const getTransitionName = (rootPrefixCls: string, motion: string, transitionName?: string) => {
|
const getTransitionName = (rootPrefixCls: string, motion: string, transitionName?: string) => {
|
||||||
if (transitionName !== undefined) {
|
if (transitionName !== undefined) {
|
||||||
|
@ -92,6 +93,8 @@ const TreeSelect = defineComponent({
|
||||||
'`replaceFields` is deprecated, please use fieldNames instead',
|
'`replaceFields` is deprecated, please use fieldNames instead',
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
const {
|
const {
|
||||||
configProvider,
|
configProvider,
|
||||||
prefixCls,
|
prefixCls,
|
||||||
|
@ -131,6 +134,7 @@ const TreeSelect = defineComponent({
|
||||||
const handleChange = (...args: any[]) => {
|
const handleChange = (...args: any[]) => {
|
||||||
emit('update:value', args[0]);
|
emit('update:value', args[0]);
|
||||||
emit('change', ...args);
|
emit('change', ...args);
|
||||||
|
formItemContext.onFieldChange();
|
||||||
};
|
};
|
||||||
const handleTreeExpand = (...args: any[]) => {
|
const handleTreeExpand = (...args: any[]) => {
|
||||||
emit('update:treeExpandedKeys', args[0]);
|
emit('update:treeExpandedKeys', args[0]);
|
||||||
|
@ -140,6 +144,10 @@ const TreeSelect = defineComponent({
|
||||||
emit('update:searchValue', args[0]);
|
emit('update:searchValue', args[0]);
|
||||||
emit('search', ...args);
|
emit('search', ...args);
|
||||||
};
|
};
|
||||||
|
const handleBlur = () => {
|
||||||
|
emit('blur');
|
||||||
|
formItemContext.onFieldBlur();
|
||||||
|
};
|
||||||
return () => {
|
return () => {
|
||||||
const {
|
const {
|
||||||
notFoundContent = slots.notFoundContent?.(),
|
notFoundContent = slots.notFoundContent?.(),
|
||||||
|
@ -154,6 +162,7 @@ const TreeSelect = defineComponent({
|
||||||
treeLine,
|
treeLine,
|
||||||
switcherIcon = slots.switcherIcon?.(),
|
switcherIcon = slots.switcherIcon?.(),
|
||||||
fieldNames = props.replaceFields,
|
fieldNames = props.replaceFields,
|
||||||
|
id = formItemContext.id.value,
|
||||||
} = props;
|
} = props;
|
||||||
// ===================== Icons =====================
|
// ===================== Icons =====================
|
||||||
const { suffixIcon, removeIcon, clearIcon } = getIcons(
|
const { suffixIcon, removeIcon, clearIcon } = getIcons(
|
||||||
|
@ -202,6 +211,7 @@ const TreeSelect = defineComponent({
|
||||||
virtual={virtual.value}
|
virtual={virtual.value}
|
||||||
dropdownMatchSelectWidth={dropdownMatchSelectWidth.value}
|
dropdownMatchSelectWidth={dropdownMatchSelectWidth.value}
|
||||||
{...selectProps}
|
{...selectProps}
|
||||||
|
id={id}
|
||||||
fieldNames={fieldNames}
|
fieldNames={fieldNames}
|
||||||
ref={treeSelectRef}
|
ref={treeSelectRef}
|
||||||
prefixCls={prefixCls.value}
|
prefixCls={prefixCls.value}
|
||||||
|
@ -223,6 +233,7 @@ const TreeSelect = defineComponent({
|
||||||
choiceTransitionName={getTransitionName(rootPrefixCls, '', choiceTransitionName)}
|
choiceTransitionName={getTransitionName(rootPrefixCls, '', choiceTransitionName)}
|
||||||
transitionName={getTransitionName(rootPrefixCls, 'slide-up', transitionName)}
|
transitionName={getTransitionName(rootPrefixCls, 'slide-up', transitionName)}
|
||||||
onChange={handleChange}
|
onChange={handleChange}
|
||||||
|
onBlur={handleBlur}
|
||||||
onSearch={handleSearch}
|
onSearch={handleSearch}
|
||||||
onTreeExpand={handleTreeExpand}
|
onTreeExpand={handleTreeExpand}
|
||||||
v-slots={{
|
v-slots={{
|
||||||
|
|
|
@ -14,6 +14,7 @@ import { UploadProps } from './interface';
|
||||||
import { T, fileToObject, genPercentAdd, getFileItem, removeFileItem } from './utils';
|
import { T, fileToObject, genPercentAdd, getFileItem, removeFileItem } from './utils';
|
||||||
import { defineComponent, inject } from 'vue';
|
import { defineComponent, inject } from 'vue';
|
||||||
import { getDataAndAriaProps } from '../_util/util';
|
import { getDataAndAriaProps } from '../_util/util';
|
||||||
|
import { useInjectFormItemContext } from '../form/FormItemContext';
|
||||||
|
|
||||||
export type UploadFileStatus = 'error' | 'success' | 'done' | 'uploading' | 'removed';
|
export type UploadFileStatus = 'error' | 'success' | 'done' | 'uploading' | 'removed';
|
||||||
export interface UploadFile<T = any> {
|
export interface UploadFile<T = any> {
|
||||||
|
@ -54,10 +55,12 @@ export default defineComponent({
|
||||||
supportServerRender: true,
|
supportServerRender: true,
|
||||||
}),
|
}),
|
||||||
setup() {
|
setup() {
|
||||||
|
const formItemContext = useInjectFormItemContext();
|
||||||
return {
|
return {
|
||||||
upload: null,
|
upload: null,
|
||||||
progressTimer: null,
|
progressTimer: null,
|
||||||
configProvider: inject('configProvider', defaultConfigProvider),
|
configProvider: inject('configProvider', defaultConfigProvider),
|
||||||
|
formItemContext,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
// recentUploadStatus: boolean | PromiseLike<any>;
|
// recentUploadStatus: boolean | PromiseLike<any>;
|
||||||
|
@ -190,6 +193,7 @@ export default defineComponent({
|
||||||
}
|
}
|
||||||
this.$emit('update:fileList', info.fileList);
|
this.$emit('update:fileList', info.fileList);
|
||||||
this.$emit('change', info);
|
this.$emit('change', info);
|
||||||
|
this.formItemContext.onFieldChange();
|
||||||
},
|
},
|
||||||
onFileDrop(e) {
|
onFileDrop(e) {
|
||||||
this.setState({
|
this.setState({
|
||||||
|
@ -276,6 +280,7 @@ export default defineComponent({
|
||||||
|
|
||||||
const vcUploadProps = {
|
const vcUploadProps = {
|
||||||
...this.$props,
|
...this.$props,
|
||||||
|
id: this.$props.id ?? this.formItemContext.id.value,
|
||||||
prefixCls,
|
prefixCls,
|
||||||
beforeUpload: this.reBeforeUpload,
|
beforeUpload: this.reBeforeUpload,
|
||||||
onStart: this.onStart,
|
onStart: this.onStart,
|
||||||
|
|
|
@ -158,7 +158,6 @@ export default defineComponent({
|
||||||
typeof nextValue === 'number' &&
|
typeof nextValue === 'number' &&
|
||||||
nextValue > max
|
nextValue > max
|
||||||
) {
|
) {
|
||||||
this.__emit('update:value', max);
|
|
||||||
this.__emit('change', max);
|
this.__emit('change', max);
|
||||||
}
|
}
|
||||||
if (
|
if (
|
||||||
|
@ -167,7 +166,6 @@ export default defineComponent({
|
||||||
typeof nextValue === 'number' &&
|
typeof nextValue === 'number' &&
|
||||||
nextValue < min
|
nextValue < min
|
||||||
) {
|
) {
|
||||||
this.__emit('update:value', min);
|
|
||||||
this.__emit('change', min);
|
this.__emit('change', min);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -277,7 +275,6 @@ export default defineComponent({
|
||||||
this.rawInput = this.parser(this.getValueFromEvent(e));
|
this.rawInput = this.parser(this.getValueFromEvent(e));
|
||||||
this.setState({ inputValue: this.rawInput });
|
this.setState({ inputValue: this.rawInput });
|
||||||
const num = this.toNumber(this.rawInput); // valid number or invalid string
|
const num = this.toNumber(this.rawInput); // valid number or invalid string
|
||||||
this.__emit('update:value', num);
|
|
||||||
this.__emit('change', num);
|
this.__emit('change', num);
|
||||||
},
|
},
|
||||||
onFocus(...args) {
|
onFocus(...args) {
|
||||||
|
@ -374,7 +371,6 @@ export default defineComponent({
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (changed) {
|
if (changed) {
|
||||||
this.__emit('update:value', newValue);
|
|
||||||
this.__emit('change', newValue);
|
this.__emit('change', newValue);
|
||||||
}
|
}
|
||||||
return newValue;
|
return newValue;
|
||||||
|
|
|
@ -16,6 +16,7 @@ function noop() {}
|
||||||
export default function createSlider(Component) {
|
export default function createSlider(Component) {
|
||||||
// const displayName = `ComponentEnhancer(${Component.displayName})`
|
// const displayName = `ComponentEnhancer(${Component.displayName})`
|
||||||
const propTypes = {
|
const propTypes = {
|
||||||
|
id: PropTypes.string,
|
||||||
min: PropTypes.number,
|
min: PropTypes.number,
|
||||||
max: PropTypes.number,
|
max: PropTypes.number,
|
||||||
step: PropTypes.number,
|
step: PropTypes.number,
|
||||||
|
@ -292,8 +293,9 @@ export default function createSlider(Component) {
|
||||||
railStyle,
|
railStyle,
|
||||||
dotStyle,
|
dotStyle,
|
||||||
activeDotStyle,
|
activeDotStyle,
|
||||||
|
id,
|
||||||
} = this;
|
} = this;
|
||||||
const { class: className, style, id } = this.$attrs;
|
const { class: className, style } = this.$attrs;
|
||||||
const { tracks, handles } = this.renderSlider();
|
const { tracks, handles } = this.renderSlider();
|
||||||
|
|
||||||
const sliderClassName = classNames(prefixCls, className, {
|
const sliderClassName = classNames(prefixCls, className, {
|
||||||
|
|
|
@ -51,7 +51,8 @@
|
||||||
"routes": "node site/scripts/genrateRoutes.js",
|
"routes": "node site/scripts/genrateRoutes.js",
|
||||||
"tsc": "tsc --noEmit",
|
"tsc": "tsc --noEmit",
|
||||||
"site": "yarn routes && ./node_modules/vite/bin/vite.js build site --base=https://next.antdv.com/",
|
"site": "yarn routes && ./node_modules/vite/bin/vite.js build site --base=https://next.antdv.com/",
|
||||||
"pub:site": "npm run site && node site/scripts/pushToOSS.js"
|
"pub:site": "npm run site && node site/scripts/pushToOSS.js",
|
||||||
|
"prepare": "husky install"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
|
@ -157,7 +158,7 @@
|
||||||
"gulp-strip-code": "^0.1.4",
|
"gulp-strip-code": "^0.1.4",
|
||||||
"gulp-typescript": "^6.0.0-alpha.1",
|
"gulp-typescript": "^6.0.0-alpha.1",
|
||||||
"html-webpack-plugin": "^5.3.1",
|
"html-webpack-plugin": "^5.3.1",
|
||||||
"husky": "^4.0.0",
|
"husky": "^6.0.0",
|
||||||
"ignore-emit-webpack-plugin": "^2.0.6",
|
"ignore-emit-webpack-plugin": "^2.0.6",
|
||||||
"jest": "^26.0.0",
|
"jest": "^26.0.0",
|
||||||
"jest-environment-jsdom-fifteen": "^1.0.2",
|
"jest-environment-jsdom-fifteen": "^1.0.2",
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
// debugger tsx
|
// debugger tsx
|
||||||
import Demo from '../../components/modal/demo/index.vue';
|
import Demo from '../../components/form/demo/validation.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
render() {
|
render() {
|
||||||
|
|
Loading…
Reference in New Issue