app.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. 'use strict'
  2. /* global siteLang */
  3. /* eslint-disable no-new */
  4. import $ from 'jquery'
  5. import _ from 'lodash'
  6. import Vue from 'vue'
  7. import VueResource from 'vue-resource'
  8. import VueClipboards from 'vue-clipboards'
  9. import VueLodash from 'vue-lodash'
  10. import store from './store'
  11. import io from 'socket-io-client'
  12. import i18next from 'i18next'
  13. import i18nextXHR from 'i18next-xhr-backend'
  14. import VueI18Next from '@panter/vue-i18next'
  15. import 'jquery-smooth-scroll'
  16. import 'jquery-sticky'
  17. // ====================================
  18. // Load Helpers
  19. // ====================================
  20. import helpers from './helpers'
  21. // ====================================
  22. // Load Vue Components
  23. // ====================================
  24. import alertComponent from './components/alert.vue'
  25. import anchorComponent from './components/anchor.vue'
  26. import colorPickerComponent from './components/color-picker.vue'
  27. import loadingSpinnerComponent from './components/loading-spinner.vue'
  28. import modalCreatePageComponent from './components/modal-create-page.vue'
  29. import modalCreateUserComponent from './components/modal-create-user.vue'
  30. import modalDiscardPageComponent from './components/modal-discard-page.vue'
  31. import modalMovePageComponent from './components/modal-move-page.vue'
  32. import pageLoaderComponent from './components/page-loader.vue'
  33. import searchComponent from './components/search.vue'
  34. import treeComponent from './components/tree.vue'
  35. import adminProfileComponent from './pages/admin-profile.component.js'
  36. import adminSettingsComponent from './pages/admin-settings.component.js'
  37. import contentViewComponent from './pages/content-view.component.js'
  38. import editorComponent from './components/editor.component.js'
  39. import sourceViewComponent from './pages/source-view.component.js'
  40. // ====================================
  41. // Initialize Vue Modules
  42. // ====================================
  43. Vue.use(VueResource)
  44. Vue.use(VueClipboards)
  45. Vue.use(VueI18Next)
  46. Vue.use(VueLodash, _)
  47. Vue.use(helpers)
  48. i18next
  49. .use(i18nextXHR)
  50. .init({
  51. backend: {
  52. loadPath: '/js/i18n/{{lng}}.json'
  53. },
  54. lng: siteLang,
  55. fallbackLng: siteLang
  56. })
  57. $(() => {
  58. // ====================================
  59. // Notifications
  60. // ====================================
  61. $(window).bind('beforeunload', () => {
  62. store.dispatch('startLoading')
  63. })
  64. $(document).ajaxSend(() => {
  65. store.dispatch('startLoading')
  66. }).ajaxComplete(() => {
  67. store.dispatch('stopLoading')
  68. })
  69. // ====================================
  70. // Establish WebSocket connection
  71. // ====================================
  72. let socket = io(window.location.origin)
  73. window.socket = socket
  74. // ====================================
  75. // Bootstrap Vue
  76. // ====================================
  77. const i18n = new VueI18Next(i18next)
  78. new Vue({
  79. mixins: [helpers],
  80. components: {
  81. alert: alertComponent,
  82. adminProfile: adminProfileComponent,
  83. adminSettings: adminSettingsComponent,
  84. anchor: anchorComponent,
  85. colorPicker: colorPickerComponent,
  86. contentView: contentViewComponent,
  87. editor: editorComponent,
  88. loadingSpinner: loadingSpinnerComponent,
  89. modalCreatePage: modalCreatePageComponent,
  90. modalCreateUser: modalCreateUserComponent,
  91. modalDiscardPage: modalDiscardPageComponent,
  92. modalMovePage: modalMovePageComponent,
  93. pageLoader: pageLoaderComponent,
  94. search: searchComponent,
  95. sourceView: sourceViewComponent,
  96. tree: treeComponent
  97. },
  98. store,
  99. i18n,
  100. el: '#root',
  101. mounted() {
  102. $('a:not(.toc-anchor)').smoothScroll({ speed: 500, offset: -50 })
  103. $('#header').sticky({ topSpacing: 0 })
  104. $('.sidebar-pagecontents').sticky({ topSpacing: 15, bottomSpacing: 75 })
  105. }
  106. })
  107. })