diff --git a/backend/controller/maintenanceVisitTodos.js b/backend/controller/maintenanceVisitTodos.js
index 707348a..6eb6f94 100644
--- a/backend/controller/maintenanceVisitTodos.js
+++ b/backend/controller/maintenanceVisitTodos.js
@@ -5,6 +5,8 @@ import {
getMaintenanceVisitTodosByAsset,
updateMaintenanceVisitTodoById,
deleteMaintenanceVisitTodosByPrimaryID,
+ deleteMaintenanceVisitTodosByTemplateID,
+ getMaintenanceVisitTodosByTemplate,
} from "../models/maintenanceVisitsTodosModel.js";
//create new maintenance visit todo
@@ -41,6 +43,17 @@ export const showMaintenanceVisitTodosByAsset = (req, res) => {
});
};
+//get maintenance visit todos by assetname
+export const showMaintenanceVisitTodosByTemplateId = (req, res) => {
+ getMaintenanceVisitTodosByTemplate(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
// Update maintenance visit todo
export const updateMaintenanceVisitTodo = (req, res) => {
const data = req.body;
@@ -63,4 +76,16 @@ export const deleteMaintenanceVisitTodos = (req, res) => {
res.json(results);
}
});
+};
+
+// Delete maintenance visit todos by template id
+export const deleteMaintenanceVisitTodosBytemplateId = (req, res) => {
+ const id = req.params.id;
+ deleteMaintenanceVisitTodosByTemplateID(id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
};
\ No newline at end of file
diff --git a/backend/controller/maintenanceVisits.js b/backend/controller/maintenanceVisits.js
index d22243d..5344d32 100644
--- a/backend/controller/maintenanceVisits.js
+++ b/backend/controller/maintenanceVisits.js
@@ -9,7 +9,9 @@ import {
insertMaintenanceVisit,
getMaintenanceVisitByName,
getMaintenanceVisitById,
- updateMaintenanceVisitStateById,
+ updateMaintenanceVisitById,
+ getSelectedMaintenanceVisitsByUser,
+ getSelectedMaintenanceVisitsByTemplate,
} from "../models/maintenanceVisitsModel.js";
//get all maintenance visits
@@ -34,6 +36,28 @@ export const showSelectedMaintenanceVisitsByChecklistname = (req, res) => {
});
};
+//get all selected maintenance visits by user
+export const showSelectedMaintenanceVisitsByUser = (req, res) => {
+ getSelectedMaintenanceVisitsByUser(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
+//get all selected maintenance visits by template
+export const showSelectedMaintenanceVisitsByTemplate = (req, res) => {
+ getSelectedMaintenanceVisitsByTemplate(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
//get all selected maintenance visits by customer
export const showSelectedMaintenanceVisitsByCustomer = (req, res) => {
getSelectedMaintenanceVisitsByCustomer(req.params.id, (err, results) => {
@@ -114,9 +138,9 @@ export const showMaintenanceVisitById = (req, res) => {
};
// Update maintenance visit
-export const updateMaintenanceVisitState = (req, res) => {
+export const updateMaintenanceVisit = (req, res) => {
const data = req.body;
- updateMaintenanceVisitStateById(data, (err, results) => {
+ updateMaintenanceVisitById(data, (err, results) => {
if (err) {
res.send(err);
} else {
diff --git a/backend/controller/productionOrderTodos.js b/backend/controller/productionOrderTodos.js
index 3dc758c..950360a 100644
--- a/backend/controller/productionOrderTodos.js
+++ b/backend/controller/productionOrderTodos.js
@@ -5,6 +5,7 @@ import {
getProductionOrderTodosByAsset,
updateProductionOrderTodoById,
deleteProductionOrderTodosChecklistID,
+ getProductionOrderTodosByTemplate,
} from "../models/productionOrdersTodosModel.js";
//create new production order todo
@@ -41,6 +42,18 @@ export const showProductionOrderTodosByAsset = (req, res) => {
});
};
+
+//get production order todos by template
+export const showProductionOrderTodosByTemplate = (req, res) => {
+ getProductionOrderTodosByTemplate(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
// Update production order todo
export const updateProductionOrderTodo = (req, res) => {
const data = req.body;
diff --git a/backend/controller/productionOrders.js b/backend/controller/productionOrders.js
index d492904..91ee5d4 100644
--- a/backend/controller/productionOrders.js
+++ b/backend/controller/productionOrders.js
@@ -10,7 +10,9 @@ import {
getProductionOrderByName,
deleteProductionOrderById,
getProductionOrderById,
- updateProductionOrderStateById,
+ updateProductionOrderById,
+ getSelectedProductionOrdersByTemplate,
+ getSelectedProductionOrdersByUser,
} from "../models/productionOrdersModel.js";
//get all production orders
@@ -46,6 +48,28 @@ export const showSelectedProductionOrdersByCustomer = (req, res) => {
});
};
+//get all selected production orders by user
+export const showSelectedProductionOrdersByUser = (req, res) => {
+ getSelectedProductionOrdersByUser(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
+//get all selected production orders by template
+export const showSelectedProductionOrdersByTemplate = (req, res) => {
+ getSelectedProductionOrdersByTemplate(req.params.id, (err, results) => {
+ if (err) {
+ res.send(err);
+ } else {
+ res.json(results);
+ }
+ });
+};
+
//get all selected production orders by ticketnumber
export const showSelectedProductionOrdersByTicketnumber = (req, res) => {
getSelectedProductionOrdersByTicketnumber(req.params.id, (err, results) => {
@@ -126,9 +150,9 @@ export const showProductionOrderById = (req, res) => {
};
// Update production order
-export const updateProductionOrderState = (req, res) => {
+export const updateProductionOrder = (req, res) => {
const data = req.body;
- updateProductionOrderStateById(data, (err, results) => {
+ updateProductionOrderById(data, (err, results) => {
if (err) {
res.send(err);
} else {
diff --git a/backend/models/maintenanceVisitsModel.js b/backend/models/maintenanceVisitsModel.js
index d699fc4..70153b4 100644
--- a/backend/models/maintenanceVisitsModel.js
+++ b/backend/models/maintenanceVisitsModel.js
@@ -28,6 +28,34 @@ export const getSelectedMaintenanceVisitsByChecklistname = async (selected, resu
}
};
+//get all selected maintenance visits by template
+export const getSelectedMaintenanceVisitsByTemplate = async (selected, result) => {
+ try {
+ let sql = `SELECT * FROM maintenancevisits WHERE templateID = ? ORDER BY name ASC`;
+ const results = await ownConn.execute(sql, [selected])
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
+//get all selected maintenance visits by user
+export const getSelectedMaintenanceVisitsByUser = async (selected, result) => {
+ try {
+ let sql = `SELECT * FROM maintenancevisits WHERE LOWER(user) LIKE '%${selected.toLowerCase()}%' ORDER BY name ASC`;
+ const results = await ownConn.execute(sql)
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
//get all selected maintenance visits by customer
export const getSelectedMaintenanceVisitsByCustomer = async (selected, result) => {
try {
@@ -75,6 +103,7 @@ export const deleteMaintenanceVisitById = async (id, result) => {
try {
let sql = `DELETE FROM maintenancevisits WHERE primaryID = ?`;
const results = await ownConn.query(sql, [id])
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
@@ -127,11 +156,11 @@ export const getMaintenanceVisitById = async (id, result) => {
};
// Update maintenance visit state to Database
-export const updateMaintenanceVisitStateById = async (data, result) => {
+export const updateMaintenanceVisitById = async (data, result) => {
try {
const id = data.primaryID;
- let sql = `UPDATE maintenancevisits SET state = ? WHERE primaryID = ?`;
- const results = await ownConn.query(sql, [data.state, id])
+ let sql = `UPDATE maintenancevisits SET primaryID = ?, name = ?, templateID = ?, maintenanceType = ?, state = ?, creationDate = ?, completionDate = ?, user = ?, customer = ?, customerID = ?, templateNotes = ?, type = ?, timeSpent = ?, notes = ? WHERE primaryID = ?`;
+ const results = await ownConn.query(sql, [data.primaryID, data.name, data.templateID, data.maintenanceType, data.state, data.creationDate, data.completionDate, data.user, data.customer, data.customerID, data.templateNotes, data.type, data.timeSpent, data.notes, id])
results.insertId = results.insertId.toString();
result(null, results);
}
diff --git a/backend/models/maintenanceVisitsTodosModel.js b/backend/models/maintenanceVisitsTodosModel.js
index 1c81333..ea8ad4f 100644
--- a/backend/models/maintenanceVisitsTodosModel.js
+++ b/backend/models/maintenanceVisitsTodosModel.js
@@ -42,12 +42,26 @@ export const getMaintenanceVisitTodosByAsset = async (id, result) => {
}
};
+//get maintenance visit todo by template
+export const getMaintenanceVisitTodosByTemplate = async (id, result) => {
+ try {
+ let sql = `SELECT * FROM maintenancevisittodos WHERE templateID = ? ORDER BY primaryID ASC`;
+ const results = await ownConn.execute(sql, [id])
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
// Update maintenance visit todo to Database
export const updateMaintenanceVisitTodoById = async (data, result) => {
try {
const id = data.primaryID;
let sql = `UPDATE maintenancevisittodos SET step = ?, asset = ?, task = ?, comment = ?, done = ? WHERE primaryID = ?`;
- const results = await ownConn.query(sql, [data.step, data.asset, data.task, data.comment, id])
+ const results = await ownConn.query(sql, [data.step, data.asset, data.task, data.comment, data.done, id])
results.insertId = results.insertId.toString();
result(null, results);
}
@@ -63,6 +77,22 @@ export const deleteMaintenanceVisitTodosByPrimaryID = async (id, result) => {
try {
let sql = `DELETE FROM maintenancevisittodos WHERE primaryID = ?`;
const results = await ownConn.query(sql, [id])
+ results.insertId = results.insertId.toString();
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
+// Delete maintenance visit todos by template to Database
+export const deleteMaintenanceVisitTodosByTemplateID = async (id, result) => {
+ try {
+ let sql = `DELETE FROM maintenancevisittodos WHERE templateID = ?`;
+ const results = await ownConn.query(sql, [id])
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
diff --git a/backend/models/productionOrdersModel.js b/backend/models/productionOrdersModel.js
index b727c8a..d19194d 100644
--- a/backend/models/productionOrdersModel.js
+++ b/backend/models/productionOrdersModel.js
@@ -3,7 +3,7 @@ import ownConn from "../dbConfig.js";
//get all production orders
export const getProductionOrders = async (result) => {
try {
- let sql = `SELECT * FROM productionorders ORDER BY name ASC`;
+ let sql = `SELECT * FROM productionorders ORDER BY ticketNumber ASC`;
const results = await ownConn.execute(sql)
result(null, results);
}
@@ -17,7 +17,7 @@ export const getProductionOrders = async (result) => {
//get all selected production orders by ticketnumber
export const getSelectedProductionOrdersByTicketnumber = async (selected, result) => {
try {
- let sql = `SELECT * FROM productionorders WHERE ticketNumber LIKE '%${selected}%' ORDER BY ticketNumber ASC`;
+ let sql = `SELECT * FROM productionorders WHERE ticketNumber = ? ORDER BY name ASC`;
const results = await ownConn.execute(sql)
result(null, results);
}
@@ -42,6 +42,34 @@ export const getSelectedProductionOrdersByCustomer = async (selected, result) =>
}
};
+//get all selected production orders by user
+export const getSelectedProductionOrdersByUser = async (selected, result) => {
+ try {
+ let sql = `SELECT * FROM productionorders WHERE LOWER(user) LIKE '%${selected.toLowerCase()}%' ORDER BY name ASC`;
+ const results = await ownConn.execute(sql)
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
+//get all selected production orders by template
+export const getSelectedProductionOrdersByTemplate = async (selected, result) => {
+ try {
+ let sql = `SELECT * FROM productionorders WHERE templateID = ? ORDER BY name ASC`;
+ const results = await ownConn.execute(sql, [selected])
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
//get all selected production orders by state
export const getSelectedProductionOrdersByState = async (selected, result) => {
try {
@@ -89,6 +117,7 @@ export const deleteProductionOrderById = async (id, result) => {
try {
let sql = `DELETE FROM productionorders WHERE ticketNumber = ?`;
const results = await ownConn.query(sql, [id])
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
@@ -141,11 +170,11 @@ export const getProductionOrderById = async (id, result) => {
};
// Update production order state to Database
-export const updateProductionOrderStateById = async (data, result) => {
+export const updateProductionOrderById = async (data, result) => {
const id = data.ticketNumber;
try {
- let sql = `UPDATE productionorders SET state = ? WHERE ticketNumber = ?`;
- const results = await ownConn.query(sql, [data.state, id])
+ let sql = `UPDATE productionorders SET name = ?, templateID = ?, customer = ?, customerID = ?, asset = ?, state = ?, creationDate = ?, completionDate = ?, user = ?, templateDescription = ?, templateNotes = ?, timeSpent = ?, notes = ? WHERE ticketNumber = ?`;
+ const results = await ownConn.query(sql, [data.name, data.templateID, data.customer, data.customerID, data.asset, data.state, data.creationDate, data.completionDate, data.user, data.templateDescription, data.templateNotes, data.timeSpent, data.notes, id])
results.insertId = results.insertId.toString();
result(null, results);
}
diff --git a/backend/models/productionOrdersTodosModel.js b/backend/models/productionOrdersTodosModel.js
index 790bc5c..faa4be1 100644
--- a/backend/models/productionOrdersTodosModel.js
+++ b/backend/models/productionOrdersTodosModel.js
@@ -4,6 +4,7 @@ import ownConn from "../dbConfig.js";
export const insertProductionOrderTodo = async (data, result) => {
try {
const results = await ownConn.query(`INSERT INTO productionordertodos(templateID, step, asset, task, comment, done) VALUES(?, ?, ?, ?, ?, ?)`, [data.templateID, data.step, data.asset, data.task, data.comment, data.done]);
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
@@ -27,7 +28,7 @@ export const getProductionOrderTodosById = async (id, result) => {
}
};
-//get single production order todo by asset
+//get production order todo by asset
export const getProductionOrderTodosByAsset = async (id, result) => {
try {
let sql = `SELECT * FROM productionordertodos WHERE asset = ? ORDER BY primaryID ASC`;
@@ -41,12 +42,27 @@ export const getProductionOrderTodosByAsset = async (id, result) => {
}
};
+//get production order todo by template
+export const getProductionOrderTodosByTemplate = async (id, result) => {
+ try {
+ let sql = `SELECT * FROM productionordertodos WHERE templateID = ? ORDER BY primaryID ASC`;
+ const results = await ownConn.execute(sql, [id])
+ result(null, results);
+ }
+ catch (err) {
+ // Manage Errors
+ console.log("SQL error : ", err);
+ result(err, null);
+ }
+};
+
// Update production order todo to Database
export const updateProductionOrderTodoById = async (data, result) => {
try {
const id = data.primaryID;
let sql = `UPDATE productionordertodos SET step = ?, asset = ?, task = ?, comment = ?, done = ? WHERE primaryID = ?`;
const results = await ownConn.query(sql, [data.step, data.asset, data.task, data.comment, data.done, id])
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
@@ -61,6 +77,7 @@ export const deleteProductionOrderTodosChecklistID = async (id, result) => {
try {
let sql = `DELETE FROM productionordertodos WHERE templateID = ?`;
const results = await ownConn.query(sql, [id])
+ results.insertId = results.insertId.toString();
result(null, results);
}
catch (err) {
diff --git a/backend/routes/routes.js b/backend/routes/routes.js
index 05fbf96..e180fb2 100644
--- a/backend/routes/routes.js
+++ b/backend/routes/routes.js
@@ -19,11 +19,13 @@ import {
showSelectedMaintenanceVisitsByCustomer,
showSelectedMaintenanceVisitsByState,
showSelectedMaintenanceVisitsByDate,
+ showSelectedMaintenanceVisitsByTemplate,
+ showSelectedMaintenanceVisitsByUser,
deleteMaintenanceVisit,
createMaintenanceVisit,
showMaintenanceVisitByName,
showMaintenanceVisitById,
- updateMaintenanceVisitState,
+ updateMaintenanceVisit,
} from "../controller/maintenanceVisits.js"
import {
@@ -32,6 +34,8 @@ import {
showMaintenanceVisitTodosByAsset,
updateMaintenanceVisitTodo,
deleteMaintenanceVisitTodos,
+ deleteMaintenanceVisitTodosBytemplateId,
+ showMaintenanceVisitTodosByTemplateId,
} from "../controller/maintenanceVisitTodos.js"
import {
@@ -60,17 +64,20 @@ import {
showSelectedProductionOrdersByTicketnumber,
showSelectedProductionOrdersByDate,
showSelectedProductionOrdersByState,
+ showSelectedProductionOrdersByTemplate,
+ showSelectedProductionOrdersByUser,
deleteProductionOrder,
createProductionOrder,
showProductionOrderByName,
showProductionOrderById,
- updateProductionOrderState,
+ updateProductionOrder,
} from "../controller/productionOrders.js";
import {
createProductionOrderTodos,
showProductionOrderTodosById,
showProductionOrderTodosByAsset,
+ showProductionOrderTodosByTemplate,
updateProductionOrderTodo,
deleteProductionOrderTodos,
} from "../controller/productionOrderTodos.js";
@@ -409,6 +416,12 @@ router.get("/selectedProductionOrdersByCustomer/:id", showSelectedProductionOrde
//get all production orders by selected state
router.get("/selectedProductionOrdersByState/:id", showSelectedProductionOrdersByState)
+//get all production orders by selected template
+router.get("/selectedProductionOrdersByTemplate/:id", showSelectedProductionOrdersByTemplate)
+
+//get all production orders by selected user
+router.get("/selectedProductionOrdersByUser/:id", showSelectedProductionOrdersByUser)
+
//get all production orders by selected date
router.get("/selectedProductionOrdersByDate/:id", showSelectedProductionOrdersByDate)
@@ -424,9 +437,8 @@ router.get("/productionOrderByName/:id", showProductionOrderByName);
//get single production order by ticketNumber
router.get("/productionOrder/:id", showProductionOrderById);
-// Update production order state
-router.put("/productionOrderState", updateProductionOrderState);
-
+// Update production order
+router.put("/productionOrder", updateProductionOrder);
// routes with production order todos:
@@ -439,10 +451,13 @@ router.get("/productionOrderTodos/:id", showProductionOrderTodosById);
//get all production order todos by assetname
router.get("/productionOrderTodosByAsset/:id", showProductionOrderTodosByAsset);
+//get all production order todos by template id
+router.get("/productionOrderTodosByTemplateID/:id", showProductionOrderTodosByTemplate);
+
// Update production order todo
router.put("/productionOrderTodos", updateProductionOrderTodo);
-// Delete production order todos
+// Delete production order todo
router.delete("/productionOrderTodos/:id", deleteProductionOrderTodos);
@@ -460,6 +475,12 @@ router.get("/selectedMaintenanceVisitsByDate/:id", showSelectedMaintenanceVisits
//get all maintenance visits by selected customer
router.get("/selectedMaintenanceVisitsByCustomer/:id", showSelectedMaintenanceVisitsByCustomer)
+//get all maintenance visits by selected user
+router.get("/selectedMaintenanceVisitsByUser/:id", showSelectedMaintenanceVisitsByUser)
+
+//get all maintenance visits by selected template
+router.get("/selectedMaintenanceVisitsByTemplate/:id", showSelectedMaintenanceVisitsByTemplate)
+
//get all maintenance visits by selected state
router.get("/selectedMaintenanceVisitsByState/:id", showSelectedMaintenanceVisitsByState)
@@ -475,8 +496,8 @@ router.get("/maintenanceVisitByName/:id", showMaintenanceVisitByName);
//get single maintenance visit by primaryId
router.get("/maintenanceVisit/:id", showMaintenanceVisitById);
-// Update maintenance visit state
-router.put("/maintenanceVisitState", updateMaintenanceVisitState);
+// Update maintenance visit
+router.put("/maintenanceVisit", updateMaintenanceVisit);
@@ -490,12 +511,18 @@ router.get("/maintenanceVisitTodos/:id", showMaintenanceVisitTodosById);
//get all maintenance visit todos by assetname
router.get("/maintenanceVisitTodosByAsset/:id", showMaintenanceVisitTodosByAsset);
+//get all maintenance visit todos by template id
+router.get("/maintenanceVisitTodosByTemplateId/:id", showMaintenanceVisitTodosByTemplateId);
+
// Update maintenance visit todo
router.put("/maintenanceVisitTodos", updateMaintenanceVisitTodo);
// Delete maintenance visit todos
router.delete("/maintenanceVisitTodos/:id", deleteMaintenanceVisitTodos);
+// Delete maintenance visit todos by template id
+router.delete("/maintenanceVisitTodosByTemplateID/:id", deleteMaintenanceVisitTodosBytemplateId);
+
// routes with issue slips:
diff --git a/components/Dashboard.vue b/components/Dashboard.vue
index 70afc58..182529d 100644
--- a/components/Dashboard.vue
+++ b/components/Dashboard.vue
@@ -2,14 +2,22 @@
@@ -24,6 +32,7 @@ const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
const modeChangedLocalstorage = computed(() => store.state.modeDashboard);
const darkMode = ref('');
+const loggedInUsername = ref('');
const getSession = async () => {
if (modeChangedLocalstorage.value) {
@@ -37,6 +46,18 @@ const getSession = async () => {
}
}
+const goToMVIList = () => {
+ store.commit('activateFilteredUserTerm');
+ store.commit('activateFiltered');
+ store.commit('changeToInstancelist');
+};
+
+const goToPOIList = () => {
+ store.commit('activateFilteredUserTerm');
+ store.commit('activateFiltered');
+ store.commit('changeToInstancelist');
+};
+
function getItem(item) {
if (process.client) {
return localStorage.getItem(item)
@@ -105,7 +126,8 @@ export default {
gap: 2.5rem;
}
-input {
+input,
+button {
display: flex;
flex-direction: row;
align-items: center;
@@ -120,6 +142,10 @@ input {
font: 400 0.875rem/2rem Overpass, sans-serif;
}
+button:hover {
+ cursor: pointer;
+}
+
.input-darkmode {
color: #fff;
background-color: #343434;
diff --git a/components/TemplateSearch.vue b/components/TemplateSearch.vue
index 8daa560..96452c7 100644
--- a/components/TemplateSearch.vue
+++ b/components/TemplateSearch.vue
@@ -1,7 +1,7 @@
-
+
Template:
- Template name
+ {{ template.name }}
@@ -10,10 +10,19 @@
import { ref, onMounted, watch } from 'vue';
import { useStore } from 'vuex';
import { computed } from 'vue';
+import Axios from '../axios.config.js';
+import clientsideConfig from '../../clientsideConfig.js';
+const route = useRoute()
+const id = computed(() => route)
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
+const template = ref({});
+const chosenMVTId = computed(() => store.state.chosenMVTId);
+const chosenPOTId = computed(() => store.state.chosenPOTId);
+const notAllInstancesIcon = computed(() => store.state.notAllInstancesIcon);
+
const darkMode = ref('');
const getSession = async () => {
@@ -25,6 +34,31 @@ const getSession = async () => {
}
}
+// get maintenance visit template from id
+const getTById = async () => {
+ if (notAllInstancesIcon.value) {
+ if (id.value.fullPath == '/maintenanceVisits') {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitTemplate/${chosenMVTId.value}`
+ );
+ template.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ } else if (id.value.fullPath == '/productionOrders') {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getProductionOrderTemplate/${chosenPOTId.value}`
+ );
+ template.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+ }
+}
+
function getItem(item) {
if (process.client) {
return localStorage.getItem(item)
@@ -36,7 +70,8 @@ function getItem(item) {
watch(modeChanged, getSession)
onMounted(async () => {
- await getSession();
+ getSession();
+ await getTById();
});
diff --git a/components/server/Accounting.vue b/components/server/Accounting.vue
index 9225982..e84acc5 100644
--- a/components/server/Accounting.vue
+++ b/components/server/Accounting.vue
@@ -487,12 +487,14 @@ const addIssueSlip = async () => {
const time = today.getHours() + ":" + today.getMinutes();
const dateTime = date + ' ' + time;
let allFine = true;
- newOIs.value.forEach(oi => {
- if (oi.article.length === 0 && oi.amount.length === 0 && oi.price.length === 0 && oi.comment.length === 0) {
- alert(`Please add data for all ordering info.`);
- allFine = false
- }
- })
+ if (newOIs.value.length != 0) {
+ newOIs.value.forEach(oi => {
+ if (oi.article.length === 0 && oi.amount.length === 0 && oi.price.length === 0 && oi.comment.length === 0) {
+ alert(`Please add data for all ordering info.`);
+ allFine = false
+ }
+ })
+ }
if (!allFine) {
return
}
@@ -526,22 +528,24 @@ const addIssueSlip = async () => {
egressBillDate: newEgressBillDate.value,
egressBill: newEgressBill.value,
});
- newOIs.value.forEach(async oi => {
- try {
- const res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addOrderingInfo`,
- {
- issueSlipID: response.data,
- article: oi.article,
- amount: oi.amount,
- price: oi.price,
- comment: oi.comment,
- });
- } catch (err) {
- console.log(err);
- }
- store.commit('resetStore');
- store.commit('changeToIssueSliplist');
- })
+ if (newOIs.value.length != 0) {
+ newOIs.value.forEach(async oi => {
+ try {
+ const res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addOrderingInfo`,
+ {
+ issueSlipID: response.data,
+ article: oi.article,
+ amount: oi.amount,
+ price: oi.price,
+ comment: oi.comment,
+ });
+ } catch (err) {
+ console.log(err);
+ }
+ })
+ }
+ store.commit('resetStore');
+ store.commit('changeToIssueSliplist');
} catch (err) {
console.log(err.response.statusText);
}
diff --git a/components/server/Asset.vue b/components/server/Asset.vue
index 21dfba7..9f17d2c 100644
--- a/components/server/Asset.vue
+++ b/components/server/Asset.vue
@@ -331,7 +331,14 @@ const updateNewCustomerID = async () => {
const triggerBackendCallsWithDelay = async (fetchDataFunc) => {
setTimeout(() => {
fetchDataFunc();
- }, 1500);
+ }, 2000);
+}
+
+// include delay to avoid 503 error
+const triggerBackendCallsWithSmallDelay = async (fetchDataFunc) => {
+ setTimeout(() => {
+ fetchDataFunc();
+ }, 500);
}
const getSession = async () => {
@@ -356,7 +363,7 @@ watch(modeChanged, getSession)
onMounted(async () => {
await getSession();
- await getItemById();
+ triggerBackendCallsWithSmallDelay(getItemById);
triggerBackendCallsWithDelay(getConfigItems);
triggerBackendCallsWithDelay(getCustomers);
});
diff --git a/components/server/AssetSolutionList.vue b/components/server/AssetSolutionList.vue
index ac783e2..4fc3118 100644
--- a/components/server/AssetSolutionList.vue
+++ b/components/server/AssetSolutionList.vue
@@ -159,7 +159,7 @@ watch(modeChanged, getSession)
onMounted(async () => {
await getSession();
- getItemById();
+ await getItemById();
});
diff --git a/components/server/InstanceChecklist.vue b/components/server/InstanceChecklist.vue
index 80b8986..07ca131 100644
--- a/components/server/InstanceChecklist.vue
+++ b/components/server/InstanceChecklist.vue
@@ -1,5 +1,5 @@
-
+
+
@@ -84,15 +280,13 @@ export default {
\ No newline at end of file
diff --git a/components/server/InstanceChecklistMVI.vue b/components/server/InstanceChecklistMVI.vue
new file mode 100644
index 0000000..dd4a197
--- /dev/null
+++ b/components/server/InstanceChecklistMVI.vue
@@ -0,0 +1,532 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/components/server/Issue.vue b/components/server/Issue.vue
index 4687943..6958b26 100644
--- a/components/server/Issue.vue
+++ b/components/server/Issue.vue
@@ -106,6 +106,23 @@ const newState = ref('');
const newAmount = ref('');
const newProperties = ref('');
+const getSession = async () => {
+ const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
+ if (loggedInUserDarkModeBool == 1) {
+ darkMode.value = true;
+ } else {
+ darkMode.value = false;
+ }
+}
+
+function getItem(item) {
+ if (process.client) {
+ return localStorage.getItem(item)
+ } else {
+ return undefined
+ }
+}
+
//get all issue
const getIssues = async () => {
try {
@@ -211,23 +228,6 @@ const triggerBackendCallsWithDelay = async (fetchDataFunc) => {
watch(deleteBool, confirmDeleteIssue);
watch(modeChanged, getSession)
-const getSession = async () => {
- const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
- if (loggedInUserDarkModeBool == 1) {
- darkMode.value = true;
- } else {
- darkMode.value = false;
- }
-}
-
-function getItem(item) {
- if (process.client) {
- return localStorage.getItem(item)
- } else {
- return undefined
- }
-}
-
onMounted(async () => {
await getSession();
await getIssueById();
diff --git a/components/server/IssueSlip.vue b/components/server/IssueSlip.vue
index 0d049e8..9dee195 100644
--- a/components/server/IssueSlip.vue
+++ b/components/server/IssueSlip.vue
@@ -19,8 +19,12 @@
Ticket No.:
-
{{ issueSlip.ticketNo }}
+
+ {{ issueSlip.ticketNo }}
+
User:
@@ -67,14 +71,15 @@
-
Ticket No.:
+
Production order:
-
+
User:
@@ -131,6 +136,7 @@ const newCustomer = ref('');
const newUser = ref('');
const newNotes = ref('');
const newDeliveryAddress = ref('');
+const chosenTemplate = ref('');
// get issue slip from id
const getIssueSlipById = async () => {
@@ -146,13 +152,24 @@ const getIssueSlipById = async () => {
}
}
+const goToChosenPOI = (id) => {
+ store.commit('setChosenPOI', id);
+ store.commit('changeToInstance');
+};
+
// update issue slip fields in the store
-const updateIS = () => {
- const is = {
+const updateIS = async (newPoiId = -1) => {
+ let is = {};
+ if (!(newPoiId == '-1')) {
+ // Find the object with the selected Name
+ const selectedObject = productionOrders.value.find(obj => obj.name === newPoiId);
+ // Get the ticketNumber
+ newTicketNo.value = selectedObject ? selectedObject.ticketNumber : null;
+ }
+ is = {
customerId: newCustomerID.value,
customer: newCustomer.value,
- // ticketNo: newTicketNo.value,
- ticketNo: 1,
+ ticketNo: newTicketNo.value,
notes: newNotes.value,
user: newUser.value,
deliveryAddress: newDeliveryAddress.value,
@@ -218,15 +235,14 @@ const getCustomers = async () => {
}
}
-//get all production orders
+//get all productionOrder instances
const getProductionOrders = async () => {
- // try {
- // const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllCustomers`
- // );
- // customers.value = response.data;
- // } catch (err) {
- // console.log(err.response.statusText);
- // }
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllProductionOrderInstances`);
+ productionOrders.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
}
const confirmDeleteIssueSlip = async () => {
@@ -498,4 +514,16 @@ export default {
padding: 0.4rem;
border-radius: 0.3125rem;
}
+
+#nuxt-link {
+ text-decoration: none;
+}
+
+.nuxt-link-darkmode {
+ color: white;
+}
+
+.nuxt-link-lightmode {
+ color: #000;
+}
\ No newline at end of file
diff --git a/components/server/IssueTable.vue b/components/server/IssueTable.vue
index 0ec64b5..1cc30e4 100644
--- a/components/server/IssueTable.vue
+++ b/components/server/IssueTable.vue
@@ -67,6 +67,23 @@ const issueSearchFilter = ref('');
const darkMode = ref('');
const issues = ref([]);
+const getSession = async () => {
+ const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
+ if (loggedInUserDarkModeBool == 1) {
+ darkMode.value = true;
+ } else {
+ darkMode.value = false;
+ }
+}
+
+function getItem(item) {
+ if (process.client) {
+ return localStorage.getItem(item)
+ } else {
+ return undefined
+ }
+}
+
// update search term
const updateSearchTerm = async () => {
issueSearchFilter.value = '';
@@ -114,24 +131,6 @@ const searchIssue = async () => {
watch(stateFilter, getIssues);
watch(searchable, updateSearchTerm);
-
-const getSession = async () => {
- const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
- if (loggedInUserDarkModeBool == 1) {
- darkMode.value = true;
- } else {
- darkMode.value = false;
- }
-}
-
-function getItem(item) {
- if (process.client) {
- return localStorage.getItem(item)
- } else {
- return undefined
- }
-}
-
watch(modeChanged, getSession)
onMounted(async () => {
diff --git a/components/server/MaintenanceVisitsInstance.vue b/components/server/MaintenanceVisitsInstance.vue
index a69a21e..51af744 100644
--- a/components/server/MaintenanceVisitsInstance.vue
+++ b/components/server/MaintenanceVisitsInstance.vue
@@ -1,29 +1,38 @@
-
- Instance ID
+
+ {{
+ mvi.name }}
+
Template ID:
-
...
+
{{ mvi.templateID }}
Customer:
-
...
+
{{ mvi.customer }}
Type:
-
...
+
{{ mvi.type }}
+
-
+
Template notes:
-
...
+
{{ mvi.templateNotes }}
+
@@ -32,15 +41,126 @@
Maintenance type:
-
...
+
{{ mvi.maintenanceType }}
+
State:
-
...
+
{{ mvi.state }}
+
User:
-
...
+
{{ mvi.user }}
+
+
+
+
+
+
Creation date:
+
{{ mvi.creationDate }}
+
+
+
Completion date:
+
{{ mvi.completionDate }}
+
+
+
+
Time spent:
+
{{ mvi.timeSpent }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Template ID:
+
Template name:
+
{{ chosenMVTId }}
+
+
+
+
Customer:
+
{{ mvi.customer }}
+
+
+
+
+
+
+
+
+
Template notes:
+
+
+
+
+
+
+
+
+
+
+
User:
+
@@ -75,11 +196,258 @@
import { ref, onMounted, watch } from 'vue';
import { useStore } from 'vuex';
import { computed } from 'vue';
+import Axios from '../axios.config.js';
+import clientsideConfig from '../../clientsideConfig.js';
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
+const editable = computed(() => store.state.editable);
+const chosenMVIId = computed(() => store.state.chosenMITId);
+const chosenMVTId = computed(() => store.state.chosenMVTId);
+const deleteBool = computed(() => store.state.deleteBool);
+const addBool = computed(() => store.state.new);
+
const darkMode = ref('');
+const mvtSelected = ref('');
+
+const mvi = ref({});
+const mvt = ref({});
+const customers = ref([]);
+
+const newName = ref('');
+const newTemplateID = ref('');
+const chosenTemplate = ref('');
+const newCustomerID = ref('');
+const newCustomer = ref('');
+const newMaintenanceType = ref('');
+const newUser = ref('');
+const newState = ref('');
+const newNotes = ref('');
+const newTemplateNotes = ref('');
+const newType = ref('');
+const newCreationDate = ref('');
+const newCompletionDate = ref('');
+const newTimeSpent = ref('');
+const maintenanceVisitInstances = ref([]);
+const maintenanceVisitTemplates = ref([]);
+const userList = ref([]);
+
+//get all customers
+const getCustomers = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllCustomers`
+ );
+ customers.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+//get all maintenance visit templates
+const getMaintenanceVisitTemplates = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllMaintenanceVisitTemplates`);
+ maintenanceVisitTemplates.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+// get maintenance visit template from id
+const getMVTById = async () => {
+ if (chosenMVTId.value == '-1') {
+ mvtSelected.value = false;
+ await getMaintenanceVisitTemplates();
+ } else {
+ mvtSelected.value = true;
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitTemplate/${chosenMVTId.value}`
+ );
+ mvt.value = response.data;
+ mvi.value.customer = mvt.value.customer;
+ mvi.value.customerID = mvt.value.customerID;
+ newCustomer.value = mvt.value.customer;
+ newCustomerID.value = mvt.value.customerID;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+ await getMaintenanceVisitInstances();
+}
+
+// get maintenance visit template from id
+const getChosenMVTById = async (newMvtId) => {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitTemplate/${newMvtId}`
+ );
+ mvt.value = response.data;
+ mvi.value.customer = mvt.value.customer;
+ mvi.value.customerID = mvt.value.customerID;
+ newCustomer.value = mvt.value.customer;
+ newCustomerID.value = mvt.value.customerID;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+const confirmDeleteMVI = async () => {
+ if (deleteBool.value === true) {
+ if (confirm("Do you really want to delete this maintenance visit instance? It cannot be undone!")) {
+ try {
+ await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteMaintenanceVisitInstance/${chosenMVIId.value}`);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ try {
+ await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteTodosMVI/${chosenMVIId.value}`);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ store.commit('undoDelete');
+ store.commit('resetStore');
+ store.commit('deactivateSearch');
+ store.commit('changeToInstancelist');
+ store.commit('seeAllIcon');
+ } else {
+ store.commit('undoDelete');
+ }
+ }
+}
+
+//get all users
+const getUsers = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllEmployees`);
+ userList.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+//update data
+const updateMVI = async () => {
+ if (mvi.value.name.trim() === "") {
+ alert("Please add a maintenance visit instance name!");
+ return;
+ } else {
+ var counter = 0;
+ // check if maintenance visit instance name already exists
+ maintenanceVisitInstances.value.forEach(m => {
+ if (m.name === mvi.value.name) {
+ counter += 1;
+ }
+ });
+ if (counter == 2) {
+ alert("This maintenance visit instance name already exists. Please choose an unique maintenance visit instance name or modify respectively delete the old one!");
+ mvi.value.name = '';
+ return;
+ }
+ try {
+ await Axios.put(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateMaintenanceVisitInstance`,
+ {
+ primaryID: mvi.value.primaryID,
+ name: mvi.value.name,
+ templateID: mvi.value.templateID,
+ maintenanceType: mvi.value.maintenanceType,
+ state: mvi.value.state,
+ creationDate: mvi.value.creationDate,
+ completionDate: mvi.value.completionDate,
+ user: mvi.value.user,
+ customerID: mvi.value.customerID,
+ customer: mvi.value.customer,
+ type: mvi.value.type,
+ templateNotes: mvi.value.templateNotes,
+ timeSpent: mvi.value.timeSpent,
+ notes: mvi.value.notes,
+ }
+ )
+ await getMVIById();
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+//get all maintenance visit instances
+const getMaintenanceVisitInstances = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllMaintenanceVisitInstances`);
+ maintenanceVisitInstances.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+// update maintenance visit instance fields in the store
+const updateMaintenanceVisitInstance = async (newMvtId = -1) => {
+ let maintenanceVisitInstance = {};
+ if (mvtSelected.value) {
+ maintenanceVisitInstance = {
+ name: newName.value,
+ templateID: chosenMVTId.value,
+ maintenanceType: newMaintenanceType.value,
+ state: newState.value,
+ creationDate: newCreationDate.value,
+ completionDate: newCompletionDate.value,
+ user: newUser.value,
+ customerID: newCustomerID.value,
+ customer: newCustomer.value,
+ templateNotes: newTemplateNotes.value,
+ type: newType.value,
+ timeSpent: newTimeSpent.value,
+ notes: newNotes.value,
+ };
+ } else {
+ if (!(newMvtId == '-1')) {
+ // Find the object with the selected Name
+ const selectedObject = maintenanceVisitTemplates.value.find(obj => obj.name === newMvtId);
+ // Get the templateID
+ newTemplateID.value = selectedObject ? selectedObject.checklistID : null;
+ await getChosenMVTById(newTemplateID.value);
+ }
+ maintenanceVisitInstance = {
+ name: newName.value,
+ templateID: newTemplateID.value,
+ maintenanceType: newMaintenanceType.value,
+ state: newState.value,
+ creationDate: newCreationDate.value,
+ completionDate: newCompletionDate.value,
+ user: newUser.value,
+ customerID: newCustomerID.value,
+ customer: newCustomer.value,
+ templateNotes: newTemplateNotes.value,
+ type: newType.value,
+ timeSpent: newTimeSpent.value,
+ notes: newNotes.value,
+ };
+ }
+ store.commit('updateMaintenanceVisitInstanceComponent', maintenanceVisitInstance);
+}
+
+// get maintenance visit instance from id
+const getMVIById = async () => {
+ if (!addBool.value) {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitInstance/${chosenMVIId.value}`
+ );
+ mvi.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+// include delay to avoid 503 error
+const triggerBackendCallsWithDelay = async (fetchDataFunc) => {
+ setTimeout(() => {
+ fetchDataFunc();
+ }, 1500);
+}
const getSession = async () => {
const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
@@ -99,9 +467,14 @@ function getItem(item) {
}
watch(modeChanged, getSession)
+watch(deleteBool, confirmDeleteMVI);
onMounted(async () => {
- await getSession();
+ getSession();
+ await getMVIById();
+ await getMVTById();
+ triggerBackendCallsWithDelay(getUsers);
+ triggerBackendCallsWithDelay(getCustomers);
});
@@ -143,6 +516,22 @@ export default {
sans-serif;
}
+.select-lightmode {
+ border: none;
+ color: black;
+ background: #EBEBEB;
+ padding: 0.4rem;
+ border-radius: 0.3125rem;
+}
+
+.select-darkmode {
+ border: none;
+ color: white;
+ background: #212121;
+ padding: 0.4rem;
+ border-radius: 0.3125rem;
+}
+
.h2-darkmode {
color: #fff;
}
@@ -199,6 +588,36 @@ export default {
font: 400 0.75rem/250% Overpass, sans-serif;
}
+.h2-darkmode {
+ color: #fff;
+}
+
+.h2-lightmode {
+ color: #000;
+}
+
+.h2-input-darkmode {
+ background-color: #212121;
+}
+
+.h2-input-lightmode {
+ background-color: #EBEBEB;
+}
+
+.input {
+ border: none;
+}
+
+.mvi-name-input {
+ /* padding: 1rem 0; */
+ margin: 1rem;
+ font-size: initial;
+ letter-spacing: 5%;
+ text-decoration-line: underline;
+ font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica,
+ sans-serif;
+}
+
.data-darkmode {
background-color: #212121;
color: #fff;
@@ -268,4 +687,8 @@ export default {
padding: 0.625rem 1.875rem 0.625rem 1.25rem;
padding-top: 0rem;
}
+
+.templateNotes {
+ padding-left: 1.8rem;
+}
\ No newline at end of file
diff --git a/components/server/MaintenanceVisitsInstanceTable.vue b/components/server/MaintenanceVisitsInstanceTable.vue
index b3dd61b..d259e49 100644
--- a/components/server/MaintenanceVisitsInstanceTable.vue
+++ b/components/server/MaintenanceVisitsInstanceTable.vue
@@ -1,4 +1,14 @@
+
+
Instances:
@@ -8,8 +18,8 @@
:class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">
ID
|
- Maintenance type |
+ :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">
+ Name
State |
@@ -21,39 +31,158 @@
Completion date
User |
-
+
|
- ... |
+
+ {{ instance.primaryID }}
+
+
- ... |
+ :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">
+
+ {{ instance.name }}
+
+
- ... |
+ {{ instance.state }}
- ... |
+ {{ instance.creationDate }}
- ... |
- ... |
+ {{ instance.completionDate }}
+ {{ instance.user }} |
-
@@ -162,6 +300,28 @@ td {
color: #000;
}
+.data-darkmode {
+ background-color: #212121;
+ color: #fff;
+}
+
+.data-lightmode {
+ background-color: #EBEBEB;
+ color: #000;
+}
+
+.mvi-search {
+ display: flex;
+ align-items: center;
+ padding: 0.625em 1.875em;
+ gap: 1.25em;
+ width: 30.125em;
+ height: 3.125em;
+ box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25);
+ border-radius: 0.625em;
+ box-sizing: border-box;
+}
+
th {
font: 700 0.875rem/1.875rem Overpass, sans-serif;
}
@@ -178,15 +338,15 @@ th {
border-right: 0.0625rem solid #8e8e8e;
}
-.MaintenanceType {
+.Name {
width: 15%;
}
-.MaintenanceType-darkmode {
+.Name-darkmode {
border-right: 0.0625rem solid #000000;
}
-.MaintenanceType-lightmode {
+.Name-lightmode {
border-right: 0.0625rem solid #8e8e8e;
}
@@ -249,4 +409,50 @@ th {
.label-lightmode {
color: #000;
}
+
+.input {
+ border: none;
+}
+
+#nuxt-link {
+ text-decoration: none;
+}
+
+.nuxt-link-darkmode {
+ color: white;
+}
+
+.nuxt-link-lightmode {
+ color: #000;
+}
+
+.dataInput {
+ display: flex;
+ flex-direction: row;
+ align-items: flex-start;
+ padding: 0 0.625rem;
+ border-radius: 0.3125rem;
+ box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset;
+ letter-spacing: 5%;
+ font: 400 0.75rem/250% Overpass, sans-serif;
+}
+
+.instanceLabel {
+ width: 5.5625em;
+ height: 1.875em;
+ font-family: "Overpass";
+ font-style: normal;
+ font-weight: 400;
+ font-size: 0.875em;
+ line-height: 1.875;
+ letter-spacing: 0.05em;
+}
+
+.section-darkmode {
+ background-color: #2c2c2c;
+}
+
+.section-lightmode {
+ background-color: #fff;
+}
\ No newline at end of file
diff --git a/components/server/ProductionOrdersInstance.vue b/components/server/ProductionOrdersInstance.vue
index f877864..55ea5d2 100644
--- a/components/server/ProductionOrdersInstance.vue
+++ b/components/server/ProductionOrdersInstance.vue
@@ -1,16 +1,19 @@
-
- Instance ID
+
+ {{
+ poi.name }}
+
Template ID:
-
...
+
{{ poi.templateID }}
Customer:
-
...
+
{{ poi.customer }}
@@ -19,14 +22,132 @@
Template notes:
-
...
+
+
+
+
+
+
+
+
+
Ticket No.:
+
{{ poi.ticketNumber }}
+
+
+
Asset:
+
{{ poi.asset }}
+
+
+
+
State:
+
{{ poi.state }}
+
+
+
+
User:
+
{{ poi.user }}
+
+
+
+
+
+
Creation date:
+
{{ poi.creationDate }}
+
+
+
Completion date:
+
{{ poi.completionDate }}
+
+
+
+
Time spent:
+
{{ poi.timeSpent }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Template ID:
+
Template name:
+
{{ chosenPOTId }}
+
+
+
+
Customer:
+
{{ poi.customer }}
+
+
+
+
+
+
+
+
Template description:
+
+
+
+
@@ -39,15 +160,26 @@
Asset:
-
...
+
User:
-
...
+
@@ -82,11 +215,261 @@
import { ref, onMounted, watch } from 'vue';
import { useStore } from 'vuex';
import { computed } from 'vue';
+import Axios from '../axios.config.js';
+import clientsideConfig from '../../clientsideConfig.js';
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
+const editable = computed(() => store.state.editable);
+const chosenPOIId = computed(() => store.state.chosenPOIId);
+const chosenPOTId = computed(() => store.state.chosenPOTId);
+const deleteBool = computed(() => store.state.deleteBool);
+const addBool = computed(() => store.state.new);
+
const darkMode = ref('');
+const potSelected = ref('');
+
+const poi = ref({});
+const pot = ref({});
+const customers = ref([]);
+const assets = ref([]);
+
+const newName = ref('');
+const newTemplateID = ref('');
+const chosenTemplate = ref('');
+const newCustomerID = ref('');
+const newCustomer = ref('');
+const newUser = ref('');
+const newState = ref('');
+const newNotes = ref('');
+const newTemplateDescription = ref('');
+const newTemplateNotes = ref('');
+const newAsset = ref('');
+const newCreationDate = ref('');
+const newCompletionDate = ref('');
+const newTimeSpent = ref('');
+const productionOrderInstances = ref([]);
+const productionOrderTemplates = ref([]);
+const userList = ref([]);
+
+//get all customers
+const getCustomers = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllCustomers`
+ );
+ customers.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+//get all productionOrder templates
+const getProductionOrderTemplates = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllProductionOrderTemplates`);
+ productionOrderTemplates.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+// get production order template from id
+const getPOTById = async () => {
+ if (chosenPOTId.value == '-1') {
+ potSelected.value = false;
+ await getProductionOrderTemplates();
+ } else {
+ potSelected.value = true;
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getProductionOrderTemplate/${chosenPOTId.value}`
+ );
+ pot.value = response.data;
+ poi.value.customer = pot.value.customer;
+ poi.value.customerID = pot.value.customerID;
+ newCustomer.value = pot.value.customer;
+ newCustomerID.value = pot.value.customerID;
+ await getConfigItemsFromCustomer();
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+ await getProductionOrderInstances();
+}
+
+// get production order template from id
+const getChosenPOTById = async (newPotId) => {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getProductionOrderTemplate/${newPotId}`
+ );
+ pot.value = response.data;
+ poi.value.customer = pot.value.customer;
+ poi.value.customerID = pot.value.customerID;
+ newCustomer.value = pot.value.customer;
+ newCustomerID.value = pot.value.customerID;
+ await getConfigItemsFromCustomer();
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+const confirmDeletePOI = async () => {
+ if (deleteBool.value === true) {
+ if (confirm("Do you really want to delete this production order instance? It cannot be undone!")) {
+ try {
+ await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteProductionOrderInstance/${chosenPOIId.value}`);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ try {
+ await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteTodosPOI/${chosenPOIId.value}`);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ store.commit('undoDelete');
+ store.commit('resetStore');
+ store.commit('deactivateSearch');
+ store.commit('changeToInstancelist');
+ store.commit('seeAllIcon');
+ } else {
+ store.commit('undoDelete');
+ }
+ }
+}
+
+//get all users
+const getUsers = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllEmployees`);
+ userList.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+//update data
+const updatePOI = async () => {
+ if (poi.value.name.trim() === "") {
+ alert("Please add a production order instance name!");
+ return;
+ } else {
+ var counter = 0;
+ // check if production order instance name already exists
+ productionOrderInstances.value.forEach(p => {
+ if (p.name === poi.value.name) {
+ counter += 1;
+ }
+ });
+ if (counter == 2) {
+ alert("This production order instance name already exists. Please choose an unique production order instance name or modify respectively delete the old one!");
+ poi.value.name = '';
+ return;
+ }
+ try {
+ await Axios.put(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateProductionOrderInstance`,
+ {
+ ticketNumber: poi.value.ticketNumber,
+ name: poi.value.name,
+ templateID: poi.value.templateID,
+ customerID: poi.value.customerID,
+ customer: poi.value.customer,
+ asset: poi.value.asset,
+ state: poi.value.state,
+ creationDate: poi.value.creationDate,
+ completionDate: poi.value.completionDate,
+ user: poi.value.user,
+ templateDescription: poi.value.templateDescription,
+ templateNotes: poi.value.templateNotes,
+ timeSpent: poi.value.timeSpent,
+ notes: poi.value.notes,
+ }
+ )
+ await getPOIById();
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+//get all productionOrder instances
+const getProductionOrderInstances = async () => {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllProductionOrderInstances`);
+ productionOrderInstances.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+}
+
+// update production order instance fields in the store
+const updateProductionOrderInstance = async (newPotId = -1) => {
+ let productionOrderInstance = {};
+ if (potSelected.value) {
+ productionOrderInstance = {
+ name: newName.value,
+ templateID: chosenPOTId.value,
+ customerID: newCustomerID.value,
+ customer: newCustomer.value,
+ asset: newAsset.value,
+ state: newState.value,
+ creationDate: newCreationDate.value,
+ completionDate: newCompletionDate.value,
+ user: newUser.value,
+ templateDescription: newTemplateDescription.value,
+ templateNotes: newTemplateNotes.value,
+ timeSpent: newTimeSpent.value,
+ notes: newNotes.value,
+ };
+ } else {
+ if (!(newPotId == '-1')) {
+ // Find the object with the selected Name
+ const selectedObject = productionOrderTemplates.value.find(obj => obj.name === newPotId);
+ // Get the templateID
+ newTemplateID.value = selectedObject ? selectedObject.templateID : null;
+ await getChosenPOTById(newTemplateID.value);
+ }
+ productionOrderInstance = {
+ name: newName.value,
+ templateID: newTemplateID.value,
+ customerID: newCustomerID.value,
+ customer: newCustomer.value,
+ asset: newAsset.value,
+ state: newState.value,
+ creationDate: newCreationDate.value,
+ completionDate: newCompletionDate.value,
+ user: newUser.value,
+ templateDescription: newTemplateDescription.value,
+ templateNotes: newTemplateNotes.value,
+ timeSpent: newTimeSpent.value,
+ notes: newNotes.value,
+ };
+ }
+ store.commit('updateProductionOrderInstanceComponent', productionOrderInstance);
+}
+
+// get production order instance from id
+const getPOIById = async () => {
+ if (!addBool.value) {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getProductionOrderInstance/${chosenPOIId.value}`
+ );
+ poi.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+// include delay to avoid 503 error
+const triggerBackendCallsWithDelay = async (fetchDataFunc) => {
+ setTimeout(() => {
+ fetchDataFunc();
+ }, 1500);
+}
const getSession = async () => {
const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
@@ -97,6 +480,25 @@ const getSession = async () => {
}
}
+//get all config items from the selected customer
+const getConfigItemsFromCustomer = async () => {
+ if (!addBool.value) {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromCustomer/${poi.value.customerID}`);
+ assets.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ } else if (!(newCustomerID.value == '')) {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromCustomer/${newCustomerID.value}`);
+ assets.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
function getItem(item) {
if (process.client) {
return localStorage.getItem(item)
@@ -105,10 +507,16 @@ function getItem(item) {
}
}
-watch(modeChanged, getSession)
+watch(modeChanged, getSession);
+watch(deleteBool, confirmDeletePOI);
+watch(editable, getConfigItemsFromCustomer);
onMounted(async () => {
- await getSession();
+ getSession();
+ await getPOIById();
+ await getPOTById();
+ triggerBackendCallsWithDelay(getCustomers);
+ triggerBackendCallsWithDelay(getUsers);
});
@@ -131,6 +539,17 @@ export default {
box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25);
}
+.data {
+ display: flex;
+ flex-direction: row;
+ align-items: flex-start;
+ padding: 0 0.625rem;
+ border-radius: 0.3125rem;
+ box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset;
+ letter-spacing: 5%;
+ font: 400 0.75rem/250% Overpass, sans-serif;
+}
+
.section-darkmode {
background-color: #2c2c2c;
}
@@ -139,7 +558,13 @@ export default {
background-color: #fff;
}
+.h2-input-darkmode {
+ background-color: #212121;
+}
+.h2-input-lightmode {
+ background-color: #EBEBEB;
+}
.production-orders-instance-name {
align-self: stretch;
@@ -158,6 +583,16 @@ export default {
color: #000;
}
+.data-darkmode {
+ background-color: #212121;
+ color: #fff;
+}
+
+.data-lightmode {
+ background-color: #EBEBEB;
+ color: #000;
+}
+
.data-field {
display: flex;
flex-direction: row;
@@ -216,17 +651,6 @@ export default {
color: #000;
}
-.data {
- display: flex;
- flex-direction: row;
- align-items: flex-start;
- padding: 0 0.625rem;
- border-radius: 0.3125rem;
- box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset;
- letter-spacing: 5%;
- font: 400 0.75rem/250% Overpass, sans-serif;
-}
-
.data-darkmode {
background-color: #212121;
color: #fff;
@@ -268,6 +692,28 @@ export default {
border-radius: 0.3125rem;
}
+.h2-darkmode {
+ color: #fff;
+}
+
+.h2-lightmode {
+ color: #000;
+}
+
+.input {
+ border: none;
+}
+
+.poi-name-input {
+ /* padding: 1rem 0; */
+ margin: 1rem;
+ font-size: initial;
+ letter-spacing: 5%;
+ text-decoration-line: underline;
+ font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica,
+ sans-serif;
+}
+
.additional {
display: flex;
flex-direction: column;
@@ -280,7 +726,7 @@ export default {
}
div#customer {
- padding-left: 2.9em;
+ padding-left: 4.4em;
}
.area-title {
@@ -314,4 +760,20 @@ div#customer {
padding: 0.625rem 1.875rem 0.625rem 1.25rem;
padding-top: 0rem;
}
+
+.select-lightmode {
+ border: none;
+ color: black;
+ background: #EBEBEB;
+ padding: 0.4rem;
+ border-radius: 0.3125rem;
+}
+
+.select-darkmode {
+ border: none;
+ color: white;
+ background: #212121;
+ padding: 0.4rem;
+ border-radius: 0.3125rem;
+}
\ No newline at end of file
diff --git a/components/server/ProductionOrdersInstanceTable.vue b/components/server/ProductionOrdersInstanceTable.vue
index f54c43a..de99d7e 100644
--- a/components/server/ProductionOrdersInstanceTable.vue
+++ b/components/server/ProductionOrdersInstanceTable.vue
@@ -1,15 +1,25 @@
+
+
Instances:
- |
- ID |
Ticket No. |
+
+ Name |
Asset |
@@ -24,26 +34,42 @@
Completion date
User |
-
- |
- ... |
+
|
- ... |
+
+ {{ instance.ticketNumber }}
+
+
+
+
+ {{ instance.name }}
+
+ |
- ... |
+
+ {{ instance.asset }}
+
+
- ... |
+ {{ instance.state }}
- ... |
+ {{ instance.creationDate }}
- ... |
- ... |
+ {{ instance.completionDate }}
+ {{ instance.user }} |
@@ -55,11 +81,136 @@
import { ref, onMounted, watch } from 'vue';
import { useStore } from 'vuex';
import { computed } from 'vue';
+import Axios from '../axios.config.js';
+import clientsideConfig from '../../clientsideConfig.js';
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
+const chosenPOTId = computed(() => store.state.chosenPOTId);
+const searchable = computed(() => store.state.searchable);
+const filtered = computed(() => store.state.filtered);
+const notAllInstancesIcon = computed(() => store.state.notAllInstancesIcon);
+const filteredUserTerm = computed(() => store.state.filteredUserTerm);
+const userSearchFilter = ref('');
+const nameSearchFilter = ref('');
+const productionOrderInstances = ref([]);
+
const darkMode = ref('');
+const pot = ref({});
+const POIByUser = ref([]);
+const POIByName = ref([]);
+
+const goToChosenPOI = (id) => {
+ store.commit('setChosenPOI', id);
+ store.commit('changeToInstance');
+};
+
+//get all production order instances
+const getProductionOrderInstances = async () => {
+ if (notAllInstancesIcon.value) {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedPOIsByPOT/${pot.value.templateID}`);
+ productionOrderInstances.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ } else {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllProductionOrderInstances`);
+ productionOrderInstances.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+// update search term
+const updateSearchTerm = async () => {
+ nameSearchFilter.value = '';
+ await getProductionOrderInstances();
+}
+
+// update filter term
+const updateFilterTerm = async () => {
+ if (filteredUserTerm.value) {
+ store.commit('activateFiltered');
+ userSearchFilter.value = getItem('logged-in-user-username');
+ } else {
+ userSearchFilter.value = '';
+ }
+ await getProductionOrderInstances();
+ if (filteredUserTerm.value) {
+ await filterInstancesByUser();
+ }
+}
+
+// get production order template from id
+const getPOTById = async () => {
+ if (notAllInstancesIcon.value) {
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getProductionOrderTemplate/${chosenPOTId.value}`
+ );
+ pot.value = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+ await getProductionOrderInstances();
+}
+
+const goToChosenAsset = async (name) => {
+ let ci = {}
+ try {
+ const response = await Axios.get(
+ `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedConfigItemsByAsset/${name}`
+ );
+ ci = response.data;
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ store.commit('setChosenAsset', ci[0].primaryID);
+ setTimeout(() => {
+ }, 1000);
+ store.commit('changeToAsset');
+};
+
+//get all instances based on the searched state
+const filterPOIByName = async () => {
+ if (nameSearchFilter.value === '') {
+ await getProductionOrderInstances();
+ } else {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedPOIsByName/${nameSearchFilter.value}`);
+ POIByName.value = response.data;
+ productionOrderInstances.value = filterObjectsWithMatchingIds(productionOrderInstances.value, POIByName.value);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+//get all instances based on the searched user
+const filterInstancesByUser = async () => {
+ if (userSearchFilter.value === '') {
+ await getProductionOrderInstances();
+ } else {
+ try {
+ const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedPOIsByUser/${userSearchFilter.value}`);
+ POIByUser.value = response.data;
+ productionOrderInstances.value = filterObjectsWithMatchingIds(productionOrderInstances.value, POIByUser.value);
+ } catch (err) {
+ console.log(err.response.statusText);
+ }
+ }
+}
+
+const filterObjectsWithMatchingIds = (arr1, arr2) => {
+ return arr1.filter(obj1 => {
+ return arr2.some(obj2 => obj2.ticketNumber === obj1.ticketNumber);
+ });
+};
const getSession = async () => {
const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode');
@@ -70,6 +221,11 @@ const getSession = async () => {
}
}
+const getAll = async () => {
+ store.commit('resetFilterSearch');
+ await getProductionOrderInstances();
+}
+
function getItem(item) {
if (process.client) {
return localStorage.getItem(item)
@@ -79,9 +235,13 @@ function getItem(item) {
}
watch(modeChanged, getSession)
+watch(searchable, updateSearchTerm);
+watch(filtered, updateFilterTerm);
+watch(notAllInstancesIcon, getAll);
onMounted(async () => {
- await getSession();
+ getSession();
+ await getPOTById();
});
@@ -171,20 +331,8 @@ th {
font: 700 0.875rem/1.875rem Overpass, sans-serif;
}
-.ID {
- width: 15.83%;
-}
-
-.ID-darkmode {
- border-right: 0.0625rem solid #000000;
-}
-
-.ID-lightmode {
- border-right: 0.0625rem solid #8e8e8e;
-}
-
.TicketNo {
- width: 15.83%;
+ width: 12.83%;
}
.TicketNo-darkmode {
@@ -195,6 +343,17 @@ th {
border-right: 0.0625rem solid #8e8e8e;
}
+.Name {
+ width: 18.83%;
+}
+
+.Name-darkmode {
+ border-right: 0.0625rem solid #000000;
+}
+
+.Name-lightmode {
+ border-right: 0.0625rem solid #8e8e8e;
+}
.Asset {
width: 15.83%;
@@ -266,4 +425,73 @@ th {
.label-lightmode {
color: #000;
}
+
+.data-darkmode {
+ background-color: #212121;
+ color: #fff;
+}
+
+.data-lightmode {
+ background-color: #EBEBEB;
+ color: #000;
+}
+
+.poi-search {
+ display: flex;
+ align-items: center;
+ padding: 0.625em 1.875em;
+ gap: 1.25em;
+ width: 30.125em;
+ height: 3.125em;
+ box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25);
+ border-radius: 0.625em;
+ box-sizing: border-box;
+}
+
+
+.input {
+ border: none;
+}
+
+#nuxt-link {
+ text-decoration: none;
+}
+
+.nuxt-link-darkmode {
+ color: white;
+}
+
+.nuxt-link-lightmode {
+ color: #000;
+}
+
+.dataInput {
+ display: flex;
+ flex-direction: row;
+ align-items: flex-start;
+ padding: 0 0.625rem;
+ border-radius: 0.3125rem;
+ box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset;
+ letter-spacing: 5%;
+ font: 400 0.75rem/250% Overpass, sans-serif;
+}
+
+.instanceLabel {
+ width: 5.5625em;
+ height: 1.875em;
+ font-family: "Overpass";
+ font-style: normal;
+ font-weight: 400;
+ font-size: 0.875em;
+ line-height: 1.875;
+ letter-spacing: 0.05em;
+}
+
+.section-darkmode {
+ background-color: #2c2c2c;
+}
+
+.section-lightmode {
+ background-color: #fff;
+}
\ No newline at end of file
diff --git a/components/server/ProductionOrdersTemplate.vue b/components/server/ProductionOrdersTemplate.vue
index f092bb7..14c384a 100644
--- a/components/server/ProductionOrdersTemplate.vue
+++ b/components/server/ProductionOrdersTemplate.vue
@@ -429,14 +429,6 @@ export default {
align-self: stretch;
}
-.select-darkmode {
- border: none;
- color: white;
- background: #212121;
- padding: 0.4rem;
- border-radius: 0.3125rem;
-}
-
.select-lightmode {
border: none;
color: black;
@@ -453,14 +445,6 @@ export default {
border-radius: 0.3125rem;
}
-.select-lightmode {
- border: none;
- color: black;
- background: #EBEBEB;
- padding: 0.4rem;
- border-radius: 0.3125rem;
-}
-
.customer-ID,
.user {
display: flex;
diff --git a/components/server/TemplateChecklist.vue b/components/server/TemplateChecklist.vue
index f6547dd..1738401 100644
--- a/components/server/TemplateChecklist.vue
+++ b/components/server/TemplateChecklist.vue
@@ -17,7 +17,7 @@
Comments |
+ :class="['table-row-data', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
{{ todo.rowID }}
@@ -42,17 +42,15 @@
|
- {{
- todo.comments
- }} |
- |
-
|
@@ -72,10 +70,10 @@
|
-
+
+ Save -
@@ -106,7 +104,7 @@
| Comments |
|
+ :class="['table-row-data', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
{{ newT.rowID }}
@@ -125,10 +123,10 @@
|
-
+ -
|
@@ -436,6 +434,43 @@ function getItem(item) {
}
}
+// const inputValue = ref('');
+// const widthMachine = computed(() => inputValue.value);
+
+// function handleInput(event) {
+// inputValue.value = event.target.value;
+// }
+
+// // Textarea height handling
+// const textareaValue = ref('');
+// const textareaHeight = computed(() => calcHeight(textareaValue.value));
+
+// function handleTextareaInput(event) {
+// textareaValue.value = event.target.value;
+// }
+
+// function calcHeight(value) {
+// const numberOfLineBreaks = (value.match(/\n/g) || []).length;
+// // min-height + lines x line-height + padding + border
+// const newHeight = 20 + numberOfLineBreaks * 20 + 12 + 2;
+// return newHeight;
+// }
+
+// const spanElement = ref(null);
+// const computedHeight = ref('auto'); // Default height is 'auto'
+
+// // Compute the height of the span element
+// const computeSpanHeight = () => {
+// if (spanElement.value) {
+// computedHeight.value = spanElement.value.offsetHeight + 'px';
+// }
+// };
+
+// // Watch for changes in the content of the span element
+// watch(() => textareaValue.value, () => {
+// computeSpanHeight();
+// });
+
watch(customerChanged, getPOTById);
watch(modeChanged, getSession)
@@ -466,6 +501,17 @@ export default {
font: 400 0.75rem/250% Overpass, sans-serif;
}
+/* .data-span {
+ display: flex;
+ flex-direction: row;
+ align-items: flex-start;
+ padding: 0 0.625rem;
+ border-radius: 0.3125rem;
+ box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset;
+ letter-spacing: 5%;
+ font: 400 0.75rem/250% Overpass, sans-serif;
+} */
+
.section-darkmode {
background-color: #2c2c2c;
}
@@ -520,6 +566,14 @@ export default {
gap: 0.625rem;
}
+.table-row-data {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 0.625rem;
+ gap: 0.625rem;
+}
+
.tr-head-darkmode {
border-top: none;
border-bottom: 0.0625rem solid #000000;
@@ -547,6 +601,10 @@ td {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
}
+td {
+ height: 5rem;
+}
+
th {
font: 700 0.875rem/1.875rem Overpass, sans-serif;
}
@@ -648,9 +706,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 10rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.saveNewPOT-darkmode {
@@ -670,9 +730,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 15.8rem;
+ margin-left: 6rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deleteLastPOTTodos-darkmode {
@@ -681,9 +743,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 15.8rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
@@ -704,9 +768,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 10rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deletePOTTodos-lightmode {
@@ -715,9 +781,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 15.8rem;
+ margin-left: 6rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deleteLastPOTTodos-lightmode {
@@ -726,9 +794,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 2rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.saveNewPOT-lightmode {
@@ -769,4 +839,10 @@ th {
#editPOTTodos {
text-align: right;
}
+
+textarea {
+ resize: none;
+ width: 20rem;
+ height: 5rem;
+}
\ No newline at end of file
diff --git a/components/server/TemplateChecklistMVT.vue b/components/server/TemplateChecklistMVT.vue
index e76c688..f6ce9a2 100644
--- a/components/server/TemplateChecklistMVT.vue
+++ b/components/server/TemplateChecklistMVT.vue
@@ -17,7 +17,7 @@
Comments |
+ :class="['table-row-data', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
{{ todo.rowID }}
@@ -42,17 +42,15 @@
|
- {{
- todo.commets
- }} |
-
+
+ -
|
-
|
@@ -72,10 +70,10 @@
|
-
+
+ Save -
@@ -106,7 +104,7 @@
| Comments |
|
+ :class="['table-row-data', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1">
|
{{ newT.rowID }}
@@ -125,10 +123,10 @@
|
-
+
+ -
|
@@ -522,6 +520,14 @@ export default {
gap: 0.625rem;
}
+.table-row-data {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 0.625rem;
+ gap: 0.625rem;
+}
+
.tr-head-darkmode {
border-top: none;
border-bottom: 0.0625rem solid #000000;
@@ -549,6 +555,10 @@ td {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
}
+td {
+ height: 5rem;
+}
+
th {
font: 700 0.875rem/1.875rem Overpass, sans-serif;
}
@@ -651,9 +661,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 10rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.saveNewMVT-darkmode {
@@ -673,9 +685,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 15.8rem;
+ margin-left: 6rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deleteLastMvtTodos-darkmode {
@@ -684,9 +698,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 2rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
@@ -707,9 +723,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 10rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deleteMvtTodos-lightmode {
@@ -718,9 +736,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 15.8rem;
+ margin-left: 6rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.deleteLastMvtTodos-lightmode {
@@ -729,9 +749,11 @@ th {
font: 400 0.875rem/1.875rem Overpass, sans-serif;
border: none;
border-radius: 0.625rem;
- margin-left: 2rem;
+ margin-left: 1rem;
padding-left: 0.9rem;
padding-right: 0.9rem;
+ height: 2.1rem;
+ margin-top: 1.5rem;
}
.saveNewMVT-lightmode {
@@ -772,4 +794,10 @@ th {
#editMvtTodos {
text-align: right;
}
+
+textarea {
+ resize: none;
+ width: 20rem;
+ height: 5rem;
+}
\ No newline at end of file
diff --git a/components/server/UserAccount.vue b/components/server/UserAccount.vue
index 001ec18..b9cf53d 100644
--- a/components/server/UserAccount.vue
+++ b/components/server/UserAccount.vue
@@ -54,7 +54,7 @@ import clientsideConfig from '../../clientsideConfig.js';
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
-const editable = computed(() => store.state.editable);
+const editable = computed(() => store.state.editableUser);
const changePasswordBool = ref(false);
const loggedInUserId = ref('');
diff --git a/components/server/UserProfile.vue b/components/server/UserProfile.vue
index 2c1bf4c..bca0995 100644
--- a/components/server/UserProfile.vue
+++ b/components/server/UserProfile.vue
@@ -81,7 +81,7 @@ import clientsideConfig from '../../clientsideConfig.js';
const store = useStore();
const modeChanged = computed(() => store.state.updateDarkMode);
-const editable = computed(() => store.state.editable);
+const editable = computed(() => store.state.editableUser);
const loggedInUserId = ref('');
const loggedInUserUsername = ref('');
const loggedInUserRegistered = ref('');
diff --git a/components/server/UserRightsList.vue b/components/server/UserRightsList.vue
deleted file mode 100644
index 41c18d3..0000000
--- a/components/server/UserRightsList.vue
+++ /dev/null
@@ -1,215 +0,0 @@
-
\ No newline at end of file
diff --git a/layouts/Actionbar.vue b/layouts/Actionbar.vue
index ec1369f..e7cc993 100644
--- a/layouts/Actionbar.vue
+++ b/layouts/Actionbar.vue
@@ -30,7 +30,7 @@
+ id="instances" @click="changeToInstancelist">

@@ -95,7 +95,8 @@
+ :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="new-instance"
+ @click="addInstance">

@@ -119,6 +120,17 @@
+
+
+

+
+
+ See all
+
+
@@ -131,6 +143,17 @@
:class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Edit
+
+
+

+
+
+ Edit
+
+
@@ -163,7 +186,9 @@ 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 editUserIcon = computed(() => store.state.editUserIcon);
const deleteIcon = computed(() => store.state.deleteIcon);
+const notAllInstancesIcon = computed(() => store.state.notAllInstancesIcon);
const loggedInUserDarkModeBoolean = ref('');
const isExpanded = ref(true);
@@ -175,6 +200,9 @@ const store = useStore()
const toggleEditable = () => {
store.commit('toggleEditable');
};
+const toggleEditableUser = () => {
+ store.commit('toggleEditableUser');
+};
const deleteFunc = () => {
store.commit('doDelete');
};
@@ -183,9 +211,11 @@ const toggleActionbar = () => {
isExpanded.value = !isExpanded.value;
};
const toggleFiltered = () => {
+ store.commit('deactivateSearch');
store.commit('toggleFiltered');
};
const toggleSearched = () => {
+ store.commit('deactivateSearch');
store.commit('toggleSearchable');
};
const add = () => {
@@ -196,10 +226,25 @@ const addSolution = () => {
store.commit('add');
};
+const addInstance = () => {
+ store.commit('addInstance');
+};
+
const changeToSolutions = () => {
store.commit('changeToSolutionlistAsset');
}
+const changeToInstancelist = () => {
+ store.commit('deactivateSearch');
+ store.commit('changeToInstancelist');
+}
+
+const changeToAllInstances = () => {
+ store.commit('deactivateSearch');
+ store.commit('changeToInstancelist');
+ store.commit('seeAllIcon');
+}
+
// const changeToSettingsPage = () => {
// store.commit('changeToSettings');
// if (changeToSet.value) {
diff --git a/layouts/Navigationbar.vue b/layouts/Navigationbar.vue
index 401e317..fa2a306 100644
--- a/layouts/Navigationbar.vue
+++ b/layouts/Navigationbar.vue
@@ -2,11 +2,11 @@