You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

161 lines
5.7 KiB

  1. 'use strict'
  2. /* global $, siteRoot */
  3. /* eslint-disable no-new */
  4. import Vue from 'vue'
  5. import VueResource from 'vue-resource'
  6. import VueClipboards from 'vue-clipboards'
  7. import VueLodash from 'vue-lodash'
  8. import store from './store'
  9. import io from 'socket-io-client'
  10. import i18next from 'i18next'
  11. import i18nextXHR from 'i18next-xhr-backend'
  12. import VueI18Next from '@panter/vue-i18next'
  13. import 'jquery-contextmenu'
  14. import 'jquery-simple-upload'
  15. import 'jquery-smooth-scroll'
  16. import 'jquery-sticky'
  17. // ====================================
  18. // Load Helpers
  19. // ====================================
  20. import helpers from './helpers'
  21. import _ from './helpers/lodash'
  22. // ====================================
  23. // Load Vue Components
  24. // ====================================
  25. import alertComponent from './components/alert.vue'
  26. import anchorComponent from './components/anchor.vue'
  27. import colorPickerComponent from './components/color-picker.vue'
  28. import editorCodeblockComponent from './components/editor-codeblock.vue'
  29. import editorFileComponent from './components/editor-file.vue'
  30. import editorVideoComponent from './components/editor-video.vue'
  31. import historyComponent from './components/history.vue'
  32. import loadingSpinnerComponent from './components/loading-spinner.vue'
  33. import modalCreatePageComponent from './components/modal-create-page.vue'
  34. import modalCreateUserComponent from './components/modal-create-user.vue'
  35. import modalDeletePageComponent from './components/modal-delete-page.vue'
  36. import modalDeleteUserComponent from './components/modal-delete-user.vue'
  37. import modalDiscardPageComponent from './components/modal-discard-page.vue'
  38. import modalMovePageComponent from './components/modal-move-page.vue'
  39. import modalProfile2faComponent from './components/modal-profile-2fa.vue'
  40. import modalUpgradeSystemComponent from './components/modal-upgrade-system.vue'
  41. import pageLoaderComponent from './components/page-loader.vue'
  42. import searchComponent from './components/search.vue'
  43. import toggleComponent from './components/toggle.vue'
  44. import treeComponent from './components/tree.vue'
  45. import adminEditUserComponent from './pages/admin-edit-user.component.js'
  46. import adminProfileComponent from './pages/admin-profile.component.js'
  47. import adminSettingsComponent from './pages/admin-settings.component.js'
  48. import adminThemeComponent from './pages/admin-theme.component.js'
  49. import contentViewComponent from './pages/content-view.component.js'
  50. import editorComponent from './components/editor.component.js'
  51. import sourceViewComponent from './pages/source-view.component.js'
  52. // ====================================
  53. // Initialize Vue Modules
  54. // ====================================
  55. Vue.use(VueResource)
  56. Vue.use(VueClipboards)
  57. Vue.use(VueI18Next)
  58. Vue.use(VueLodash, _)
  59. Vue.use(helpers)
  60. // ====================================
  61. // Register Vue Components
  62. // ====================================
  63. Vue.component('alert', alertComponent)
  64. Vue.component('adminEditUser', adminEditUserComponent)
  65. Vue.component('adminProfile', adminProfileComponent)
  66. Vue.component('adminSettings', adminSettingsComponent)
  67. Vue.component('adminTheme', adminThemeComponent)
  68. Vue.component('anchor', anchorComponent)
  69. Vue.component('colorPicker', colorPickerComponent)
  70. Vue.component('contentView', contentViewComponent)
  71. Vue.component('editor', editorComponent)
  72. Vue.component('editorCodeblock', editorCodeblockComponent)
  73. Vue.component('editorFile', editorFileComponent)
  74. Vue.component('editorVideo', editorVideoComponent)
  75. Vue.component('history', historyComponent)
  76. Vue.component('loadingSpinner', loadingSpinnerComponent)
  77. Vue.component('modalCreatePage', modalCreatePageComponent)
  78. Vue.component('modalCreateUser', modalCreateUserComponent)
  79. Vue.component('modalDeletePage', modalDeletePageComponent)
  80. Vue.component('modalDeleteUser', modalDeleteUserComponent)
  81. Vue.component('modalDiscardPage', modalDiscardPageComponent)
  82. Vue.component('modalMovePage', modalMovePageComponent)
  83. Vue.component('modalProfile2fa', modalProfile2faComponent)
  84. Vue.component('modalUpgradeSystem', modalUpgradeSystemComponent)
  85. Vue.component('pageLoader', pageLoaderComponent)
  86. Vue.component('search', searchComponent)
  87. Vue.component('sourceView', sourceViewComponent)
  88. Vue.component('toggle', toggleComponent)
  89. Vue.component('tree', treeComponent)
  90. // ====================================
  91. // Load Localization strings
  92. // ====================================
  93. i18next
  94. .use(i18nextXHR)
  95. .init({
  96. backend: {
  97. loadPath: siteRoot + '/js/i18n/{{lng}}.json'
  98. },
  99. lng: siteLang,
  100. fallbackLng: siteLang
  101. })
  102. $(() => {
  103. // ====================================
  104. // Notifications
  105. // ====================================
  106. $(window).bind('beforeunload', () => {
  107. store.dispatch('startLoading')
  108. })
  109. $(document).ajaxSend(() => {
  110. store.dispatch('startLoading')
  111. }).ajaxComplete(() => {
  112. store.dispatch('stopLoading')
  113. })
  114. // ====================================
  115. // Establish WebSocket connection
  116. // ====================================
  117. let socket = io(window.location.origin)
  118. window.socket = socket
  119. // ====================================
  120. // Bootstrap Vue
  121. // ====================================
  122. const i18n = new VueI18Next(i18next)
  123. window.wikijs = new Vue({
  124. mixins: [helpers],
  125. components: {},
  126. store,
  127. i18n,
  128. el: '#root',
  129. methods: {
  130. changeTheme(opts) {
  131. this.$el.className = `has-stickynav is-primary-${opts.primary} is-alternate-${opts.alt}`
  132. this.$refs.header.className = `nav is-${opts.primary}`
  133. this.$refs.footer.className = `footer is-${opts.footer}`
  134. }
  135. },
  136. mounted() {
  137. $('a:not(.toc-anchor)').smoothScroll({ speed: 500, offset: -50 })
  138. $('#header').sticky({ topSpacing: 0 })
  139. $('.sidebar-pagecontents').sticky({ topSpacing: 15, bottomSpacing: 75 })
  140. }
  141. })
  142. })