]> BookStack Code Mirror - bookstack/blobdiff - resources/js/app.js
Adapt tests with displayName array
[bookstack] / resources / js / app.js
index 82748b75e223c2f21612a2662bc2fad22c23b6c0..5f4902f866f70b55af84ef7eb6ae6309c0bbe0d3 100644 (file)
@@ -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();