mirror of
https://github.com/KevinMidboe/seasoned.git
synced 2026-03-11 03:49:07 +00:00
Add admin page with route configuration
This commit is contained in:
108
src/pages/AdminPage.vue
Normal file
108
src/pages/AdminPage.vue
Normal file
@@ -0,0 +1,108 @@
|
||||
<template>
|
||||
<section class="admin">
|
||||
<h1 class="admin__title">Admin Dashboard</h1>
|
||||
|
||||
<div class="admin__grid">
|
||||
<AdminStats class="admin__stats" />
|
||||
<SystemStatusPanel class="admin__system-status" />
|
||||
</div>
|
||||
|
||||
<div class="admin__torrents">
|
||||
<TorrentManagementGrid />
|
||||
</div>
|
||||
|
||||
<div class="admin__activity">
|
||||
<RecentActivityFeed />
|
||||
</div>
|
||||
</section>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import AdminStats from "@/components/admin/AdminStats.vue";
|
||||
import TorrentManagementGrid from "@/components/admin/TorrentManagementGrid.vue";
|
||||
import SystemStatusPanel from "@/components/admin/SystemStatusPanel.vue";
|
||||
import RecentActivityFeed from "@/components/admin/RecentActivityFeed.vue";
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
@import "scss/variables";
|
||||
@import "scss/media-queries";
|
||||
|
||||
.admin {
|
||||
padding: 3rem;
|
||||
max-width: 100%;
|
||||
overflow-x: hidden;
|
||||
|
||||
@include mobile-only {
|
||||
padding: 0.75rem;
|
||||
width: 100%;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
&__title {
|
||||
margin: 0 0 2rem 0;
|
||||
font-size: 2rem;
|
||||
font-weight: 300;
|
||||
color: $text-color;
|
||||
line-height: 1;
|
||||
|
||||
@include mobile-only {
|
||||
font-size: 1.5rem;
|
||||
margin: 0 0 1rem 0;
|
||||
}
|
||||
}
|
||||
|
||||
&__grid {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
gap: 1.5rem;
|
||||
margin-bottom: 1.5rem;
|
||||
|
||||
@include mobile-only {
|
||||
grid-template-columns: 1fr;
|
||||
gap: 1rem;
|
||||
margin-bottom: 1rem;
|
||||
}
|
||||
}
|
||||
|
||||
&__stats {
|
||||
grid-column: 1;
|
||||
min-width: 0;
|
||||
|
||||
@include mobile-only {
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
&__system-status {
|
||||
grid-column: 2;
|
||||
min-width: 0;
|
||||
|
||||
@include mobile-only {
|
||||
grid-column: 1;
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
&__torrents {
|
||||
margin-bottom: 1.5rem;
|
||||
min-width: 0;
|
||||
overflow-x: hidden;
|
||||
|
||||
@include mobile-only {
|
||||
margin-bottom: 1rem;
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
&__activity {
|
||||
margin-bottom: 1.5rem;
|
||||
min-width: 0;
|
||||
|
||||
@include mobile-only {
|
||||
margin-bottom: 1rem;
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@@ -4,7 +4,6 @@ import type { RouteRecordRaw, RouteLocationNormalized } from "vue-router";
|
||||
/* eslint-disable-next-line import-x/no-cycle */
|
||||
import store from "./store";
|
||||
import { usePlexAuth } from "./composables/usePlexAuth";
|
||||
|
||||
const { getPlexAuthCookie } = usePlexAuth();
|
||||
|
||||
declare global {
|
||||
@@ -80,6 +79,12 @@ const routes: RouteRecordRaw[] = [
|
||||
path: "/password",
|
||||
component: () => import("./pages/GenPasswordPage.vue")
|
||||
},
|
||||
{
|
||||
name: "admin",
|
||||
path: "/admin",
|
||||
meta: { requiresAuth: true },
|
||||
component: () => import("./pages/AdminPage.vue")
|
||||
},
|
||||
{
|
||||
name: "missing-plex-auth",
|
||||
path: "/missing/plex",
|
||||
|
||||
Reference in New Issue
Block a user