2021-12-09 11:53:54 +00:00
|
|
|
<script lang="ts">
|
2021-12-12 09:31:08 +00:00
|
|
|
import { Router, Route } from "svelte-navigator";
|
2022-11-26 12:23:59 +00:00
|
|
|
import Navigation from "./components/common/Navigation.svelte";
|
2022-11-28 06:30:25 +00:00
|
|
|
import Dash from "./routes/Dash/Dash.svelte";
|
2022-11-26 12:23:59 +00:00
|
|
|
import Home from "./routes/Home.svelte";
|
2022-11-28 06:30:25 +00:00
|
|
|
import Settings from './routes/Settings/Settings.svelte';
|
2022-11-26 12:23:59 +00:00
|
|
|
import Public from "./routes/Public.svelte";
|
2022-11-28 06:30:25 +00:00
|
|
|
import Main from "./routes/Dash/Profile.svelte";
|
2022-11-28 06:34:48 +00:00
|
|
|
import Status from './routes/Status/Status.svelte';
|
|
|
|
import Member from './routes/Dash/Member/Member.svelte';
|
|
|
|
import Group from './routes/Dash/Group/Group.svelte';
|
2022-11-26 12:23:59 +00:00
|
|
|
import PageNotFound from './routes/PageNotFound.svelte';
|
2022-03-19 12:10:14 +00:00
|
|
|
import { Alert } from 'sveltestrap';
|
2022-11-26 12:23:59 +00:00
|
|
|
import DiscordLogin from "./routes/DiscordLogin.svelte";
|
2022-04-07 17:33:11 +00:00
|
|
|
import { onMount } from 'svelte';
|
2022-11-28 06:30:25 +00:00
|
|
|
import BulkGroupPrivacy from "./routes/Dash/System/BulkGroupPrivacy.svelte";
|
|
|
|
import BulkMemberPrivacy from "./routes/Dash/System/BulkMemberPrivacy.svelte";
|
|
|
|
import Random from './routes/Dash/Random.svelte';
|
2021-12-09 12:56:06 +00:00
|
|
|
|
2021-12-11 10:58:50 +00:00
|
|
|
// theme cdns (I might make some myself too)
|
2021-12-11 11:00:38 +00:00
|
|
|
// if there's a style already set, retrieve it
|
|
|
|
let style = localStorage.getItem("pk-style") && localStorage.getItem("pk-style");
|
2021-12-09 12:56:06 +00:00
|
|
|
|
2021-12-11 11:00:38 +00:00
|
|
|
// this automatically applies the style every time it is updated
|
|
|
|
$: setStyle(style);
|
2021-12-09 11:53:54 +00:00
|
|
|
|
2021-12-11 11:00:38 +00:00
|
|
|
// not sure if there's a better way to handle this
|
2021-12-09 11:53:54 +00:00
|
|
|
function setStyle(style) {
|
|
|
|
switch (style) {
|
2022-06-03 12:24:54 +00:00
|
|
|
case "light": document.documentElement.className = "light";
|
2021-12-09 11:53:54 +00:00
|
|
|
localStorage.setItem("pk-style", "light");
|
|
|
|
break;
|
2022-06-03 12:24:54 +00:00
|
|
|
case "dark": document.documentElement.className = "dark";
|
2021-12-09 11:53:54 +00:00
|
|
|
localStorage.setItem("pk-style", "dark");
|
|
|
|
break;
|
2022-06-03 12:24:54 +00:00
|
|
|
default: document.documentElement.className = "dark";
|
2021-12-11 10:58:50 +00:00
|
|
|
localStorage.setItem("pk-style", "dark");
|
2022-06-03 12:24:54 +00:00
|
|
|
break;
|
2021-12-09 11:53:54 +00:00
|
|
|
};
|
|
|
|
};
|
2022-03-19 09:17:29 +00:00
|
|
|
|
2022-04-07 17:33:11 +00:00
|
|
|
onMount(() => {
|
|
|
|
let settings = JSON.parse(localStorage.getItem("pk-settings"));
|
|
|
|
|
2022-04-25 17:10:17 +00:00
|
|
|
if (settings && settings.accessibility && settings.accessibility.opendyslexic === true) {
|
2022-04-07 17:33:11 +00:00
|
|
|
document.getElementById("app").classList.add("dyslexic");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-12-09 11:53:54 +00:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<Router>
|
2021-12-11 11:00:38 +00:00
|
|
|
<Navigation bind:style={style}/>
|
2021-12-12 09:31:08 +00:00
|
|
|
<Route path="/"><Home /></Route>
|
2022-04-07 13:22:35 +00:00
|
|
|
<Route path="/login/discord"><DiscordLogin /></Route>
|
2021-12-12 13:32:58 +00:00
|
|
|
<Route path="dash"><Dash /></Route>
|
2022-06-26 22:28:40 +00:00
|
|
|
<Route path="dash/m/:id"><Member isPublic={false}/></Route>
|
|
|
|
<Route path = "dash/g/:id"><Group isPublic={false}/></Route>
|
|
|
|
<Route path="dash/random"><Random isPublic={false} type={"member"}/></Route>
|
|
|
|
<Route path="dash/random/m"><Random isPublic={false} type={"member"}/></Route>
|
|
|
|
<Route path="dash/random/g"><Random isPublic={false} type={"group"}/></Route>
|
|
|
|
<Route path="dash/g/:groupId/random"><Random isPublic={false} type={"member"} pickFromGroup={true}/></Route>
|
2022-05-09 21:15:00 +00:00
|
|
|
<Route path="dash/bulk-member-privacy"><BulkMemberPrivacy/></Route>
|
|
|
|
<Route path="dash/bulk-group-privacy"><BulkGroupPrivacy/></Route>
|
2021-12-12 13:32:58 +00:00
|
|
|
<Route path="settings"><Settings /></Route>
|
2021-12-15 12:51:50 +00:00
|
|
|
<Route path="profile"><Public /></Route>
|
|
|
|
<Route path = "profile/s/:id"><Main /></Route>
|
2022-06-26 22:28:40 +00:00
|
|
|
<Route path = "profile/s">
|
2022-03-19 12:10:14 +00:00
|
|
|
<Alert color="danger">Please provide a system ID in the URL.</Alert>
|
2021-12-15 12:51:50 +00:00
|
|
|
</Route>
|
2022-06-26 22:28:40 +00:00
|
|
|
<Route path="profile/s/:id/random"><Random isPublic={true} type={"member"}/></Route>
|
|
|
|
<Route path="profile/s/:id/random/m"><Random isPublic={true} type={"member"}/></Route>
|
|
|
|
<Route path="profile/s/:id/random/g"><Random isPublic={true} type={"group"}/></Route>
|
2022-03-19 09:17:29 +00:00
|
|
|
<Route path = "profile/m/:id"><Member/></Route>
|
2021-12-15 12:51:50 +00:00
|
|
|
<Route path = "profile/m">
|
2022-03-19 12:10:14 +00:00
|
|
|
<Alert color="danger">Please provide a member ID in the URL.</Alert>
|
2021-12-15 12:51:50 +00:00
|
|
|
</Route>
|
2022-03-19 12:10:14 +00:00
|
|
|
<Route path = "profile/g/:id"><Group/></Route>
|
2022-06-26 22:28:40 +00:00
|
|
|
<Route path="profile/g/:groupId/random"><Random isPublic={true} type={"member"} pickFromGroup={true}/></Route>
|
2021-12-15 12:51:50 +00:00
|
|
|
<Route path = "profile/g">
|
2022-03-19 12:10:14 +00:00
|
|
|
<Alert color="danger">Please provide a group ID in the URL.</Alert>
|
2021-12-11 14:56:47 +00:00
|
|
|
</Route>
|
2022-01-12 03:09:50 +00:00
|
|
|
<Route path="status"><Status /></Route>
|
2022-04-25 18:44:40 +00:00
|
|
|
<Route component={PageNotFound}/>
|
2021-12-09 11:53:54 +00:00
|
|
|
</Router>
|