2020-06-23 13:44:14 +02:00
|
|
|
/*
|
|
|
|
|
|
|
|
Copyright (c) 2018 - 2020 Michael Mayer <hello@photoprism.org>
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
2020-09-21 02:48:22 +02:00
|
|
|
PhotoPrism® is a registered trademark of Michael Mayer. You may use it as required
|
2020-06-23 13:53:11 +02:00
|
|
|
to describe our software, run your own server, for educational purposes, but not for
|
|
|
|
offering commercial goods, products, or services without prior written permission.
|
|
|
|
In other words, please ask.
|
2020-06-23 13:44:14 +02:00
|
|
|
|
|
|
|
Feel free to send an e-mail to hello@photoprism.org if you have questions,
|
|
|
|
want to support our work, or just want to say hello.
|
|
|
|
|
|
|
|
Additional information can be found in our Developer Guide:
|
|
|
|
https://docs.photoprism.org/developer-guide/
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2020-06-22 20:15:08 +02:00
|
|
|
import "core-js/stable";
|
|
|
|
import "regenerator-runtime/runtime";
|
|
|
|
import Api from "common/api";
|
|
|
|
import Notify from "common/notify";
|
|
|
|
import Clipboard from "common/clipboard";
|
|
|
|
import Components from "share/components";
|
|
|
|
import Dialogs from "dialog/dialogs";
|
|
|
|
import Event from "pubsub-js";
|
|
|
|
import GetTextPlugin from "vue-gettext";
|
|
|
|
import Log from "common/log";
|
|
|
|
import PhotoPrism from "share.vue";
|
|
|
|
import Router from "vue-router";
|
|
|
|
import Routes from "share/routes";
|
|
|
|
import {config, session} from "session";
|
|
|
|
import {Settings} from "luxon";
|
|
|
|
import Socket from "common/websocket";
|
|
|
|
import Viewer from "common/viewer";
|
|
|
|
import Vue from "vue";
|
|
|
|
import Vuetify from "vuetify";
|
|
|
|
import VueLuxon from "vue-luxon";
|
|
|
|
import VueFilters from "vue2-filters";
|
|
|
|
import VueFullscreen from "vue-fullscreen";
|
|
|
|
import VueInfiniteScroll from "vue-infinite-scroll";
|
|
|
|
import VueModal from "vue-js-modal";
|
|
|
|
import Hls from "hls.js";
|
2020-07-03 16:27:26 +02:00
|
|
|
import {$gettext, Mount} from "common/vm";
|
2020-06-22 20:15:08 +02:00
|
|
|
|
|
|
|
// Initialize helpers
|
|
|
|
const viewer = new Viewer();
|
|
|
|
const clipboard = new Clipboard(window.localStorage, "photo_clipboard");
|
|
|
|
const isPublic = config.get("public");
|
2020-07-02 09:10:29 +02:00
|
|
|
const isMobile = (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent));
|
2020-06-22 20:15:08 +02:00
|
|
|
|
|
|
|
// HTTP Live Streaming (video support)
|
|
|
|
window.Hls = Hls;
|
|
|
|
|
|
|
|
// Assign helpers to VueJS prototype
|
|
|
|
Vue.prototype.$event = Event;
|
|
|
|
Vue.prototype.$notify = Notify;
|
|
|
|
Vue.prototype.$viewer = viewer;
|
|
|
|
Vue.prototype.$session = session;
|
|
|
|
Vue.prototype.$api = Api;
|
|
|
|
Vue.prototype.$log = Log;
|
|
|
|
Vue.prototype.$socket = Socket;
|
|
|
|
Vue.prototype.$config = config;
|
|
|
|
Vue.prototype.$clipboard = clipboard;
|
2020-07-02 09:10:29 +02:00
|
|
|
Vue.prototype.$isMobile = isMobile;
|
2020-06-22 20:15:08 +02:00
|
|
|
|
|
|
|
// Register Vuetify
|
|
|
|
Vue.use(Vuetify, {"theme": config.theme});
|
|
|
|
|
2020-12-13 14:53:26 +01:00
|
|
|
Vue.config.language = config.values.settings.ui.language;
|
|
|
|
Settings.defaultLocale = Vue.config.language;
|
2020-06-22 20:15:08 +02:00
|
|
|
|
|
|
|
// Register other VueJS plugins
|
|
|
|
Vue.use(GetTextPlugin, {
|
|
|
|
translations: config.translations,
|
|
|
|
silent: true, // !config.values.debug,
|
|
|
|
defaultLanguage: Vue.config.language,
|
|
|
|
autoAddKeyAttributes: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
Vue.use(VueLuxon);
|
|
|
|
Vue.use(VueInfiniteScroll);
|
|
|
|
Vue.use(VueFullscreen);
|
2020-07-02 14:09:02 +02:00
|
|
|
Vue.use(VueModal, {dynamic: true, dynamicDefaults: {clickToClose: true}});
|
2020-06-22 20:15:08 +02:00
|
|
|
Vue.use(VueFilters);
|
|
|
|
Vue.use(Components);
|
|
|
|
Vue.use(Dialogs);
|
|
|
|
Vue.use(Router);
|
|
|
|
|
|
|
|
// Configure client-side routing
|
|
|
|
const router = new Router({
|
|
|
|
routes: Routes,
|
|
|
|
mode: "history",
|
|
|
|
saveScrollPosition: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
router.beforeEach((to, from, next) => {
|
|
|
|
if (to.matched.some(record => record.meta.admin)) {
|
|
|
|
if (isPublic || session.isAdmin()) {
|
|
|
|
next();
|
|
|
|
} else {
|
|
|
|
next({
|
|
|
|
name: "login",
|
|
|
|
params: {nextUrl: to.fullPath},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else if (to.matched.some(record => record.meta.auth)) {
|
|
|
|
if (isPublic || session.isUser()) {
|
|
|
|
next();
|
|
|
|
} else {
|
|
|
|
next({
|
|
|
|
name: "login",
|
|
|
|
params: {nextUrl: to.fullPath},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
next();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
router.afterEach((to) => {
|
2020-07-03 16:27:26 +02:00
|
|
|
if (to.meta.title && config.values.siteTitle !== to.meta.title) {
|
|
|
|
config.page.title = $gettext(to.meta.title);
|
|
|
|
window.document.title = config.page.title;
|
2020-06-22 20:15:08 +02:00
|
|
|
} else {
|
2020-07-03 16:27:26 +02:00
|
|
|
config.page.title = config.values.siteTitle;
|
2020-06-27 09:28:32 +02:00
|
|
|
window.document.title = config.values.siteTitle;
|
2020-06-22 20:15:08 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2020-07-02 09:10:29 +02:00
|
|
|
// Pull client config every 10 minutes in case push fails (except on mobile to save battery).
|
2020-07-02 14:09:02 +02:00
|
|
|
if (isMobile) {
|
2020-07-02 09:10:29 +02:00
|
|
|
document.body.classList.add("mobile");
|
|
|
|
} else {
|
|
|
|
setInterval(() => config.update(), 600000);
|
|
|
|
}
|
|
|
|
|
2020-07-02 14:09:02 +02:00
|
|
|
// Start application.
|
|
|
|
Mount(Vue, PhotoPrism, router);
|