You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
49 lines
1.8 KiB
49 lines
1.8 KiB
import { getCurrentInstance, inject, ref, computed } from 'vue';
|
|
import '../../utils/index.mjs';
|
|
import { buildProps } from '../../utils/vue/props/runtime.mjs';
|
|
import { isFunction } from '@vue/shared';
|
|
import { debugWarn } from '../../utils/error.mjs';
|
|
|
|
const emptyValuesContextKey = Symbol("emptyValuesContextKey");
|
|
const SCOPE = "use-empty-values";
|
|
const DEFAULT_EMPTY_VALUES = ["", void 0, null];
|
|
const DEFAULT_VALUE_ON_CLEAR = void 0;
|
|
const useEmptyValuesProps = buildProps({
|
|
emptyValues: Array,
|
|
valueOnClear: {
|
|
type: [String, Number, Boolean, Function],
|
|
default: void 0,
|
|
validator: (val) => isFunction(val) ? !val() : !val
|
|
}
|
|
});
|
|
const useEmptyValues = (props, defaultValue) => {
|
|
const config = getCurrentInstance() ? inject(emptyValuesContextKey, ref({})) : ref({});
|
|
const emptyValues = computed(() => props.emptyValues || config.value.emptyValues || DEFAULT_EMPTY_VALUES);
|
|
const valueOnClear = computed(() => {
|
|
if (isFunction(props.valueOnClear)) {
|
|
return props.valueOnClear();
|
|
} else if (props.valueOnClear !== void 0) {
|
|
return props.valueOnClear;
|
|
} else if (isFunction(config.value.valueOnClear)) {
|
|
return config.value.valueOnClear();
|
|
} else if (config.value.valueOnClear !== void 0) {
|
|
return config.value.valueOnClear;
|
|
}
|
|
return defaultValue !== void 0 ? defaultValue : DEFAULT_VALUE_ON_CLEAR;
|
|
});
|
|
const isEmptyValue = (value) => {
|
|
return emptyValues.value.includes(value);
|
|
};
|
|
if (!emptyValues.value.includes(valueOnClear.value)) {
|
|
debugWarn(SCOPE, "value-on-clear should be a value of empty-values");
|
|
}
|
|
return {
|
|
emptyValues,
|
|
valueOnClear,
|
|
isEmptyValue
|
|
};
|
|
};
|
|
|
|
export { DEFAULT_EMPTY_VALUES, DEFAULT_VALUE_ON_CLEAR, SCOPE, emptyValuesContextKey, useEmptyValues, useEmptyValuesProps };
|
|
//# sourceMappingURL=index.mjs.map
|