123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- 'use strict'
- /* global alertsData, siteLang */
- /* eslint-disable no-new */
- import $ from 'jquery'
- import _ from 'lodash'
- import Vue from 'vue'
- import VueResource from 'vue-resource'
- import store from './store'
- import io from 'socket.io-client'
- import i18next from 'i18next'
- import i18nextXHR from 'i18next-xhr-backend'
- import VueI18Next from '@panter/vue-i18next'
- // import Alerts from './components/alerts.js'
- import 'jquery-smooth-scroll'
- import 'jquery-sticky'
- // ====================================
- // Load Vue Components
- // ====================================
- import alertComponent from './components/alert.vue'
- import anchorComponent from './components/anchor.vue'
- import colorPickerComponent from './components/color-picker.vue'
- import loadingSpinnerComponent from './components/loading-spinner.vue'
- import searchComponent from './components/search.vue'
- import adminUsersCreateComponent from './modals/admin-users-create.vue'
- import adminProfileComponent from './pages/admin-profile.component.js'
- import adminSettingsComponent from './pages/admin-settings.component.js'
- // ====================================
- // Initialize Vue Modules
- // ====================================
- Vue.use(VueResource)
- Vue.use(VueI18Next)
- i18next
- .use(i18nextXHR)
- .init({
- backend: {
- loadPath: '/js/i18n/{{lng}}.json'
- },
- lng: siteLang,
- fallbackLng: siteLang
- })
- $(() => {
- // ====================================
- // Notifications
- // ====================================
- $(window).bind('beforeunload', () => {
- store.dispatch('startLoading')
- })
- $(document).ajaxSend(() => {
- store.dispatch('startLoading')
- }).ajaxComplete(() => {
- store.dispatch('stopLoading')
- })
- var alerts = {}
- /*var alerts = new Alerts()
- if (alertsData) {
- _.forEach(alertsData, (alertRow) => {
- alerts.push(alertRow)
- })
- }*/
- // ====================================
- // Establish WebSocket connection
- // ====================================
- let socket = io(window.location.origin)
- window.socket = socket
- // ====================================
- // Bootstrap Vue
- // ====================================
- const i18n = new VueI18Next(i18next)
- new Vue({
- components: {
- alert: alertComponent,
- adminProfile: adminProfileComponent,
- adminSettings: adminSettingsComponent,
- adminUsersCreate: adminUsersCreateComponent,
- anchor: anchorComponent,
- colorPicker: colorPickerComponent,
- loadingSpinner: loadingSpinnerComponent,
- search: searchComponent
- },
- directives: {
- // sticky: VueSticky
- },
- store,
- i18n,
- el: '#root',
- mounted() {
- $('a').smoothScroll({
- speed: 500,
- offset: -50
- })
- $('#header').sticky({ topSpacing: 0 })
- $('.sidebar-pagecontents').sticky({ topSpacing: 15, bottomSpacing: 75 })
- // ====================================
- // Pages logic
- // ====================================
- require('./pages/view.js')(alerts)
- require('./pages/all.js')(alerts, socket)
- require('./pages/create.js')(alerts, socket)
- require('./pages/edit.js')(alerts, socket)
- require('./pages/source.js')(alerts)
- require('./pages/history.js')(alerts)
- require('./pages/admin.js')(alerts)
- }
- })
- })
|