| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- import { ref, computed } from 'vue';
- import '../../components/config-provider/index.mjs';
- import '../../utils/index.mjs';
- import { buildProps } from '../../utils/vue/props/runtime.mjs';
- import { isFunction } from '@vue/shared';
- import { useGlobalConfig } from '../../components/config-provider/src/hooks/use-global-config.mjs';
- import { debugWarn } from '../../utils/error.mjs';
- 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) => {
- let config = useGlobalConfig();
- if (!config.value) {
- config = 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, useEmptyValues, useEmptyValuesProps };
- //# sourceMappingURL=index.mjs.map
|