added bools for actionbar rendering
This commit is contained in:
2
app.vue
2
app.vue
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
useHead({
|
useHead({
|
||||||
//title: `Tüit ERP - ${route.meta.title}`,
|
//title: `Tüit ERP - ${route.meta.title}`,
|
||||||
title: `Tüit ERP`,
|
title: `tüit app`,
|
||||||
link: [{ rel: "icon", type: "image/png", href: "/favicon-gelb-rot-32x32.png" }]
|
link: [{ rel: "icon", type: "image/png", href: "/favicon-gelb-rot-32x32.png" }]
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -103,8 +103,8 @@ export const getSelectedSolutionsBySolutionName = async (selected, result) => {
|
|||||||
//get all selected solutions by asset name
|
//get all selected solutions by asset name
|
||||||
export const getSelectedSolutionsByAssetName = async (selected, result) => {
|
export const getSelectedSolutionsByAssetName = async (selected, result) => {
|
||||||
try {
|
try {
|
||||||
let sql = `SELECT * FROM solutions WHERE LOWER(assetName) LIKE '%${selected.toLowerCase()}%' ORDER BY assetName ASC`;
|
let sql = `SELECT * FROM solutions WHERE assetName = ? ORDER BY solutionName ASC`;
|
||||||
const results = await ownConn.execute(sql)
|
const results = await ownConn.execute(sql, [selected])
|
||||||
result(null, results);
|
result(null, results);
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
|
|||||||
@ -1,15 +1,40 @@
|
|||||||
<template>
|
<template>
|
||||||
<section :class="['asset-search', darkMode ? 'section-darkmode' : 'section-lightmode']">
|
<section :class="['asset-search', darkMode ? 'section-darkmode' : 'section-lightmode']">
|
||||||
<div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Asset:</div>
|
<div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Asset:</div>
|
||||||
<pre :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Asset name</pre>
|
<pre :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ asset.assetName }}</pre>
|
||||||
</section>
|
</section>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from 'vue';
|
import { ref, onMounted } from 'vue';
|
||||||
|
import Axios from '../axios.config.js';
|
||||||
|
import clientsideConfig from '../../clientsideConfig.js';
|
||||||
|
import { useStore } from 'vuex';
|
||||||
|
import { computed } from 'vue';
|
||||||
|
|
||||||
|
const store = useStore();
|
||||||
|
const chosenAssetId = computed(() => store.state.chosenAssetId);
|
||||||
|
|
||||||
|
const asset = ref({});
|
||||||
const darkMode = ref(true)
|
const darkMode = ref(true)
|
||||||
|
|
||||||
|
// get config item from id
|
||||||
|
const getItemById = async () => {
|
||||||
|
try {
|
||||||
|
const response = await Axios.get(
|
||||||
|
`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getConfigItem/${chosenAssetId.value}`
|
||||||
|
);
|
||||||
|
asset.value = response.data;
|
||||||
|
} catch (err) {
|
||||||
|
console.log(err.response.statusText);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
getItemById();
|
||||||
|
});
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|||||||
@ -9,32 +9,78 @@
|
|||||||
Solution</th>
|
Solution</th>
|
||||||
<th :class="['Type', darkMode ? 'th-darkmode' : 'th-lightmode']">Type</th>
|
<th :class="['Type', darkMode ? 'th-darkmode' : 'th-lightmode']">Type</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
<tr v-for="sol in solutions" :key="sol.primaryID"
|
||||||
|
:class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
||||||
<td
|
<td
|
||||||
:class="['Solution', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Solution-darkmode' : 'Solution-lightmode']">
|
:class="['Solution', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Solution-darkmode' : 'Solution-lightmode']">
|
||||||
...</td>
|
<nuxt-link to="/solutions" id="nuxt-link" class="button"
|
||||||
<td :class="['Type', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td>
|
:class="[darkMode ? 'button-darkmode' : 'button-lightmode']"
|
||||||
|
@click="goToChosenSolution(sol.primaryID)">
|
||||||
|
{{ sol.solutionName }}
|
||||||
|
</nuxt-link>
|
||||||
|
</td>
|
||||||
|
<td :class="['Type', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ sol.type }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
|
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|
||||||
<script setup>
|
|
||||||
import { ref } from 'vue';
|
|
||||||
|
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { ref, onMounted } from 'vue';
|
||||||
|
import Axios from '../axios.config.js';
|
||||||
|
import clientsideConfig from '../../clientsideConfig.js';
|
||||||
|
import { useStore } from 'vuex';
|
||||||
|
import { computed } from 'vue';
|
||||||
|
|
||||||
|
const store = useStore();
|
||||||
|
const chosenAssetId = computed(() => store.state.chosenAssetId);
|
||||||
|
|
||||||
|
const asset = ref({});
|
||||||
|
const solutions = ref({});
|
||||||
const darkMode = ref(true)
|
const darkMode = ref(true)
|
||||||
|
|
||||||
|
//get all solutions from the chosen asset
|
||||||
|
const getSolutions = async () => {
|
||||||
|
try {
|
||||||
|
const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedSolutionsByAsset/${asset.value.assetName}`);
|
||||||
|
solutions.value = response.data;
|
||||||
|
} catch (err) {
|
||||||
|
console.log(err.response.statusText);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const goToChosenSolution = (id) => {
|
||||||
|
store.commit('setChosenSolution', id);
|
||||||
|
store.commit('changeToSolution');
|
||||||
|
};
|
||||||
|
|
||||||
|
// get config item from id
|
||||||
|
const getItemById = async () => {
|
||||||
|
try {
|
||||||
|
const response = await Axios.get(
|
||||||
|
`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getConfigItem/${chosenAssetId.value}`
|
||||||
|
);
|
||||||
|
asset.value = response.data;
|
||||||
|
await getSolutions();
|
||||||
|
} catch (err) {
|
||||||
|
console.log(err.response.statusText);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
getItemById();
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
name: "AssetSolutionList",
|
name: "AssetSolutionList",
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
.data {
|
.data {
|
||||||
display: flex;
|
display: flex;
|
||||||
@ -73,6 +119,11 @@ export default {
|
|||||||
gap: 0.625rem;
|
gap: 0.625rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#nuxt-link {
|
||||||
|
text-decoration: none;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
.tr-head-darkmode {
|
.tr-head-darkmode {
|
||||||
border-top: none;
|
border-top: none;
|
||||||
border-bottom: 0.0625rem solid #000000;
|
border-bottom: 0.0625rem solid #000000;
|
||||||
|
|||||||
@ -1,76 +1,118 @@
|
|||||||
<template>
|
<template>
|
||||||
<aside :class="['actionbar', darkMode ? 'actionbar-darkmode' : 'actionbar-lightmode', isExpanded ? 'is-expanded' : 'is-not-expanded']">
|
<aside
|
||||||
<div :class="['icon', darkMode ? 'indicator-darkmode' : 'indicator-lightmode']" id="indicator-icon" @click="toggleActionbar">
|
:class="['actionbar', darkMode ? 'actionbar-darkmode' : 'actionbar-lightmode', isExpanded ? 'is-expanded' : 'is-not-expanded']">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Indicator-Icon-Opened.svg" />
|
<div :class="['icon', darkMode ? 'indicator-darkmode' : 'indicator-lightmode']" id="indicator-icon"
|
||||||
|
@click="toggleActionbar">
|
||||||
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Indicator-Icon-Opened.svg" />
|
||||||
</div>
|
</div>
|
||||||
<nav class="actions">
|
<nav class="actions">
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="search" @click="toggleSearched">
|
<button v-if="searchIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="search"
|
||||||
|
@click="toggleSearched">
|
||||||
<div class="icon" id="search-icon">
|
<div class="icon" id="search-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Search-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Search-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Search</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Search</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="filter" @click="toggleFiltered">
|
<button v-if="filterIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="filter" @click="toggleFiltered">
|
||||||
<div class="icon" id="filter-icon">
|
<div class="icon" id="filter-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Filter-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Filter-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Filter</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Filter</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="instances">
|
<button v-if="instancesIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="instances">
|
||||||
<div class="icon" id="instances-icon">
|
<div class="icon" id="instances-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Instances-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Instances-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Instances</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Instances</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="attachments">
|
<button v-if="solutionIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="solutions" @click="changeToSolutions">
|
||||||
|
<div class="icon" id="instances-icon">
|
||||||
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Instances-Icon.svg" />
|
||||||
|
</div>
|
||||||
|
<Transition name="fade">
|
||||||
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Solutions</pre>
|
||||||
|
</Transition>
|
||||||
|
</button>
|
||||||
|
<button v-if="attachmentsIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="attachments">
|
||||||
<div class="icon" id="attachments-icon">
|
<div class="icon" id="attachments-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Attachments-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Attachments-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Attachments</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Attachments</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="sell">
|
<button v-if="sellIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="sell">
|
||||||
<div class="icon" id="sell-icon">
|
<div class="icon" id="sell-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Sell-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Sell-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Sell</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Sell</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="archive">
|
<button v-if="archiveIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="archive">
|
||||||
<div class="icon" id="archive-icon">
|
<div class="icon" id="archive-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Archive-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Archive-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Archive</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Archive</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="new" @click="add">
|
<button v-if="addIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="new" @click="add">
|
||||||
<div class="icon" id="new-icon">
|
<div class="icon" id="new-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Add-New-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Add-New-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">New</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">New</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="edit" @click="toggleEditable">
|
<button v-if="addInstanceIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="new-instance">
|
||||||
|
<div class="icon" id="new-icon">
|
||||||
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Add-New-Icon.svg" />
|
||||||
|
</div>
|
||||||
|
<Transition name="fade">
|
||||||
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Instance</pre>
|
||||||
|
</Transition>
|
||||||
|
</button>
|
||||||
|
<button v-if="addSolutionIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="new-solution">
|
||||||
|
<div class="icon" id="new-icon">
|
||||||
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Add-New-Icon.svg" />
|
||||||
|
</div>
|
||||||
|
<Transition name="fade">
|
||||||
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Solution</pre>
|
||||||
|
</Transition>
|
||||||
|
</button>
|
||||||
|
<button v-if="editIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="edit"
|
||||||
|
@click="toggleEditable">
|
||||||
<div class="icon" id="edit-icon">
|
<div class="icon" id="edit-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Edit-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Edit-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Edit</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Edit</pre>
|
||||||
</Transition>
|
</Transition>
|
||||||
</button>
|
</button>
|
||||||
<button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="delete" @click="deleteFunc">
|
<button v-if="deleteIcon" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="delete"
|
||||||
|
@click="deleteFunc">
|
||||||
<div class="icon" id="delete-icon">
|
<div class="icon" id="delete-icon">
|
||||||
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="/icons/actionbar-icons/Delete-Icon.svg" />
|
<img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy"
|
||||||
|
src="/icons/actionbar-icons/Delete-Icon.svg" />
|
||||||
</div>
|
</div>
|
||||||
<Transition name="fade">
|
<Transition name="fade">
|
||||||
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Delete</pre>
|
<pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Delete</pre>
|
||||||
@ -81,8 +123,22 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from 'vue';
|
import { ref, onMounted } from 'vue';
|
||||||
import { useStore } from 'vuex';
|
import { useStore } from 'vuex';
|
||||||
|
import { computed } from 'vue';
|
||||||
|
|
||||||
|
const addIcon = computed(() => store.state.addIcon);
|
||||||
|
const addInstanceIcon = computed(() => store.state.addInstanceIcon);
|
||||||
|
const addSolutionIcon = computed(() => store.state.addSolutionIcon);
|
||||||
|
const solutionIcon = computed(() => store.state.solutionIcon);
|
||||||
|
const filterIcon = computed(() => store.state.filterIcon);
|
||||||
|
const searchIcon = computed(() => store.state.searchIcon);
|
||||||
|
const instancesIcon = computed(() => store.state.instancesIcon);
|
||||||
|
const attachmentsIcon = computed(() => store.state.attachmentsIcon);
|
||||||
|
const sellIcon = computed(() => store.state.sellIcon);
|
||||||
|
const archiveIcon = computed(() => store.state.archiveIcon);
|
||||||
|
const editIcon = computed(() => store.state.editIcon);
|
||||||
|
const deleteIcon = computed(() => store.state.deleteIcon);
|
||||||
|
|
||||||
const darkMode = ref(true)
|
const darkMode = ref(true)
|
||||||
const isExpanded = ref(true)
|
const isExpanded = ref(true)
|
||||||
@ -108,6 +164,14 @@ const toggleSearched = () => {
|
|||||||
const add = () => {
|
const add = () => {
|
||||||
store.commit('add');
|
store.commit('add');
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const changeToSolutions = () => {
|
||||||
|
store.commit('changeToSolutionlistAsset');
|
||||||
|
}
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
store.commit('changeToAssetlist')
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
@ -345,4 +409,5 @@ img {
|
|||||||
max-width: 0;
|
max-width: 0;
|
||||||
max-inline-size: 0;
|
max-inline-size: 0;
|
||||||
}
|
}
|
||||||
}</style>
|
}
|
||||||
|
</style>
|
||||||
315
plugins/vuex.js
315
plugins/vuex.js
@ -12,6 +12,19 @@ const store = createStore({
|
|||||||
changedCustomerId: -1,
|
changedCustomerId: -1,
|
||||||
filteredByCustomer: '',
|
filteredByCustomer: '',
|
||||||
|
|
||||||
|
addIcon: false,
|
||||||
|
addSolutionIcon: false,
|
||||||
|
solutionIcon: false,
|
||||||
|
addInstanceIcon: false,
|
||||||
|
filterIcon: false,
|
||||||
|
searchIcon: false,
|
||||||
|
instancesIcon: false,
|
||||||
|
attachmentsIcon: false,
|
||||||
|
sellIcon: false,
|
||||||
|
archiveIcon: false,
|
||||||
|
editIcon: false,
|
||||||
|
deleteIcon: false,
|
||||||
|
|
||||||
onAssetlist: true,
|
onAssetlist: true,
|
||||||
onCustomerAssetlist: false,
|
onCustomerAssetlist: false,
|
||||||
onAsset: false,
|
onAsset: false,
|
||||||
@ -150,92 +163,86 @@ const store = createStore({
|
|||||||
state.changedCustomerId = id
|
state.changedCustomerId = id
|
||||||
},
|
},
|
||||||
|
|
||||||
|
refresh() {
|
||||||
|
//
|
||||||
|
},
|
||||||
|
|
||||||
// functions to change the asset pages
|
// functions to change the asset pages
|
||||||
changeToAssetlist(state) {
|
changeToAssetlist(state) {
|
||||||
state.onAssetlist = true
|
state.onAssetlist = true
|
||||||
state.onCustomerAssetlist = false
|
state.onCustomerAssetlist = false
|
||||||
state.onAsset = false
|
state.onAsset = false
|
||||||
state.onSolutionlistAsset = false
|
state.onSolutionlistAsset = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToCustomerAssetlist(state) {
|
changeToCustomerAssetlist(state) {
|
||||||
state.onAssetlist = false
|
state.onAssetlist = false
|
||||||
state.onCustomerAssetlist = true
|
state.onCustomerAssetlist = true
|
||||||
state.onAsset = false
|
state.onAsset = false
|
||||||
state.onSolutionlistAsset = false
|
state.onSolutionlistAsset = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToAsset(state) {
|
changeToAsset(state) {
|
||||||
state.onAssetlist = false
|
state.onAssetlist = false
|
||||||
state.onCustomerAssetlist = false
|
state.onCustomerAssetlist = false
|
||||||
state.onAsset = true
|
state.onAsset = true
|
||||||
state.onSolutionlistAsset = false
|
state.onSolutionlistAsset = false
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = true
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = false
|
||||||
|
state.searchIcon = false
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = true
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
changeToSolutionlistAsset(state) {
|
changeToSolutionlistAsset(state) {
|
||||||
state.onAssetlist = false
|
state.onAssetlist = false
|
||||||
state.onCustomerAssetlist = false
|
state.onCustomerAssetlist = false
|
||||||
state.onAsset = false
|
state.onAsset = false
|
||||||
state.onSolutionlistAsset = true
|
state.onSolutionlistAsset = true
|
||||||
},
|
|
||||||
setChosenAsset(state, id) {
|
state.addIcon = false
|
||||||
state.chosenAssetId = id
|
state.addSolutionIcon = true
|
||||||
},
|
state.solutionIcon = false
|
||||||
resetAssetStore(state) {
|
state.addInstanceIcon = false
|
||||||
state.editable = false
|
state.filterIcon = true
|
||||||
state.filtered = false
|
state.searchIcon = true
|
||||||
state.searchable = false
|
state.instancesIcon = false
|
||||||
state.deleteAsset = false
|
state.attachmentsIcon = false
|
||||||
state.chosenAssetId = -1
|
state.sellIcon = false
|
||||||
state.filteredByCustomer = ''
|
state.archiveIcon = false
|
||||||
state.newAssetName = ''
|
state.editIcon = false
|
||||||
state.newCustomerID = ''
|
state.deleteIcon = false
|
||||||
state.newCustomer = ''
|
|
||||||
state.newLocation = ''
|
|
||||||
state.newRemoteLocation = ''
|
|
||||||
state.newType = ''
|
|
||||||
state.newDescription = ''
|
|
||||||
state.newNotes = ''
|
|
||||||
state.newState = ''
|
|
||||||
state.newLastView = ''
|
|
||||||
state.newUser = ''
|
|
||||||
state.hardwareBool = false
|
|
||||||
state.newModel = ''
|
|
||||||
state.newSerialnumber = ''
|
|
||||||
state.newCPU = ''
|
|
||||||
state.newRAM = ''
|
|
||||||
state.newStorageConfiguration = ''
|
|
||||||
state.newMiscellaneous = ''
|
|
||||||
state.softwareBool = false
|
|
||||||
state.newSoftware = ''
|
|
||||||
state.newVersion = ''
|
|
||||||
state.newLicense = ''
|
|
||||||
},
|
|
||||||
// functions to change the production order and maintenance visit pages
|
|
||||||
changeToTemplatelist(state) {
|
|
||||||
state.onTemplatelist = true
|
|
||||||
state.onCustomerTemplatelist = false
|
|
||||||
state.onTemplate = false
|
|
||||||
state.onInstancelist = false
|
|
||||||
state.onInstance = false
|
|
||||||
},
|
|
||||||
changeToCustomerTemplatelist(state) {
|
|
||||||
state.onTemplatelist = false
|
|
||||||
state.onCustomerTemplatelist = true
|
|
||||||
state.onTemplate = false
|
|
||||||
state.onInstancelist = false
|
|
||||||
state.onInstance = false
|
|
||||||
},
|
|
||||||
changeToTemplate(state) {
|
|
||||||
state.onTemplatelist = false
|
|
||||||
state.onCustomerTemplatelist = false
|
|
||||||
state.onTemplate = true
|
|
||||||
state.onInstancelist = false
|
|
||||||
state.onInstance = false
|
|
||||||
},
|
|
||||||
changeToInstancelist(state) {
|
|
||||||
state.onTemplatelist = false
|
|
||||||
state.onCustomerTemplatelist = false
|
|
||||||
state.onTemplate = false
|
|
||||||
state.onInstancelist = true
|
|
||||||
state.onInstance = false
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// functions to change the production order and maintenance visit pages
|
// functions to change the production order and maintenance visit pages
|
||||||
@ -245,6 +252,19 @@ const store = createStore({
|
|||||||
state.onTemplate = false
|
state.onTemplate = false
|
||||||
state.onInstancelist = false
|
state.onInstancelist = false
|
||||||
state.onInstance = false
|
state.onInstance = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToCustomerTemplatelist(state) {
|
changeToCustomerTemplatelist(state) {
|
||||||
state.onTemplatelist = false
|
state.onTemplatelist = false
|
||||||
@ -252,6 +272,19 @@ const store = createStore({
|
|||||||
state.onTemplate = false
|
state.onTemplate = false
|
||||||
state.onInstancelist = false
|
state.onInstancelist = false
|
||||||
state.onInstance = false
|
state.onInstance = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToTemplate(state) {
|
changeToTemplate(state) {
|
||||||
state.onTemplatelist = false
|
state.onTemplatelist = false
|
||||||
@ -259,6 +292,19 @@ const store = createStore({
|
|||||||
state.onTemplate = true
|
state.onTemplate = true
|
||||||
state.onInstancelist = false
|
state.onInstancelist = false
|
||||||
state.onInstance = false
|
state.onInstance = false
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = true
|
||||||
|
state.filterIcon = false
|
||||||
|
state.searchIcon = false
|
||||||
|
state.instancesIcon = true
|
||||||
|
state.attachmentsIcon = true
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
changeToInstancelist(state) {
|
changeToInstancelist(state) {
|
||||||
state.onTemplatelist = false
|
state.onTemplatelist = false
|
||||||
@ -266,21 +312,19 @@ const store = createStore({
|
|||||||
state.onTemplate = false
|
state.onTemplate = false
|
||||||
state.onInstancelist = true
|
state.onInstancelist = true
|
||||||
state.onInstance = false
|
state.onInstance = false
|
||||||
},
|
|
||||||
doDeleteAsset(state) {
|
state.addIcon = false
|
||||||
state.deleteAsset = true
|
state.addSolutionIcon = false
|
||||||
},
|
state.solutionIcon = false
|
||||||
undoDeleteAsset(state) {
|
state.addInstanceIcon = true
|
||||||
state.deleteAsset = false
|
state.filterIcon = true
|
||||||
},
|
state.searchIcon = true
|
||||||
toggleAssetSearchable(state) {
|
state.instancesIcon = false
|
||||||
if (state.searchable == false) {
|
state.attachmentsIcon = false
|
||||||
state.searchable = true
|
state.sellIcon = false
|
||||||
state.filtered = false
|
state.archiveIcon = false
|
||||||
} else {
|
state.editIcon = false
|
||||||
state.searchable = false
|
state.deleteIcon = false
|
||||||
}
|
|
||||||
state.filteredByCustomer = ''
|
|
||||||
},
|
},
|
||||||
addNewAsset(state) {
|
addNewAsset(state) {
|
||||||
state.newAsset = true
|
state.newAsset = true
|
||||||
@ -298,16 +342,55 @@ const store = createStore({
|
|||||||
state.onSolutionlist = true
|
state.onSolutionlist = true
|
||||||
state.onCustomerSolutionlist = false
|
state.onCustomerSolutionlist = false
|
||||||
state.onSolution = false
|
state.onSolution = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToCustomerSolutionlist(state) {
|
changeToCustomerSolutionlist(state) {
|
||||||
state.onSolutionlist = false
|
state.onSolutionlist = false
|
||||||
state.onCustomerSolutionlist = true
|
state.onCustomerSolutionlist = true
|
||||||
state.onSolution = false
|
state.onSolution = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToSolution(state) {
|
changeToSolution(state) {
|
||||||
state.onSolutionlist = false
|
state.onSolutionlist = false
|
||||||
state.onCustomerSolutionlist = false
|
state.onCustomerSolutionlist = false
|
||||||
state.onSolution = true
|
state.onSolution = true
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = false
|
||||||
|
state.searchIcon = false
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = true
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
|
|
||||||
// functions to change the issue slip pages
|
// functions to change the issue slip pages
|
||||||
@ -315,16 +398,55 @@ const store = createStore({
|
|||||||
state.onIssueSliplist = true
|
state.onIssueSliplist = true
|
||||||
state.onCustomerIssueSliplist = false
|
state.onCustomerIssueSliplist = false
|
||||||
state.onIssueSlip = false
|
state.onIssueSlip = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToCustomerIssueSliplist(state) {
|
changeToCustomerIssueSliplist(state) {
|
||||||
state.onIssueSliplist = false
|
state.onIssueSliplist = false
|
||||||
state.onCustomerIssueSliplist = true
|
state.onCustomerIssueSliplist = true
|
||||||
state.onIssueSlip = false
|
state.onIssueSlip = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToIssueSlip(state) {
|
changeToIssueSlip(state) {
|
||||||
state.onIssueSliplist = false
|
state.onIssueSliplist = false
|
||||||
state.onCustomerIssueSliplist = false
|
state.onCustomerIssueSliplist = false
|
||||||
state.onIssueSlip = true
|
state.onIssueSlip = true
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = false
|
||||||
|
state.searchIcon = false
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = true
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
|
|
||||||
// functions to change the issue pages
|
// functions to change the issue pages
|
||||||
@ -332,16 +454,55 @@ const store = createStore({
|
|||||||
state.onIssueItemList = true
|
state.onIssueItemList = true
|
||||||
state.onIssueItem = false
|
state.onIssueItem = false
|
||||||
state.onIssueItemVariant = false
|
state.onIssueItemVariant = false
|
||||||
|
|
||||||
|
state.addIcon = true
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = false
|
||||||
|
state.editIcon = false
|
||||||
|
state.deleteIcon = false
|
||||||
},
|
},
|
||||||
changeToIssueItem(state) {
|
changeToIssueItem(state) {
|
||||||
state.onIssueItemList = false
|
state.onIssueItemList = false
|
||||||
state.onIssueItem = true
|
state.onIssueItem = true
|
||||||
state.onIssueItemVariant = false
|
state.onIssueItemVariant = false
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = true
|
||||||
|
state.searchIcon = true
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = false
|
||||||
|
state.archiveIcon = true
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
changeToIssueItemVariant(state) {
|
changeToIssueItemVariant(state) {
|
||||||
state.onIssueItemList = false
|
state.onIssueItemList = false
|
||||||
state.onIssueItem = false
|
state.onIssueItem = false
|
||||||
state.onIssueItemVariant = true
|
state.onIssueItemVariant = true
|
||||||
|
|
||||||
|
state.addIcon = false
|
||||||
|
state.addSolutionIcon = false
|
||||||
|
state.solutionIcon = false
|
||||||
|
state.addInstanceIcon = false
|
||||||
|
state.filterIcon = false
|
||||||
|
state.searchIcon = false
|
||||||
|
state.instancesIcon = false
|
||||||
|
state.attachmentsIcon = false
|
||||||
|
state.sellIcon = true
|
||||||
|
state.archiveIcon = true
|
||||||
|
state.editIcon = true
|
||||||
|
state.deleteIcon = true
|
||||||
},
|
},
|
||||||
|
|
||||||
// functions to update the asset
|
// functions to update the asset
|
||||||
|
|||||||
23
server/api/getSelectedSolutionsByAsset/[id].ts
Normal file
23
server/api/getSelectedSolutionsByAsset/[id].ts
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
import { selectedSolutionsByAsset, errorMsg } from "../../middleware/solutions";
|
||||||
|
import { OutgoingMessage } from 'http';
|
||||||
|
|
||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
|
||||||
|
const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = {
|
||||||
|
'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de',
|
||||||
|
'Access-Control-Allow-Headers': 'authorization, content-type',
|
||||||
|
'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE',
|
||||||
|
'Access-Control-Allow-Credentials': 'true',
|
||||||
|
};
|
||||||
|
setResponseHeaders(event, headers)
|
||||||
|
|
||||||
|
if (!(errorMsg === '')) {
|
||||||
|
throw createError({
|
||||||
|
statusCode: 400,
|
||||||
|
statusMessage: errorMsg,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
setResponseStatus(event, 200)
|
||||||
|
return selectedSolutionsByAsset
|
||||||
|
})
|
||||||
@ -6,6 +6,7 @@ let solutions = [];
|
|||||||
let solution = {};
|
let solution = {};
|
||||||
let selectedSolutionsByCustomer = [];
|
let selectedSolutionsByCustomer = [];
|
||||||
let selectedSolutionsBySolution = [];
|
let selectedSolutionsBySolution = [];
|
||||||
|
let selectedSolutionsByAsset = [];
|
||||||
let solTodosBySolutionId = [];
|
let solTodosBySolutionId = [];
|
||||||
let insertId = -1;
|
let insertId = -1;
|
||||||
let errorMsg = '';
|
let errorMsg = '';
|
||||||
@ -84,6 +85,38 @@ export default defineEventHandler(async (event) => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (event.path.startsWith("/api/getSelectedSolutionsByAsset")) {
|
||||||
|
// get selected solutions object by asset from backend
|
||||||
|
let filteredAsset = null;
|
||||||
|
const path = event._path;
|
||||||
|
const pathSegments = path.split('/');
|
||||||
|
filteredAsset = pathSegments[pathSegments.length - 1];
|
||||||
|
|
||||||
|
try {
|
||||||
|
let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/selectedSolutionsByAssetName/${filteredAsset}`);
|
||||||
|
selectedSolutionsByAsset = res.data;
|
||||||
|
} catch (err) {
|
||||||
|
if (axios.isAxiosError(err)) {
|
||||||
|
const axiosError = err as AxiosError;
|
||||||
|
|
||||||
|
if (axiosError.response) {
|
||||||
|
// Axios error
|
||||||
|
console.error(axiosError.response.data.message);
|
||||||
|
errorMsg = axiosError.response.data.message;
|
||||||
|
} else if (axiosError.request) {
|
||||||
|
// If error was caused by the request
|
||||||
|
console.error(axiosError.request);
|
||||||
|
} else {
|
||||||
|
// Other errors
|
||||||
|
console.error('Error', axiosError.message);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// No AxiosError
|
||||||
|
console.error('Error', err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (event.path.startsWith("/api/getSelectedSolutionsBySolution")) {
|
if (event.path.startsWith("/api/getSelectedSolutionsBySolution")) {
|
||||||
// get selected solutions object by asset from backend
|
// get selected solutions object by asset from backend
|
||||||
let filteredSolution = null;
|
let filteredSolution = null;
|
||||||
@ -391,4 +424,4 @@ export default defineEventHandler(async (event) => {
|
|||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
export { solutions, solution, selectedSolutionsByCustomer, selectedSolutionsBySolution, solTodosBySolutionId, insertId, errorMsg };
|
export { solutions, solution, selectedSolutionsByAsset, selectedSolutionsByCustomer, selectedSolutionsBySolution, solTodosBySolutionId, insertId, errorMsg };
|
||||||
Reference in New Issue
Block a user