112 lines
2.5 KiB
TypeScript
112 lines
2.5 KiB
TypeScript
![]() |
import type { VxeGridInstance } from 'vxe-table';
|
||
|
|
||
|
import type { VxeGridProps } from './types';
|
||
|
|
||
|
import { toRaw } from 'vue';
|
||
|
|
||
|
import { Store } from '@vben-core/shared/store';
|
||
|
import {
|
||
|
bindMethods,
|
||
|
isFunction,
|
||
|
mergeWithArrayOverride,
|
||
|
StateHandler,
|
||
|
} from '@vben-core/shared/utils';
|
||
|
|
||
|
function getDefaultState(): VxeGridProps {
|
||
|
return {
|
||
|
class: '',
|
||
|
gridClass: '',
|
||
|
gridOptions: {},
|
||
|
gridEvents: {},
|
||
|
formOptions: undefined,
|
||
|
};
|
||
|
}
|
||
|
|
||
|
export class VxeGridApi {
|
||
|
// private prevState: null | VxeGridProps = null;
|
||
|
public grid = {} as VxeGridInstance;
|
||
|
|
||
|
isMounted = false;
|
||
|
public state: null | VxeGridProps = null;
|
||
|
|
||
|
stateHandler: StateHandler;
|
||
|
|
||
|
public store: Store<VxeGridProps>;
|
||
|
|
||
|
constructor(options: VxeGridProps = {}) {
|
||
|
const storeState = { ...options };
|
||
|
|
||
|
const defaultState = getDefaultState();
|
||
|
this.store = new Store<VxeGridProps>(
|
||
|
mergeWithArrayOverride(storeState, defaultState),
|
||
|
{
|
||
|
onUpdate: () => {
|
||
|
// this.prevState = this.state;
|
||
|
this.state = this.store.state;
|
||
|
},
|
||
|
},
|
||
|
);
|
||
|
|
||
|
this.state = this.store.state;
|
||
|
this.stateHandler = new StateHandler();
|
||
|
bindMethods(this);
|
||
|
}
|
||
|
|
||
|
mount(instance: null | VxeGridInstance) {
|
||
|
if (!this.isMounted && instance) {
|
||
|
this.grid = instance;
|
||
|
this.stateHandler.setConditionTrue();
|
||
|
this.isMounted = true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
async query(params: Record<string, any> = {}) {
|
||
|
try {
|
||
|
await this.grid.commitProxy('query', toRaw(params));
|
||
|
} catch (error) {
|
||
|
console.error('Error occurred while querying:', error);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
async reload(params: Record<string, any> = {}) {
|
||
|
try {
|
||
|
await this.grid.commitProxy('reload', toRaw(params));
|
||
|
} catch (error) {
|
||
|
console.error('Error occurred while reloading:', error);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
setGridOptions(options: Partial<VxeGridProps['gridOptions']>) {
|
||
|
this.setState({
|
||
|
gridOptions: options,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
setLoading(isLoading: boolean) {
|
||
|
this.setState({
|
||
|
gridOptions: {
|
||
|
loading: isLoading,
|
||
|
},
|
||
|
});
|
||
|
}
|
||
|
|
||
|
setState(
|
||
|
stateOrFn:
|
||
|
| ((prev: VxeGridProps) => Partial<VxeGridProps>)
|
||
|
| Partial<VxeGridProps>,
|
||
|
) {
|
||
|
if (isFunction(stateOrFn)) {
|
||
|
this.store.setState((prev) => {
|
||
|
return mergeWithArrayOverride(stateOrFn(prev), prev);
|
||
|
});
|
||
|
} else {
|
||
|
this.store.setState((prev) => mergeWithArrayOverride(stateOrFn, prev));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
unmount() {
|
||
|
this.isMounted = false;
|
||
|
this.stateHandler.reset();
|
||
|
}
|
||
|
}
|