149 lines
3.6 KiB
TypeScript
149 lines
3.6 KiB
TypeScript
/**
|
|
* @copyright Copyright (c) 2018 John Molakvoæ <skjnldsv@protonmail.com>
|
|
*
|
|
* @author John Molakvoæ <skjnldsv@protonmail.com>
|
|
*
|
|
* @license AGPL-3.0-or-later
|
|
*
|
|
* 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 <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
import { generateUrl } from "@nextcloud/router";
|
|
import { translate as t, translatePlural as n } from "@nextcloud/l10n";
|
|
import Router from "vue-router";
|
|
import Vue from "vue";
|
|
import Timeline from "./components/Timeline.vue";
|
|
|
|
Vue.use(Router);
|
|
|
|
/**
|
|
* Parse the path of a route : join the elements of the array and return a single string with slashes
|
|
* + always lead current path with a slash
|
|
*
|
|
* @param {string | Array} path path arguments to parse
|
|
* @return {string}
|
|
*/
|
|
const parsePathParams = (path) => {
|
|
return `/${Array.isArray(path) ? path.join("/") : path || ""}`;
|
|
};
|
|
|
|
export default new Router({
|
|
mode: "history",
|
|
// if index.php is in the url AND we got this far, then it's working:
|
|
// let's keep using index.php in the url
|
|
base: generateUrl("/apps/memories"),
|
|
linkActiveClass: "active",
|
|
routes: [
|
|
{
|
|
path: "/",
|
|
component: Timeline,
|
|
name: "timeline",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Timeline"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/folders/:path*",
|
|
component: Timeline,
|
|
name: "folders",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Folders"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/favorites",
|
|
component: Timeline,
|
|
name: "favorites",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Favorites"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/videos",
|
|
component: Timeline,
|
|
name: "videos",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Videos"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/albums/:user?/:name?",
|
|
component: Timeline,
|
|
name: "albums",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Albums"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/archive",
|
|
component: Timeline,
|
|
name: "archive",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Archive"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/thisday",
|
|
component: Timeline,
|
|
name: "thisday",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "On this day"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/people/:user?/:name?",
|
|
component: Timeline,
|
|
name: "people",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "People"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/tags/:name*",
|
|
component: Timeline,
|
|
name: "tags",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Tags"),
|
|
}),
|
|
},
|
|
|
|
{
|
|
path: "/maps",
|
|
name: "maps",
|
|
// router-link doesn't support external url, let's force the redirect
|
|
beforeEnter() {
|
|
window.open(generateUrl("/apps/maps"), "_blank");
|
|
},
|
|
},
|
|
|
|
{
|
|
path: "/s/:token",
|
|
component: Timeline,
|
|
name: "folder-share",
|
|
props: (route) => ({
|
|
rootTitle: t("memories", "Shared Folder"),
|
|
}),
|
|
},
|
|
],
|
|
});
|