Page Menu
Home
DevCentral
Search
Configure Global Search
Log In
Files
F3763034
D3205.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
23 KB
Referenced Files
None
Subscribers
None
D3205.diff
View Options
diff --git a/backend/servpulse-backend/app.js b/backend/servpulse-backend/app.js
--- a/backend/servpulse-backend/app.js
+++ b/backend/servpulse-backend/app.js
@@ -18,10 +18,12 @@
// Import routes
const serviceRoutes = require('./routes/serviceRoutes.js');
const incidentRoutes = require('./routes/incidentRoutes.js');
+const configRoutes = require('./routes/configRoutes.js');
// Use the routes
app.use('/api', serviceRoutes);
app.use('/api', incidentRoutes);
+app.use('/api', configRoutes);
// Start the server
const PORT = process.env.EXPRESS_PORT || 3000;
diff --git a/backend/servpulse-backend/config/app.json b/backend/servpulse-backend/config/app.json
new file mode 100644
--- /dev/null
+++ b/backend/servpulse-backend/config/app.json
@@ -0,0 +1,15 @@
+{
+ "navbar": {
+ "title": "ServPulse",
+ "button_left": {
+ "name": "DevCentral",
+ "icon": "fa fa-play",
+ "link": "https://devcentral.nasqueron.org"
+ },
+ "button_right": {
+ "name": "Agora",
+ "icon": "fa fa-book",
+ "link": "https://agora.nasqueron.org"
+ }
+ }
+}
diff --git a/backend/servpulse-backend/controllers/configController.js b/backend/servpulse-backend/controllers/configController.js
new file mode 100644
--- /dev/null
+++ b/backend/servpulse-backend/controllers/configController.js
@@ -0,0 +1,12 @@
+const configModel = require('../models/configModel.js');
+
+const getConfig = async (req, res) => {
+ try {
+ const config = await configModel.getConfig();
+ res.status(200).json(config);
+ } catch (error) {
+ res.status(500).json({ message: 'Error fetching the config', error: error.message });
+ }
+};
+
+module.exports = { getConfig };
diff --git a/backend/servpulse-backend/models/configModel.js b/backend/servpulse-backend/models/configModel.js
new file mode 100644
--- /dev/null
+++ b/backend/servpulse-backend/models/configModel.js
@@ -0,0 +1,9 @@
+const fs = require('fs');
+
+const getConfig = async () => {
+ const jsonString = fs.readFileSync('config/app.json');
+ const jsonObject = JSON.parse(jsonString);
+ return await jsonObject;
+};
+
+module.exports = { getConfig };
diff --git a/backend/servpulse-backend/routes/configRoutes.js b/backend/servpulse-backend/routes/configRoutes.js
new file mode 100644
--- /dev/null
+++ b/backend/servpulse-backend/routes/configRoutes.js
@@ -0,0 +1,7 @@
+const express = require('express');
+const router = express.Router();
+const configController = require('../controllers/configController.js');
+
+router.get('/config/getAll', configController.getConfig);
+
+module.exports = router;
diff --git a/frontend/servpulse-frontend/.env.development b/frontend/servpulse-frontend/.env.development
new file mode 100644
--- /dev/null
+++ b/frontend/servpulse-frontend/.env.development
@@ -0,0 +1,3 @@
+# Make sure that your environment variable starts with VUE_APP_ for Vue CLI to pick it up automatically
+# For example, instead of PORT=8070, use VUE_APP_PORT=8070
+VUE_APP_CONFIG_API_ENDPOINT=http://test.com:3000/api/config/
diff --git a/frontend/servpulse-frontend/index.html b/frontend/servpulse-frontend/index.html
--- a/frontend/servpulse-frontend/index.html
+++ b/frontend/servpulse-frontend/index.html
@@ -1,13 +1,16 @@
<!DOCTYPE html>
<html lang="en">
- <head>
- <meta charset="UTF-8">
- <link rel="icon" href="/favicon.ico">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>Vite App</title>
- </head>
- <body>
- <div id="app"></div>
- <script type="module" src="/src/main.js"></script>
- </body>
+
+<head>
+ <meta charset="UTF-8">
+ <link rel="icon" href="/favicon.ico">
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
+ <title>Vite App</title>
+</head>
+
+<body>
+ <div id="app"></div>
+ <script type="module" src="/src/main.js"></script>
+</body>
+
</html>
diff --git a/frontend/servpulse-frontend/package.json b/frontend/servpulse-frontend/package.json
--- a/frontend/servpulse-frontend/package.json
+++ b/frontend/servpulse-frontend/package.json
@@ -12,6 +12,7 @@
},
"dependencies": {
"axios": "^1.4.0",
+ "foundation-sites": "^6.7.5",
"vue": "^3.3.2",
"vue-router": "^4.2.0"
},
diff --git a/frontend/servpulse-frontend/src/App.vue b/frontend/servpulse-frontend/src/App.vue
--- a/frontend/servpulse-frontend/src/App.vue
+++ b/frontend/servpulse-frontend/src/App.vue
@@ -1,85 +1,9 @@
<script setup>
import { RouterLink, RouterView } from 'vue-router'
-import HelloWorld from './components/HelloWorld.vue'
+import NavbarSection from './components/home/NavbarSection.vue'
</script>
<template>
- <header>
- <img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
-
- <div class="wrapper">
- <HelloWorld msg="You did it!" />
-
- <nav>
- <RouterLink to="/">Home</RouterLink>
- <RouterLink to="/about">About</RouterLink>
- </nav>
- </div>
- </header>
-
- <RouterView />
+ <NavbarSection />
+ <RouterView />
</template>
-
-<style scoped>
-header {
- line-height: 1.5;
- max-height: 100vh;
-}
-
-.logo {
- display: block;
- margin: 0 auto 2rem;
-}
-
-nav {
- width: 100%;
- font-size: 12px;
- text-align: center;
- margin-top: 2rem;
-}
-
-nav a.router-link-exact-active {
- color: var(--color-text);
-}
-
-nav a.router-link-exact-active:hover {
- background-color: transparent;
-}
-
-nav a {
- display: inline-block;
- padding: 0 1rem;
- border-left: 1px solid var(--color-border);
-}
-
-nav a:first-of-type {
- border: 0;
-}
-
-@media (min-width: 1024px) {
- header {
- display: flex;
- place-items: center;
- padding-right: calc(var(--section-gap) / 2);
- }
-
- .logo {
- margin: 0 2rem 0 0;
- }
-
- header .wrapper {
- display: flex;
- place-items: flex-start;
- flex-wrap: wrap;
- }
-
- nav {
- text-align: left;
- margin-left: -1rem;
- font-size: 1rem;
-
- padding: 1rem 0;
- margin-top: 1rem;
- }
-}
-</style>
diff --git a/frontend/servpulse-frontend/src/components/HelloWorld.vue b/frontend/servpulse-frontend/src/components/HelloWorld.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/HelloWorld.vue
+++ /dev/null
@@ -1,43 +0,0 @@
-<script setup>
-defineProps({
- msg: {
- type: String,
- required: true
- }
-})
-</script>
-
-<template>
- <div class="greetings">
- <h1 class="green">{{ msg }}</h1>
- <h3>
- You’ve successfully created a project with
- <a href="https://vitejs.dev/" target="_blank" rel="noopener">Vite</a> +
- <a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a>.
- </h3>
- </div>
-</template>
-
-<style scoped>
-h1 {
- font-weight: 500;
- font-size: 2.6rem;
- top: -10px;
-}
-
-h3 {
- font-size: 1.2rem;
-}
-
-.greetings h1,
-.greetings h3 {
- text-align: center;
-}
-
-@media (min-width: 1024px) {
- .greetings h1,
- .greetings h3 {
- text-align: left;
- }
-}
-</style>
diff --git a/frontend/servpulse-frontend/src/components/TheWelcome.vue b/frontend/servpulse-frontend/src/components/TheWelcome.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/TheWelcome.vue
+++ /dev/null
@@ -1,86 +0,0 @@
-<script setup>
-import WelcomeItem from './WelcomeItem.vue'
-import DocumentationIcon from './icons/IconDocumentation.vue'
-import ToolingIcon from './icons/IconTooling.vue'
-import EcosystemIcon from './icons/IconEcosystem.vue'
-import CommunityIcon from './icons/IconCommunity.vue'
-import SupportIcon from './icons/IconSupport.vue'
-</script>
-
-<template>
- <WelcomeItem>
- <template #icon>
- <DocumentationIcon />
- </template>
- <template #heading>Documentation</template>
-
- Vue’s
- <a href="https://vuejs.org/" target="_blank" rel="noopener">official documentation</a>
- provides you with all information you need to get started.
- </WelcomeItem>
-
- <WelcomeItem>
- <template #icon>
- <ToolingIcon />
- </template>
- <template #heading>Tooling</template>
-
- This project is served and bundled with
- <a href="https://vitejs.dev/guide/features.html" target="_blank" rel="noopener">Vite</a>. The
- recommended IDE setup is
- <a href="https://code.visualstudio.com/" target="_blank" rel="noopener">VSCode</a> +
- <a href="https://github.com/johnsoncodehk/volar" target="_blank" rel="noopener">Volar</a>. If
- you need to test your components and web pages, check out
- <a href="https://www.cypress.io/" target="_blank" rel="noopener">Cypress</a> and
- <a href="https://on.cypress.io/component" target="_blank">Cypress Component Testing</a>.
-
- <br />
-
- More instructions are available in <code>README.md</code>.
- </WelcomeItem>
-
- <WelcomeItem>
- <template #icon>
- <EcosystemIcon />
- </template>
- <template #heading>Ecosystem</template>
-
- Get official tools and libraries for your project:
- <a href="https://pinia.vuejs.org/" target="_blank" rel="noopener">Pinia</a>,
- <a href="https://router.vuejs.org/" target="_blank" rel="noopener">Vue Router</a>,
- <a href="https://test-utils.vuejs.org/" target="_blank" rel="noopener">Vue Test Utils</a>, and
- <a href="https://github.com/vuejs/devtools" target="_blank" rel="noopener">Vue Dev Tools</a>. If
- you need more resources, we suggest paying
- <a href="https://github.com/vuejs/awesome-vue" target="_blank" rel="noopener">Awesome Vue</a>
- a visit.
- </WelcomeItem>
-
- <WelcomeItem>
- <template #icon>
- <CommunityIcon />
- </template>
- <template #heading>Community</template>
-
- Got stuck? Ask your question on
- <a href="https://chat.vuejs.org" target="_blank" rel="noopener">Vue Land</a>, our official
- Discord server, or
- <a href="https://stackoverflow.com/questions/tagged/vue.js" target="_blank" rel="noopener"
- >StackOverflow</a
- >. You should also subscribe to
- <a href="https://news.vuejs.org" target="_blank" rel="noopener">our mailing list</a> and follow
- the official
- <a href="https://twitter.com/vuejs" target="_blank" rel="noopener">@vuejs</a>
- twitter account for latest news in the Vue world.
- </WelcomeItem>
-
- <WelcomeItem>
- <template #icon>
- <SupportIcon />
- </template>
- <template #heading>Support Vue</template>
-
- As an independent project, Vue relies on community backing for its sustainability. You can help
- us by
- <a href="https://vuejs.org/sponsor/" target="_blank" rel="noopener">becoming a sponsor</a>.
- </WelcomeItem>
-</template>
diff --git a/frontend/servpulse-frontend/src/components/WelcomeItem.vue b/frontend/servpulse-frontend/src/components/WelcomeItem.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/WelcomeItem.vue
+++ /dev/null
@@ -1,85 +0,0 @@
-<template>
- <div class="item">
- <i>
- <slot name="icon"></slot>
- </i>
- <div class="details">
- <h3>
- <slot name="heading"></slot>
- </h3>
- <slot></slot>
- </div>
- </div>
-</template>
-
-<style scoped>
-.item {
- margin-top: 2rem;
- display: flex;
-}
-
-.details {
- flex: 1;
- margin-left: 1rem;
-}
-
-i {
- display: flex;
- place-items: center;
- place-content: center;
- width: 32px;
- height: 32px;
- color: var(--color-text);
-}
-
-h3 {
- font-size: 1.2rem;
- font-weight: 500;
- margin-bottom: 0.4rem;
- color: var(--color-heading);
-}
-
-@media (min-width: 1024px) {
- .item {
- margin-top: 0;
- padding: 0.4rem 0 1rem calc(var(--section-gap) / 2);
- }
-
- i {
- top: calc(50% - 25px);
- left: -26px;
- position: absolute;
- border: 1px solid var(--color-border);
- background: var(--color-background);
- border-radius: 8px;
- width: 50px;
- height: 50px;
- }
-
- .item:before {
- content: ' ';
- border-left: 1px solid var(--color-border);
- position: absolute;
- left: 0;
- bottom: calc(50% + 25px);
- height: calc(50% - 25px);
- }
-
- .item:after {
- content: ' ';
- border-left: 1px solid var(--color-border);
- position: absolute;
- left: 0;
- top: calc(50% + 25px);
- height: calc(50% - 25px);
- }
-
- .item:first-of-type:before {
- display: none;
- }
-
- .item:last-of-type:after {
- display: none;
- }
-}
-</style>
diff --git a/frontend/servpulse-frontend/src/components/home/NavbarSection.vue b/frontend/servpulse-frontend/src/components/home/NavbarSection.vue
new file mode 100644
--- /dev/null
+++ b/frontend/servpulse-frontend/src/components/home/NavbarSection.vue
@@ -0,0 +1,69 @@
+<template>
+ <!-- Used: https://get.foundation/building-blocks/blocks/topbar-center-logo.html -->
+ <main>
+ <div class="top-bar topbar-center-logo" id="topbar-center-logo">
+ <div class="top-bar-left">
+ <ul class="menu vertical medium-horizontal">
+ <li><a :href="apiResponse.navbar.button_left.link" class="button">{{ apiResponse.navbar.button_left.name }}</a></li>
+ </ul>
+ </div>
+ <div class="top-bar-center">
+ <span class="navbar-brand">{{ apiResponse.navbar.title }}</span>
+ </div>
+ <div class="top-bar-right">
+ <ul class="menu vertical medium-horizontal">
+ <li><a :href="apiResponse.navbar.button_right.link" class="button">{{ apiResponse.navbar.button_right.name }}</a></li>
+ </ul>
+ </div>
+ </div>
+ </main>
+</template>
+
+<script>
+import { fetchConfigData } from "../../plugins/api";
+
+export default {
+ data() {
+ return {
+ apiResponse: '',
+ };
+ },
+ async created() {
+ this.apiResponse = await fetchConfigData();
+ },
+};
+</script>
+
+
+<style>
+.topbar-center-logo {
+ background: #2c3840;
+}
+
+.topbar-center-logo .menu {
+ background: #2c3840;
+}
+
+.topbar-center-logo .menu a {
+ color: #fefefe;
+}
+
+.topbar-center-logo .top-bar-center {
+ -webkit-flex: 1 0 auto;
+ -ms-flex: 1 0 auto;
+ flex: 1 0 auto;
+}
+
+.top-bar-center {
+ color: #fefefe;
+ font-weight: 700;
+ text-transform: uppercase;
+ word-spacing: 1px; letter-spacing:2px;
+}
+
+@media screen and (max-width: 39.9375em) {
+ .topbar-center-logo .top-bar-center {
+ display: none;
+ }
+}
+</style>
diff --git a/frontend/servpulse-frontend/src/components/icons/IconCommunity.vue b/frontend/servpulse-frontend/src/components/icons/IconCommunity.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/icons/IconCommunity.vue
+++ /dev/null
@@ -1,7 +0,0 @@
-<template>
- <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor">
- <path
- d="M15 4a1 1 0 1 0 0 2V4zm0 11v-1a1 1 0 0 0-1 1h1zm0 4l-.707.707A1 1 0 0 0 16 19h-1zm-4-4l.707-.707A1 1 0 0 0 11 14v1zm-4.707-1.293a1 1 0 0 0-1.414 1.414l1.414-1.414zm-.707.707l-.707-.707.707.707zM9 11v-1a1 1 0 0 0-.707.293L9 11zm-4 0h1a1 1 0 0 0-1-1v1zm0 4H4a1 1 0 0 0 1.707.707L5 15zm10-9h2V4h-2v2zm2 0a1 1 0 0 1 1 1h2a3 3 0 0 0-3-3v2zm1 1v6h2V7h-2zm0 6a1 1 0 0 1-1 1v2a3 3 0 0 0 3-3h-2zm-1 1h-2v2h2v-2zm-3 1v4h2v-4h-2zm1.707 3.293l-4-4-1.414 1.414 4 4 1.414-1.414zM11 14H7v2h4v-2zm-4 0c-.276 0-.525-.111-.707-.293l-1.414 1.414C5.42 15.663 6.172 16 7 16v-2zm-.707 1.121l3.414-3.414-1.414-1.414-3.414 3.414 1.414 1.414zM9 12h4v-2H9v2zm4 0a3 3 0 0 0 3-3h-2a1 1 0 0 1-1 1v2zm3-3V3h-2v6h2zm0-6a3 3 0 0 0-3-3v2a1 1 0 0 1 1 1h2zm-3-3H3v2h10V0zM3 0a3 3 0 0 0-3 3h2a1 1 0 0 1 1-1V0zM0 3v6h2V3H0zm0 6a3 3 0 0 0 3 3v-2a1 1 0 0 1-1-1H0zm3 3h2v-2H3v2zm1-1v4h2v-4H4zm1.707 4.707l.586-.586-1.414-1.414-.586.586 1.414 1.414z"
- />
- </svg>
-</template>
diff --git a/frontend/servpulse-frontend/src/components/icons/IconDocumentation.vue b/frontend/servpulse-frontend/src/components/icons/IconDocumentation.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/icons/IconDocumentation.vue
+++ /dev/null
@@ -1,7 +0,0 @@
-<template>
- <svg xmlns="http://www.w3.org/2000/svg" width="20" height="17" fill="currentColor">
- <path
- d="M11 2.253a1 1 0 1 0-2 0h2zm-2 13a1 1 0 1 0 2 0H9zm.447-12.167a1 1 0 1 0 1.107-1.666L9.447 3.086zM1 2.253L.447 1.42A1 1 0 0 0 0 2.253h1zm0 13H0a1 1 0 0 0 1.553.833L1 15.253zm8.447.833a1 1 0 1 0 1.107-1.666l-1.107 1.666zm0-14.666a1 1 0 1 0 1.107 1.666L9.447 1.42zM19 2.253h1a1 1 0 0 0-.447-.833L19 2.253zm0 13l-.553.833A1 1 0 0 0 20 15.253h-1zm-9.553-.833a1 1 0 1 0 1.107 1.666L9.447 14.42zM9 2.253v13h2v-13H9zm1.553-.833C9.203.523 7.42 0 5.5 0v2c1.572 0 2.961.431 3.947 1.086l1.107-1.666zM5.5 0C3.58 0 1.797.523.447 1.42l1.107 1.666C2.539 2.431 3.928 2 5.5 2V0zM0 2.253v13h2v-13H0zm1.553 13.833C2.539 15.431 3.928 15 5.5 15v-2c-1.92 0-3.703.523-5.053 1.42l1.107 1.666zM5.5 15c1.572 0 2.961.431 3.947 1.086l1.107-1.666C9.203 13.523 7.42 13 5.5 13v2zm5.053-11.914C11.539 2.431 12.928 2 14.5 2V0c-1.92 0-3.703.523-5.053 1.42l1.107 1.666zM14.5 2c1.573 0 2.961.431 3.947 1.086l1.107-1.666C18.203.523 16.421 0 14.5 0v2zm3.5.253v13h2v-13h-2zm1.553 12.167C18.203 13.523 16.421 13 14.5 13v2c1.573 0 2.961.431 3.947 1.086l1.107-1.666zM14.5 13c-1.92 0-3.703.523-5.053 1.42l1.107 1.666C11.539 15.431 12.928 15 14.5 15v-2z"
- />
- </svg>
-</template>
diff --git a/frontend/servpulse-frontend/src/components/icons/IconEcosystem.vue b/frontend/servpulse-frontend/src/components/icons/IconEcosystem.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/icons/IconEcosystem.vue
+++ /dev/null
@@ -1,7 +0,0 @@
-<template>
- <svg xmlns="http://www.w3.org/2000/svg" width="18" height="20" fill="currentColor">
- <path
- d="M11.447 8.894a1 1 0 1 0-.894-1.789l.894 1.789zm-2.894-.789a1 1 0 1 0 .894 1.789l-.894-1.789zm0 1.789a1 1 0 1 0 .894-1.789l-.894 1.789zM7.447 7.106a1 1 0 1 0-.894 1.789l.894-1.789zM10 9a1 1 0 1 0-2 0h2zm-2 2.5a1 1 0 1 0 2 0H8zm9.447-5.606a1 1 0 1 0-.894-1.789l.894 1.789zm-2.894-.789a1 1 0 1 0 .894 1.789l-.894-1.789zm2 .789a1 1 0 1 0 .894-1.789l-.894 1.789zm-1.106-2.789a1 1 0 1 0-.894 1.789l.894-1.789zM18 5a1 1 0 1 0-2 0h2zm-2 2.5a1 1 0 1 0 2 0h-2zm-5.447-4.606a1 1 0 1 0 .894-1.789l-.894 1.789zM9 1l.447-.894a1 1 0 0 0-.894 0L9 1zm-2.447.106a1 1 0 1 0 .894 1.789l-.894-1.789zm-6 3a1 1 0 1 0 .894 1.789L.553 4.106zm2.894.789a1 1 0 1 0-.894-1.789l.894 1.789zm-2-.789a1 1 0 1 0-.894 1.789l.894-1.789zm1.106 2.789a1 1 0 1 0 .894-1.789l-.894 1.789zM2 5a1 1 0 1 0-2 0h2zM0 7.5a1 1 0 1 0 2 0H0zm8.553 12.394a1 1 0 1 0 .894-1.789l-.894 1.789zm-1.106-2.789a1 1 0 1 0-.894 1.789l.894-1.789zm1.106 1a1 1 0 1 0 .894 1.789l-.894-1.789zm2.894.789a1 1 0 1 0-.894-1.789l.894 1.789zM8 19a1 1 0 1 0 2 0H8zm2-2.5a1 1 0 1 0-2 0h2zm-7.447.394a1 1 0 1 0 .894-1.789l-.894 1.789zM1 15H0a1 1 0 0 0 .553.894L1 15zm1-2.5a1 1 0 1 0-2 0h2zm12.553 2.606a1 1 0 1 0 .894 1.789l-.894-1.789zM17 15l.447.894A1 1 0 0 0 18 15h-1zm1-2.5a1 1 0 1 0-2 0h2zm-7.447-5.394l-2 1 .894 1.789 2-1-.894-1.789zm-1.106 1l-2-1-.894 1.789 2 1 .894-1.789zM8 9v2.5h2V9H8zm8.553-4.894l-2 1 .894 1.789 2-1-.894-1.789zm.894 0l-2-1-.894 1.789 2 1 .894-1.789zM16 5v2.5h2V5h-2zm-4.553-3.894l-2-1-.894 1.789 2 1 .894-1.789zm-2.894-1l-2 1 .894 1.789 2-1L8.553.106zM1.447 5.894l2-1-.894-1.789-2 1 .894 1.789zm-.894 0l2 1 .894-1.789-2-1-.894 1.789zM0 5v2.5h2V5H0zm9.447 13.106l-2-1-.894 1.789 2 1 .894-1.789zm0 1.789l2-1-.894-1.789-2 1 .894 1.789zM10 19v-2.5H8V19h2zm-6.553-3.894l-2-1-.894 1.789 2 1 .894-1.789zM2 15v-2.5H0V15h2zm13.447 1.894l2-1-.894-1.789-2 1 .894 1.789zM18 15v-2.5h-2V15h2z"
- />
- </svg>
-</template>
diff --git a/frontend/servpulse-frontend/src/components/icons/IconSupport.vue b/frontend/servpulse-frontend/src/components/icons/IconSupport.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/icons/IconSupport.vue
+++ /dev/null
@@ -1,7 +0,0 @@
-<template>
- <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor">
- <path
- d="M10 3.22l-.61-.6a5.5 5.5 0 0 0-7.666.105 5.5 5.5 0 0 0-.114 7.665L10 18.78l8.39-8.4a5.5 5.5 0 0 0-.114-7.665 5.5 5.5 0 0 0-7.666-.105l-.61.61z"
- />
- </svg>
-</template>
diff --git a/frontend/servpulse-frontend/src/components/icons/IconTooling.vue b/frontend/servpulse-frontend/src/components/icons/IconTooling.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/components/icons/IconTooling.vue
+++ /dev/null
@@ -1,19 +0,0 @@
-<!-- This icon is from <https://github.com/Templarian/MaterialDesign>, distributed under Apache 2.0 (https://www.apache.org/licenses/LICENSE-2.0) license-->
-<template>
- <svg
- xmlns="http://www.w3.org/2000/svg"
- xmlns:xlink="http://www.w3.org/1999/xlink"
- aria-hidden="true"
- role="img"
- class="iconify iconify--mdi"
- width="24"
- height="24"
- preserveAspectRatio="xMidYMid meet"
- viewBox="0 0 24 24"
- >
- <path
- d="M20 18v-4h-3v1h-2v-1H9v1H7v-1H4v4h16M6.33 8l-1.74 4H7v-1h2v1h6v-1h2v1h2.41l-1.74-4H6.33M9 5v1h6V5H9m12.84 7.61c.1.22.16.48.16.8V18c0 .53-.21 1-.6 1.41c-.4.4-.85.59-1.4.59H4c-.55 0-1-.19-1.4-.59C2.21 19 2 18.53 2 18v-4.59c0-.32.06-.58.16-.8L4.5 7.22C4.84 6.41 5.45 6 6.33 6H7V5c0-.55.18-1 .57-1.41C7.96 3.2 8.44 3 9 3h6c.56 0 1.04.2 1.43.59c.39.41.57.86.57 1.41v1h.67c.88 0 1.49.41 1.83 1.22l2.34 5.39z"
- fill="currentColor"
- ></path>
- </svg>
-</template>
diff --git a/frontend/servpulse-frontend/src/main.js b/frontend/servpulse-frontend/src/main.js
--- a/frontend/servpulse-frontend/src/main.js
+++ b/frontend/servpulse-frontend/src/main.js
@@ -1,11 +1,12 @@
-import './assets/main.css'
+// import './assets/main.css'; // Customize CSS
+import 'foundation-sites/dist/css/foundation.css';
-import { createApp } from 'vue'
-import App from './App.vue'
-import router from './router'
+import { createApp } from 'vue';
+import App from './App.vue';
+import router from './router';
-const app = createApp(App)
+const app = createApp(App);
-app.use(router)
+app.use(router);
-app.mount('#app')
+app.mount('#app');
diff --git a/frontend/servpulse-frontend/src/plugins/api.js b/frontend/servpulse-frontend/src/plugins/api.js
new file mode 100644
--- /dev/null
+++ b/frontend/servpulse-frontend/src/plugins/api.js
@@ -0,0 +1,11 @@
+import axios from 'axios';
+
+export async function fetchConfigData() {
+ try {
+ // # FIXME: `VUE_APP_CONFIG_API_ENDPOINT` is somehow not working from a .env (hardcoded the url for now)
+ const response = await axios.get('http://localhost:3000/api/config/getAll');
+ return response.data;
+ } catch (error) {
+ throw new Error('Failed to fetch the config data');
+ }
+}
diff --git a/frontend/servpulse-frontend/src/router/index.js b/frontend/servpulse-frontend/src/router/index.js
--- a/frontend/servpulse-frontend/src/router/index.js
+++ b/frontend/servpulse-frontend/src/router/index.js
@@ -1,5 +1,7 @@
import { createRouter, createWebHistory } from 'vue-router'
import HomeView from '../views/HomeView.vue'
+import LoginView from '../views/LoginView.vue'
+import DashboardView from '../views/DashboardView.vue'
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
@@ -10,12 +12,14 @@
component: HomeView
},
{
- path: '/about',
- name: 'about',
- // route level code-splitting
- // this generates a separate chunk (About.[hash].js) for this route
- // which is lazy-loaded when the route is visited.
- component: () => import('../views/AboutView.vue')
+ path: '/login',
+ name: 'login',
+ component: LoginView
+ },
+ {
+ path: '/dashboard',
+ name: 'dashboard',
+ component: DashboardView
}
]
})
diff --git a/frontend/servpulse-frontend/src/views/AboutView.vue b/frontend/servpulse-frontend/src/views/AboutView.vue
deleted file mode 100644
--- a/frontend/servpulse-frontend/src/views/AboutView.vue
+++ /dev/null
@@ -1,15 +0,0 @@
-<template>
- <div class="about">
- <h1>This is an about page</h1>
- </div>
-</template>
-
-<style>
-@media (min-width: 1024px) {
- .about {
- min-height: 100vh;
- display: flex;
- align-items: center;
- }
-}
-</style>
diff --git a/frontend/servpulse-frontend/src/views/HomeView.vue b/frontend/servpulse-frontend/src/views/HomeView.vue
--- a/frontend/servpulse-frontend/src/views/HomeView.vue
+++ b/frontend/servpulse-frontend/src/views/HomeView.vue
@@ -1,9 +1,9 @@
<script setup>
-import TheWelcome from '../components/TheWelcome.vue'
+// Sample
</script>
<template>
<main>
- <TheWelcome />
+<!-- Sample -->
</main>
</template>
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Fri, Nov 22, 18:58 (14 h, 15 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
2256046
Default Alt Text
D3205.diff (23 KB)
Attached To
Mode
D3205: Add basic navbar with API integration
Attached
Detach File
Event Timeline
Log In to Comment