X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/c6ad16dba657c82512ae495a4a38b99b8cfa9eeb..refs/pull/5280/head:/resources/js/app.js diff --git a/resources/js/app.js b/resources/js/app.js index 82748b75e..5f4902f86 100644 --- a/resources/js/app.js +++ b/resources/js/app.js @@ -1,31 +1,33 @@ +import {EventManager} from './services/events.ts'; +import {HttpManager} from './services/http.ts'; +import {Translator} from './services/translations.ts'; +import * as componentMap from './components'; +import {ComponentStore} from './services/components.ts'; + +// eslint-disable-next-line no-underscore-dangle +window.__DEV__ = false; + // Url retrieval function -window.baseUrl = function(path) { +window.baseUrl = function baseUrl(path) { + let targetPath = path; let basePath = document.querySelector('meta[name="base-url"]').getAttribute('content'); - if (basePath[basePath.length-1] === '/') basePath = basePath.slice(0, basePath.length-1); - if (path[0] === '/') path = path.slice(1); - return basePath + '/' + path; + if (basePath[basePath.length - 1] === '/') basePath = basePath.slice(0, basePath.length - 1); + if (targetPath[0] === '/') targetPath = targetPath.slice(1); + return `${basePath}/${targetPath}`; }; -window.importVersioned = function(moduleName) { +window.importVersioned = function importVersioned(moduleName) { const version = document.querySelector('link[href*="/dist/styles.css?version="]').href.split('?version=').pop(); const importPath = window.baseUrl(`dist/${moduleName}.js?version=${version}`); return import(importPath); }; -// Set events and http services on window -import events from "./services/events" -import httpInstance from "./services/http" -window.$http = httpInstance; -window.$events = events; - -// Translation setup -// Creates a global function with name 'trans' to be used in the same way as Laravel's translation system -import Translations from "./services/translations" -const translator = new Translations(); -window.trans = translator.get.bind(translator); -window.trans_choice = translator.getPlural.bind(translator); -window.trans_plural = translator.parsePlural.bind(translator); +// Set events, http & translation services on window +window.$http = new HttpManager(); +window.$events = new EventManager(); +window.$trans = new Translator(); -// Load Components -import components from "./components" -components(); \ No newline at end of file +// Load & initialise components +window.$components = new ComponentStore(); +window.$components.register(componentMap); +window.$components.init();