123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- import type { SetupVxeTable } from './types';
- import { defineComponent, watch } from 'vue';
- import { usePreferences } from '@vben/preferences';
- import { useVbenForm } from '@vben-core/form-ui';
- import {
- VxeButton,
- VxeCheckbox,
- // VxeFormGather,
- // VxeForm,
- // VxeFormItem,
- VxeIcon,
- VxeInput,
- VxeLoading,
- VxeModal,
- VxePager,
- // VxeList,
- // VxeModal,
- // VxeOptgroup,
- // VxeOption,
- // VxePulldown,
- // VxeRadio,
- // VxeRadioButton,
- VxeRadioGroup,
- VxeSelect,
- VxeTooltip,
- VxeUI,
- // VxeSwitch,
- // VxeTextarea,
- } from 'vxe-pc-ui';
- import enUS from 'vxe-pc-ui/lib/language/en-US';
- // 导入默认的语言
- import zhCN from 'vxe-pc-ui/lib/language/zh-CN';
- import {
- VxeColgroup,
- VxeColumn,
- VxeGrid,
- VxeTable,
- VxeToolbar,
- } from 'vxe-table';
- import { extendsDefaultFormatter } from './extends';
- // 是否加载过
- let isInit = false;
- // eslint-disable-next-line import/no-mutable-exports
- export let useTableForm: typeof useVbenForm;
- // 部分组件,如果没注册,vxe-table 会报错,这里实际没用组件,只是为了不报错,同时可以减少打包体积
- const createVirtualComponent = (name = '') => {
- return defineComponent({
- name,
- });
- };
- export function initVxeTable() {
- if (isInit) {
- return;
- }
- VxeUI.component(VxeTable);
- VxeUI.component(VxeColumn);
- VxeUI.component(VxeColgroup);
- VxeUI.component(VxeGrid);
- VxeUI.component(VxeToolbar);
- VxeUI.component(VxeButton);
- // VxeUI.component(VxeButtonGroup);
- VxeUI.component(VxeCheckbox);
- // VxeUI.component(VxeCheckboxGroup);
- VxeUI.component(createVirtualComponent('VxeForm'));
- // VxeUI.component(VxeFormGather);
- // VxeUI.component(VxeFormItem);
- VxeUI.component(VxeIcon);
- VxeUI.component(VxeInput);
- // VxeUI.component(VxeList);
- VxeUI.component(VxeLoading);
- VxeUI.component(VxeModal);
- // VxeUI.component(VxeOptgroup);
- // VxeUI.component(VxeOption);
- VxeUI.component(VxePager);
- // VxeUI.component(VxePulldown);
- // VxeUI.component(VxeRadio);
- // VxeUI.component(VxeRadioButton);
- VxeUI.component(VxeRadioGroup);
- VxeUI.component(VxeSelect);
- // VxeUI.component(VxeSwitch);
- // VxeUI.component(VxeTextarea);
- VxeUI.component(VxeTooltip);
- isInit = true;
- }
- export function setupVbenVxeTable(setupOptions: SetupVxeTable) {
- const { configVxeTable, useVbenForm } = setupOptions;
- initVxeTable();
- useTableForm = useVbenForm;
- const preference = usePreferences();
- const localMap = {
- 'zh-CN': zhCN,
- 'en-US': enUS,
- };
- watch(
- [() => preference.theme.value, () => preference.locale.value],
- ([theme, locale]) => {
- VxeUI.setTheme(theme === 'dark' ? 'dark' : 'light');
- VxeUI.setI18n(locale, localMap[locale]);
- VxeUI.setLanguage(locale);
- },
- {
- immediate: true,
- },
- );
- extendsDefaultFormatter(VxeUI);
- configVxeTable(VxeUI);
- }
|