init.ts 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. import type { SetupVxeTable } from './types';
  2. import { defineComponent, watch } from 'vue';
  3. import { usePreferences } from '@vben/preferences';
  4. import { useVbenForm } from '@vben-core/form-ui';
  5. import {
  6. VxeButton,
  7. VxeButtonGroup,
  8. // VxeFormGather,
  9. // VxeForm,
  10. // VxeFormItem,
  11. VxeIcon,
  12. VxeInput,
  13. VxeLoading,
  14. VxePager,
  15. // VxeList,
  16. // VxeModal,
  17. // VxeOptgroup,
  18. // VxeOption,
  19. // VxePulldown,
  20. // VxeRadio,
  21. // VxeRadioButton,
  22. // VxeRadioGroup,
  23. VxeSelect,
  24. VxeTooltip,
  25. VxeUI,
  26. // VxeSwitch,
  27. // VxeTextarea,
  28. } from 'vxe-pc-ui';
  29. import enUS from 'vxe-pc-ui/lib/language/en-US';
  30. // 导入默认的语言
  31. import zhCN from 'vxe-pc-ui/lib/language/zh-CN';
  32. import {
  33. VxeColgroup,
  34. VxeColumn,
  35. VxeGrid,
  36. VxeTable,
  37. VxeToolbar,
  38. } from 'vxe-table';
  39. import { extendsDefaultFormatter } from './extends';
  40. // 是否加载过
  41. let isInit = false;
  42. // eslint-disable-next-line import/no-mutable-exports
  43. export let useTableForm: typeof useVbenForm;
  44. // 部分组件,如果没注册,vxe-table 会报错,这里实际没用组件,只是为了不报错,同时可以减少打包体积
  45. const createVirtualComponent = (name = '') => {
  46. return defineComponent({
  47. name,
  48. });
  49. };
  50. export function initVxeTable() {
  51. if (isInit) {
  52. return;
  53. }
  54. VxeUI.component(VxeTable);
  55. VxeUI.component(VxeColumn);
  56. VxeUI.component(VxeColgroup);
  57. VxeUI.component(VxeLoading);
  58. VxeUI.component(VxeGrid);
  59. VxeUI.component(VxeToolbar);
  60. VxeUI.component(VxeButton);
  61. VxeUI.component(VxeButtonGroup);
  62. // VxeUI.component(VxeCheckbox);
  63. // VxeUI.component(VxeCheckboxGroup);
  64. VxeUI.component(createVirtualComponent('VxeForm'));
  65. // VxeUI.component(VxeFormGather);
  66. // VxeUI.component(VxeFormItem);
  67. VxeUI.component(VxeIcon);
  68. VxeUI.component(VxeInput);
  69. // VxeUI.component(VxeList);
  70. VxeUI.component(VxeLoading);
  71. // VxeUI.component(VxeModal);
  72. // VxeUI.component(VxeOptgroup);
  73. // VxeUI.component(VxeOption);
  74. VxeUI.component(VxePager);
  75. // VxeUI.component(VxePulldown);
  76. // VxeUI.component(VxeRadio);
  77. // VxeUI.component(VxeRadioButton);
  78. // VxeUI.component(VxeRadioGroup);
  79. VxeUI.component(VxeSelect);
  80. // VxeUI.component(VxeSwitch);
  81. // VxeUI.component(VxeTextarea);
  82. VxeUI.component(VxeTooltip);
  83. isInit = true;
  84. }
  85. export function setupVbenVxeTable(setupOptions: SetupVxeTable) {
  86. const { configVxeTable, useVbenForm } = setupOptions;
  87. initVxeTable();
  88. useTableForm = useVbenForm;
  89. const preference = usePreferences();
  90. const localMap = {
  91. 'zh-CN': zhCN,
  92. 'en-US': enUS,
  93. };
  94. watch(
  95. [() => preference.theme.value, () => preference.locale.value],
  96. ([theme, locale]) => {
  97. VxeUI.setTheme(theme === 'dark' ? 'dark' : 'light');
  98. VxeUI.setI18n(locale, localMap[locale]);
  99. VxeUI.setLanguage(locale);
  100. },
  101. {
  102. immediate: true,
  103. },
  104. );
  105. extendsDefaultFormatter(VxeUI);
  106. configVxeTable(VxeUI);
  107. }