main.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. import Vue from 'vue';
  2. import './public-path';
  3. import initParentStore from '../qiankun_config/store';
  4. import App from './App.vue';
  5. import store from './store';
  6. import router from './router';
  7. import permission from './utils/permission';
  8. import { MAP_KEY, LICENSE_CODE } from '@/config/setting';
  9. import EleAdmin from 'ele-admin';
  10. import VueClipboard from 'vue-clipboard2';
  11. import i18n from './i18n';
  12. import './styles/index.scss';
  13. import DictSelection from '@/components/Dict/DictSelection';
  14. import HeaderTitle from '@/components/header-title';
  15. import authSelection from '@/components/authSelection';
  16. import Vue2OrgTree from 'vue2-org-tree';
  17. import seekPage from '@/BIZComponents/seekPage';
  18. import clickOnce from './utils/clickOnce.js';
  19. import noChinese from './utils/noChinese.js';
  20. import { VirtualScroller } from 'vue-virtual-scroller';
  21. import LimitDirective from './plugins/limit-plugin'
  22. import 'vue-virtual-scroller/dist/vue-virtual-scroller.css';
  23. Vue.component('virtual-scroller', VirtualScroller);
  24. import { all, create } from 'mathjs'; // 引入mathjs工具并初始化
  25. // 注册全局自定义指令
  26. Vue.directive('click-once', clickOnce);
  27. Vue.directive('no-chinese', noChinese);
  28. Vue.component('HeaderTitle', HeaderTitle);
  29. Vue.component('authSelection', authSelection);
  30. // // register globally
  31. import '@/icons';
  32. Vue.component('DictSelection', DictSelection);
  33. Vue.component('seekPage', seekPage);
  34. Vue.config.productionTip = false;
  35. Vue.prototype.$math = create(all, {
  36. number: 'BigNumber',
  37. precision: 64
  38. });
  39. Vue.use(LimitDirective)
  40. Vue.use(Vue2OrgTree);
  41. Vue.use(EleAdmin, {
  42. response: {
  43. dataName: 'list'
  44. },
  45. mapKey: MAP_KEY,
  46. license: LICENSE_CODE,
  47. i18n: (key, value) => i18n.t(key, value)
  48. });
  49. Vue.use(permission);
  50. Vue.use(VueClipboard);
  51. let instance = null;
  52. // bpmnProcessDesigner 需要引入
  53. import MyPD from '@/components/bpmnProcessDesigner/package/index.js';
  54. Vue.use(MyPD);
  55. import paramsDataMixins from './mixins/paramsDataMixins';
  56. Vue.mixin(paramsDataMixins);
  57. import '@/components/bpmnProcessDesigner/package/theme/index.scss';
  58. import 'bpmn-js/dist/assets/diagram-js.css';
  59. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn.css';
  60. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css';
  61. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css';
  62. import fileMain from '@/components/addDoc/index.vue';
  63. import FormMaking from '../lib/vue-form-making/src/index';
  64. Vue.use(FormMaking, {
  65. lang: 'zh-CN',
  66. i18n: i18n
  67. });
  68. Vue.component('fileMain', fileMain);
  69. function render(props = {}) {
  70. const { container, routerBase } = props;
  71. // const router = new VueRouter({
  72. // base: window.__POWERED_BY_QIANKUN__ ? routerBase : process.env.BASE_URL,
  73. // mode: 'history',
  74. // routes
  75. // });
  76. instance = new Vue({
  77. router,
  78. store,
  79. i18n,
  80. render: (h) => h(App)
  81. }).$mount(container ? container.querySelector('#app') : '#app');
  82. }
  83. if (!window.__POWERED_BY_QIANKUN__) {
  84. // 这里是子应用独立运行的环境,实现子应用的登录逻辑
  85. render();
  86. }
  87. // window.location.reload()
  88. export async function bootstrap() {
  89. console.log('[vue] vue app bootstraped');
  90. }
  91. export async function mount(props) {
  92. console.log('[vue] props from main framework', props);
  93. Vue.prototype.$portalStore = props.store;
  94. initParentStore(props.store);
  95. props.onGlobalStateChange((state, prev) => {
  96. // state: 变更后的状态; prev 变更前的状态
  97. initParentStore(state);
  98. });
  99. render(props);
  100. }
  101. export async function unmount() {
  102. instance.$destroy();
  103. instance.$el.innerHTML = '';
  104. instance = null;
  105. }