entry.js 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. import Vue from 'vue';
  2. import entry from './app';
  3. import VueRouter from 'vue-router';
  4. import Element from 'main/index.js';
  5. import hljs from 'highlight.js';
  6. import routes from './route.config';
  7. import demoBlock from './components/demo-block';
  8. import MainFooter from './components/footer';
  9. import MainHeader from './components/header';
  10. import SideNav from './components/side-nav';
  11. import FooterNav from './components/footer-nav';
  12. import title from './i18n/title';
  13. import 'packages/theme-chalk/src/index.scss';
  14. import './demo-styles/index.scss';
  15. import './assets/styles/common.css';
  16. import './assets/styles/fonts/style.css';
  17. import icon from './icon.json';
  18. Vue.use(Element);
  19. Vue.use(VueRouter);
  20. Vue.component('demo-block', demoBlock);
  21. Vue.component('main-footer', MainFooter);
  22. Vue.component('main-header', MainHeader);
  23. Vue.component('side-nav', SideNav);
  24. Vue.component('footer-nav', FooterNav);
  25. const globalEle = new Vue({
  26. data: { $isEle: false } // 是否 ele 用户
  27. });
  28. Vue.mixin({
  29. computed: {
  30. $isEle: {
  31. get: () => (globalEle.$data.$isEle),
  32. set: (data) => {globalEle.$data.$isEle = data;}
  33. }
  34. }
  35. });
  36. Vue.prototype.$icon = icon; // Icon 列表页用
  37. const router = new VueRouter({
  38. mode: 'hash',
  39. base: __dirname,
  40. routes
  41. });
  42. router.afterEach(route => {
  43. // https://github.com/highlightjs/highlight.js/issues/909#issuecomment-131686186
  44. Vue.nextTick(() => {
  45. const blocks = document.querySelectorAll('pre code:not(.hljs)');
  46. Array.prototype.forEach.call(blocks, hljs.highlightBlock);
  47. });
  48. const data = title[route.meta.lang];
  49. for (let val in data) {
  50. if (new RegExp('^' + val, 'g').test(route.name)) {
  51. document.title = data[val];
  52. return;
  53. }
  54. }
  55. document.title = 'Element';
  56. ga('send', 'event', 'PageView', route.name);
  57. });
  58. new Vue({ // eslint-disable-line
  59. ...entry,
  60. router
  61. }).$mount('#app');