added page and edit backend for edit calendar by token

This commit is contained in:
masterelmar
2023-10-17 11:01:26 +02:00
parent 01e32448c9
commit 0923d51b7e
11 changed files with 512 additions and 4 deletions

View File

@@ -1,4 +1,4 @@
import { Module } from "../model/module.ts";
import { Module } from "../model/module";
export async function fetchModule( name: string): Promise<Module> {
const request = new Request("/api/module", {

View File

@@ -0,0 +1,16 @@
import { Module } from "../model/module";
import { Calendar } from "../model/calendar";
export async function getCalender( token: string): Promise<Module[]> {
const request = new Request("/api/collections/feeds/records/" + token, {
method: "GET",
});
return await fetch(request)
.then((response) => {
return response.json();
})
.then(
(calendarResponse: Calendar) => calendarResponse.modules
);
}

View File

@@ -7,6 +7,11 @@ const items = ref([
icon: "pi pi-fw pi-plus",
url: "/",
},
{
label: "Edit Calendar",
icon: "pi pi-fw pi-pencil",
url: "/edit",
},
{
label: "FAQ",
icon: "pi pi-fw pi-book",

View File

@@ -0,0 +1,38 @@
<script setup lang="ts">
import { ref, Ref } from "vue";
import moduleStore from "../../store/moduleStore";
import { getCalender } from "../../api/loadCalendar";
const token: Ref<string> = ref("");
function loadCalendar() {
moduleStore().removeAllModules();
getCalender(token.value).then((data) => {
console.log(data);
data.forEach((module) => {
moduleStore().addModule(module);
});
});
}
</script>
<template>
<div class="flex flex-column">
<div class="flex align-items-center justify-content-center h-4rem border-round">
<p class="text-2xl">Please enter your existing calendar token</p>
</div>
<div class="flex align-items-center justify-content-center border-round m-2">
<InputText type="text" v-model="token" />
</div>
<div class="flex align-items-center justify-content-center border-round m-2">
<Button label="Load Calendar" @click="loadCalendar" />
</div>
</div>
</template>
<style scoped>
</style>

View File

@@ -0,0 +1,10 @@
import { Module } from "./module";
export type Calendar = {
collectionId: string;
collectionName: string;
created: string;
id: string;
modules: Module[];
updated: string;
}

View File

@@ -6,6 +6,7 @@ import CalendarLink from "../components/CalendarLink.vue";
import Imprint from "../components/Imprint.vue";
import PrivacyPolicy from "../components/PrivacyPolicy.vue";
import RenameModules from "../components/RenameModules.vue";
import EditCalendarView from "../view/editCalendarView.vue";
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
@@ -30,6 +31,11 @@ const router = createRouter({
name: "calendar-link",
component: CalendarLink,
},
{
path: "/edit",
name: "edit",
component: EditCalendarView,
},
{
path: "/privacy-policy",
name: "privacy-policy",

View File

@@ -12,6 +12,9 @@ const moduleStore = defineStore("moduleStore", {
removeModule(module: Module) {
this.modules.splice(this.modules.indexOf(module), 1);
},
removeAllModules() {
this.modules = [];
}
},
});

View File

@@ -0,0 +1,22 @@
<script setup lang="ts">
import LoadCalender from "../components/editCalendar/loadCalender.vue";
</script>
<template>
<div class="flex flex-column">
<div class="flex align-items-center justify-content-center h-4rem mt-2">
<h3 class="text-2xl">Edit your HTWKalender <i class="pi pi-calendar vertical-align-baseline" style="font-size: 2rem"></i></h3>
</div>
<div class="flex align-items-center justify-content-center">
<LoadCalender />
</div>
</div>
</template>
<style scoped>
</style>