main.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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 { LICENSE_CODE, MAP_KEY } 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 '@/components/FormGenerator/styles/index.scss';
  14. import DictSelection from '@/components/Dict/DictSelection';
  15. import elTableInfiniteScroll from 'el-table-infinite-scroll';
  16. import lodash from 'lodash';
  17. import processSubmitDialog from '@/BIZComponents/processSubmitDialog/processSubmitDialog.vue';
  18. // import tinymce from '@/components/FormGenerator/components/tinymce/index.js';
  19. // import TinymceEditor from '@/components/TinymceEditor/index.vue';
  20. // import SvgIcon from '@/components/FormGenerator/components/SvgIcon'; // svg component
  21. import HeaderTitle from '@/components/header-title';
  22. import { all, create } from 'mathjs'; // 引入mathjs工具并初始化
  23. // // register globally
  24. // Vue.component('tinymce', TinymceEditor);
  25. import '@/icons';
  26. // bpmnProcessDesigner 需要引入
  27. import MyPD from '@/components/bpmnProcessDesigner/package/index.js';
  28. import '@/components/bpmnProcessDesigner/package/theme/index.scss';
  29. import 'bpmn-js/dist/assets/diagram-js.css';
  30. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn.css';
  31. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css';
  32. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css';
  33. import FormMaking from '../lib/vue-form-making/src/index';
  34. import '@/assets/font_icon/iconfont.css';
  35. import fileMain from '@/components/addDoc/index.vue';
  36. import './directives';
  37. import seekPage from '@/BIZComponents/seekPage';
  38. Vue.component('seekPage', seekPage);
  39. import clickOnce from './utils/clickOnce.js';
  40. Vue.directive('click-once', clickOnce);
  41. import Tooltip from './utils/tooltip'; // 引入封装的工具
  42. Vue.prototype.$tooltip = Tooltip;
  43. Vue.use(elTableInfiniteScroll);
  44. Vue.component('HeaderTitle', HeaderTitle);
  45. Vue.component('fileMain', fileMain);
  46. Vue.component('processSubmitDialog', processSubmitDialog);
  47. const config = {
  48. number: 'BigNumber',
  49. precision: 64
  50. };
  51. Vue.prototype.$math = create(all, config);
  52. Vue.use(MyPD);
  53. Vue.use(FormMaking, {
  54. lang: 'zh-CN',
  55. i18n: i18n
  56. });
  57. Vue.component('DictSelection', DictSelection);
  58. Vue.config.productionTip = false;
  59. Vue.prototype._ = lodash;
  60. // 表单重置
  61. Vue.prototype.resetForm = function resetForm(refName) {
  62. if (this.$refs[refName]) {
  63. this.$refs[refName].resetFields();
  64. }
  65. };
  66. Vue.use(EleAdmin, {
  67. response: {
  68. dataName: 'list'
  69. },
  70. mapKey: MAP_KEY,
  71. license: LICENSE_CODE,
  72. i18n: (key, value) => i18n.t(key, value)
  73. });
  74. Vue.use(permission);
  75. Vue.use(VueClipboard);
  76. // new Vue({
  77. // router,
  78. // store,
  79. // i18n,
  80. // render: (h) => h(App)
  81. // }).$mount('#app');
  82. let instance = null;
  83. function render(props = {}) {
  84. const { container, routerBase } = props;
  85. // Vue.component('fileMain', fileMain);
  86. // const router = new VueRouter({
  87. // base: window.__POWERED_BY_QIANKUN__ ? routerBase : process.env.BASE_URL,
  88. // mode: 'history',
  89. // routes
  90. // });
  91. instance = new Vue({
  92. router,
  93. store,
  94. i18n,
  95. render: (h) => h(App)
  96. }).$mount(container ? container.querySelector('#app') : '#app');
  97. }
  98. if (!window.__POWERED_BY_QIANKUN__) {
  99. // 这里是子应用独立运行的环境,实现子应用的登录逻辑
  100. render();
  101. }
  102. export async function bootstrap() {
  103. console.log('[vue] vue app bootstraped');
  104. }
  105. export async function mount(props) {
  106. console.log('[vue] props from main framework', props);
  107. Vue.prototype.$portalStore = props.store;
  108. initParentStore(props.store);
  109. // initParentStore(props.store?.state);
  110. props.onGlobalStateChange((state, prev) => {
  111. // state: 变更后的状态; prev 变更前的状态
  112. initParentStore(state);
  113. });
  114. render(props);
  115. }
  116. export async function unmount() {
  117. instance.$destroy();
  118. instance.$el.innerHTML = '';
  119. instance = null;
  120. }