1234567891011121314151617181920212223242526272829303132333435363738394041 |
- import type { UnwrapRef } from 'vue';
- import { reactive, readonly, computed, getCurrentInstance, watchEffect } from 'vue';
- import { isEqual } from 'lodash-es';
- export function useRuleFormItem<T extends Recordable>(
- props: T,
- key: keyof T = 'value',
- changeEvent = 'change'
- ) {
- const instance = getCurrentInstance();
- const emit = instance?.emit;
- const innerState = reactive({
- value: props[key],
- });
- const defaultState = readonly(innerState);
- const setState = (val: UnwrapRef<T[keyof T]>): void => {
- innerState.value = val as T[keyof T];
- };
- watchEffect(() => {
- innerState.value = props[key];
- });
- const state = computed({
- get() {
- return innerState.value;
- },
- set(value) {
- if (isEqual(value, defaultState.value)) return;
- innerState.value = value as T[keyof T];
- emit?.(changeEvent, value);
- },
- });
- return [state, setState, defaultState];
- }
|