Compare commits
	
		
			5 Commits
		
	
	
		
			production
			...
			Accounting
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e56af94a88 | |||
| 3a1e468789 | |||
| 488eba45e1 | |||
| 1e001bb4a1 | |||
| df60461a53 | 
| @ -5,6 +5,8 @@ import { | ||||
|     deleteIssueById, | ||||
|     insertIssue, | ||||
|     getAllIssues, | ||||
|     getSelectedIssuesByState, | ||||
|     getSelectedIssuesByIssueName, | ||||
| } from "../models/issuesModel.js"; | ||||
|  | ||||
| //get all issues | ||||
| @ -18,6 +20,28 @@ export const showIssues = (req, res) => { | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| //get all selected issues by name | ||||
| export const showSelectedIssuesByIssueName = (req, res) => { | ||||
|     getSelectedIssuesByIssueName(req.params.id, (err, results) => { | ||||
|         if (err) { | ||||
|             res.send(err); | ||||
|         } else { | ||||
|             res.json(results); | ||||
|         } | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| //get all selected issues by state | ||||
| export const showSelectedIssuesByState = (req, res) => { | ||||
|     getSelectedIssuesByState(req.params.id, (err, results) => { | ||||
|         if (err) { | ||||
|             res.send(err); | ||||
|         } else { | ||||
|             res.json(results); | ||||
|         } | ||||
|     }); | ||||
| }; | ||||
|  | ||||
| // Delete issue | ||||
| export const deleteIssue = (req, res) => { | ||||
|     const id = req.params.id; | ||||
|  | ||||
| @ -4,6 +4,7 @@ import ownConn from "../dbConfig.js"; | ||||
| export const insertChecklistSolutionTodo = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO checklistsolutions(solutionID, step, asset, task, comments) VALUES(?, ?, ?, ?, ?)`, [data.solutionID, data.step, data.asset, data.task, data.comments]); | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -47,6 +48,7 @@ export const updateChecklistSolutionTodoById = async (data, result) => { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE checklistsolutions SET step = ?, asset = ?, task = ?, comments = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.step, data.asset, data.task, data.comments, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -61,6 +63,7 @@ export const deleteAllChecklistSolutionTodosSolutionID = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM checklistsolutions WHERE solutionID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -75,6 +78,7 @@ export const deleteChecklistSolutionTodo = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM checklistsolutions WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -61,6 +61,7 @@ export const deleteIssueSlipById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM issueslips WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -75,6 +76,7 @@ export const deleteIssueSlipByTicketNo = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM issueslips WHERE ticketNo = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -87,7 +89,8 @@ export const deleteIssueSlipByTicketNo = async (id, result) => { | ||||
| //insert issue slip to database | ||||
| export const insertIssueSlip = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO issueslips(customerID, customer, ticketNo, creationDate, lastView, user, notes, supplierRequest, supplierOffer, clientOffer, clientOrder, supplierOrder, ingress, egress, ingressBill, egressBill) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [data.customerID, data.customer, data.ticketNo, data.creationDate, data.lastView, data.user, data.notes, data.supplierRequest, data.supplierOffer, data.clientOffer, data.clientOrder, data.supplierOrder, data.ingress, data.egress, data.ingressBill, data.egressBill]) | ||||
|         const results = await ownConn.query(`INSERT INTO issueslips(customerID, customer, ticketNo, creationDate, lastView, user, notes, deliveryAddress, supplierRequestDate, supplierRequest, supplierOfferDate, supplierOffer, clientOfferDate, clientOffer, clientOrderDate, clientOrder, supplierOrderDate, supplierOrder, ingressDate, ingress, egressDate, egress, ingressBillDate, ingressBill, egressBillDate, egressBill) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [data.customerID, data.customer, data.ticketNo, data.creationDate, data.lastView, data.user, data.notes, data.deliveryAddress, data.supplierRequestDate, data.supplierRequest, data.supplierOfferDate, data.supplierOffer, data.clientOfferDate, data.clientOffer, data.clientOrderDate, data.clientOrder, data.supplierOrderDate, data.supplierOrder, data.ingressDate, data.ingress, data.egressDate, data.egress, data.ingressBillDate, data.ingressBill, data.egressBillDate, data.egressBill]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -129,8 +132,9 @@ export const getIssueSlipById = async (id, result) => { | ||||
| export const updateIssueSlipById = async (data, result) => { | ||||
|     const id = data.primaryID; | ||||
|     try { | ||||
|         let sql = `UPDATE issueslips SET customerID = ?, customer = ?, ticketNo = ?, creationDate = ?, lastView = ?, user = ?, notes = ?, supplierRequest = ?, supplierOffer = ?, clientOffer = ?, clientOrder = ?, supplierOrder = ?, ingress = ?, egress = ?, ingressBill = ?, egressBill = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.customerID, data.customer, data.ticketNo, data.creationDate, data.lastView, data.user, data.notes, data.supplierRequest, data.supplierOffer, data.clientOffer, data.clientOrder, data.supplierOrder, data.ingress, data.egress, data.ingressBill, data.egressBill, id]) | ||||
|         let sql = `UPDATE issueslips SET customerID = ?, customer = ?, ticketNo = ?, creationDate = ?, lastView = ?, user = ?, notes = ?, deliveryAddress = ?, supplierRequestDate = ?, supplierRequest = ?, supplierOfferDate = ?, supplierOffer = ?, clientOfferDate = ?, clientOffer = ?, clientOrderDate = ?, clientOrder = ?, supplierOrderDate = ?, supplierOrder = ?, ingressDate = ?, ingress = ?, egressDate = ?, egress = ?, ingressBillDate = ?, ingressBill = ?, egressBillDate = ?, egressBill = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.customerID, data.customer, data.ticketNo, data.creationDate, data.lastView, data.user, data.notes, data.deliveryAddress, data.supplierRequestDate, data.supplierRequest, data.supplierOfferDate, data.supplierOffer, data.clientOfferDate, data.clientOffer, data.clientOrderDate, data.clientOrder, data.supplierOrderDate, data.supplierOrder, data.ingressDate, data.ingress, data.egressDate, data.egress, data.ingressBillDate, data.ingressBill, data.egressBillDate, data.egressBill, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -19,7 +19,7 @@ export const getIssueVariantById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `SELECT * FROM issuevariants WHERE primaryID = ? ORDER BY primaryID ASC`; | ||||
|         const results = await ownConn.execute(sql, [id]) | ||||
|         result(null, results); | ||||
|         result(null, results[0]); | ||||
|     } | ||||
|     catch (err) { | ||||
|         // Manage Errors | ||||
| @ -62,6 +62,7 @@ export const updateIssueVariantById = async (data, result) => { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE issuevariants SET issueID = ?, name = ? , properties = ?, state = ?, amount = ?, price = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.issueID, data.name, data.properties, data.state, data.amount, data.price, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -77,6 +78,7 @@ export const deleteIssueVariantById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM issuevariants WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -91,6 +93,7 @@ export const deleteIssueVariantByIssueSlipId = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM issuevariants WHERE issueID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -104,6 +107,7 @@ export const deleteIssueVariantByIssueSlipId = async (id, result) => { | ||||
| export const insertIssueVariant = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO issuevariants(issueID, name, properties, state, amount, price) VALUES(?, ?, ?, ?, ?, ?)`, [data.issueID, data.name, data.properties, data.state, data.amount, data.price]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -14,12 +14,40 @@ export const getAllIssues = async (result) => { | ||||
|     } | ||||
| }; | ||||
|  | ||||
| //get all selected issues by state | ||||
| export const getSelectedIssuesByState = async (selected, result) => { | ||||
|     try { | ||||
|         let sql = `SELECT * FROM issues WHERE state LIKE '%${selected}%' ORDER BY state 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 issues by issue name | ||||
| export const getSelectedIssuesByIssueName = async (selected, result) => { | ||||
|     try { | ||||
|         let sql = `SELECT * FROM issues WHERE name LIKE '%${selected}%' 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 single issue  | ||||
| export const getIssueById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `SELECT * FROM issues WHERE primaryID = ? ORDER BY primaryID ASC`; | ||||
|         const results = await ownConn.execute(sql, [id]) | ||||
|         result(null, results); | ||||
|         result(null, results[0]); | ||||
|     } | ||||
|     catch (err) { | ||||
|         // Manage Errors | ||||
| @ -34,6 +62,7 @@ export const updateIssueById = async (data, result) => { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE issues SET name = ?, type = ? , state = ?, amount = ?, properties = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.name, data.type, data.state, data.amount, data.properties, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -48,6 +77,7 @@ export const deleteIssueById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM issues WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -61,6 +91,7 @@ export const deleteIssueById = async (id, result) => { | ||||
| export const insertIssue = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO issues(name, type, state, amount, properties) VALUES(?, ?, ?, ?, ?)`, [data.name, data.type, data.state, data.amount, data.properties]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -88,6 +88,7 @@ export const deleteMaintenanceVisitById = async (id, result) => { | ||||
| export const insertMaintenanceVisit = async (data, result) => { | ||||
|   try { | ||||
|     const results = await ownConn.query(`INSERT INTO maintenancevisits(name, templateID, maintenanceType, state, creationDate, completionDate, user, customer, customerID, templateNotes, type, timeSpent, notes) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [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]) | ||||
|     results.insertId = results.insertId.toString(); | ||||
|     result(null, results); | ||||
|   } | ||||
|   catch (err) { | ||||
| @ -131,6 +132,7 @@ export const updateMaintenanceVisitStateById = async (data, result) => { | ||||
|     const id = data.primaryID; | ||||
|     let sql = `UPDATE maintenancevisits SET state = ? WHERE primaryID = ?`; | ||||
|     const results = await ownConn.query(sql, [data.state, id]) | ||||
|     results.insertId = results.insertId.toString(); | ||||
|     result(null, results); | ||||
|   } | ||||
|   catch (err) { | ||||
|  | ||||
| @ -4,6 +4,7 @@ import ownConn from "../dbConfig.js"; | ||||
| export const insertMaintenanceVisitTodo = async (data, result) => { | ||||
|   try { | ||||
|     const results = await ownConn.query(`INSERT INTO maintenancevisittodos(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) { | ||||
| @ -47,6 +48,7 @@ export const updateMaintenanceVisitTodoById = async (data, result) => { | ||||
|     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]) | ||||
|     results.insertId = results.insertId.toString(); | ||||
|     result(null, results); | ||||
|   } | ||||
|   catch (err) { | ||||
|  | ||||
| @ -18,8 +18,9 @@ export const getMasterMaintenanceVisitTodoById = async (id, result) => { | ||||
| export const updateMasterMaintenanceVisitTodoById = async (data, result) => { | ||||
|     try { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE mastermaintenancetodos SET templateID = ?, asset = ? , task = ?, comments = ? WHERE primaryID = ?`; | ||||
|         let sql = `UPDATE mastermaintenancetodos SET templateID = ?, asset = ? , task = ?, commets = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.templateID, data.asset, data.task, data.comments, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -35,6 +36,7 @@ export const deleteMasterMaintenanceVisitTodoById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM mastermaintenancetodos WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -49,6 +51,7 @@ export const deleteMasterMaintenanceVisitTodoByTemplateId = async (id, result) = | ||||
|     try { | ||||
|         let sql = `DELETE FROM mastermaintenancetodos WHERE templateID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -79,7 +82,8 @@ export const updateMasterMaintenanceVisitTodos = async (data, result) => { | ||||
| //insert master maintenance visit todo to databased | ||||
| export const insertMasterMaintenanceVisitTodo = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO mastermaintenancetodos(templateID, rowID, asset, task, comments) VALUES(?, ?, ?, ?, ?)`, [data.templateID, data.rowID, data.asset, data.task, asset.comments]) | ||||
|         const results = await ownConn.query(`INSERT INTO mastermaintenancetodos(templateID, rowID, asset, task, commets) VALUES(?, ?, ?, ?, ?)`, [data.templateID, data.rowID, data.asset, data.task, data.comment]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -62,6 +62,7 @@ export const updateMasterMaintenanceVisitById = async (data, result) => { | ||||
|         const id = data.checklistID; | ||||
|         let sql = `UPDATE mastermaintenancevisits SET name = ?, customerID = ? , customer = ?, type = ?, lastView = ?, user = ?, notes = ? WHERE checklistID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.name, data.customerID, data.customer, data.type, data.lastView, data.user, data.notes, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -75,6 +76,7 @@ export const updateMasterMaintenanceVisitById = async (data, result) => { | ||||
| export const insertMasterMaintenanceVisit = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO mastermaintenancevisits(name, customerID, customer, type, lastView, user, notes) VALUES(?, ?, ?, ?, ?, ?, ?)`, [data.name, data.customerID, data.customer, data.type, data.lastView, data.user, data.notes]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -89,6 +91,7 @@ export const deleteMasterMaintenanceVisitById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM mastermaintenancevisits WHERE checklistID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -20,6 +20,7 @@ export const updateOrderingInfoIssueSlipById = async (data, result) => { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE orderinginfoissueslips SET issueSlipID = ?, article = ? , amount = ?, price = ?, comment = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.issueSlipID, data.article, data.amount, data.price, data.comment, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -35,6 +36,7 @@ export const deleteOrderingInfoIssueSlipById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM orderinginfoissueslips WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -49,6 +51,7 @@ export const deleteOrderingInfoIssueSlipByIssueSlipId = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM orderinginfoissueslips WHERE issueSlipID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -62,6 +65,7 @@ export const deleteOrderingInfoIssueSlipByIssueSlipId = async (id, result) => { | ||||
| export const insertOrderingInfoIssueSlip = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO orderinginfoissueslips(issueSlipID, article, amount, price, comment) VALUES(?, ?, ?, ?, ?)`, [data.issueSlipID, data.article, data.amount, data.price, data.comment]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -46,6 +46,7 @@ export const getSolutionByName = async (id, result) => { | ||||
| export const insertSolution = async (data, result) => { | ||||
|     try { | ||||
|         const results = await ownConn.query(`INSERT INTO solutions(solutionName, assetName, customer, customerID, type, lastView, user, description, notes) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?)`, [data.solutionName, data.assetName, data.customer, data.customerID, data.type, data.lastView, data.user, data.description, data.notes]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -61,6 +62,7 @@ export const updateSolutionById = async (data, result) => { | ||||
|         const id = data.primaryID; | ||||
|         let sql = `UPDATE solutions SET solutionName = ?, assetName = ?, customer = ?, customerID = ?, type = ?, lastView = ?, user = ?, description = ?, notes = ? WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [data.solutionName, data.assetName, data.customer, data.customerID, data.type, data.lastView, data.user, data.description, data.notes, id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
| @ -131,6 +133,7 @@ export const deleteSolutionById = async (id, result) => { | ||||
|     try { | ||||
|         let sql = `DELETE FROM solutions WHERE primaryID = ?`; | ||||
|         const results = await ownConn.query(sql, [id]) | ||||
|         results.insertId = results.insertId.toString(); | ||||
|         result(null, results); | ||||
|     } | ||||
|     catch (err) { | ||||
|  | ||||
| @ -166,6 +166,8 @@ import { | ||||
|     showIssueById, | ||||
|     updateIssue, | ||||
|     showIssues, | ||||
|     showSelectedIssuesByIssueName, | ||||
|     showSelectedIssuesByState, | ||||
| } from "../controller/issues.js"; | ||||
|  | ||||
| import { | ||||
| @ -219,8 +221,8 @@ router.put("/masterMaintenanceVisitTodos", updateMasterMaintenanceVisitTodo); | ||||
| // Delete master maintenance visit todo | ||||
| router.delete("/masterMaintenanceVisitTodos/:id", deleteMasterMaintenanceVisitTodo); | ||||
|  | ||||
| // Delete master maintenance visit todo by customer id | ||||
| router.delete("/masterMaintenanceVisitTodosByCustomerid/:id", deleteMasterMaintenanceVisitTodoByTemplateIds); | ||||
| // Delete master maintenance visit todo by template id | ||||
| router.delete("/masterMaintenanceVisitTodosByTemplateid/:id", deleteMasterMaintenanceVisitTodoByTemplateIds); | ||||
|  | ||||
| // Update all master maintenance visit todos | ||||
| router.put("/allMasterMaintenanceVisitTodos", updateAllMasterMaintenanceVisitTodos) | ||||
| @ -552,6 +554,12 @@ router.get("/issues", showIssues); | ||||
| //get issue by id | ||||
| router.get("/issues/:id", showIssueById); | ||||
|  | ||||
| //get all issues by selected name | ||||
| router.get("/selectedIssuesByIssueName/:id", showSelectedIssuesByIssueName) | ||||
|  | ||||
| //get all issues by selected state | ||||
| router.get("/selectedIssuesByState/:id", showSelectedIssuesByState) | ||||
|  | ||||
| // Update issue | ||||
| router.put("/issues", updateIssue); | ||||
|  | ||||
|  | ||||
| @ -1,9 +1,9 @@ | ||||
| <template> | ||||
|   <section :class="['client-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Client</div> | ||||
|     <pre v-if="!filtered" :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ clientFilter }}</pre> | ||||
|     <input v-if="filtered" v-model="clientFilter" @change="filterConfigItemList()" | ||||
|       :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Customer</div> | ||||
|     <pre v-if="!filtered" :class="['data', 'pre-customer', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ clientFilter }}</pre> | ||||
|     <input v-if="filtered" v-model="clientFilter" @change="filterList()" | ||||
|       :class="['data', 'input-customer', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
| @ -24,12 +24,20 @@ const updateFilterTerm = () => { | ||||
|   clientFilter.value = filteredTerm.value | ||||
| } | ||||
|  | ||||
| const checkFiltered = () => { | ||||
|   if (!filtered.value) { | ||||
|     clientFilter.value = '' | ||||
|     filterList(); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // update the filtered term in the store | ||||
| const filterConfigItemList = () => { | ||||
| const filterList = () => { | ||||
|   store.commit('updateFilterbyClient', clientFilter.value); | ||||
| } | ||||
|  | ||||
| watch(filteredTerm, updateFilterTerm) | ||||
| watch(filtered, checkFiltered) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -98,8 +106,13 @@ export default { | ||||
|   color: #000; | ||||
| } | ||||
|  | ||||
| .input { | ||||
| .input-customer { | ||||
|   border: none; | ||||
|   margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .pre-customer { | ||||
|   margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|  | ||||
							
								
								
									
										128
									
								
								components/IssueStateSearch.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								components/IssueStateSearch.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,128 @@ | ||||
| <template> | ||||
|     <section :class="['issue-state-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Issue state</div> | ||||
|         <pre v-if="!filtered" | ||||
|             :class="['data', 'pre-issue', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ issueStateFilter }}</pre> | ||||
|         <input v-if="filtered" v-model="issueStateFilter" @change="filterList()" | ||||
|             :class="['data', 'input-state', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
| <script setup> | ||||
| import { ref, watch } from 'vue'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const filtered = computed(() => store.state.filtered); | ||||
| const filteredTerm = computed(() => store.state.filteredByClient); | ||||
| const issueStateFilter = ref(store.state.filteredByClient); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| // update filtered term | ||||
| const updateFilterTerm = () => { | ||||
|     issueStateFilter.value = filteredTerm.value | ||||
| } | ||||
|  | ||||
| const checkFiltered = () => { | ||||
|     if (!filtered.value) { | ||||
|         issueStateFilter.value = '' | ||||
|         filterList(); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update the filtered term in the store | ||||
| const filterList = () => { | ||||
|     store.commit('updateFilterbyClient', issueStateFilter.value); | ||||
| } | ||||
|  | ||||
| watch(filteredTerm, updateFilterTerm) | ||||
| watch(filtered, checkFiltered) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "IssueStateSearch", | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style scoped> | ||||
| .issue-state-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; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .label-darkmode { | ||||
|     color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .input-state { | ||||
|     border: none; | ||||
|     margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .pre-issue { | ||||
|     margin-left: 1rem; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
| </style> | ||||
| @ -44,7 +44,6 @@ | ||||
|   </form> | ||||
| </template> | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { useRouter } from 'vue-router'; | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| @ -1,5 +1,204 @@ | ||||
| <template> | ||||
|     <section :class="['accounting-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <section v-if="!addBool" :class="['accounting-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']" id="accounting">Accounting: | ||||
|             <div class="asset-data"> | ||||
|                 <table class="data-table" id="asset-table-no-client"> | ||||
|                     <tbody> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                             <th | ||||
|                                 :class="['Action', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Action</th> | ||||
|                             <th | ||||
|                                 :class="['Date', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 Date</th> | ||||
|                             <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'first-tr-darkmode' : 'first-tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Supplier request</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.supplierRequestDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierRequestDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.supplierRequest }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierRequest" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Supplier offer</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.supplierOfferDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierOfferDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.supplierOffer }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierOffer" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Customer offer</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.clientOfferDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.clientOfferDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.clientOffer }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.clientOffer" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Customer order</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.clientOrderDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.clientOrderDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.clientOrder }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.clientOrder" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Supplier order</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.supplierOrderDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierOrderDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.supplierOrder }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.supplierOrder" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Ingress</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.ingressDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.ingressDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.ingress }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.ingress" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Egress</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.egressDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.egressDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.egress }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.egress" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'final-tr-darkmode' : 'final-tr-lightmode']" id="row-2"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Ingress bill</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.ingressBillDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.ingressBillDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.ingressBill }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.ingressBill" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'final-tr-darkmode' : 'final-tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Egress bill</td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 {{ | ||||
|         issueSlip.egressBillDate }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.egressBillDate" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         issueSlip.egressBill }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="issueSlip.egressBill" @change="updateIssueSlip()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['accounting-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']" id="accounting">Accounting: | ||||
|             <div class="asset-data"> | ||||
|                 <table class="data-table" id="asset-table-no-client"> | ||||
| @ -19,8 +218,13 @@ | ||||
|                                 Supplier request</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newSupplierRequestDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newSupplierRequest" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
| @ -28,26 +232,41 @@ | ||||
|                                 Supplier offer</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newSupplierOfferDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newSupplierOffer" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Client offer</td> | ||||
|                                 Customer offer</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newClientOfferDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newClientOffer" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Action', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Action-darkmode' : 'Action-lightmode']"> | ||||
|                                 Client order</td> | ||||
|                                 Customer order</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newClientOrderDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newClientOrder" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
| @ -55,8 +274,13 @@ | ||||
|                                 Supplier order</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newSupplierOrderDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newSupplierOrder" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
| @ -64,8 +288,13 @@ | ||||
|                                 Ingress</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newIngressDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newIngress" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
| @ -73,8 +302,13 @@ | ||||
|                                 Egress</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newEgressDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newEgress" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'final-tr-darkmode' : 'final-tr-lightmode']" id="row-2"> | ||||
|                             <td | ||||
| @ -82,8 +316,13 @@ | ||||
|                                 Ingress bill</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newIngressBillDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newIngressBill" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'final-tr-darkmode' : 'final-tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
| @ -91,20 +330,224 @@ | ||||
|                                 Egress bill</td> | ||||
|                             <td | ||||
|                                 :class="['Date', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Date-darkmode' : 'Date-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newEgressBillDate" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newEgressBill" @change="updateIS()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewItem"> | ||||
|         <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" | ||||
|             @click="addIssueSlip()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
| <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 editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
| const addBool = computed(() => store.state.new); | ||||
| const newTicketNoIS = computed(() => store.state.newTicketNoIS); | ||||
| const newCustomerIdIS = computed(() => store.state.newCustomerIdIS); | ||||
| const newCustomerIS = computed(() => store.state.newCustomerIS); | ||||
| const newNotesIS = computed(() => store.state.newNotesIS); | ||||
| const newUserIS = computed(() => store.state.newUserIS); | ||||
| const newDeliveryAddressIS = computed(() => store.state.newDeliveryAddressIS); | ||||
| const newAddRowOI = computed(() => store.state.newAddRowOI); | ||||
| const newOIs = computed(() => store.state.newOIs); | ||||
|  | ||||
| const newClientOffer = ref(''); | ||||
| const newClientOrder = ref(''); | ||||
| const newSupplierOffer = ref(''); | ||||
| const newSupplierOrder = ref(''); | ||||
| const newSupplierRequest = ref(''); | ||||
| const newIngress = ref(''); | ||||
| const newIngressBill = ref(''); | ||||
| const newEgress = ref(''); | ||||
| const newEgressBill = ref(''); | ||||
| const newClientOfferDate = ref(''); | ||||
| const newClientOrderDate = ref(''); | ||||
| const newSupplierOfferDate = ref(''); | ||||
| const newSupplierOrderDate = ref(''); | ||||
| const newSupplierRequestDate = ref(''); | ||||
| const newIngressDate = ref(''); | ||||
| const newIngressBillDate = ref(''); | ||||
| const newEgressDate = ref(''); | ||||
| const newEgressBillDate = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const issueSlip = ref({}); | ||||
|  | ||||
| // get issue slip from id | ||||
| const getIssueSlipById = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueSlip/${chosenIssueSlipId.value}` | ||||
|         ); | ||||
|         issueSlip.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update accounting fields in the store | ||||
| const updateIS = () => { | ||||
|     const is = { | ||||
|         supplierRequestDate: newSupplierRequestDate.value, | ||||
|         supplierRequest: newSupplierRequest.value, | ||||
|         supplierOfferDate: newSupplierOfferDate.value, | ||||
|         supplierOffer: newSupplierOffer.value, | ||||
|         clientOfferDate: newClientOfferDate.value, | ||||
|         clientOffer: newClientOffer.value, | ||||
|         clientOrderDate: newClientOrderDate.value, | ||||
|         clientOrder: newClientOrder.value, | ||||
|         supplierOrderDate: newSupplierOrderDate.value, | ||||
|         supplierOrder: newSupplierOrder.value, | ||||
|         ingressDate: newIngressDate.value, | ||||
|         ingress: newIngress.value, | ||||
|         egressDate: newEgressDate.value, | ||||
|         egress: newEgress.value, | ||||
|         ingressBillDate: newIngressBillDate.value, | ||||
|         ingressBill: newIngressBill.value, | ||||
|         egressBillDate: newEgressBillDate.value, | ||||
|         egressBill: newEgressBill.value, | ||||
|     }; | ||||
|     store.commit('updateAccountingComponent', is); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateIssueSlip = async () => { | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateIssueSlip`, | ||||
|             { | ||||
|                 primaryID: issueSlip.value.primaryID, | ||||
|                 customerID: issueSlip.value.customerID, | ||||
|                 customer: issueSlip.value.customer, | ||||
|                 ticketNo: issueSlip.value.ticketNo, | ||||
|                 creationDate: issueSlip.value.creationDate, | ||||
|                 lastView: issueSlip.value.lastView, | ||||
|                 user: issueSlip.value.user, | ||||
|                 notes: issueSlip.value.notes, | ||||
|                 deliveryAddress: issueSlip.value.deliveryAddress, | ||||
|                 supplierRequestDate: issueSlip.value.supplierRequestDate, | ||||
|                 supplierRequest: issueSlip.value.supplierRequest, | ||||
|                 supplierOfferDate: issueSlip.value.supplierOfferDate, | ||||
|                 supplierOffer: issueSlip.value.supplierOffer, | ||||
|                 clientOfferDate: issueSlip.value.clientOfferDate, | ||||
|                 clientOffer: issueSlip.value.clientOffer, | ||||
|                 clientOrderDate: issueSlip.value.clientOrderDate, | ||||
|                 clientOrder: issueSlip.value.clientOrder, | ||||
|                 supplierOrder: issueSlip.value.supplierOrder, | ||||
|                 supplierOrderDate: issueSlip.value.supplierOrderDate, | ||||
|                 ingressDate: issueSlip.value.ingressDate, | ||||
|                 ingress: issueSlip.value.ingress, | ||||
|                 egressDate: issueSlip.value.egressDate, | ||||
|                 egress: issueSlip.value.egress, | ||||
|                 ingressBillDate: issueSlip.value.ingressBillDate, | ||||
|                 ingressBill: issueSlip.value.ingressBill, | ||||
|                 egressBillDate: issueSlip.value.egressBillDate, | ||||
|                 egressBill: issueSlip.value.egressBill, | ||||
|             } | ||||
|         ) | ||||
|         await getIssueSlipById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new issue slip | ||||
| const addIssueSlip = async () => { | ||||
|     if (newTicketNoIS.value.length === 0) { | ||||
|         alert("Please add a ticket number!"); | ||||
|         return; | ||||
|     } | ||||
|     if (newCustomerIS.value.length === 0) { | ||||
|         alert("Please choose a customer!"); | ||||
|         return; | ||||
|     } | ||||
|     // get the time and date | ||||
|     const today = new Date(); | ||||
|     const date = today.getFullYear() + '-' + (today.getMonth() + 1) + '-' + today.getDate(); | ||||
|     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 (!allFine) { | ||||
|         return | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addIssueSlip`, | ||||
|             { | ||||
|                 customerID: newCustomerIdIS.value, | ||||
|                 customer: newCustomerIS.value, | ||||
|                 ticketNo: newTicketNoIS.value, | ||||
|                 creationDate: dateTime, | ||||
|                 lastView: '', | ||||
|                 user: newUserIS.value, | ||||
|                 notes: newNotesIS.value, | ||||
|                 deliveryAddress: newDeliveryAddressIS.value, | ||||
|                 supplierRequestDate: newSupplierRequestDate.value, | ||||
|                 supplierRequest: newSupplierRequest.value, | ||||
|                 supplierOfferDate: newSupplierOfferDate.value, | ||||
|                 supplierOffer: newSupplierOffer.value, | ||||
|                 clientOfferDate: newClientOfferDate.value, | ||||
|                 clientOffer: newClientOffer.value, | ||||
|                 clientOrderDate: newClientOrderDate.value, | ||||
|                 clientOrder: newClientOrder.value, | ||||
|                 supplierOrderDate: newClientOrderDate.value, | ||||
|                 supplierOrder: newSupplierOrder.value, | ||||
|                 ingressDate: newIngressDate.value, | ||||
|                 ingress: newIngress.value, | ||||
|                 egressDate: newEgressDate.value, | ||||
|                 egress: newEgress.value, | ||||
|                 ingressBillDate: newIngressBillDate.value, | ||||
|                 ingressBill: newIngressBill.value, | ||||
|                 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'); | ||||
|         }) | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueSlipById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -134,6 +577,31 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|     letter-spacing: 5%; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| @ -204,6 +672,41 @@ export default { | ||||
|     background-color: #EBEBEB; | ||||
| } | ||||
|  | ||||
| .saveNewItem-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .saveNewItem-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .saveNewItem-darkmode:hover { | ||||
|     background-color: #444444; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .saveNewItem-lightmode:hover { | ||||
|     background-color: #ACACAC; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| #saveNewItem { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|  | ||||
| @ -7,7 +7,7 @@ | ||||
|         <div class="asset-data"> | ||||
|             <div class="client-location"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"> {{ item.customer }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="item.customer" | ||||
| @ -83,7 +83,7 @@ | ||||
|         <div class="asset-data"> | ||||
|             <div class="client-location"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newCustomer" @change="updateNewCustomerID()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
| @ -280,6 +280,7 @@ const confirmDeleteAsset = async () => { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteConfigItem/${chosenAssetId.value}`); | ||||
|                 store.commit('undoDelete'); | ||||
|                 store.commit('resetStore'); | ||||
|                 store.commit('changeToAssetlist'); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
| @ -337,7 +338,6 @@ onMounted(() => { | ||||
|     getConfigItems(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
|  | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| @ -11,7 +11,7 @@ | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Client', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Client-darkmode' : 'Client-lightmode']"> | ||||
|                         Client</th> | ||||
|                         Customer</th> | ||||
|                     <th | ||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         Name</th> | ||||
| @ -136,7 +136,6 @@ export default { | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     /* width: 100%; */ | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Client name</pre> | ||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Customer name</pre> | ||||
|     <div class="data-field" id="client-id"> | ||||
|       <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
| @ -94,7 +94,7 @@ section { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: row; | ||||
|   padding: 0 1.875rem; | ||||
|   padding: 0.8rem 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
|  | ||||
| @ -7,7 +7,7 @@ | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="client-id"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client ID:</pre> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="head"> | ||||
| @ -86,7 +86,7 @@ display: flex; | ||||
| flex: auto; | ||||
| width: 30%; | ||||
| flex-direction: row; | ||||
| padding: 0.625rem 1.875rem; | ||||
| padding: 0.8rem 1.875rem; | ||||
| align-items: center; | ||||
| justify-content: flex-start; | ||||
| gap: 1.25rem; | ||||
|  | ||||
| @ -33,7 +33,7 @@ | ||||
|     </div> | ||||
|     <div class="data-group" id="employment-data"> | ||||
|       <div class="data-field" id="client-id"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client ID:</pre> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|       <div class="data-field" id="department"> | ||||
| @ -133,7 +133,7 @@ section { | ||||
|   flex: auto; | ||||
|   width: 20%; | ||||
|   flex-direction: row; | ||||
|   padding: 0 1.875rem; | ||||
|   padding: 0.8rem 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
|  | ||||
| @ -1,22 +1,33 @@ | ||||
| <template> | ||||
|     <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['issue-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Name</h2> | ||||
|     <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 v-if="!editable" :class="['issue-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ issue.name }}</h2> | ||||
|         <input v-if="editable" v-model="issue.name" @change="updateIssueItem()" | ||||
|             :class="['data', 'issue-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="issue-data"> | ||||
|             <div class="type"> | ||||
|                 <div class="data-field" id="type"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issue.type }}</pre> | ||||
|                     <input v-if="editable" v-model="issue.type" @change="updateIssueItem()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="state-amount"> | ||||
|                     <div class="data-field" id="state"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">State:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issue.state }}</pre> | ||||
|                         <input v-if="editable" v-model="issue.state" @change="updateIssueItem()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="amount"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Amount:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issue.amount }}</pre> | ||||
|                         <input v-if="editable" v-model="issue.amount" @change="updateIssueItem()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
| @ -25,7 +36,44 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="properties"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Properties:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="properties">...</pre> | ||||
|                     <input v-model="issue.properties" :readonly="!editable" @change="updateIssueItem()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="properties"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <input v-model="newName" @change="updateII()" | ||||
|             :class="['data', 'issue-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="issue-data"> | ||||
|             <div class="type"> | ||||
|                 <div class="data-field" id="type"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                     <input v-model="newType" @change="updateII()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="state-amount"> | ||||
|                     <div class="data-field" id="state"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">State:</pre> | ||||
|                         <input v-model="newState" @change="updateII()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="amount"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Amount:</pre> | ||||
|                         <input v-model="newAmount" @change="updateII()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|         <div class="issue-data"> | ||||
|             <div class="additional"> | ||||
|                 <div class="properties"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Properties:</h3> | ||||
|                     <input v-model="newProperties" @change="updateII()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="properties"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
| @ -34,9 +82,136 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 editable = computed(() => store.state.editable); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const issue = ref({}); | ||||
| const issues = ref([]); | ||||
|  | ||||
| const newName = ref(''); | ||||
| const newType = ref(''); | ||||
| const newState = ref(''); | ||||
| const newAmount = ref(''); | ||||
| const newProperties = ref(''); | ||||
|  | ||||
| //get all issue | ||||
| const getIssues = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllIssues`); | ||||
|         issues.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| const confirmDeleteIssue = async () => { | ||||
|     if (deleteBool.value === true) { | ||||
|         if (confirm("Do you really want to delete this issue? It cannot be undone!")) { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteIssueItem/${chosenIssueId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteIV/${chosenIssueId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             store.commit('undoDelete'); | ||||
|             store.commit('resetStore'); | ||||
|             store.commit('changeToIssueItemList'); | ||||
|         } else { | ||||
|             store.commit('undoDelete'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateIssueItem = async () => { | ||||
|     if (issue.value.name.trim() === "") { | ||||
|         alert("Please add an issue name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         // check if the issue name already exists | ||||
|         issues.value.forEach(i => { | ||||
|             if (i.name === issue.value.name) { | ||||
|                 counter += 1; | ||||
|             } | ||||
|         }); | ||||
|         if (counter == 2) { | ||||
|             alert("This issue name already exists. Please choose an unique issue name or modify respectively delete the old one!"); | ||||
|             issue.value.name = ''; | ||||
|             return; | ||||
|         } | ||||
|         try { | ||||
|             await Axios.put( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateIssueItem`, | ||||
|                 { | ||||
|                     primaryID: issue.value.primaryID, | ||||
|                     name: issue.value.name, | ||||
|                     type: issue.value.type, | ||||
|                     state: issue.value.state, | ||||
|                     amount: issue.value.amount, | ||||
|                     properties: issue.value.properties, | ||||
|                 } | ||||
|             ) | ||||
|             await getIssueById(); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // get issue from id | ||||
| const getIssueById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueItem/${chosenIssueId.value}` | ||||
|             ); | ||||
|             issue.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update issue fields in the store | ||||
| const updateII = () => { | ||||
|     const ii = { | ||||
|         name: newName.value, | ||||
|         type: newType.value, | ||||
|         state: newState.value, | ||||
|         amount: newAmount.value, | ||||
|         properties: newProperties.value, | ||||
|     }; | ||||
|     store.commit('updateIssueComponent', ii); | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssue); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getIssues); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -67,7 +242,27 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .issue-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; | ||||
| } | ||||
|  | ||||
| .h2-input-darkmode { | ||||
|     background-color: #212121; | ||||
| } | ||||
|  | ||||
| .h2-input-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .issue-name { | ||||
|     align-self: stretch; | ||||
| @ -92,7 +287,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| @ -1,22 +1,33 @@ | ||||
| <template> | ||||
|     <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['issueSlip-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">ID issue slips</h2> | ||||
|     <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['issueSlip-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ issueSlip.primaryID }}</h2> | ||||
|         <div class="issueSlip-data"> | ||||
|             <div class="client"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueSlip.customer }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="issueSlip.customer" | ||||
|                         @change="updateCustomerID()" :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="ticketNo-user"> | ||||
|                     <div class="data-field" id="ticketNo"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Ticket No.:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueSlip.ticketNo }}</pre> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="user"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueSlip.user }}</pre> | ||||
|                         <input v-if="editable" v-model="issueSlip.user" @change="updateIssueSlip()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
| @ -25,18 +36,256 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|                     <input v-model="issueSlip.notes" :readonly="!editable" @change="updateIssueSlip()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="additional"> | ||||
|                 <div class="deliveryAddress"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Different delivery address: | ||||
|                     </h3> | ||||
|                     <input v-model="issueSlip.deliveryAddress" :readonly="!editable" @change="updateIssueSlip()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="deliveryAddress"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['issueSlip-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Issue slip ID</h2> | ||||
|         <div class="issueSlip-data"> | ||||
|             <div class="client"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newCustomer" @change="updateNewCustomerID()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="ticketNo-user"> | ||||
|                     <div class="data-field" id="ticketNo"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Ticket No.:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"></pre> | ||||
|                         <!-- <select id="ticketNoDropDownChosenCI" v-model="newTicketNo" @change="updateIS()" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="po in productionOrders" :key="po.ticketNumber"> | ||||
|                                 {{ po.ticketNumber }} | ||||
|                             </option> | ||||
|                         </select> --> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="user"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                         <input v-model="newUser" @change="updateIS()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|         <div class="issueSlip-data"> | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <input v-model="newNotes" @change="updateIS()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="additional"> | ||||
|                 <div class="deliveryAddress"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Different delivery address: | ||||
|                     </h3> | ||||
|                     <input v-model="newDeliveryAddress" @change="updateIS()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="deliveryAddress"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
|      | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const issueSlip = ref({}); | ||||
| const customer = ref({}); | ||||
| const productionOrders = ref([]); | ||||
| const customers = ref([]); | ||||
|  | ||||
| const newTicketNo = ref(''); | ||||
| const newCustomerID = ref(''); | ||||
| const newCustomer = ref(''); | ||||
| const newUser = ref(''); | ||||
| const newNotes = ref(''); | ||||
| const newDeliveryAddress = ref(''); | ||||
|  | ||||
| // get issue slip from id | ||||
| const getIssueSlipById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueSlip/${chosenIssueSlipId.value}` | ||||
|             ); | ||||
|             issueSlip.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update issue slip fields in the store | ||||
| const updateIS = () => { | ||||
|     const is = { | ||||
|         customerId: newCustomerID.value, | ||||
|         customer: newCustomer.value, | ||||
|         // ticketNo: newTicketNo.value, | ||||
|         ticketNo: 1, | ||||
|         notes: newNotes.value, | ||||
|         user: newUser.value, | ||||
|         deliveryAddress: newDeliveryAddress.value, | ||||
|     }; | ||||
|     store.commit('updateIssueSlipComponent', is); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateIssueSlip = async () => { | ||||
|     // delete later | ||||
|     issueSlip.value.ticketNo = 1; | ||||
|     if (issueSlip.value.ticketNo.length === 0) { | ||||
|         alert("Please add a ticket Number!"); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateIssueSlip`, | ||||
|             { | ||||
|                 primaryID: issueSlip.value.primaryID, | ||||
|                 customerID: issueSlip.value.customerID, | ||||
|                 customer: issueSlip.value.customer, | ||||
|                 ticketNo: issueSlip.value.ticketNo, | ||||
|                 creationDate: issueSlip.value.creationDate, | ||||
|                 lastView: issueSlip.value.lastView, | ||||
|                 user: issueSlip.value.user, | ||||
|                 notes: issueSlip.value.notes, | ||||
|                 deliveryAddress: issueSlip.value.deliveryAddress, | ||||
|                 supplierRequestDate: issueSlip.value.supplierRequestDate, | ||||
|                 supplierRequest: issueSlip.value.supplierRequest, | ||||
|                 supplierOfferDate: issueSlip.value.supplierOfferDate, | ||||
|                 supplierOffer: issueSlip.value.supplierOffer, | ||||
|                 clientOfferDate: issueSlip.value.clientOfferDate, | ||||
|                 clientOffer: issueSlip.value.clientOffer, | ||||
|                 clientOrderDate: issueSlip.value.clientOrderDate, | ||||
|                 clientOrder: issueSlip.value.clientOrder, | ||||
|                 supplierOrder: issueSlip.value.supplierOrder, | ||||
|                 supplierOrderDate: issueSlip.value.supplierOrderDate, | ||||
|                 ingressDate: issueSlip.value.ingressDate, | ||||
|                 ingress: issueSlip.value.ingress, | ||||
|                 egressDate: issueSlip.value.egressDate, | ||||
|                 egress: issueSlip.value.egress, | ||||
|                 ingressBillDate: issueSlip.value.ingressBillDate, | ||||
|                 ingressBill: issueSlip.value.ingressBill, | ||||
|                 egressBillDate: issueSlip.value.egressBillDate, | ||||
|                 egressBill: issueSlip.value.egressBill, | ||||
|             } | ||||
|         ) | ||||
|         await getIssueSlipById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //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 production orders | ||||
| 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); | ||||
|     // } | ||||
| } | ||||
|  | ||||
| const confirmDeleteIssueSlip = async () => { | ||||
|     if (deleteBool.value === true) { | ||||
|         if (confirm("Do you really want to delete this issue slip? It cannot be undone!")) { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteIssueSlip/${chosenIssueSlipId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteTodosOI/${chosenIssueSlipId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             store.commit('undoDelete'); | ||||
|             store.commit('resetStore'); | ||||
|             store.commit('changeToIssueSliplist'); | ||||
|         } else { | ||||
|             store.commit('undoDelete'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${issueSlip.value.customer}`); | ||||
|         customer.value = response.data; | ||||
|         issueSlip.value.customerID = customer.value.customerID; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     await updateIssueSlip(); | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateNewCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${newCustomer.value}`); | ||||
|         newCustomerID.value = response.data.customerID; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     updateIS(); | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueSlip); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueSlipById(); | ||||
|     getProductionOrders(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -92,7 +341,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
| @ -129,6 +378,10 @@ export default { | ||||
|     font: 400 0.75rem/250% Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| @ -165,7 +418,7 @@ export default { | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     line-height: normal; | ||||
|     width: 100%; | ||||
|     width: 50%; | ||||
|     padding: 0rem 0.625rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
| @ -193,10 +446,12 @@ export default { | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .data#notes { | ||||
| .data#notes, | ||||
| .data#deliveryAddress { | ||||
|     align-self: stretch; | ||||
| } | ||||
|  | ||||
| .deliveryAddress, | ||||
| .notes { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
| @ -206,4 +461,20 @@ export default { | ||||
|     padding: 0.625rem 1.875rem 0.625rem 1.25rem; | ||||
|     padding-top: 0rem; | ||||
| } | ||||
|  | ||||
| .select-darkmode { | ||||
|     border: none; | ||||
|     color: white; | ||||
|     background: #212121; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .select-lightmode { | ||||
|     border: none; | ||||
|     color: black; | ||||
|     background: #EBEBEB; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
| </style> | ||||
| @ -1,4 +1,9 @@ | ||||
| <template> | ||||
|     <section v-if="searchable" :class="['issue-slip-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Ticket No</div> | ||||
|         <input v-model="issueSlipSearchFilter" @change="searchIssueSlip()" | ||||
|             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Last viewed:</div> | ||||
|         <table class="data-table" id="asset-table"> | ||||
| @ -6,7 +11,7 @@ | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Client', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Client-darkmode' : 'Client-lightmode']"> | ||||
|                         Client</th> | ||||
|                         Customer</th> | ||||
|                     <th | ||||
|                         :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                         ID | ||||
| @ -26,7 +31,12 @@ | ||||
|                         {{ issueSlip.customer }}</td> | ||||
|                     <td | ||||
|                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                         {{ issueSlip.primaryID }}</td> | ||||
|                         <nuxt-link to="/issueSlips" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             @click="goToChosenIssueSlip(issueSlip.primaryID)"> | ||||
|                             {{ issueSlip.primaryID }} | ||||
|                         </nuxt-link> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['TicketNo', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'TicketNo-darkmode' : 'TicketNo-lightmode']"> | ||||
|                         {{ issueSlip.ticketNo }}</td> | ||||
| @ -42,25 +52,76 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const goToChosenIssueSlip = (id) => { | ||||
|     store.commit('setChosenIssueSlip', id); | ||||
|     store.commit('changeToIssueSlip'); | ||||
| }; | ||||
|  | ||||
| const clientFilter = computed(() => store.state.filteredByClient); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const issueSlipSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const issueSlips = ref([]); | ||||
|  | ||||
| // update search term | ||||
| const updateSearchTerm = async () => { | ||||
|     issueSlipSearchFilter.value = ''; | ||||
|     await getIssueSlips(); | ||||
| } | ||||
|  | ||||
| //get all issueSlips | ||||
| const getIssueSlips = async () => { | ||||
|     if (!(clientFilter.value === '')) { | ||||
|         await getFilteredIssueSlipsByClient(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllIssueSlips`); | ||||
|             issueSlips.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueSlips(); | ||||
| //get all issue slips based on the searched client | ||||
| const getFilteredIssueSlipsByClient = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedIssueSlipsByClient/${clientFilter.value}`); | ||||
|         issueSlips.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all issue slips based on the searched issue slip id | ||||
| const searchIssueSlip = async () => { | ||||
|     if (issueSlipSearchFilter.value === '') { | ||||
|         await getIssueSlips(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedIssueSlipsByTicketNo/${issueSlipSearchFilter.value}`); | ||||
|             issueSlips.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(clientFilter, getIssueSlips); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getIssueSlips(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -77,7 +138,6 @@ export default { | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     width: 100%; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| @ -92,6 +152,46 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .issue-slip-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; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
| @ -118,6 +218,27 @@ export default { | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .clientLabel { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .tr-darkmode { | ||||
|     border-top: 0.0625rem solid #000000; | ||||
| } | ||||
| @ -218,4 +339,5 @@ th { | ||||
|  | ||||
| .label-lightmode { | ||||
|     color: #000; | ||||
| }</style> | ||||
| } | ||||
| </style> | ||||
| @ -1,4 +1,9 @@ | ||||
| <template> | ||||
|     <section v-if="searchable" :class="['issue-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Issue name</div> | ||||
|         <input v-model="issueSearchFilter" @change="searchIssue()" | ||||
|             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Issues:</div> | ||||
|         <table class="data-table" id="asset-table"> | ||||
| @ -19,7 +24,12 @@ | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         {{ issue.name }}</td> | ||||
|                         <nuxt-link to="/issues" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             @click="goToChosenIssue(issue.primaryID)"> | ||||
|                             {{ issue.name }} | ||||
|                         </nuxt-link> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Type', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Type-darkmode' : 'Type-lightmode']"> | ||||
|                         {{ issue.type }}</td> | ||||
| @ -35,25 +45,76 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const goToChosenIssue = (id) => { | ||||
|     store.commit('setChosenIssue', id); | ||||
|     store.commit('changeToIssueItem'); | ||||
| }; | ||||
|  | ||||
| const stateFilter = computed(() => store.state.filteredByClient); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const issueSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const issues = ref([]); | ||||
|  | ||||
| // update search term | ||||
| const updateSearchTerm = async () => { | ||||
|     issueSearchFilter.value = ''; | ||||
|     await getIssues(); | ||||
| } | ||||
|  | ||||
|  | ||||
| //get all issue | ||||
| const getIssues = async () => { | ||||
|     if (!(stateFilter.value === '')) { | ||||
|         await getFilteredIssuesByState(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllIssues`); | ||||
|             issues.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssues(); | ||||
| //get all issues based on the searched state | ||||
| const getFilteredIssuesByState = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedIssuesByState/${stateFilter.value}`); | ||||
|         issues.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all issues based on the searched issue name | ||||
| const searchIssue = async () => { | ||||
|     if (issueSearchFilter.value === '') { | ||||
|         await getIssues(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedIssuesByIssueName/${issueSearchFilter.value}`); | ||||
|             issues.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(stateFilter, getIssues); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getIssues(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -87,6 +148,27 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .clientLabel { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
| @ -94,6 +176,46 @@ export default { | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .issue-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; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|  | ||||
| @ -1,26 +1,40 @@ | ||||
| <template> | ||||
|     <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['issue-variant-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Name</h2> | ||||
|         <h2 v-if="!editable" :class="['issue-variant-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ | ||||
|         issueVariant.name }}</h2> | ||||
|         <input v-if="editable" v-model="issueVariant.name" @change="updateIssueVariant()" | ||||
|             :class="['data', 'issue-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="issue-variant-data"> | ||||
|             <div class="variantOf"> | ||||
|                 <div class="data-field" id="variantOf"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Variant of:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"><nuxt-link to="/issues" id="nuxt-link" class="button" @click="goToChosenIssue(issue.primaryID)">{{ nameOfVariant }}</nuxt-link></pre> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="state-amount-price"> | ||||
|                     <div class="data-field" id="state"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">State:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueVariant.state }}</pre> | ||||
|                         <input v-if="editable" v-model="issueVariant.state" @change="updateIssueVariant()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|  | ||||
|                     </div> | ||||
|                     <div class="data-field" id="amount"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Amount:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueVariant.amount }}</pre> | ||||
|                         <input v-if="editable" v-model="issueVariant.amount" @change="updateIssueVariant()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="price"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Price:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ issueVariant.price }}</pre> | ||||
|                         <input v-if="editable" v-model="issueVariant.price" @change="updateIssueVariant()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
| @ -29,18 +43,143 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="properties"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Properties:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="properties">...</pre> | ||||
|                     <input v-model="issueVariant.properties" :readonly="!editable" @change="updateIssueVariant()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="properties"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
|      | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 editable = computed(() => store.state.editable); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
| const chosenIssueVariantId = computed(() => store.state.chosenIssueVariantId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const issue = ref({}); | ||||
| const issueVariant = ref({}); | ||||
| const issueVariants = ref([]); | ||||
| const nameOfVariant = ref(''); | ||||
|  | ||||
| //get all issue variants | ||||
| const getIssueVariants = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllIssueVariants`); | ||||
|         issueVariants.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| const goToChosenIssue = (id) => { | ||||
|     store.commit('setChosenIssue', id); | ||||
|     store.commit('changeToIssueItem'); | ||||
| }; | ||||
|  | ||||
| const confirmDeleteIssueVariant = async () => { | ||||
|     if (deleteBool.value === true) { | ||||
|         if (confirm("Do you really want to delete this issue variant? It cannot be undone!")) { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteIssueVariant/${chosenIssueVariantId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             store.commit('undoDelete'); | ||||
|             store.commit('resetStore'); | ||||
|             store.commit('changeToIssueItemList'); | ||||
|         } else { | ||||
|             store.commit('undoDelete'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateIssueVariant = async () => { | ||||
|     if (issueVariant.value.name.trim() === "") { | ||||
|         alert("Please add an issue variant name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         // check if the issue variant name already exists | ||||
|         issueVariants.value.forEach(i => { | ||||
|             if (i.name === issueVariant.value.name) { | ||||
|                 counter += 1; | ||||
|             } | ||||
|         }); | ||||
|         if (counter == 2) { | ||||
|             alert("This issue variant name already exists. Please choose an unique issue variant name or modify respectively delete the old one!"); | ||||
|             issueVariant.value.name = ''; | ||||
|             return; | ||||
|         } | ||||
|         try { | ||||
|             await Axios.put( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateIssueVariant`, | ||||
|                 { | ||||
|                     primaryID: issueVariant.value.primaryID, | ||||
|                     issueID: issueVariant.value.issueID, | ||||
|                     name: issueVariant.value.name, | ||||
|                     state: issueVariant.value.state, | ||||
|                     amount: issueVariant.value.amount, | ||||
|                     properties: issueVariant.value.properties, | ||||
|                     price: issueVariant.value.price, | ||||
|                 } | ||||
|             ) | ||||
|             await getIssueVariantById(); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| // get issue variant from id | ||||
| const getIssueVariantById = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueVariant/${chosenIssueVariantId.value}` | ||||
|         ); | ||||
|         issueVariant.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // get issue from id | ||||
| const getIssueById = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueItem/${chosenIssueId.value}` | ||||
|         ); | ||||
|         issue.value = response.data; | ||||
|         nameOfVariant.value = issue.value.name; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteIssueVariant); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueVariantById(); | ||||
|     getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getIssueVariants); | ||||
| }); | ||||
|  | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -71,8 +210,6 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| .issue-variant-name { | ||||
|     align-self: stretch; | ||||
|     padding: 1rem 0; | ||||
| @ -96,7 +233,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
| @ -151,18 +288,46 @@ export default { | ||||
|     align-self: stretch; | ||||
| } | ||||
|  | ||||
| .variantOf, | ||||
| .variantOf { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     line-height: normal; | ||||
|     width: 30%; | ||||
|     padding: 0 0; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .info { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     line-height: normal; | ||||
|     width: 50%; | ||||
|     width: 70%; | ||||
|     padding: 0 0; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .issue-name-input { | ||||
|     margin: 1rem; | ||||
|     letter-spacing: 5%; | ||||
|     text-decoration-line: underline; | ||||
| } | ||||
|  | ||||
| .h2-input-darkmode { | ||||
|     background-color: #212121; | ||||
| } | ||||
|  | ||||
| .h2-input-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .additional { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
| @ -210,4 +375,9 @@ export default { | ||||
|     padding: 0.625rem 1.875rem 0.625rem 1.25rem; | ||||
|     padding-top: 0rem; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
| </style> | ||||
| @ -1,5 +1,6 @@ | ||||
| <template> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|     <section v-if="!addBool" | ||||
|         :class="['issue-variant-list-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Variants:</div> | ||||
|         <table class="data-table" id="issue-variants-table"> | ||||
|             <tbody> | ||||
| @ -18,30 +19,403 @@ | ||||
|                         Amount</th> | ||||
|                     <th :class="['Price', darkMode ? 'th-darkmode' : 'th-lightmode']">Price</th> | ||||
|                 </tr> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <tr v-for="issueVar in issueVariants" :key="issueVar.primaryID" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <nuxt-link to="/issues" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             @click="goToChosenIssueVariant(issueVar.primaryID)"> | ||||
|                             {{ issueVar.name }} | ||||
|                         </nuxt-link> | ||||
|                     </td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <input type="text" v-model="issueVar.name" @change="updateIssueVariant(issueVar)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Properties', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Properties-darkmode' : 'Properties-lightmode']"> | ||||
|                         {{ issueVar.properties }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Properties', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Properties-darkmode' : 'Properties-lightmode']"> | ||||
|                         <input type="text" v-model="issueVar.properties" @change="updateIssueVariant(issueVar)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['State', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'State-darkmode' : 'State-lightmode']"> | ||||
|                         {{ issueVar.state }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['State', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'State-darkmode' : 'State-lightmode']"> | ||||
|                         <input type="text" v-model="issueVar.state" @change="updateIssueVariant(issueVar)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                         {{ issueVar.amount }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                         <input type="text" v-model="issueVar.amount" @change="updateIssueVariant(issueVar)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ issueVar.price | ||||
|                         }}</td> | ||||
|                     <td v-if="editable" :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                             v-model="issueVar.price" @change="updateIssueVariant(issueVar)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"><button | ||||
|                             :class="[darkMode ? 'deleteIssueVariant-darkmode' : 'deleteIssueVariant-lightmode']" | ||||
|                             @click="deleteIssueVariant(issueVar.primaryID)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                     id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         ...</td> | ||||
|                         <input type="text" v-model="newNameIV" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Properties', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Properties-darkmode' : 'Properties-lightmode']"> | ||||
|                         ...</td> | ||||
|                         <input type="text" v-model="newPropertiesIV" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['State', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'State-darkmode' : 'State-lightmode']"> | ||||
|                         ...</td> | ||||
|                         <input type="text" v-model="newStateIV" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                         ...</td> | ||||
|                     <td :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                         <input type="text" v-model="newAmountIV" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                             v-model="newPriceIV" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'saveIssueVariant-darkmode' : 'saveIssueVariant-lightmode']" | ||||
|                             @click="addIssueVariant()">Save</button> <button | ||||
|                             :class="[darkMode ? 'deleteLastIssueVariant-darkmode' : 'deleteLastIssueVariant-lightmode']" | ||||
|                             @click="deleteNewRow()">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </div> | ||||
|     </section> | ||||
|     <section v-if="editable && !addBool" id="editIssueVariant"> | ||||
|         <button :class="[darkMode ? 'editIssueVariant-darkmode' : 'editIssueVariant-lightmode']" | ||||
|             @click="addChecklistRow()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" | ||||
|         :class="['issue-variant-list-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Variants:</div> | ||||
|         <table class="data-table" id="issue-variants-table"> | ||||
|             <tbody> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         Name</th> | ||||
|                     <th | ||||
|                         :class="['Properties', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Properties-darkmode' : 'Properties-lightmode']"> | ||||
|                         Properties</th> | ||||
|                     <th | ||||
|                         :class="['State', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'State-darkmode' : 'State-lightmode']"> | ||||
|                         State</th> | ||||
|                     <th | ||||
|                         :class="['Amount', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                         Amount</th> | ||||
|                     <th :class="['Price', darkMode ? 'th-darkmode' : 'th-lightmode']">Price</th> | ||||
|                 </tr> | ||||
|                 <tr v-for="(newIV, index) in newVariants" :key="index" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         <input type="text" v-model="newIV.name" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Properties', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Properties-darkmode' : 'Properties-lightmode']"> | ||||
|                         <input type="text" v-model="newIV.properties" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['State', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'State-darkmode' : 'State-lightmode']"> | ||||
|                         <input type="text" v-model="newIV.state" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                         <input type="text" v-model="newIV.amount" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                             v-model="newIV.price" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deleteLastIssueVariant-darkmode' : 'deleteLastIssueVariant-lightmode']" | ||||
|                             @click="deleteIssueVariantFromNewTodos(index)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="editIssueVariant"> | ||||
|         <button :class="[darkMode ? 'editIssueVariant-darkmode' : 'editIssueVariant-lightmode']" | ||||
|             @click="addRowForNewIVs()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewIssueVariant"> | ||||
|         <button :class="[darkMode ? 'saveNewIssueVariant-darkmode' : 'saveNewIssueVariant-lightmode']" | ||||
|             @click="addIV()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
| <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 addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| const newName = computed(() => store.state.newNameII); | ||||
| const newType = computed(() => store.state.newTypeII); | ||||
| const newState = computed(() => store.state.newStateII); | ||||
| const newAmount = computed(() => store.state.newAmountII); | ||||
| const newProperties = computed(() => store.state.newPropertiesII); | ||||
| const chosenIssueId = computed(() => store.state.chosenIssueId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const addRow = ref(false); | ||||
| const issueVariants = ref([]) | ||||
| const issue = ref({}) | ||||
| const issues = ref([]) | ||||
| const newNameIV = ref(''); | ||||
| const newAmountIV = ref(''); | ||||
| const newStateIV = ref(''); | ||||
| const newPropertiesIV = ref(''); | ||||
| const newPriceIV = ref(''); | ||||
| const newVariants = reactive([]); | ||||
|  | ||||
| // delete new todo row | ||||
| const deleteNewRow = () => { | ||||
|     newNameIV.value = ''; | ||||
|     newAmountIV.value = ''; | ||||
|     newPropertiesIV.value = ''; | ||||
|     newStateIV.value = ''; | ||||
|     newPriceIV.value = ''; | ||||
|     addRow.value = false; | ||||
| } | ||||
|  | ||||
| const goToChosenIssueVariant = (id) => { | ||||
|     store.commit('setChosenIssueVariant', id); | ||||
|     store.commit('changeToIssueItemVariant'); | ||||
| }; | ||||
|  | ||||
| const deleteIssueVariantFromNewTodos = (index) => { | ||||
|     newVariants.splice(index, 1); | ||||
| } | ||||
|  | ||||
| // add issue variant | ||||
| const addIV = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newName.value.trim() === "") { | ||||
|         alert("Please add an issue name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         if (!(issues.value.length == null)) { | ||||
|             // check if issue name already exists | ||||
|             issues.value.forEach(i => { | ||||
|                 if (i.name === newName.value) { | ||||
|                     counter += 1; | ||||
|                 } | ||||
|             }); | ||||
|             if (counter >= 1) { | ||||
|                 alert("This issue name already exists. Please choose an unique issue name or modify respectively delete the old one!"); | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     let allFine = true; | ||||
|     newVariants.forEach(variant => { | ||||
|         if (variant.name.length === 0) { | ||||
|             alert(`Please choose a name for all variants.`); | ||||
|             allFine = false | ||||
|         } | ||||
|     }) | ||||
|     if (!allFine) { | ||||
|         return | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addII`, | ||||
|             { | ||||
|                 name: newName.value, | ||||
|                 type: newType.value, | ||||
|                 state: newState.value, | ||||
|                 amount: newAmount.value, | ||||
|                 properties: newProperties.value, | ||||
|             }); | ||||
|         store.commit('resetStore'); | ||||
|         store.commit('changeToIssueItemList'); | ||||
|         newVariants.forEach(async variant => { | ||||
|             try { | ||||
|                 const res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addIssueVariant`, | ||||
|                     { | ||||
|                         issueID: response.data, | ||||
|                         name: variant.name, | ||||
|                         properties: variant.properties, | ||||
|                         state: variant.state, | ||||
|                         amount: variant.amount, | ||||
|                         price: variant.price, | ||||
|                     }); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|         }) | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row of variant for the new issue | ||||
| const addRowForNewIVs = async () => { | ||||
|     newVariants.push({ | ||||
|         issueID: chosenIssueId.value, | ||||
|         name: '', | ||||
|         properties: '', | ||||
|         state: '', | ||||
|         amount: '', | ||||
|         price: '' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateIssueVariant = async (todo) => { | ||||
|     if (todo.name.length === 0) { | ||||
|         alert(`Please add the missing variant name!`); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateIssueVariant`, | ||||
|             { | ||||
|                 primaryID: todo.primaryID, | ||||
|                 issueID: todo.issueID, | ||||
|                 name: todo.name, | ||||
|                 properties: todo.properties, | ||||
|                 asset: todo.asset, | ||||
|                 state: todo.state, | ||||
|                 amount: todo.amount, | ||||
|                 price: todo.price, | ||||
|             } | ||||
|         ); | ||||
|         await getIssueById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new issue variant | ||||
| const addIssueVariant = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newNameIV.value.length === 0) { | ||||
|         alert("Please choose a name for the new issue variant!"); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addIssueVariant`, | ||||
|             { | ||||
|                 issueID: chosenIssueId.value, | ||||
|                 name: newNameIV.value, | ||||
|                 properties: newPropertiesIV.value, | ||||
|                 state: newStateIV.value, | ||||
|                 amount: newAmountIV.value, | ||||
|                 price: newPriceIV.value, | ||||
|             }); | ||||
|         addRow.value = false; | ||||
|         await getIssueVariantsById(); | ||||
|         newNameIV.value = ''; | ||||
|         newPropertiesIV.value = ''; | ||||
|         newStateIV.value = ''; | ||||
|         newAmountIV.value = ''; | ||||
|         newPriceIV.value = ''; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row for the issue variant | ||||
| const addChecklistRow = async () => { | ||||
|     if (addRow.value) { | ||||
|         alert('Please confirm the last added row first.') | ||||
|         return | ||||
|     } | ||||
|     addRow.value = true | ||||
| } | ||||
|  | ||||
| // get issue variants from id | ||||
| const getIssueVariantsById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIVs/${chosenIssueId.value}` | ||||
|             ); | ||||
|             issueVariants.value = response.data; | ||||
|         } catch (err) { | ||||
|             // console.log(err.response.statusText); | ||||
|             console.log(err.response); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // get issue from id | ||||
| const getIssueById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getIssueItem/${chosenIssueId.value}` | ||||
|             ); | ||||
|             issue.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| const deleteIssueVariant = async (id) => { | ||||
|     if (confirm("Do you really want to delete this issue variant? It cannot be undone!")) { | ||||
|         try { | ||||
|             await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteIssueVariant/${id}`); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getIssueVariantsById(); | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| //get all issue | ||||
| const getAllIssues = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllIssues`); | ||||
|         issues.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getIssueVariantsById(); | ||||
|     getIssueById(); | ||||
|     triggerBackendCallsWithDelay(getAllIssues); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -55,22 +429,42 @@ export default { | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     flex-direction: row; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     width: 100%; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .div-darkmode { | ||||
| .saveIssueVariant-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 3.25rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveIssueVariant-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 3.25rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .div-lightmode { | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| @ -90,6 +484,64 @@ export default { | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .deleteLastIssueVariant-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastIssueVariant-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .editIssueVariant-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 0.825rem 0.7rem; | ||||
|     width: 4%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .editIssueVariant-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     margin-left: 15rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| @ -108,6 +560,38 @@ export default { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .deleteIssueVariant-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteIssueVariant-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .issue-variant-list-information { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
| @ -131,8 +615,58 @@ th { | ||||
|     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .deleteIssueVariant-darkmode:hover, | ||||
| .deleteLastIssueVariant-darkmode:hover, | ||||
|  | ||||
| .saveIssueVariant-darkmode:hover, | ||||
| .editIssueVariant-darkmode:hover, | ||||
| .saveNewIssueVariant-darkmode:hover { | ||||
|     background-color: #444444; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .deleteIssueVariant-lightmode:hover, | ||||
| .deleteLastIssueVariant-lightmode:hover, | ||||
|  | ||||
| .saveIssueVariant-lightmode:hover, | ||||
| .editIssueVariant-lightmode:hover, | ||||
| .saveNewIssueVariant-lightmode:hover { | ||||
|     background-color: #ACACAC; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .saveNewIssueVariant-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .saveNewIssueVariant-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| #saveNewIssueVariant { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| #editIssueVariant { | ||||
|     text-align: right; | ||||
| } | ||||
|  | ||||
| .Properties { | ||||
|     width: 30%; | ||||
|     width: 25%; | ||||
| } | ||||
|  | ||||
| .Properties-darkmode { | ||||
| @ -144,7 +678,7 @@ th { | ||||
| } | ||||
|  | ||||
| .Name { | ||||
|     width: 30%; | ||||
|     width: 20%; | ||||
| } | ||||
|  | ||||
| .Name-darkmode { | ||||
| @ -180,7 +714,8 @@ th { | ||||
| } | ||||
|  | ||||
| .Price { | ||||
|     width: 10%; | ||||
|     width: 25%; | ||||
|     display: flex; | ||||
| } | ||||
|  | ||||
| .label { | ||||
| @ -201,4 +736,9 @@ th { | ||||
| .label-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
| </style> | ||||
| @ -9,7 +9,7 @@ | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                     <div class="templateId-client-type" id="client"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                     <div class="templateId-client-type" id="type"> | ||||
| @ -129,7 +129,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 95%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| @ -1,24 +1,40 @@ | ||||
| <template> | ||||
|     <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['maintenance-visits-template-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Template name</h2> | ||||
|     <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 v-if="!editable" :class="['maintenance-visits-template-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ | ||||
|             mvt.name }}</h2> | ||||
|         <input v-if="editable" v-model="mvt.name" @change="updateMVT()" | ||||
|             :class="['data', 'mvt-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="maintenance-visits-template-data"> | ||||
|             <div class="client-ID-type-user"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ mvt.customer }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="mvt.customer" | ||||
|                         @change="updateCustomerID()" :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="info"> | ||||
|                     <div class="id-type-user" id="ID"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ mvt.checklistID }}</pre> | ||||
|                     </div> | ||||
|                     <div class="id-type-user" id="type"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ mvt.type }}</pre> | ||||
|                         <input v-if="editable" v-model="mvt.type" @change="updateMVT()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="id-type-user" id="user"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ mvt.user }}</pre> | ||||
|                         <input v-if="editable" v-model="mvt.user" @change="updateMVT()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
| @ -27,7 +43,50 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|                     <input v-model="mvt.notes" :readonly="!editable" @change="updateMVT()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <input v-model="newName" @change="updateMaintenanceVisit()" | ||||
|             :class="['data', 'maintenance-visits-template-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="maintenance-visits-template-data"> | ||||
|             <div class="client-ID-type-user"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newCustomer" @change="updateNewCustomerID()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="info"> | ||||
|                     <div class="id-type-user" id="ID"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                     <div class="id-type-user" id="type"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                         <input v-model="newType" @change="updateMaintenanceVisit()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="id-type-user" id="user"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                         <input v-model="newUser" @change="updateMaintenanceVisit()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|         <div class="maintenance-visits-template-data"> | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <input v-model="newNotes" @change="updateMaintenanceVisit()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
| @ -36,9 +95,183 @@ | ||||
|      | ||||
|      | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 editable = computed(() => store.state.editable); | ||||
| const chosenMVTId = computed(() => store.state.chosenMVTId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const mvt = ref({}); | ||||
| const customers = ref([]); | ||||
| const customer = ref({}); | ||||
| const maintenanceVisitTemplates = ref([]); | ||||
|  | ||||
| const newName = ref(''); | ||||
| const newCustomerID = ref(''); | ||||
| const newCustomer = ref(''); | ||||
| const newUser = ref(''); | ||||
| const newType = ref(''); | ||||
| const newNotes = 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); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // function to delete a maintenance visit template | ||||
| const confirmDeleteMVT = async () => { | ||||
|     if (deleteBool.value === true) { | ||||
|         if (confirm("Do you really want to delete this maintenance visit template? It cannot be undone!")) { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteMaintenanceVisitTemplate/${chosenMVTId.value}`); | ||||
|                 store.commit('undoDelete'); | ||||
|                 store.commit('resetStore'); | ||||
|                 store.commit('changeToTemplatelist'); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteTodosMVT/${chosenMVTId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|         } else { | ||||
|             store.commit('undoDelete'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //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); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateMVT = async () => { | ||||
|     if (mvt.value.name.trim() === "") { | ||||
|         alert("Please add a maintenance visit template name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         // check if maintenance visit template name already exists | ||||
|         maintenanceVisitTemplates.value.forEach(m => { | ||||
|             if (m.name === mvt.value.name) { | ||||
|                 counter += 1; | ||||
|             } | ||||
|         }); | ||||
|         if (counter == 2) { | ||||
|             alert("This maintenance visit template name already exists. Please choose an unique production order template name or modify respectively delete the old one!"); | ||||
|             mvt.value.name = ''; | ||||
|             return; | ||||
|         } | ||||
|         try { | ||||
|             await Axios.put( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateMaintenanceVisitTemplate`, | ||||
|                 { | ||||
|                     checklistID: mvt.value.checklistID, | ||||
|                     name: mvt.value.name, | ||||
|                     customerID: mvt.value.customerID, | ||||
|                     customer: mvt.value.customer, | ||||
|                     lastView: mvt.value.lastView, | ||||
|                     user: mvt.value.user, | ||||
|                     type: mvt.value.type, | ||||
|                     notes: mvt.value.notes, | ||||
|                 } | ||||
|             ) | ||||
|             await getMVTById(); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${mvt.value.customer}`); | ||||
|         customer.value = response.data; | ||||
|         mvt.value.customerID = customer.value.customerID; | ||||
|         store.commit('toggleClientChanged'); | ||||
|         store.commit('toggleClientId', mvt.value.customerID); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     await updateMVT(); | ||||
| } | ||||
|  | ||||
| // get maintenance visit template from id | ||||
| const getMVTById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitTemplate/${chosenMVTId.value}` | ||||
|             ); | ||||
|             mvt.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateNewCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${newCustomer.value}`); | ||||
|         newCustomerID.value = response.data.customerID; | ||||
|         store.commit('toggleClientChanged'); | ||||
|         store.commit('toggleClientId', newCustomerID.value) | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     updateMaintenanceVisit(); | ||||
| } | ||||
|  | ||||
| // update maintenance visit template fields in the store | ||||
| const updateMaintenanceVisit = () => { | ||||
|     const maintenanceVisitTemplate = { | ||||
|         name: newName.value, | ||||
|         customerId: newCustomerID.value, | ||||
|         customer: newCustomer.value, | ||||
|         user: newUser.value, | ||||
|         type: newType.value, | ||||
|         notes: newNotes.value | ||||
|     }; | ||||
|     store.commit('updateMaintenanceVisitTemplateComponent', maintenanceVisitTemplate); | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteMVT); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getMVTById(); | ||||
|     triggerBackendCallsWithDelay(getMaintenanceVisitTemplates); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
|  | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -61,6 +294,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; | ||||
| } | ||||
| @ -69,7 +313,21 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .select-darkmode { | ||||
|     border: none; | ||||
|     color: white; | ||||
|     background: #212121; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .select-lightmode { | ||||
|     border: none; | ||||
|     color: black; | ||||
|     background: #EBEBEB; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .maintenance-visits-template-name { | ||||
|     align-self: stretch; | ||||
| @ -80,6 +338,16 @@ export default { | ||||
|         sans-serif; | ||||
| } | ||||
|  | ||||
| .maintenance-visits-template-name-input { | ||||
|     padding: 0 0.625rem; | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .h2-darkmode { | ||||
|     color: #fff; | ||||
| } | ||||
| @ -94,11 +362,23 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 95%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .h2-input-darkmode { | ||||
|     background-color: #212121; | ||||
| } | ||||
|  | ||||
| .h2-input-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .id-type-user { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
| @ -123,17 +403,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; | ||||
| @ -144,6 +413,16 @@ export default { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .mvt-name-input { | ||||
|     padding: 0 0.625rem; | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .maintenance-visits-template-data { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|  | ||||
| @ -1,4 +1,9 @@ | ||||
| <template> | ||||
|     <section v-if="searchable" :class="['mvt-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Template:</div> | ||||
|         <input v-model="mvtSearchFilter" @change="searchMVT()" | ||||
|             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Last viewed:</div> | ||||
|         <table class="data-table" name="maintenance-visits-template-table"> | ||||
| @ -6,7 +11,7 @@ | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Client', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Client-darkmode' : 'Client-lightmode']"> | ||||
|                         Client</th> | ||||
|                         Customer</th> | ||||
|                     <th | ||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         Name</th> | ||||
| @ -26,7 +31,11 @@ | ||||
|                         {{ template.customer }}</td> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         {{ template.name }}</td> | ||||
|                         <nuxt-link to="/maintenanceVisits" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             @click="goToChosenMVT(template.checklistID)"> | ||||
|                             {{ template.name }} | ||||
|                         </nuxt-link></td> | ||||
|                     <td | ||||
|                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                         {{ template.checklistID }}</td> | ||||
| @ -42,25 +51,75 @@ | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const goToChosenMVT = (id) => { | ||||
|     store.commit('setChosenMVT', id); | ||||
|     store.commit('changeToTemplate'); | ||||
| }; | ||||
|  | ||||
| const clientFilter = computed(() => store.state.filteredByClient); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
| const mvtSearchFilter = ref(''); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const maintenanceVisitTemplates = ref([]); | ||||
|  | ||||
| //get all maintenance visit templates | ||||
| const getMaintenanceVisitTemplates = async () => { | ||||
|     if (!(clientFilter.value === '')) { | ||||
|         await getFilteredMVTByClient(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllMaintenanceVisitTemplates`); | ||||
|             maintenanceVisitTemplates.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getMaintenanceVisitTemplates(); | ||||
| //get all maintenance visit templates based on the searched mvt name | ||||
| const searchMVT = async () => { | ||||
|     if (mvtSearchFilter.value === '') { | ||||
|         await getMaintenanceVisitTemplates(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedMVTsByMVT/${mvtSearchFilter.value}`); | ||||
|             maintenanceVisitTemplates.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update search term | ||||
| const updateSearchTerm = async () => { | ||||
|     mvtSearchFilter.value = ''; | ||||
|     await getMaintenanceVisitTemplates(); | ||||
| } | ||||
|  | ||||
| //get all maintenance visit templates based on the searched client | ||||
| const getFilteredMVTByClient = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedMVTsByClient/${clientFilter.value}`); | ||||
|         maintenanceVisitTemplates.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(searchable, updateSearchTerm); | ||||
| watch(clientFilter, getMaintenanceVisitTemplates); | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getMaintenanceVisitTemplates(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -79,13 +138,30 @@ export default { | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     width: 100%; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .div-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
| @ -94,6 +170,37 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| .clientLabel { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
| @ -101,6 +208,18 @@ export default { | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
| .mvt-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; | ||||
| } | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
| @ -220,4 +339,5 @@ th { | ||||
|  | ||||
| .label-lightmode { | ||||
|     color: #000; | ||||
| }</style> | ||||
| } | ||||
| </style> | ||||
| @ -67,7 +67,7 @@ | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewItem"> | ||||
|         <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addItem()">Safe</button> | ||||
|         <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addItem()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|      | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| <template> | ||||
|     <section :class="['ordering-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <section v-if="!addBool" :class="['ordering-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']" id="ordering">Ordering information: | ||||
|             <div class="asset-data"> | ||||
|                 <table class="data-table" id="asset-table-no-client"> | ||||
| @ -16,30 +16,271 @@ | ||||
|                                 Price</th> | ||||
|                             <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                         </tr> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                         <tr v-for="info in orderingInfo" :key="info.primaryID" | ||||
|                             :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Article', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Article-darkmode' : 'Article-lightmode']"> | ||||
|                                 {{ info.article }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Article', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Article-darkmode' : 'Article-lightmode']"> | ||||
|                                 <input type="text" v-model="info.article" @change="updateOrderingInfo(info)" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                                 {{ info.amount }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                                 <input type="text" v-model="info.amount" @change="updateOrderingInfo(info)" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" | ||||
|                                 :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Price-darkmode' : 'Price-lightmode']"> | ||||
|                                 {{ info.price }}</td> | ||||
|                             <td v-if="editable" | ||||
|                                 :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Price-darkmode' : 'Price-lightmode']"> | ||||
|                                 <input type="text" v-model="info.price" @change="updateOrderingInfo(info)" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         info.comment }}</td> | ||||
|                             <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="info.comment" @change="updateOrderingInfo(info)" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                                     :class="[darkMode ? 'deleteOrderingInfo-darkmode' : 'deleteOrderingInfo-lightmode']" | ||||
|                                     @click="deleteOrderingInfo(info.primaryID)">-</button> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" | ||||
|                             id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Article', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Article-darkmode' : 'Article-lightmode']"> | ||||
|                                 ...</td> | ||||
|                                 <input type="text" v-model="newArticle" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td | ||||
|                                 :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                                 ...</td> | ||||
|                                 <input type="text" v-model="newAmount" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td | ||||
|                                 :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Price-darkmode' : 'Price-lightmode']"> | ||||
|                                 ...</td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                                 <input type="text" v-model="newPrice" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                                     v-model="newComment" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                                     :class="[darkMode ? 'saveOrderingInfo-darkmode' : 'saveOrderingInfo-lightmode']" | ||||
|                                     @click="addOrderingInfo()">Save</button> <button | ||||
|                                     :class="[darkMode ? 'deleteLastOrderingInfo-darkmode' : 'deleteLastOrderingInfo-lightmode']" | ||||
|                                     @click="deleteNewRow()">-</button> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="editable && !addBool" id="editOrderingInfo"> | ||||
|         <button :class="[darkMode ? 'editOrderingInfo-darkmode' : 'editOrderingInfo-lightmode']" | ||||
|             @click="addChecklistRow()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['ordering-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']" id="ordering">Ordering information: | ||||
|             <div class="asset-data"> | ||||
|                 <table class="data-table" id="asset-table-no-client"> | ||||
|                     <tbody> | ||||
|                         <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                             <th | ||||
|                                 :class="['Article', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Article-darkmode' : 'Article-lightmode']"> | ||||
|                                 Article</th> | ||||
|                             <th | ||||
|                                 :class="['Amount', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                                 Amount</th> | ||||
|                             <th | ||||
|                                 :class="['Price', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Price-darkmode' : 'Price-lightmode']"> | ||||
|                                 Price</th> | ||||
|                             <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                         </tr> | ||||
|                         <tr v-for="(newOI, index) in newOIs" :key="index" | ||||
|                             :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                             <td | ||||
|                                 :class="['Article', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Article-darkmode' : 'Article-lightmode']"> | ||||
|                                 <input type="text" v-model="newOI.article" @change="updateOI()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td | ||||
|                                 :class="['Amount', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Amount-darkmode' : 'Amount-lightmode']"> | ||||
|                                 <input type="text" v-model="newOI.amount" @change="updateOI()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td | ||||
|                                 :class="['Price', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Price-darkmode' : 'Price-lightmode']"> | ||||
|                                 <input type="text" v-model="newOI.price" @change="updateOI()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                             </td> | ||||
|                             <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                                 <input type="text" v-model="newOI.comment" @change="updateOI()" | ||||
|                                     :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                                     :class="[darkMode ? 'deleteOrderingInfo-darkmode' : 'deleteOrderingInfo-lightmode']" | ||||
|                                     @click="deleteOIFromNewTodos(index)">-</button> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="editOrderingInfo"> | ||||
|         <button :class="[darkMode ? 'editOrderingInfo-darkmode' : 'editOrderingInfo-lightmode']" | ||||
|             @click="addRowForNewOI()">+</button> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenIssueSlipId = computed(() => store.state.chosenIssueSlipId); | ||||
|  | ||||
| const addRow = ref(false); | ||||
| const orderingInfo = ref([]) | ||||
| const newArticle = ref(''); | ||||
| const newAmount = ref(''); | ||||
| const newPrice = ref(''); | ||||
| const newComment = ref(''); | ||||
|  | ||||
| const newOIs = reactive([]); | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| // delete new todo row | ||||
| const deleteNewRow = () => { | ||||
|     newArticle.value = ''; | ||||
|     newAmount.value = ''; | ||||
|     newPrice.value = ''; | ||||
|     newComment.value = ''; | ||||
|     addRow.value = false; | ||||
| } | ||||
|  | ||||
| const deleteOIFromNewTodos = (index) => { | ||||
|     newOIs.splice(index, 1); | ||||
| } | ||||
|  | ||||
| // add new ordering info | ||||
| const addOrderingInfo = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newAmount.value.length === 0 && newArticle.value.length === 0 && newPrice.value.length === 0 && newComment.value.length === 0) { | ||||
|         alert(`Please add some data in the ordering info row!`); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addOrderingInfo`, | ||||
|             { | ||||
|                 issueSlipID: chosenIssueSlipId.value, | ||||
|                 article: newArticle.value, | ||||
|                 amount: newAmount.value, | ||||
|                 price: newPrice.value, | ||||
|                 comment: newComment.value, | ||||
|             }); | ||||
|         addRow.value = false; | ||||
|         await getOIById(); | ||||
|         newArticle.value = ''; | ||||
|         newAmount.value = ''; | ||||
|         newPrice.value = ''; | ||||
|         newComment.value = ''; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update ordering info fields in the store | ||||
| const updateOI = () => { | ||||
|     const infos = { | ||||
|         ois: newOIs, | ||||
|     }; | ||||
|     store.commit('updateOrderingInfoComponent', infos); | ||||
| } | ||||
|  | ||||
| // add new row of ordering info | ||||
| const addRowForNewOI = async () => { | ||||
|     newOIs.push({ | ||||
|         issueSlipID: -1, | ||||
|         article: '', | ||||
|         amount: '', | ||||
|         price: '', | ||||
|         comment: '' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateOrderingInfo = async (info) => { | ||||
|     if (info.amount.length === 0 && info.article.length === 0 && info.price.length === 0 && info.comment.length === 0) { | ||||
|         alert(`Please add some data in the ordering info row!`); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateOrderingInfo`, | ||||
|             { | ||||
|                 primaryID: info.primaryID, | ||||
|                 issueSlipID: info.issueSlipID, | ||||
|                 article: info.article, | ||||
|                 amount: info.amount, | ||||
|                 price: info.price, | ||||
|                 comment: info.comment, | ||||
|             } | ||||
|         ); | ||||
|         await getOIById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row for the ordering info | ||||
| const addChecklistRow = async () => { | ||||
|     if (addRow.value) { | ||||
|         alert('Please confirm the last added row first.') | ||||
|         return | ||||
|     } | ||||
|     addRow.value = true | ||||
| } | ||||
|  | ||||
| // get ordering info from id | ||||
| const getOIById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getOrderingInfo/${chosenIssueSlipId.value}` | ||||
|             ); | ||||
|             orderingInfo.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| const deleteOrderingInfo = async (id) => { | ||||
|     if (confirm("Do you really want to delete this ordering info? It cannot be undone!")) { | ||||
|         try { | ||||
|             await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteOrderingInfo/${id}`); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     }  | ||||
|     await getOIById(); | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getOIById(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -70,6 +311,31 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|     letter-spacing: 5%; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| @ -194,5 +460,116 @@ th { | ||||
|  | ||||
| .Comments { | ||||
|     width: 50%; | ||||
|     display: flex; | ||||
| } | ||||
|  | ||||
| .deleteOrderingInfo-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 24.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastOrderingInfo-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .editOrderingInfo-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 0.825rem 0.7rem; | ||||
|     width: 4%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .editOrderingInfo-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     margin-left: 15rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .saveOrderingInfo-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 19rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveOrderingInfo-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 19rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteOrderingInfo-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 24.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastOrderingInfo-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteOrderingInfo-darkmode:hover, | ||||
| .deleteLastOrderingInfo-darkmode:hover, | ||||
|  | ||||
| .saveOrderingInfo-darkmode:hover, | ||||
| .editOrderingInfo-darkmode:hover { | ||||
|     background-color: #444444; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .deleteOrderingInfo-lightmode:hover, | ||||
| .deleteLastOrderingInfo-lightmode:hover, | ||||
|  | ||||
| .saveOrderingInfo-lightmode:hover, | ||||
| .editOrderingInfo-lightmode:hover { | ||||
|     background-color: #ACACAC; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| #editOrderingInfo { | ||||
|     text-align: right; | ||||
| } | ||||
| </style> | ||||
| @ -9,7 +9,7 @@ | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                     <div class="templateId-client" id="client"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                 </div> | ||||
| @ -135,7 +135,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 95%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| @ -7,7 +7,7 @@ | ||||
|         <div class="production-orders-template-data"> | ||||
|             <div class="client-ID"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']">Client:</pre> | ||||
|                     <pre :class="['label', darkMode ? 'div-darkmode' : 'div-lightmode']">Customer:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']"> {{ pot.customer }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="pot.customer" | ||||
| @ -58,7 +58,7 @@ | ||||
|         <div class="production-orders-template-data"> | ||||
|             <div class="client-ID"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newCustomer" @change="updateNewCustomerID()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
| @ -144,6 +144,7 @@ const confirmDeletePOT = async () => { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteProductionOrderTemplate/${chosenPOTId.value}`); | ||||
|                 store.commit('undoDelete'); | ||||
|                 store.commit('resetStore'); | ||||
|                 store.commit('changeToTemplatelist'); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
| @ -159,7 +160,7 @@ const confirmDeletePOT = async () => { | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all productionOrder templates todos | ||||
| //get all productionOrder templates | ||||
| const getProductionOrderTemplates = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllProductionOrderTemplates`); | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| <template> | ||||
|     <section v-if="searchable" :class="['pot-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Config item</div> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Template:</div> | ||||
|         <input v-model="potSearchFilter" @change="searchPOT()" | ||||
|             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
| @ -11,7 +11,7 @@ | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Client', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Client-darkmode' : 'Client-lightmode']"> | ||||
|                         Client</th> | ||||
|                         Customer</th> | ||||
|                     <th | ||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         Name</th> | ||||
|  | ||||
| @ -1,15 +1,96 @@ | ||||
| <template> | ||||
|     <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 :class="['solution-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Solution name</h2> | ||||
|     <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <h2 v-if="!editable" :class="['solution-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ sol.solutionName | ||||
|             }}</h2> | ||||
|         <input v-if="editable" v-model="sol.solutionName" @change="updateSolution()" | ||||
|             :class="['data', 'solution-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="solution-data"> | ||||
|             <div class="client-asset"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ sol.customer }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="sol.customer" | ||||
|                         @change="updateCustomerID()" :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="asset"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Asset:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     <pre v-if="!editable" | ||||
|                         :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ sol.assetName }}</pre> | ||||
|                     <select v-if="editable" id="customersDropDownChosenCI" v-model="sol.assetName" | ||||
|                         @change="updateSolution()" :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="ci in configItems" :key="ci.primaryID"> | ||||
|                             {{ ci.assetName }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
|                 <div class="data-field" id="user"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ sol.user }}</pre> | ||||
|                 </div> | ||||
|                 <div class="type-id"> | ||||
|                     <div class="data-field" id="type"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                         <pre v-if="!editable" | ||||
|                             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ sol.type }}</pre> | ||||
|                         <input v-if="editable" v-model="sol.type" @change="updateSolution()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="id"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ sol.primaryID }}</pre> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|         <div class="solution-data"> | ||||
|             <div class="additional"> | ||||
|                 <div class="description"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Description of the | ||||
|                         problem/intended use:</h3> | ||||
|                     <input v-model="sol.description" :readonly="!editable" @change="updateSolution()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="description"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|         <div class="solution-data"> | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <input v-model="sol.notes" :readonly="!editable" @change="updateSolution()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <input v-model="newSolutionName" @change="updateSol()" | ||||
|             :class="['data', 'solution-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||
|         <div class="solution-data"> | ||||
|             <div class="client-asset"> | ||||
|                 <div class="data-field" id="client"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newCustomer" @change="updateNewCustomerID()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="cust in customers" :key="cust.primaryID"> | ||||
|                             {{ cust.customername }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|                 <div class="data-field" id="asset"> | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Asset:</pre> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newAssetName" @change="updateSol()" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="ci in configItems" :key="ci.primaryID"> | ||||
|                             {{ ci.assetName }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div class="info"> | ||||
| @ -17,13 +98,14 @@ | ||||
|                     <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">User:</pre> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                 </div> | ||||
|                 <div class="type-state"> | ||||
|                 <div class="type-id"> | ||||
|                     <div class="data-field" id="type"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Type:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                         <input v-model="newType" @change="updateSol()" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </div> | ||||
|                     <div class="data-field" id="state"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">State:</pre> | ||||
|                     <div class="data-field" id="id"> | ||||
|                         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|                         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|                     </div> | ||||
|                 </div> | ||||
| @ -34,7 +116,8 @@ | ||||
|                 <div class="description"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Description of the | ||||
|                         problem/intended use:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="description">...</pre> | ||||
|                     <input v-model="newDescription" @change="updateSol()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="description"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
| @ -42,7 +125,8 @@ | ||||
|             <div class="additional"> | ||||
|                 <div class="notes"> | ||||
|                     <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|                     <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|                     <input v-model="newNotes" @change="updateSol()" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
| @ -51,9 +135,217 @@ | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const store = useStore(); | ||||
| const editable = computed(() => store.state.editable); | ||||
| const chosenSolutionId = computed(() => store.state.chosenSolutionId); | ||||
| const deleteBool = computed(() => store.state.deleteBool); | ||||
| const addBool = computed(() => store.state.new); | ||||
|  | ||||
| const darkMode = ref(true); | ||||
| const sol = ref({}); | ||||
| const customer = ref({}); | ||||
| const solutions = ref([]); | ||||
| const customers = ref([]); | ||||
| const configItems = ref([]); | ||||
|  | ||||
| const newAssetName = ref(''); | ||||
| const newCustomerID = ref(''); | ||||
| const newCustomer = ref(''); | ||||
| const newSolutionName = ref(''); | ||||
| const newType = ref(''); | ||||
| const newDescription = ref(''); | ||||
| const newNotes = ref(''); | ||||
| const newLastView = ref(''); | ||||
| const newUser = ref(''); | ||||
| const changedClientId = computed(() => store.state.changedClientId); | ||||
| const clientChanged = computed(() => store.state.clientChanged); | ||||
|  | ||||
| // get solution from id | ||||
| const getSolutionById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSolution/${chosenSolutionId.value}` | ||||
|             ); | ||||
|             sol.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getConfigItemsFromClient(); | ||||
| } | ||||
|  | ||||
| //get all config items from the selected client | ||||
| const getConfigItemsFromClient = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${sol.value.customerID}`); | ||||
|             configItems.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${changedClientId.value}`); | ||||
|             configItems.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     if (clientChanged.value) { | ||||
|         store.commit('toggleClientChanged'); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update solution fields in the store | ||||
| const updateSol = () => { | ||||
|     const solution = { | ||||
|         solutionName: newSolutionName.value, | ||||
|         customerId: newCustomerID.value, | ||||
|         customer: newCustomer.value, | ||||
|         assetName: newAssetName.value, | ||||
|         lastView: newLastView.value, | ||||
|         type: newType.value, | ||||
|         description: newDescription.value, | ||||
|         notes: newNotes.value, | ||||
|         user: newUser.value | ||||
|     }; | ||||
|     store.commit('updateSolutionComponent', solution); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateSolution = async () => { | ||||
|     if (sol.value.solutionName.trim() === "") { | ||||
|         alert("Please add a solution name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         // check if solution name already exists | ||||
|         solutions.value.forEach(s => { | ||||
|             if (s.solutionName === sol.value.solutionName) { | ||||
|                 counter += 1; | ||||
|             } | ||||
|         }); | ||||
|         if (counter == 1) { | ||||
|             alert("This solution name already exists. Please choose an unique solution name or modify respectively delete the old one!"); | ||||
|             sol.value.solutionName = ''; | ||||
|             return; | ||||
|         } | ||||
|         try { | ||||
|             await Axios.put( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateSolution`, | ||||
|                 { | ||||
|                     primaryID: sol.value.primaryID, | ||||
|                     solutionName: sol.value.solutionName, | ||||
|                     customerID: sol.value.customerID, | ||||
|                     customer: sol.value.customer, | ||||
|                     assetName: sol.value.assetName, | ||||
|                     type: sol.value.type, | ||||
|                     description: sol.value.description, | ||||
|                     notes: sol.value.notes, | ||||
|                     lastView: sol.value.lastView, | ||||
|                     user: sol.value.user, | ||||
|                 } | ||||
|             ) | ||||
|             await getSolutionById(); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //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); | ||||
|     } | ||||
| } | ||||
|  | ||||
| const confirmDeleteSolution = async () => { | ||||
|     if (deleteBool.value === true) { | ||||
|         if (confirm("Do you really want to delete this solution? It cannot be undone!")) { | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteSolution/${chosenSolutionId.value}`); | ||||
|                 store.commit('undoDelete'); | ||||
|                 store.commit('resetStore'); | ||||
|                 store.commit('changeToSolutionlist'); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|             try { | ||||
|                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteTodosSolution/${chosenSolutionId.value}`); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|         } else { | ||||
|             store.commit('undoDelete'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all solutions | ||||
| const getSolutions = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllSolutions`); | ||||
|         solutions.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${sol.value.customer}`); | ||||
|         customer.value = response.data; | ||||
|         sol.value.customerID = customer.value.customerID; | ||||
|         store.commit('toggleClientChanged'); | ||||
|         store.commit('toggleClientId', sol.value.customerID); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     await updateSolution(); | ||||
| } | ||||
|  | ||||
| // update customerid if customer was changed | ||||
| const updateNewCustomerID = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerByName/${newCustomer.value}`); | ||||
|         newCustomerID.value = response.data.customerID; | ||||
|         store.commit('toggleClientChanged'); | ||||
|         store.commit('toggleClientId', newCustomerID.value); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
|     updateSol(); | ||||
|     await getConfigItemsFromClient(); | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1500); | ||||
| } | ||||
|  | ||||
| watch(deleteBool, confirmDeleteSolution); | ||||
| watch(clientChanged, getSolutionById); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSolutionById(); | ||||
|     getSolutions(); | ||||
|     triggerBackendCallsWithDelay(getCustomers); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -83,7 +375,15 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
|  | ||||
| .solution-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; | ||||
| } | ||||
|  | ||||
| .solution-name { | ||||
|     align-self: stretch; | ||||
| @ -102,17 +402,41 @@ export default { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .h2-input-darkmode { | ||||
|     background-color: #212121; | ||||
| } | ||||
|  | ||||
| .h2-input-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
| } | ||||
|  | ||||
| .data-field { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .select-darkmode { | ||||
|     border: none; | ||||
|     color: white; | ||||
|     background: #212121; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .select-lightmode { | ||||
|     border: none; | ||||
|     color: black; | ||||
|     background: #EBEBEB; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .data-field#street-name { | ||||
|     width: 70%; | ||||
| } | ||||
| @ -175,6 +499,10 @@ export default { | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .additional { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
| @ -199,7 +527,7 @@ export default { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .type-state { | ||||
| .type-id { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|  | ||||
| @ -1,5 +1,6 @@ | ||||
| <template> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|     <section v-if="!addBool" | ||||
|         :class="['solution-checklist-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Checklist:</div> | ||||
|         <table class="data-table" id="solution-checkklist"> | ||||
|             <tbody> | ||||
| @ -15,28 +16,416 @@ | ||||
|                         Task</th> | ||||
|                     <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                 </tr> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <tr v-for="todo in solTodos" :key="todo.primaryID" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         ...</td> | ||||
|                         {{ todo.step }}</td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         {{ todo.asset }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         <select id="customersDropDownChosenCI" v-model="todo.asset" @change="updateSolTodo(todo)" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                                 {{ ci.assetName }} | ||||
|                             </option> | ||||
|                         </select> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         {{ todo.task }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         <input type="text" v-model="todo.task" @change="updateSolTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">{{ | ||||
|         todo.comments }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> | ||||
|                         <input type="text" v-model="todo.comments" @change="updateSolTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                         <button :class="[darkMode ? 'deleteSolTodos-darkmode' : 'deleteSolTodos-lightmode']" | ||||
|                             @click="deleteSolTodo(todo.primaryID)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|             <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td | ||||
|                     :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                     {{ newStepTodo }} | ||||
|                 </td> | ||||
|                 <td | ||||
|                     :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         ...</td> | ||||
|                     <select id="customersDropDownChosenCI" v-model="newAssetTodo" | ||||
|                         :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                         <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                             {{ ci.assetName }} | ||||
|                         </option> | ||||
|                     </select> | ||||
|                 </td> | ||||
|                 <td | ||||
|                     :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         ...</td> | ||||
|                     <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']">...</td> | ||||
|                     <input type="text" v-model="newTaskTodo" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                 </td> | ||||
|                 <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                         v-model="newCommentsTodo" | ||||
|                         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                         :class="[darkMode ? 'saveSolTodos-darkmode' : 'saveSolTodos-lightmode']" | ||||
|                         @click="addSolTodo()">Save</button> <button | ||||
|                         :class="[darkMode ? 'deleteLastSolTodos-darkmode' : 'deleteLastSolTodos-lightmode']" | ||||
|                         @click="deleteNewRow()">-</button> | ||||
|                 </td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
|     <section v-if="editable && !addBool" id="editSolTodos"> | ||||
|         <button :class="[darkMode ? 'editSolTodos-darkmode' : 'editSolTodos-lightmode']" | ||||
|             @click="addChecklistRow()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" | ||||
|         :class="['solution-checklist-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Checklist:</div> | ||||
|         <table class="data-table" id="template-checklist"> | ||||
|             <tbody> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Step', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         Step</th> | ||||
|                     <th | ||||
|                         :class="['Asset', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         Asset</th> | ||||
|                     <th | ||||
|                         :class="['Task', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         Task</th> | ||||
|                     <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                 </tr> | ||||
|                 <tr v-for="(newT, index) in newTodos" :key="index" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ newT.step }} | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         <select id="customersDropDownChosenCI" v-model="newT.asset" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                                 {{ ci.assetName }} | ||||
|                             </option> | ||||
|                         </select> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         <input type="text" v-model="newT.task" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="newT.comments" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deleteSolTodos-darkmode' : 'deleteLastSolTodos-lightmode']" | ||||
|                             @click="deleteSolTodoFromNewTodos(index)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </div> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="editSolTodos"> | ||||
|         <button :class="[darkMode ? 'editSolTodos-darkmode' : 'editSolTodos-lightmode']" | ||||
|             @click="addRowForNewSol()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewSol"> | ||||
|         <button :class="[darkMode ? 'saveNewSol-darkmode' : 'saveNewSol-lightmode']" @click="addSol()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
| import { ref, onMounted, watch } 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 addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| const newSolutionNameSol = computed(() => store.state.newSolutionNameSol); | ||||
| const newCustomerIDSol = computed(() => store.state.newCustomerIDSol); | ||||
| const newCustomerSol = computed(() => store.state.newCustomerSol); | ||||
| const newAssetNameSol = computed(() => store.state.newAssetNameSol); | ||||
| const newLastViewSol = computed(() => store.state.newLastViewSol); | ||||
| const newUserSol = computed(() => store.state.newUserSol); | ||||
| const newTypeSol = computed(() => store.state.newTypeSol); | ||||
| const newNotesSol = computed(() => store.state.newNotesSol); | ||||
| const newDescriptionSol = computed(() => store.state.newDescriptionSol); | ||||
|  | ||||
| const newStepTodo = computed(() => solTodos.value.length); | ||||
| const chosenSolId = computed(() => store.state.chosenSolutionId); | ||||
| const clientChanged = computed(() => store.state.clientChanged); | ||||
| const changedClientId = computed(() => store.state.changedClientId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const addRow = ref(false); | ||||
| const configItemList = ref([]); | ||||
| const solutions = ref([]); | ||||
| const solTodos = ref([]) | ||||
| const sol = ref({}) | ||||
| const newAssetTodo = ref(''); | ||||
| const newTaskTodo = ref(''); | ||||
| const newCommentsTodo = ref(''); | ||||
| const newTodos = reactive([]); | ||||
| const newRowId = computed(() => newTodos.length) | ||||
|  | ||||
| // delete new todo row | ||||
| const deleteNewRow = () => { | ||||
|     newAssetTodo.value = ''; | ||||
|     newTaskTodo.value = ''; | ||||
|     newCommentsTodo.value = ''; | ||||
|     addRow.value = false; | ||||
| } | ||||
|  | ||||
| const deleteSolTodoFromNewTodos = (index) => { | ||||
|     newTodos.splice(index, 1); | ||||
|     newTodos.forEach((todo, i) => { | ||||
|         todo.step = i | ||||
|     }) | ||||
| } | ||||
|  | ||||
| // add new solution | ||||
| const addSol = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newSolutionNameSol.value.trim() === "") { | ||||
|         alert("Please add a solution name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         if (!(solutions.value.length == null)) { | ||||
|             // check if solution name already exists | ||||
|             solutions.value.forEach(s => { | ||||
|                 if (s.solutionName === newSolutionNameSol.value) { | ||||
|                     counter += 1; | ||||
|                 } | ||||
|             }); | ||||
|             if (counter == 1) { | ||||
|                 alert("This solution name already exists. Please choose an unique solution name or modify respectively delete the old one!"); | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     if (newCustomerSol.value.length === 0) { | ||||
|         alert("Please choose a client!"); | ||||
|         return; | ||||
|     } | ||||
|     let allFine = true; | ||||
|     newTodos.forEach(todo => { | ||||
|         if (todo.asset.length === 0) { | ||||
|             alert(`Please choose a config item for all todos.`); | ||||
|             allFine = false | ||||
|         } | ||||
|     }) | ||||
|     if (!allFine) { | ||||
|         return | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addSol`, | ||||
|             { | ||||
|                 solutionName: newSolutionNameSol.value, | ||||
|                 assetName: newAssetNameSol.value, | ||||
|                 customerID: newCustomerIDSol.value, | ||||
|                 customer: newCustomerSol.value, | ||||
|                 type: newTypeSol.value, | ||||
|                 lastView: newLastViewSol.value, | ||||
|                 user: newUserSol.value, | ||||
|                 description: newDescriptionSol.value, | ||||
|                 notes: newNotesSol.value, | ||||
|             }); | ||||
|         store.commit('resetStore'); | ||||
|         store.commit('changeToSolutionlist'); | ||||
|         newTodos.forEach(async todo => { | ||||
|             try { | ||||
|                 const res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addTodoSol`, | ||||
|                     { | ||||
|                         solutionID: response.data, | ||||
|                         step: todo.step, | ||||
|                         asset: todo.asset, | ||||
|                         task: todo.task, | ||||
|                         comments: todo.comments, | ||||
|                     }); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|         }) | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row of todo for the new solution | ||||
| const addRowForNewSol = async () => { | ||||
|     if (newCustomerSol.value.length === 0) { | ||||
|         alert("Please choose a client first!"); | ||||
|         return; | ||||
|     } | ||||
|     await getConfigItemsFromClient(); | ||||
|     newTodos.push({ | ||||
|         solutionID: chosenSolId.value, | ||||
|         step: newRowId.value, | ||||
|         asset: '', | ||||
|         task: '', | ||||
|         comments: '' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateSolTodo = async (todo) => { | ||||
|     if (todo.asset.length === 0) { | ||||
|         alert(`Please add the missing config item in row ${todo.step}!`); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateSolTodo`, | ||||
|             { | ||||
|                 primaryID: todo.primaryID, | ||||
|                 solutionID: todo.solutionIDID, | ||||
|                 step: todo.step, | ||||
|                 asset: todo.asset, | ||||
|                 task: todo.task, | ||||
|                 comments: todo.comments, | ||||
|             } | ||||
|         ); | ||||
|         await getSolutionById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new solution todo | ||||
| const addSolTodo = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newAssetTodo.value.length === 0) { | ||||
|         alert("Please choose an asset for the new todo!"); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addTodoSol`, | ||||
|             { | ||||
|                 solutionID: chosenSolId.value, | ||||
|                 step: newStepTodo.value, | ||||
|                 asset: newAssetTodo.value, | ||||
|                 task: newTaskTodo.value, | ||||
|                 comments: newCommentsTodo.value, | ||||
|             }); | ||||
|         addRow.value = false; | ||||
|         await getSolutionTodosById(); | ||||
|         newAssetTodo.value = ''; | ||||
|         newTaskTodo.value = ''; | ||||
|         newCommentsTodo.value = ''; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row for the template | ||||
| const addChecklistRow = async () => { | ||||
|     await getConfigItemsFromClient(); | ||||
|     if (addRow.value) { | ||||
|         alert('Please confirm the last added row first.') | ||||
|         return | ||||
|     } | ||||
|     addRow.value = true | ||||
| } | ||||
|  | ||||
| //get all solutions | ||||
| const getAllSolutions = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllSolutions`); | ||||
|         solutions.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| // get solution todos from id | ||||
| const getSolutionTodosById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getTodosSolution/${chosenSolId.value}` | ||||
|             ); | ||||
|             solTodos.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all config items from the selected client | ||||
| const getConfigItemsFromClient = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${sol.value.customerID}`); | ||||
|             configItemList.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${changedClientId.value}`); | ||||
|             configItemList.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     if (clientChanged.value) { | ||||
|         store.commit('toggleClientChanged'); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // get solution from id | ||||
| const getSolutionById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSolution/${chosenSolId.value}` | ||||
|             ); | ||||
|             sol.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getConfigItemsFromClient(); | ||||
| } | ||||
|  | ||||
| const deleteSolTodo = async (id) => { | ||||
|     if (confirm("Do you really want to delete this solution todo? It cannot be undone!")) { | ||||
|         try { | ||||
|             await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteSolTodo/${id}`); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getSolutionTodosById(); | ||||
| } | ||||
|  | ||||
| watch(clientChanged, getSolutionById); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSolutionTodosById(); | ||||
|     getSolutionById(); | ||||
|     triggerBackendCallsWithDelay(getAllSolutions); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -49,17 +438,108 @@ export default { | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     flex-direction: row; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     width: 100%; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .saveSolTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 10rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveSolTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 10rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveNewSol-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .saveNewSol-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .deleteSolTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 15.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastSolTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteSolTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 15.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastSolTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .div-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
| @ -68,6 +548,16 @@ export default { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
| @ -75,6 +565,24 @@ export default { | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
| .solution-checklist-information { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
| @ -84,6 +592,22 @@ export default { | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .select-darkmode { | ||||
|     border: none; | ||||
|     color: white; | ||||
|     background: #212121; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .select-lightmode { | ||||
|     border: none; | ||||
|     color: black; | ||||
|     background: #EBEBEB; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| @ -163,6 +687,7 @@ th { | ||||
|  | ||||
| .Comments { | ||||
|     width: 35%; | ||||
|     display: flex; | ||||
| } | ||||
|  | ||||
| .label { | ||||
| @ -183,4 +708,54 @@ th { | ||||
| .label-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .editSolTodos-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 0.825rem 0.7rem; | ||||
|     width: 4%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .editSolTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     margin-left: 15rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .deleteSolTodos-darkmode:hover, | ||||
| .deleteLastSolTodos-darkmode:hover, | ||||
|  | ||||
| .saveSolTodos-darkmode:hover, | ||||
| .editSolTodos-darkmode:hover, | ||||
| .saveNewSol-darkmode:hover { | ||||
|     background-color: #444444; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .deleteSolTodos-lightmode:hover, | ||||
| .deleteLastSolTodos-lightmode:hover, | ||||
|  | ||||
| .saveSolTodos-lightmode:hover, | ||||
| .editSolTodos-lightmode:hover, | ||||
| .saveNewSol-lightmode:hover { | ||||
|     background-color: #ACACAC; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| #saveNewSol { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| #editSolTodos { | ||||
|     text-align: right; | ||||
| } | ||||
| </style> | ||||
| @ -1,4 +1,9 @@ | ||||
| <template> | ||||
|     <section v-if="searchable" :class="['solution-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['clientLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Solution</div> | ||||
|         <input v-model="solutionSearchFilter" @change="searchSolution()" | ||||
|             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|     </section> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Last viewed:</div> | ||||
|         <table class="data-table" id="solution-table"> | ||||
| @ -6,7 +11,7 @@ | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Client', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Client-darkmode' : 'Client-lightmode']"> | ||||
|                         Client</th> | ||||
|                         Customer</th> | ||||
|                     <th | ||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         Name</th> | ||||
| @ -25,7 +30,12 @@ | ||||
|                         {{ sol.customer }}</td> | ||||
|                     <td | ||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                         {{ sol.solutionName }}</td> | ||||
|                         <nuxt-link to="/solutions" id="nuxt-link" class="button" | ||||
|                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" | ||||
|                             @click="goToChosenSolution(sol.primaryID)"> | ||||
|                             {{ sol.solutionName }} | ||||
|                         </nuxt-link> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         {{ sol.assetName }}</td> | ||||
| @ -44,22 +54,73 @@ | ||||
| import { ref, onMounted } from 'vue'; | ||||
| import Axios from '../axios.config.js'; | ||||
| import clientsideConfig from '../../clientsideConfig.js'; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| // get accesss to the store | ||||
| const store = useStore() | ||||
| const goToChosenSolution = (id) => { | ||||
|     store.commit('setChosenSolution', id); | ||||
|     store.commit('changeToSolution'); | ||||
| }; | ||||
|  | ||||
| const clientFilter = computed(() => store.state.filteredByClient); | ||||
| const searchable = computed(() => store.state.searchable); | ||||
|  | ||||
| const solutionSearchFilter = ref(''); | ||||
| const darkMode = ref(true) | ||||
| const solutions = ref([]); | ||||
|  | ||||
| // update search term | ||||
| const updateSearchTerm = async () => { | ||||
|     solutionSearchFilter.value = ''; | ||||
|     await getSolutions(); | ||||
| } | ||||
|  | ||||
| //get all solutions | ||||
| const getSolutions = async () => { | ||||
|     if (!(clientFilter.value === '')) { | ||||
|         await getFilteredSolutionsByClient(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllSolutions`); | ||||
|             solutions.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| onMounted(() => { | ||||
|     getSolutions(); | ||||
| //get all solutions based on the searched client | ||||
| const getFilteredSolutionsByClient = async () => { | ||||
|     try { | ||||
|         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedSolutionsByClient/${clientFilter.value}`); | ||||
|         solutions.value = response.data; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all solutions based on the searched solution name | ||||
| const searchSolution = async () => { | ||||
|     if (solutionSearchFilter.value === '') { | ||||
|         await getSolutions(); | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedSolutionsBySolution/${solutionSearchFilter.value}`); | ||||
|             solutions.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| watch(clientFilter, getSolutions); | ||||
| watch(searchable, updateSearchTerm); | ||||
|  | ||||
|  | ||||
| onMounted(async () => { | ||||
|     await getSolutions(); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| @ -77,7 +138,6 @@ export default { | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     width: 100%; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     gap: 1.25rem; | ||||
|     border-radius: 0.625rem; | ||||
| @ -118,6 +178,32 @@ export default { | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .solution-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; | ||||
| } | ||||
|  | ||||
| .tr-darkmode { | ||||
|     border-top: 0.0625rem solid #000000; | ||||
| } | ||||
| @ -126,6 +212,17 @@ export default { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
| @ -135,6 +232,14 @@ td { | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
|     color: #ffffff; | ||||
| @ -149,6 +254,22 @@ th { | ||||
|     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| #nuxt-link { | ||||
|     text-decoration: none; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| .clientLabel { | ||||
|     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; | ||||
| } | ||||
|  | ||||
| .Client { | ||||
|     width: 33.3%; | ||||
| } | ||||
|  | ||||
| @ -126,7 +126,7 @@ | ||||
|                     <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="newT.comments" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deletePOTTodos-darkmode' : 'deleteLastPOTTodos-lightmode']" | ||||
|                             :class="[darkMode ? 'deleteLastPOTTodos-darkmode' : 'deleteLastPOTTodos-lightmode']" | ||||
|                             @click="deletePOTTodoFromNewTodos(index)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
| @ -138,7 +138,7 @@ | ||||
|             @click="addRowForNewPOT()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewPOT"> | ||||
|         <button :class="[darkMode ? 'saveNewPOT-darkmode' : 'saveNewPOT-lightmode']" @click="addPOT()">Safe</button> | ||||
|         <button :class="[darkMode ? 'saveNewPOT-darkmode' : 'saveNewPOT-lightmode']" @click="addPOT()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
| @ -619,7 +619,6 @@ th { | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
|  | ||||
| .savePOTTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|  | ||||
							
								
								
									
										750
									
								
								components/server/TemplateChecklistMVT.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										750
									
								
								components/server/TemplateChecklistMVT.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,750 @@ | ||||
| <template> | ||||
|     <section v-if="!addBool" | ||||
|         :class="['template-checklist-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Checklist:</div> | ||||
|         <table class="data-table" id="template-checklist"> | ||||
|             <tbody> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Step', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         Step</th> | ||||
|                     <th | ||||
|                         :class="['Asset', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         Asset</th> | ||||
|                     <th | ||||
|                         :class="['Task', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         Task</th> | ||||
|                     <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                 </tr> | ||||
|                 <tr v-for="todo in mvtTodos" :key="todo.primaryID" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ todo.rowID }} | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         {{ todo.asset }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         <select id="customersDropDownChosenCI" v-model="todo.asset" @change="updateMVTTodo(todo)" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                                 {{ ci.assetName }} | ||||
|                             </option> | ||||
|                         </select> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         {{ todo.task }}</td> | ||||
|                     <td v-if="editable" | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         <input type="text" v-model="todo.task" @change="updateMVTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td v-if="!editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> {{ todo.commets | ||||
|                     }}</td> | ||||
|                     <td v-if="editable" :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="todo.commets" @change="updateMVTTodo(todo)" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deleteMvtTodos-darkmode' : 'deleteMvtTodos-lightmode']" | ||||
|                             @click="deleteMVTTodo(todo.primaryID)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|                 <tr v-if="editable && addRow" :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ newStepTodo }} | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         <select id="customersDropDownChosenCI" v-model="newAssetTodo" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                                 {{ ci.assetName }} | ||||
|                             </option> | ||||
|                         </select> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         <input type="text" v-model="newTaskTodo" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"><input type="text" | ||||
|                             v-model="newCommentsTodo" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'saveMvtTodos-darkmode' : 'saveMvtTodos-lightmode']" | ||||
|                             @click="addMVTTodo()">Save</button> <button | ||||
|                             :class="[darkMode ? 'deleteLastMvtTodos-darkmode' : 'deleteLastMvtTodos-lightmode']" | ||||
|                             @click="deleteNewRow()">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </section> | ||||
|     <section v-if="editable && !addBool" id="editMvtTodos"> | ||||
|         <button :class="[darkMode ? 'editMvtTodos-darkmode' : 'editMvtTodos-lightmode']" | ||||
|             @click="addChecklistRow()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" | ||||
|         :class="['template-checklist-information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Checklist:</div> | ||||
|         <table class="data-table" id="template-checklist"> | ||||
|             <tbody> | ||||
|                 <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||
|                     <th | ||||
|                         :class="['Step', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         Step</th> | ||||
|                     <th | ||||
|                         :class="['Asset', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         Asset</th> | ||||
|                     <th | ||||
|                         :class="['Task', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         Task</th> | ||||
|                     <th :class="['Comments', darkMode ? 'th-darkmode' : 'th-lightmode']">Comments</th> | ||||
|                 </tr> | ||||
|                 <tr v-for="(newT, index) in newTodos" :key="index" | ||||
|                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                     <td | ||||
|                         :class="['Step', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Step-darkmode' : 'Step-lightmode']"> | ||||
|                         {{ newT.rowID }} | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Asset', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Asset-darkmode' : 'Asset-lightmode']"> | ||||
|                         <select id="customersDropDownChosenCI" v-model="newT.asset" | ||||
|                             :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||
|                             <option v-for="ci in configItemList" :key="ci.primaryID"> | ||||
|                                 {{ ci.assetName }} | ||||
|                             </option> | ||||
|                         </select> | ||||
|                     </td> | ||||
|                     <td | ||||
|                         :class="['Task', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Task-darkmode' : 'Task-lightmode']"> | ||||
|                         <input type="text" v-model="newT.task" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||
|                     </td> | ||||
|                     <td :class="['Comments', darkMode ? 'td-darkmode' : 'td-lightmode']"> <input type="text" | ||||
|                             v-model="newT.comments" | ||||
|                             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> <button | ||||
|                             :class="[darkMode ? 'deleteMvtTodos-darkmode' : 'deleteLastMvtTodos-lightmode']" | ||||
|                             @click="deleteMVTTodoFromNewTodos(index)">-</button> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             </tbody> | ||||
|         </table> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="editMvtTodos"> | ||||
|         <button :class="[darkMode ? 'editMvtTodos-darkmode' : 'editMvtTodos-lightmode']" | ||||
|             @click="addRowForNewMVT()">+</button> | ||||
|     </section> | ||||
|     <section v-if="addBool" id="saveNewMVT"> | ||||
|         <button :class="[darkMode ? 'saveNewMVT-darkmode' : 'saveNewMVT-lightmode']" @click="addMVT()">Save</button> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|  | ||||
| <script setup> | ||||
| import { ref, onMounted, watch } 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 addBool = computed(() => store.state.new); | ||||
| const editable = computed(() => store.state.editable); | ||||
|  | ||||
| const newNameMVT = computed(() => store.state.newNameMVT); | ||||
| const newCustomerIDMVT = computed(() => store.state.newCustomerIDMVT); | ||||
| const newCustomerMVT = computed(() => store.state.newCustomerMVT); | ||||
| const newLastViewMVT = computed(() => store.state.newLastViewMVT); | ||||
| const newUserMVT = computed(() => store.state.newUserMVT); | ||||
| const newTypeMVT = computed(() => store.state.newTypeMVT); | ||||
| const newNotesMVT = computed(() => store.state.newNotesMVT); | ||||
| const newStepTodo = computed(() => mvtTodos.value.length); | ||||
| const chosenMVTId = computed(() => store.state.chosenMVTId); | ||||
| const clientChanged = computed(() => store.state.clientChanged); | ||||
| const changedClientId = computed(() => store.state.changedClientId); | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const addRow = ref(false); | ||||
| const configItemList = ref([]); | ||||
| const maintenanceVisitTemplates = ref([]); | ||||
| const mvtTodos = ref([]) | ||||
| const MVT = ref({}) | ||||
| const newAssetTodo = ref(''); | ||||
| const newTaskTodo = ref(''); | ||||
| const newCommentsTodo = ref(''); | ||||
| const newTodos = reactive([]); | ||||
| const newRowId = computed(() => newTodos.length) | ||||
|  | ||||
| // delete new todo row | ||||
| const deleteNewRow = () => { | ||||
|     newAssetTodo.value = ''; | ||||
|     newTaskTodo.value = ''; | ||||
|     newCommentsTodo.value = ''; | ||||
|     addRow.value = false; | ||||
| } | ||||
|  | ||||
| const deleteMVTTodoFromNewTodos = (index) => { | ||||
|     newTodos.splice(index, 1); | ||||
|     newTodos.forEach((todo, i) => { | ||||
|         todo.rowID = i | ||||
|     }) | ||||
| } | ||||
|  | ||||
| // add new maintenance visit template | ||||
| const addMVT = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newNameMVT.value.trim() === "") { | ||||
|         alert("Please add a maintenance visit template name!"); | ||||
|         return; | ||||
|     } else { | ||||
|         var counter = 0; | ||||
|         if (!(maintenanceVisitTemplates.value.length == null)) { | ||||
|             // check if maintenance visit template name already exists | ||||
|             maintenanceVisitTemplates.value.forEach(MVT => { | ||||
|                 if (MVT.name === newNameMVT.value) { | ||||
|                     counter += 1; | ||||
|                 } | ||||
|             }); | ||||
|             if (counter == 1) { | ||||
|                 alert("This maintenance visit template name already exists. Please choose an unique maintenance visit template name or modify respectively delete the old one!"); | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     if (newCustomerMVT.value.length === 0) { | ||||
|         alert("Please choose a client!"); | ||||
|         return; | ||||
|     } | ||||
|     let allFine = true; | ||||
|     newTodos.forEach(todo => { | ||||
|         if (todo.asset.length === 0) { | ||||
|             alert(`Please choose a config item for all todos.`); | ||||
|             allFine = false | ||||
|         } | ||||
|     }) | ||||
|     if (!allFine) { | ||||
|         return | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addMVT`, | ||||
|             { | ||||
|                 name: newNameMVT.value, | ||||
|                 customerID: newCustomerIDMVT.value, | ||||
|                 customer: newCustomerMVT.value, | ||||
|                 lastView: newLastViewMVT.value, | ||||
|                 user: newUserMVT.value, | ||||
|                 type: newTypeMVT.value, | ||||
|                 notes: newNotesMVT.value, | ||||
|             }); | ||||
|         store.commit('resetStore'); | ||||
|         store.commit('changeToTemplatelist'); | ||||
|         newTodos.forEach(async todo => { | ||||
|             try { | ||||
|                 const res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addTodoMVT`, | ||||
|                     { | ||||
|                         templateID: response.data, | ||||
|                         rowID: todo.rowID, | ||||
|                         asset: todo.asset, | ||||
|                         task: todo.task, | ||||
|                         comment: todo.comments, | ||||
|                     }); | ||||
|             } catch (err) { | ||||
|                 console.log(err.response.statusText); | ||||
|             } | ||||
|         }) | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row of todo for the new MVT | ||||
| const addRowForNewMVT = async () => { | ||||
|     if (newCustomerMVT.value.length === 0) { | ||||
|         alert("Please choose a client first!"); | ||||
|         return; | ||||
|     } | ||||
|     await getConfigItemsFromClient(); | ||||
|     newTodos.push({ | ||||
|         templateID: chosenMVTId.value, | ||||
|         rowID: newRowId.value, | ||||
|         asset: '', | ||||
|         task: '', | ||||
|         comments: '' | ||||
|     }); | ||||
| } | ||||
|  | ||||
| //update data | ||||
| const updateMVTTodo = async (todo) => { | ||||
|     if (todo.asset.length === 0) { | ||||
|         alert(`Please add the missing config item in row ${todo.rowID}!`); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         await Axios.put( | ||||
|             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateMVTTodo`, | ||||
|             { | ||||
|                 primaryID: todo.primaryID, | ||||
|                 templateID: todo.templateID, | ||||
|                 rowID: todo.rowID, | ||||
|                 asset: todo.asset, | ||||
|                 task: todo.task, | ||||
|                 comments: todo.commets, | ||||
|             } | ||||
|         ); | ||||
|         await getMVTById(); | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new maintenance visit template todo | ||||
| const addMVTTodo = async () => { | ||||
|     // check if all input data is valid | ||||
|     if (newAssetTodo.value.length === 0) { | ||||
|         alert("Please choose an asset for the new todo!"); | ||||
|         return; | ||||
|     } | ||||
|     try { | ||||
|         const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addTodoMVT`, | ||||
|             { | ||||
|                 templateID: chosenMVTId.value, | ||||
|                 rowID: newStepTodo.value, | ||||
|                 asset: newAssetTodo.value, | ||||
|                 task: newTaskTodo.value, | ||||
|                 comment: newCommentsTodo.value, | ||||
|             }); | ||||
|         addRow.value = false; | ||||
|         await getMvtTodosById(); | ||||
|         newAssetTodo.value = ''; | ||||
|         newTaskTodo.value = ''; | ||||
|         newCommentsTodo.value = ''; | ||||
|     } catch (err) { | ||||
|         console.log(err.response.statusText); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // add new row for the template checklist | ||||
| const addChecklistRow = async () => { | ||||
|     await getConfigItemsFromClient(); | ||||
|     if (addRow.value) { | ||||
|         alert('Please confirm the last added row first.') | ||||
|         return | ||||
|     } | ||||
|     addRow.value = true | ||||
| } | ||||
|  | ||||
| //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); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // include delay to avoid 503 error | ||||
| const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||
|     setTimeout(() => { | ||||
|         fetchDataFunc(); | ||||
|     }, 1000); | ||||
| } | ||||
|  | ||||
| // get maintenance visit template todos from id | ||||
| const getMvtTodosById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getTodosMaintenanceVisitTemplate/${chosenMVTId.value}` | ||||
|             ); | ||||
|             mvtTodos.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //get all config items from the selected client | ||||
| const getConfigItemsFromClient = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${MVT.value.customerID}`); | ||||
|             configItemList.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } else { | ||||
|         try { | ||||
|             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCIFromClient/${changedClientId.value}`); | ||||
|             configItemList.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     if (clientChanged.value) { | ||||
|         store.commit('toggleClientChanged'); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // get maintenance visit template from id | ||||
| const getMVTById = async () => { | ||||
|     if (!addBool.value) { | ||||
|         try { | ||||
|             const response = await Axios.get( | ||||
|                 `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getMaintenanceVisitTemplate/${chosenMVTId.value}` | ||||
|             ); | ||||
|             MVT.value = response.data; | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getConfigItemsFromClient(); | ||||
| } | ||||
|  | ||||
| const deleteMVTTodo = async (id) => { | ||||
|     if (confirm("Do you really want to delete this maintenance visit template todo? It cannot be undone!")) { | ||||
|         try { | ||||
|             await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteMVTTodo/${id}`); | ||||
|         } catch (err) { | ||||
|             console.log(err.response.statusText); | ||||
|         } | ||||
|     } | ||||
|     await getMvtTodosById(); | ||||
| } | ||||
|  | ||||
| watch(clientChanged, getMVTById); | ||||
|  | ||||
| onMounted(() => { | ||||
|     getMvtTodosById(); | ||||
|     getMVTById(); | ||||
|     triggerBackendCallsWithDelay(getMaintenanceVisitTemplates); | ||||
| }); | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     name: "TemplateChecklist", | ||||
| }; | ||||
| </script>  | ||||
|    | ||||
|      | ||||
| <style scoped> | ||||
| .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; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .select-darkmode { | ||||
|     border: none; | ||||
|     color: white; | ||||
|     background: #212121; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .select-lightmode { | ||||
|     border: none; | ||||
|     color: black; | ||||
|     background: #EBEBEB; | ||||
|     padding: 0.4rem; | ||||
|     border-radius: 0.3125rem; | ||||
| } | ||||
|  | ||||
| .input { | ||||
|     border: none; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
|     table-layout: fixed; | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|     height: 3.125rem; | ||||
|     padding: 0.625rem; | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .tr-darkmode { | ||||
|     border-top: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .tr-lightmode { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
|     height: 1.875rem; | ||||
|     text-align: left; | ||||
|     padding: 0; | ||||
|     letter-spacing: 5%; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| th { | ||||
|     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| .th-lightmode, | ||||
| .td-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .template-checklist-information { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .Step { | ||||
|     width: 8%; | ||||
| } | ||||
|  | ||||
| .Step-darkmode { | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .Step-lightmode { | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .Asset { | ||||
|     width: 22%; | ||||
| } | ||||
|  | ||||
| .Asset-darkmode { | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .Asset-lightmode { | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .Task { | ||||
|     width: 35%; | ||||
| } | ||||
|  | ||||
| .Task-darkmode { | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
|  | ||||
| .Task-lightmode { | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .Comments { | ||||
|     width: 35%; | ||||
|     display: flex; | ||||
| } | ||||
|  | ||||
| .label { | ||||
|     width: 6.0625em; | ||||
|     height: 1.875em; | ||||
|     font-family: 'Overpass'; | ||||
|     font-style: normal; | ||||
|     font-weight: 400; | ||||
|     font-size: 1em; | ||||
|     line-height: 1.875em; | ||||
|     letter-spacing: 0.05em; | ||||
| } | ||||
|  | ||||
| .label-darkmode { | ||||
|     color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .editMvtTodos-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 0.825rem 0.7rem; | ||||
|     width: 4%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
|  | ||||
| .saveMvtTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 10rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveNewMVT-darkmode { | ||||
|     background: #2c2c2c; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .deleteMvtTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 15.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastMvtTodos-darkmode { | ||||
|     background: #212121; | ||||
|     color: #fff; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
|  | ||||
| .editMvtTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     margin-left: 15rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .saveMvtTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 10rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteMvtTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 15.8rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .deleteLastMvtTodos-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     border-radius: 0.625rem; | ||||
|     margin-left: 2rem; | ||||
|     padding-left: 0.9rem; | ||||
|     padding-right: 0.9rem; | ||||
| } | ||||
|  | ||||
| .saveNewMVT-lightmode { | ||||
|     background: #EBEBEB; | ||||
|     color: #212121; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
|     border: none; | ||||
|     padding: 1rem 1.875rem; | ||||
|     width: 8%; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .deleteMvtTodos-darkmode:hover, | ||||
| .deleteLastMvtTodos-darkmode:hover, | ||||
|  | ||||
| .saveMvtTodos-darkmode:hover, | ||||
| .editMvtTodos-darkmode:hover, | ||||
| .saveNewMVT-darkmode:hover { | ||||
|     background-color: #444444; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .deleteMvtTodos-lightmode:hover, | ||||
| .deleteLastMvtTodos-lightmode:hover, | ||||
|  | ||||
| .saveMvtTodos-lightmode:hover, | ||||
| .editMvtTodos-lightmode:hover, | ||||
| .saveNewMVT-lightmode:hover { | ||||
|     background-color: #ACACAC; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| #saveNewMVT { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| #editMvtTodos { | ||||
|     text-align: right; | ||||
| } | ||||
| </style> | ||||
| @ -99,7 +99,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     gap: 1.25rem; | ||||
| } | ||||
|  | ||||
| @ -70,7 +70,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     gap: 1.25rem; | ||||
| } | ||||
|  | ||||
| @ -100,7 +100,7 @@ export default { | ||||
|     align-items: center; | ||||
|     justify-content: flex-start; | ||||
|     width: 100%; | ||||
|     padding: 0 1.875rem; | ||||
|     padding: 0.8rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     gap: 1.25rem; | ||||
| } | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| <mxfile host="Electron" modified="2024-02-14T10:28:35.536Z" agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/22.0.3 Chrome/114.0.5735.289 Electron/25.8.4 Safari/537.36" etag="_zOGEdVgp7g5JHBy-mYE" version="22.0.3" type="device" pages="2"> | ||||
| <mxfile host="Electron" modified="2024-02-27T19:18:30.556Z" agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/22.0.3 Chrome/114.0.5735.289 Electron/25.8.4 Safari/537.36" etag="pTIMz7977P7LLgTl7RJZ" version="22.0.3" type="device" pages="2"> | ||||
|   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> | ||||
|     <mxGraphModel dx="393" dy="2849" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="827" pageHeight="1169" math="0" shadow="0"> | ||||
|     <mxGraphModel dx="395" dy="2842" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="827" pageHeight="1169" math="0" shadow="0"> | ||||
|       <root> | ||||
|         <mxCell id="0" /> | ||||
|         <mxCell id="1" parent="0" /> | ||||
| @ -580,7 +580,7 @@ | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-108" value="task" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-103" vertex="1"> | ||||
|           <mxGeometry y="150" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-109" value="comment" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-103" vertex="1"> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-109" value="comments" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-103" vertex="1"> | ||||
|           <mxGeometry y="180" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-128" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;" parent="1" source="WukdXvazNq34soQIU5Al-126" target="DauqCNUrC7Z9yIe88X-r-22" edge="1"> | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,6 +1,6 @@ | ||||
| <mxfile host="Electron" modified="2024-02-27T19:18:30.556Z" agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/22.0.3 Chrome/114.0.5735.289 Electron/25.8.4 Safari/537.36" etag="pTIMz7977P7LLgTl7RJZ" version="22.0.3" type="device" pages="2"> | ||||
| <mxfile host="Electron" modified="2024-03-11T18:43:59.748Z" agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/22.0.3 Chrome/114.0.5735.289 Electron/25.8.4 Safari/537.36" etag="Ub9Iakw2VLrdzjhM2iAH" version="22.0.3" type="device" pages="2"> | ||||
|   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> | ||||
|     <mxGraphModel dx="395" dy="2842" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="827" pageHeight="1169" math="0" shadow="0"> | ||||
|     <mxGraphModel dx="409" dy="2842" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="827" pageHeight="1169" math="0" shadow="0"> | ||||
|       <root> | ||||
|         <mxCell id="0" /> | ||||
|         <mxCell id="1" parent="0" /> | ||||
| @ -395,7 +395,7 @@ | ||||
|           <mxGeometry y="510" width="150" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-15" value="issueSlips" style="swimlane;fontStyle=0;childLayout=stackLayout;horizontal=1;startSize=30;horizontalStack=0;resizeParent=1;resizeParentMax=0;resizeLast=0;collapsible=1;marginBottom=0;whiteSpace=wrap;html=1;fillColor=#00CC00;" parent="1" vertex="1"> | ||||
|           <mxGeometry x="2040" y="-560" width="140" height="540" as="geometry" /> | ||||
|           <mxGeometry x="2040" y="-560" width="140" height="840" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-16" value="primaryID*" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="30" width="140" height="30" as="geometry" /> | ||||
| @ -421,33 +421,63 @@ | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-21" value="notes" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="240" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-23" value="supplierRequest" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-14" value="deliveryAddress" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="270" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-32" value="supplierOffer" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-23" value="supplierRequestDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="300" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-33" value="clientOffer" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-5" value="supplierRequest" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="330" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-34" value="clientOrder" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-32" value="supplierOfferDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="360" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-35" value="supplierOrder" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-6" value="supplierOffer" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="390" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-36" value="ingress" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-33" value="clientOfferDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="420" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-37" value="egress" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-7" value="clientOffer" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="450" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-38" value="ingressBill" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-34" value="clientOrderDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="480" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-39" value="egressBill" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-8" value="clientOrder" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="510" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-35" value="supplierOrderDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="540" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-9" value="supplierOrder" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="570" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-36" value="ingressDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="600" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-10" value="ingress" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="630" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-11" value="egressDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="660" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-37" value="egress" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="690" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-12" value="ingressBillDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="720" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-38" value="ingressBill" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="750" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="6nz9YpIofWTpyD1iDkT1-13" value="egressBillDate" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="780" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-39" value="egressBill" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-15" vertex="1"> | ||||
|           <mxGeometry y="810" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-40" value="orderingInfoIssueSlips" style="swimlane;fontStyle=0;childLayout=stackLayout;horizontal=1;startSize=30;horizontalStack=0;resizeParent=1;resizeParentMax=0;resizeLast=0;collapsible=1;marginBottom=0;whiteSpace=wrap;html=1;fillColor=#00CC00;" parent="1" vertex="1"> | ||||
|           <mxGeometry x="2220" y="-440" width="140" height="210" as="geometry" /> | ||||
|         </mxCell> | ||||
| @ -470,7 +500,7 @@ | ||||
|           <mxGeometry y="180" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-48" value="issues" style="swimlane;fontStyle=0;childLayout=stackLayout;horizontal=1;startSize=30;horizontalStack=0;resizeParent=1;resizeParentMax=0;resizeLast=0;collapsible=1;marginBottom=0;whiteSpace=wrap;html=1;fillColor=#00CC00;" parent="1" vertex="1"> | ||||
|           <mxGeometry x="2040" y="120" width="140" height="210" as="geometry" /> | ||||
|           <mxGeometry x="2040" y="400" width="140" height="210" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-49" value="primaryID*" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-48" vertex="1"> | ||||
|           <mxGeometry y="30" width="140" height="30" as="geometry" /> | ||||
| @ -491,7 +521,7 @@ | ||||
|           <mxGeometry y="180" width="140" height="30" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-56" value="issueVariants" style="swimlane;fontStyle=0;childLayout=stackLayout;horizontal=1;startSize=30;horizontalStack=0;resizeParent=1;resizeParentMax=0;resizeLast=0;collapsible=1;marginBottom=0;whiteSpace=wrap;html=1;fillColor=#00CC00;" parent="1" vertex="1"> | ||||
|           <mxGeometry x="2220" y="180" width="140" height="240" as="geometry" /> | ||||
|           <mxGeometry x="2220" y="460" width="140" height="240" as="geometry" /> | ||||
|         </mxCell> | ||||
|         <mxCell id="WukdXvazNq34soQIU5Al-57" value="primaryID*" style="text;strokeColor=none;fillColor=none;align=left;verticalAlign=middle;spacingLeft=4;spacingRight=4;overflow=hidden;points=[[0,0.5],[1,0.5]];portConstraint=eastwest;rotatable=0;whiteSpace=wrap;html=1;" parent="WukdXvazNq34soQIU5Al-56" vertex="1"> | ||||
|           <mxGeometry y="30" width="140" height="30" as="geometry" /> | ||||
|  | ||||
| @ -1,12 +1,16 @@ | ||||
| <template> | ||||
|   <aside :class="['actionbar', darkMode ? 'actionbar-darkmode' : 'actionbar-lightmode', isExpanded ? 'is-expanded' : 'is-not-expanded']"> | ||||
|     <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" /> | ||||
|   <aside | ||||
|     :class="['actionbar', darkMode ? 'actionbar-darkmode' : 'actionbar-lightmode', isExpanded ? 'is-expanded' : 'is-not-expanded']"> | ||||
|     <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> | ||||
|     <nav class="actions"> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="search" @click="toggleSearched"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Search</pre> | ||||
| @ -14,7 +18,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="filter" @click="toggleFiltered"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Filter</pre> | ||||
| @ -22,7 +27,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="instances"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Instances</pre> | ||||
| @ -30,7 +36,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="attachments"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Attachments</pre> | ||||
| @ -38,7 +45,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="sell"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Sell</pre> | ||||
| @ -46,7 +54,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="archive"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Archive</pre> | ||||
| @ -54,7 +63,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="new" @click="add"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">New</pre> | ||||
| @ -62,7 +72,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="edit" @click="toggleEditable"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Edit</pre> | ||||
| @ -70,7 +81,8 @@ | ||||
|       </button> | ||||
|       <button :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="delete" @click="deleteFunc"> | ||||
|         <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> | ||||
|         <Transition name="fade"> | ||||
|           <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Delete</pre> | ||||
| @ -141,17 +153,21 @@ aside.actionbar { | ||||
|   gap: 1.25rem; | ||||
|   overflow: clip; | ||||
| } | ||||
|  | ||||
| .actionbar-darkmode { | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   background-color: #2C2C2C; | ||||
| } | ||||
|  | ||||
| .actionbar-lightmode { | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   background-color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| aside.is-expanded { | ||||
|   animation: expand 0.5s linear both; | ||||
| } | ||||
|  | ||||
| aside.is-not-expanded { | ||||
|   animation: contract 0.5s linear both; | ||||
| } | ||||
| @ -181,16 +197,30 @@ button { | ||||
|   transition: 0.2s ease-in-out; | ||||
|   overflow: clip; | ||||
| } | ||||
| .button-darkmode { background-color: #2C2C2C; }  | ||||
| .button-lightmode { background-color: #FFFFFF; }  | ||||
|  | ||||
| .button-darkmode { | ||||
|   background-color: #2C2C2C; | ||||
| } | ||||
|  | ||||
| .button-lightmode { | ||||
|   background-color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| .button-darkmode:hover, | ||||
| .indicator-darkmode:hover { background-color: #444444; }  | ||||
| .indicator-darkmode:hover { | ||||
|   background-color: #444444; | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| .button-lightmode:hover, | ||||
| .indicator-lightmode:hover {  background-color: #ACACAC; }  | ||||
| .indicator-lightmode:hover { | ||||
|   background-color: #ACACAC; | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| .is-not-expanded>button { align-self: center; } | ||||
| .is-not-expanded>button { | ||||
|   align-self: center; | ||||
| } | ||||
|  | ||||
|  | ||||
| .icon { | ||||
| @ -202,6 +232,7 @@ button { | ||||
|   justify-content: center; | ||||
|   padding: 0 0.5rem; | ||||
| } | ||||
|  | ||||
| .is-not-expanded .icon { | ||||
|   align-self: center; | ||||
| } | ||||
| @ -212,7 +243,10 @@ button { | ||||
|   border-radius: 0.3125rem; | ||||
|   transition: 0.2s ease-in-out; | ||||
| } | ||||
| .is-not-expanded #indicator-icon { transform: rotate(180deg); } | ||||
|  | ||||
| .is-not-expanded #indicator-icon { | ||||
|   transform: rotate(180deg); | ||||
| } | ||||
|  | ||||
|  | ||||
| img { | ||||
| @ -222,8 +256,14 @@ img { | ||||
|   object-position: center; | ||||
|   overflow: hidden; | ||||
| } | ||||
| .img-darkmode { filter: invert(100%); }  | ||||
| #indicator-icon>img { height: 1.25rem; } | ||||
|  | ||||
| .img-darkmode { | ||||
|   filter: invert(100%); | ||||
| } | ||||
|  | ||||
| #indicator-icon>img { | ||||
|   height: 1.25rem; | ||||
| } | ||||
|  | ||||
|  | ||||
| .label { | ||||
| @ -235,12 +275,19 @@ img { | ||||
|   white-space: nowrap; | ||||
|   font: 400 0.875rem/1.25rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #FFFFFF; }  | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
| .label-darkmode { | ||||
|   color: #FFFFFF; | ||||
| } | ||||
|  | ||||
| .label-lightmode { | ||||
|   color: #000000; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| .fade-enter-from, .fade-leave-to { | ||||
| .fade-enter-from, | ||||
| .fade-leave-to { | ||||
|   opacity: 0; | ||||
| } | ||||
|  | ||||
| @ -310,5 +357,4 @@ img { | ||||
|     max-width: 0; | ||||
|     max-inline-size: 0; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| }</style> | ||||
| @ -20,7 +20,7 @@ | ||||
|         </router-link> | ||||
|       </nav> | ||||
|       <nav id="site-menu"> | ||||
|         <router-link to="/maintenanceVisits" class="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" @click="defaultProductionOrderPage()" id="checklists-button"> | ||||
|         <router-link to="/maintenanceVisits" class="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" @click="defaultMasterChecklistPage()" id="checklists-button"> | ||||
|           <div class="icon" id="checklists-icon"> | ||||
|             <img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="../icons/navbar-icons/Checklists-Icon.svg" /> | ||||
|           </div> | ||||
| @ -36,7 +36,7 @@ | ||||
|             <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Assets</pre> | ||||
|           </Transition> | ||||
|         </nuxt-link> | ||||
|         <router-link to="/solutions" class="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="solutions-button"> | ||||
|         <router-link to="/solutions" class="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" @click="defaultSolutionPage()" id="solutions-button"> | ||||
|           <div class="icon" id="solutions-icon"> | ||||
|             <img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="../icons/navbar-icons/Solutions-Icon.svg" /> | ||||
|           </div> | ||||
| @ -57,7 +57,7 @@ | ||||
|             <img :class="[darkMode ? 'img-darkmode' : 'img-lightmode']" loading="lazy" src="../icons/navbar-icons/Clients-Icon.svg" /> | ||||
|           </div> | ||||
|           <Transition name="fade"> | ||||
|             <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Clients</pre> | ||||
|             <pre v-if="isExpanded" :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Customers</pre> | ||||
|           </Transition> | ||||
|         </router-link> | ||||
|       </nav> | ||||
| @ -81,11 +81,16 @@ const defaultAssetPage = () => { | ||||
|   store.commit('changeToAssetlist'); | ||||
| }; | ||||
|  | ||||
| const defaultProductionOrderPage = () => { | ||||
| const defaultMasterChecklistPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToTemplatelist') | ||||
| } | ||||
|  | ||||
| const defaultSolutionPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToSolutionlist') | ||||
| } | ||||
|  | ||||
| const ToggleSidebar = () => { | ||||
|   isExpanded.value = !isExpanded.value; | ||||
| }; | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| <template> | ||||
|   <section id="content"> | ||||
|     <div id="content-header"> | ||||
|       <router-link to="/assets" class="button" id="assets-button" @click="defaultAssetPage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Assets</h1> | ||||
|       </router-link> | ||||
|     </div> | ||||
|     <div id="content-body"> | ||||
|       <ClientSearch v-if="onAssetlist || onCustomerAssetlist" /> | ||||
| @ -43,6 +45,11 @@ definePageMeta({ | ||||
|   layout: 'default' | ||||
| }) | ||||
|  | ||||
| const defaultAssetPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToAssetlist') | ||||
| } | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| @ -102,4 +109,8 @@ export default { | ||||
|   margin-bottom: 0.625rem; | ||||
|   border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .button { | ||||
|   text-decoration: none; | ||||
| } | ||||
| </style> | ||||
| @ -16,7 +16,6 @@ | ||||
|   </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| <template> | ||||
|   <section id="content"> | ||||
|     <div id="content-header"> | ||||
|       <router-link to="/issueSlips" class="button" id="issueSlips-button"> | ||||
|       <router-link to="/issueSlips" class="button" id="issueSlips-button" @click="defaultIssueSlipPage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name">Issue slips</h1> | ||||
|       </router-link> | ||||
|         | ||||
| @ -20,17 +20,17 @@ | ||||
|         | ||||
|         | ||||
|         | ||||
|       <router-link to="/issues" class="button" id="issues-button"> | ||||
|       <router-link to="/issues" class="button" id="issues-button" @click="defaultIssuePage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Issues</h1> | ||||
|       </router-link> | ||||
|     </div> | ||||
|     <div id="content-body"> | ||||
|       <ClientSearch v-if="onIssueSliplist || onCustomerIssueSliplist"/> | ||||
|       <IssueSlipTable v-if="onIssueSliplist"/> | ||||
|       <IssueSlipTableNoClient v-if="onCustomerIssueSliplist"/> | ||||
|       <IssueSlip v-if="onIssueSlip"/> | ||||
|       <OrderingInformation v-if="onIssueSlip"/> | ||||
|       <Accounting v-if="onIssueSlip"/> | ||||
|       <ClientSearch v-if="onIssueSliplist || onCustomerIssueSliplist" /> | ||||
|       <IssueSlipTable v-if="onIssueSliplist" /> | ||||
|       <IssueSlipTableNoClient v-if="onCustomerIssueSliplist" /> | ||||
|       <IssueSlip v-if="onIssueSlip" /> | ||||
|       <OrderingInformation v-if="onIssueSlip" /> | ||||
|       <Accounting v-if="onIssueSlip" /> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
| @ -45,6 +45,13 @@ import IssueSlipTableNoClient from "../components/server/IssueSlipTableNoClient. | ||||
| import IssueSlip from "../components/server/IssueSlip.vue"; | ||||
| import OrderingInformation from "../components/server/OrderingInformation.vue"; | ||||
| import Accounting from "../components/server/Accounting.vue"; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const onIssueSliplist = computed(() => store.state.onIssueSliplist); | ||||
| const onCustomerIssueSliplist = computed(() => store.state.onCustomerIssueSliplist); | ||||
| const onIssueSlip = computed(() => store.state.onIssueSlip); | ||||
|  | ||||
| definePageMeta({ | ||||
|   layout: 'default' | ||||
| @ -52,10 +59,15 @@ definePageMeta({ | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| // to render the right components | ||||
| const onIssueSliplist = ref(true) | ||||
| const onCustomerIssueSliplist = ref(false) | ||||
| const onIssueSlip = ref(false) | ||||
| const defaultIssueSlipPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToIssueSliplist') | ||||
| } | ||||
|  | ||||
| const defaultIssuePage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToIssueItemList') | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| <template> | ||||
|     <section id="content"> | ||||
|         <div id="content-header"> | ||||
|             <router-link to="/issueSlips" class="button" id="issueSlips-button"> | ||||
|             <router-link to="/issueSlips" class="button" id="issueSlips-button" @click="defaultIssueSlipPage()"> | ||||
|                 <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Issue slips</h1> | ||||
|             </router-link> | ||||
|               | ||||
| @ -20,11 +20,12 @@ | ||||
|               | ||||
|               | ||||
|               | ||||
|             <router-link to="/issues" class="button" id="issues-button"> | ||||
|             <router-link to="/issues" class="button" id="issues-button" @click="defaultIssuePage()"> | ||||
|                 <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name">Issues</h1> | ||||
|             </router-link> | ||||
|         </div> | ||||
|         <div id="content-body"> | ||||
|             <IssueStateSearch v-if="onIssueItemList" /> | ||||
|             <IssueTable v-if="onIssueItemList"/> | ||||
|             <Issue v-if="onIssueItem"/> | ||||
|             <IssueVariants v-if="onIssueItem"/> | ||||
| @ -37,10 +38,18 @@ | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| import IssueStateSearch from "../components/IssueStateSearch.vue"; | ||||
| import IssueTable from "../components/server/IssueTable.vue"; | ||||
| import Issue from "../components/server/Issue.vue"; | ||||
| import IssueVariants from "../components/server/IssueVariants.vue"; | ||||
| import IssueVariant from "../components/server/IssueVariant.vue"; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const onIssueItemList = computed(() => store.state.onIssueItemList); | ||||
| const onIssueItem = computed(() => store.state.onIssueItem); | ||||
| const onIssueItemVariant = computed(() => store.state.onIssueItemVariant); | ||||
|  | ||||
| definePageMeta({ | ||||
|     layout: 'default' | ||||
| @ -48,10 +57,15 @@ definePageMeta({ | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| // to render the right components | ||||
| const onIssueItem = ref(false) | ||||
| const onIssueItemList = ref(true) | ||||
| const onIssueItemVariant = ref(false) | ||||
| const defaultIssueSlipPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToIssueSliplist') | ||||
| } | ||||
|  | ||||
| const defaultIssuePage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToIssueItemList') | ||||
| } | ||||
| </script> | ||||
|    | ||||
| <script> | ||||
| @ -123,4 +137,4 @@ export default { | ||||
|     margin-bottom: 0.625rem; | ||||
|     border-radius: 0.625rem; | ||||
| } | ||||
| </style> | ||||
| </style>../components/IssueStateSearch.vue | ||||
| @ -1,7 +1,8 @@ | ||||
| <template> | ||||
|   <section id="content"> | ||||
|     <div id="content-header"> | ||||
|       <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button"> | ||||
|       <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button" | ||||
|         @click="defaultMasterChecklistPage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name">Maintenance visits</h1> | ||||
|       </router-link> | ||||
|         | ||||
| @ -20,20 +21,21 @@ | ||||
|         | ||||
|         | ||||
|         | ||||
|       <router-link to="/productionOrders" class="button" id="productionOrders-button"> | ||||
|       <router-link to="/productionOrders" class="button" id="productionOrders-button" | ||||
|         @click="defaultMasterChecklistPage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Production orders</h1> | ||||
|       </router-link> | ||||
|     </div> | ||||
|     <div id="content-body"> | ||||
|       <ClientSearch v-if="onTemplatelist || onCustomerTemplatelist"/> | ||||
|       <MaintenanceVisitsTemplateTable v-if="onTemplatelist"/> | ||||
|       <MaintenanceVisitsTemplateTableNoClient v-if="onCustomerTemplatelist"/> | ||||
|       <MaintenanceVisitsTemplate v-if="onTemplate"/> | ||||
|       <TemplateChecklist v-if="onTemplate"/> | ||||
|       <TemplateSearch v-if="onInstancelist"/> | ||||
|       <MaintenanceVisitsInstanceTable v-if="onInstancelist"/> | ||||
|       <MaintenanceVisitsInstance v-if="onInstance"/> | ||||
|       <InstanceChecklist v-if="onInstance"/> | ||||
|       <ClientSearch v-if="onTemplatelist || onCustomerTemplatelist" /> | ||||
|       <MaintenanceVisitsTemplateTable v-if="onTemplatelist" /> | ||||
|       <MaintenanceVisitsTemplateTableNoClient v-if="onCustomerTemplatelist" /> | ||||
|       <MaintenanceVisitsTemplate v-if="onTemplate" /> | ||||
|       <TemplateChecklistMVT v-if="onTemplate" /> | ||||
|       <TemplateSearch v-if="onInstancelist" /> | ||||
|       <MaintenanceVisitsInstanceTable v-if="onInstancelist" /> | ||||
|       <MaintenanceVisitsInstance v-if="onInstance" /> | ||||
|       <InstanceChecklist v-if="onInstance" /> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
| @ -46,11 +48,20 @@ import ClientSearch from "../components/ClientSearch.vue"; | ||||
| import MaintenanceVisitsTemplateTable from "../components/server/MaintenanceVisitsTemplateTable.vue"; | ||||
| import MaintenanceVisitsTemplateTableNoClient from "../components/server/MaintenanceVisitsTemplateTableNoClient.vue"; | ||||
| import MaintenanceVisitsTemplate from "../components/server/MaintenanceVisitsTemplate.vue"; | ||||
| import TemplateChecklist from "../components/server/TemplateChecklist.vue"; | ||||
| import TemplateChecklistMVT from "../components/server/TemplateChecklistMVT.vue"; | ||||
| import TemplateSearch from "../components/TemplateSearch.vue"; | ||||
| import MaintenanceVisitsInstanceTable from "../components/server/MaintenanceVisitsInstanceTable.vue"; | ||||
| import MaintenanceVisitsInstance from "../components/server/MaintenanceVisitsInstance.vue"; | ||||
| import InstanceChecklist from "../components/server/InstanceChecklist.vue"; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const onTemplatelist = computed(() => store.state.onTemplatelist); | ||||
| const onCustomerTemplatelist = computed(() => store.state.onCustomerTemplatelist); | ||||
| const onTemplate = computed(() => store.state.onTemplate); | ||||
| const onInstancelist = computed(() => store.state.onInstancelist); | ||||
| const onInstance = computed(() => store.state.onInstance); | ||||
|  | ||||
| definePageMeta({ | ||||
|   layout: 'default' | ||||
| @ -58,12 +69,10 @@ definePageMeta({ | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| // to render the right components | ||||
| const onTemplatelist = ref(true) | ||||
| const onCustomerTemplatelist = ref(false) | ||||
| const onTemplate = ref(false) | ||||
| const onInstancelist = ref(false) | ||||
| const onInstance = ref(false) | ||||
| const defaultMasterChecklistPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToTemplatelist') | ||||
| } | ||||
| </script> | ||||
|      | ||||
| <script> | ||||
|  | ||||
| @ -1,7 +1,8 @@ | ||||
| <template> | ||||
|     <section id="content"> | ||||
|         <div id="content-header"> | ||||
|             <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button"> | ||||
|             <router-link to="/maintenanceVisits" class="button" id="maintenanceVisits-button" | ||||
|                 @click="defaultMasterChecklistPage"> | ||||
|                 <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Maintenance visits</h1> | ||||
|             </router-link> | ||||
|               | ||||
| @ -21,19 +22,20 @@ | ||||
|               | ||||
|               | ||||
|             <router-link to="/productionOrders" class="button" id="productionOrders-button"> | ||||
|                 <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name">Production orders</h1> | ||||
|                 <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="active-page-name" | ||||
|                     @click="defaultMasterChecklistPage()">Production orders</h1> | ||||
|             </router-link> | ||||
|         </div> | ||||
|         <div id="content-body"> | ||||
|             <ClientSearch v-if="onTemplatelist || onCustomerTemplatelist"/> | ||||
|             <ProductionOrdersTemplateTable v-if="onTemplatelist"/> | ||||
|             <ProductionOrdersTemplateTableNoClient v-if="onCustomerTemplatelist"/> | ||||
|             <ProductionOrdersTemplate v-if="onTemplate"/> | ||||
|             <TemplateChecklist v-if="onTemplate"/> | ||||
|             <TemplateSearch v-if="onInstancelist"/> | ||||
|             <ProductionOrdersInstanceTable v-if="onInstancelist"/> | ||||
|             <ProductionOrdersInstance v-if="onInstance"/> | ||||
|             <InstanceChecklist v-if="onInstance"/> | ||||
|             <ClientSearch v-if="onTemplatelist || onCustomerTemplatelist" /> | ||||
|             <ProductionOrdersTemplateTable v-if="onTemplatelist" /> | ||||
|             <ProductionOrdersTemplateTableNoClient v-if="onCustomerTemplatelist" /> | ||||
|             <ProductionOrdersTemplate v-if="onTemplate" /> | ||||
|             <TemplateChecklist v-if="onTemplate" /> | ||||
|             <TemplateSearch v-if="onInstancelist" /> | ||||
|             <ProductionOrdersInstanceTable v-if="onInstancelist" /> | ||||
|             <ProductionOrdersInstance v-if="onInstance" /> | ||||
|             <InstanceChecklist v-if="onInstance" /> | ||||
|         </div> | ||||
|     </section> | ||||
| </template> | ||||
| @ -66,6 +68,11 @@ definePageMeta({ | ||||
| }) | ||||
|  | ||||
| const darkMode = ref(true) | ||||
|  | ||||
| const defaultMasterChecklistPage = () => { | ||||
|     store.commit('resetStore'); | ||||
|     store.commit('changeToTemplatelist') | ||||
| } | ||||
| </script> | ||||
|    | ||||
| <script> | ||||
|  | ||||
| @ -1,19 +1,20 @@ | ||||
| <template> | ||||
|   <section id="content"> | ||||
|     <div id="content-header"> | ||||
|       <router-link to="/solutions" class="button" id="solutions-button" @click="defaultSolutionPage()"> | ||||
|         <h1 :class="[darkMode ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Solutions</h1> | ||||
|       </router-link> | ||||
|     </div> | ||||
|     <div id="content-body"> | ||||
|       <ClientSearch v-if="onSolutionlist || onCustomerSolutionlist"/> | ||||
|       <SolutionTable v-if="onSolutionlist"/> | ||||
|       <SolutionTableNoClient v-if="onCustomerSolutionlist"/> | ||||
|       <Solution v-if="onSolution"/> | ||||
|       <SolutionChecklist v-if="onSolution"/> | ||||
|       <ClientSearch v-if="onSolutionlist || onCustomerSolutionlist" /> | ||||
|       <SolutionTable v-if="onSolutionlist" /> | ||||
|       <SolutionTableNoClient v-if="onCustomerSolutionlist" /> | ||||
|       <Solution v-if="onSolution" /> | ||||
|       <SolutionChecklist v-if="onSolution" /> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| @ -22,17 +23,24 @@ import SolutionTable from "../components/server/SolutionTable.vue"; | ||||
| import SolutionTableNoClient from "../components/server/SolutionTableNoClient.vue"; | ||||
| import Solution from "../components/server/Solution.vue"; | ||||
| import SolutionChecklist from "../components/server/SolutionChecklist.vue"; | ||||
| import { useStore } from 'vuex'; | ||||
| import { computed } from 'vue'; | ||||
|  | ||||
| const store = useStore(); | ||||
| const onSolutionlist = computed(() => store.state.onSolutionlist); | ||||
| const onCustomerSolutionlist = computed(() => store.state.onCustomerSolutionlist); | ||||
| const onSolution = computed(() => store.state.onSolution); | ||||
|  | ||||
| definePageMeta({ | ||||
|   layout: 'default' | ||||
| }) | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| const defaultSolutionPage = () => { | ||||
|   store.commit('resetStore'); | ||||
|   store.commit('changeToSolutionlist') | ||||
| } | ||||
|  | ||||
| // to render the right components | ||||
| const onSolutionlist = ref(true) | ||||
| const onCustomerSolutionlist = ref(false) | ||||
| const onSolution = ref(false) | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| @ -93,4 +101,8 @@ export default { | ||||
|   margin-bottom: 0.625rem; | ||||
|   border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .button { | ||||
|   text-decoration: none; | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										291
									
								
								plugins/vuex.js
									
									
									
									
									
								
							
							
						
						
									
										291
									
								
								plugins/vuex.js
									
									
									
									
									
								
							| @ -45,6 +45,7 @@ const store = createStore({ | ||||
|             onTemplate: false, | ||||
|             onInstancelist: false, | ||||
|             onInstance: false, | ||||
|  | ||||
|             newNamePOT: '', | ||||
|             newCustomerIDPOT: '', | ||||
|             newCustomerPOT: '', | ||||
| @ -54,6 +55,69 @@ const store = createStore({ | ||||
|             newNotesPOT: '', | ||||
|             chosenPOTId: -1, | ||||
|  | ||||
|             newNameMVT: '', | ||||
|             newCustomerIDMVT: '', | ||||
|             newCustomerMVT: '', | ||||
|             newLastViewMVT: '', | ||||
|             newUserMVT: '', | ||||
|             newTypeMVT: '', | ||||
|             newNotesMVT: '', | ||||
|             chosenMVTId: -1, | ||||
|  | ||||
|             onSolutionlist: true, | ||||
|             onCustomerSolutionlist: false, | ||||
|             onSolution: false, | ||||
|             chosenSolutionId: -1, | ||||
|             newSolutionNameSol: '', | ||||
|             newCustomerIDSol: '', | ||||
|             newCustomerSol: '', | ||||
|             newAssetNameSol: '', | ||||
|             newTypeSol: '', | ||||
|             newLastViewSol: '', | ||||
|             newUserSol: '', | ||||
|             newDescriptionSol: '', | ||||
|             newNotesSol: '', | ||||
|  | ||||
|             onIssueSliplist: true, | ||||
|             onCustomerIssueSliplist: false, | ||||
|             onIssueSlip: false, | ||||
|             chosenIssueSlipId: -1, | ||||
|             newTicketNoIS: '', | ||||
|             newCustomerIdIS: '', | ||||
|             newCustomerIS: '', | ||||
|             newNotesIS: '', | ||||
|             newUserIS: '', | ||||
|             newDeliveryAddressIS: '', | ||||
|             newOIs: [], | ||||
|             newSupplierRequestDateIS: '', | ||||
|             newSupplierRequestIS: '', | ||||
|             newSupplierOfferDateIS: '', | ||||
|             newSupplierOfferIS: '', | ||||
|             newClientOfferDateIS: '', | ||||
|             newClientOfferIS: '', | ||||
|             newClientOrderDateIS: '', | ||||
|             newClientOrderIS: '', | ||||
|             newSupplierOrderDateIS: '', | ||||
|             newSupplierOrderIS: '', | ||||
|             newIngressDateIS: '', | ||||
|             newIngressIS: '', | ||||
|             newEgressDateIS: '', | ||||
|             newEgressIS: '', | ||||
|             newIngressBillDateIS: '', | ||||
|             newIngressBillIS: '', | ||||
|             newEgressBillDateIS: '', | ||||
|             newEgressBillIS: '', | ||||
|  | ||||
|             onIssueItemList: true, | ||||
|             onIssueItem: false, | ||||
|             onIssueItemVariant: false, | ||||
|             chosenIssueId: -1, | ||||
|             newNameII: '', | ||||
|             newTypeII: '', | ||||
|             newStateII: '', | ||||
|             newAmountII: '', | ||||
|             newPropertiesII: '', | ||||
|             chosenIssueVariantId: -1, | ||||
|         }; | ||||
|     }, | ||||
|     mutations: { | ||||
| @ -112,7 +176,7 @@ const store = createStore({ | ||||
|             state.onSolutionlistAsset = true | ||||
|         }, | ||||
|  | ||||
|         // functions to change the production order pages | ||||
|         // functions to change the production order and maintenance visit pages | ||||
|         changeToTemplatelist(state) { | ||||
|             state.onTemplatelist = true | ||||
|             state.onCustomerTemplatelist = false | ||||
| @ -149,6 +213,57 @@ const store = createStore({ | ||||
|             state.onInstance = true | ||||
|         }, | ||||
|  | ||||
|         // functions to change the solution pages | ||||
|         changeToSolutionlist(state) { | ||||
|             state.onSolutionlist = true | ||||
|             state.onCustomerSolutionlist = false | ||||
|             state.onSolution = false | ||||
|         }, | ||||
|         changeToCustomerSolutionlist(state) { | ||||
|             state.onSolutionlist = false | ||||
|             state.onCustomerSolutionlist = true | ||||
|             state.onSolution = false | ||||
|         }, | ||||
|         changeToSolution(state) { | ||||
|             state.onSolutionlist = false | ||||
|             state.onCustomerSolutionlist = false | ||||
|             state.onSolution = true | ||||
|         }, | ||||
|  | ||||
|         // functions to change the issue slip pages | ||||
|         changeToIssueSliplist(state) { | ||||
|             state.onIssueSliplist = true | ||||
|             state.onCustomerIssueSliplist = false | ||||
|             state.onIssueSlip = false | ||||
|         }, | ||||
|         changeToCustomerIssueSliplist(state) { | ||||
|             state.onIssueSliplist = false | ||||
|             state.onCustomerIssueSliplist = true | ||||
|             state.onIssueSlip = false | ||||
|         }, | ||||
|         changeToIssueSlip(state) { | ||||
|             state.onIssueSliplist = false | ||||
|             state.onCustomerIssueSliplist = false | ||||
|             state.onIssueSlip = true | ||||
|         }, | ||||
|  | ||||
|         // functions to change the issue pages | ||||
|         changeToIssueItemList(state) { | ||||
|             state.onIssueItemList = true | ||||
|             state.onIssueItem = false | ||||
|             state.onIssueItemVariant = false | ||||
|         }, | ||||
|         changeToIssueItem(state) { | ||||
|             state.onIssueItemList = false | ||||
|             state.onIssueItem = true | ||||
|             state.onIssueItemVariant = false | ||||
|         }, | ||||
|         changeToIssueItemVariant(state) { | ||||
|             state.onIssueItemList = false | ||||
|             state.onIssueItem = false | ||||
|             state.onIssueItemVariant = true | ||||
|         }, | ||||
|  | ||||
|         // functions to update the asset | ||||
|         updateAssetComponent(state, asset) { | ||||
|             state.newAssetName = asset.assetName | ||||
| @ -187,6 +302,75 @@ const store = createStore({ | ||||
|             state.newNotesPOT = pot.notes | ||||
|         }, | ||||
|  | ||||
|         // functions to update the maintenance visit template | ||||
|         updateMaintenanceVisitTemplateComponent(state, mvt) { | ||||
|             state.newNameMVT = mvt.name | ||||
|             state.newCustomerIDMVT = mvt.customerId | ||||
|             state.newCustomerMVT = mvt.customer | ||||
|             state.newUserMVT = mvt.user | ||||
|             state.newTypeMVT = mvt.type | ||||
|             state.newNotesMVT = mvt.notes | ||||
|         }, | ||||
|  | ||||
|         // functions to update the solution | ||||
|         updateSolutionComponent(state, sol) { | ||||
|             state.newSolutionNameSol = sol.solutionName | ||||
|             state.newCustomerIDSol = sol.customerId | ||||
|             state.newCustomerSol = sol.customer | ||||
|             state.newAssetNameSol = sol.assetName | ||||
|             state.newLastViewSol = sol.lastView | ||||
|             state.newTypeSol = sol.type | ||||
|             state.newDescriptionSol = sol.description | ||||
|             state.newNotesSol = sol.notes | ||||
|             state.newUserSol = sol.user | ||||
|         }, | ||||
|  | ||||
|         // functions to update the issue slip component | ||||
|         updateIssueSlipComponent(state, is) { | ||||
|             state.newTicketNoIS = is.ticketNo | ||||
|             state.newCustomerIdIS = is.customerId | ||||
|             state.newCustomerIS = is.customer | ||||
|             state.newNotesIS = is.notes | ||||
|             state.newUserIS = is.user | ||||
|             state.newDeliveryAddressIS = is.deliveryAddress | ||||
|         }, | ||||
|          | ||||
|         // functions to update the accounting info component | ||||
|         updateOrderingInfoComponent(state, o) { | ||||
|             state.newOIs = o.ois | ||||
|         }, | ||||
|  | ||||
|         // functions to update the accounting component | ||||
|         updateAccountingComponent(state, is) { | ||||
|             state.newSupplierRequestDateIS = is.supplierRequestDate | ||||
|             state.newSupplierRequestIS = is.supplierRequest | ||||
|             state.newSupplierOfferDateIS = is.supplierOfferDate | ||||
|             state.newSupplierOfferIS = is.supplierOffer | ||||
|             state.newClientOfferDateIS = is.clientOfferDate | ||||
|             state.newClientOfferIS = is.clientOffer | ||||
|             state.newClientOrderDateIS = is.clientOrderDate | ||||
|             state.newClientOrderIS = is.clientOrder | ||||
|             state.newSupplierOrderDateIS = is.supplierOrderDate | ||||
|             state.newSupplierOrderIS = is.supplierOrder | ||||
|             state.newIngressDateIS = is.ingressDate | ||||
|             state.newIngressIS = is.ingress | ||||
|             state.newEgressDateIS = is.egressDate | ||||
|             state.newEgressIS = is.egress | ||||
|             state.newIngressBillDateIS = is.ingressBillDate | ||||
|             state.newIngressBillIS = is.ingressBill | ||||
|             state.newEgressBillDateIS = is.egressBillDate | ||||
|             state.newEgressBillIS = is.egressBill | ||||
|         }, | ||||
|  | ||||
|         // functions to update the issue component | ||||
|         updateIssueComponent(state, is) { | ||||
|             state.newNameII = is.name | ||||
|             state.newTypeII = is.type | ||||
|             state.newStateII = is.state | ||||
|             state.newAmountII = is.amount | ||||
|             state.newPropertiesII = is.properties | ||||
|         }, | ||||
|  | ||||
|         // function to set the chosen asset | ||||
|         setChosenAsset(state, id) { | ||||
|             state.chosenAssetId = id | ||||
| @ -197,6 +381,31 @@ const store = createStore({ | ||||
|             state.chosenPOTId = id | ||||
|         }, | ||||
|  | ||||
|         // function to set the chosen maintenance visit template | ||||
|         setChosenMVT(state, id) { | ||||
|             state.chosenMVTId = id | ||||
|         }, | ||||
|  | ||||
|         // function to set the chosen solution | ||||
|         setChosenSolution(state, id) { | ||||
|             state.chosenSolutionId = id | ||||
|         }, | ||||
|  | ||||
|         // function to set the chosen issue slip | ||||
|         setChosenIssueSlip(state, id) { | ||||
|             state.chosenIssueSlipId = id | ||||
|         }, | ||||
|  | ||||
|         // function to set the chosen issue | ||||
|         setChosenIssue(state, id) { | ||||
|             state.chosenIssueId = id | ||||
|         }, | ||||
|  | ||||
|          // function to set the chosen issue variant | ||||
|          setChosenIssueVariant(state, id) { | ||||
|             state.chosenIssueVariantId = id | ||||
|         }, | ||||
|  | ||||
|         // function to reset the pages | ||||
|         resetStore(state) { | ||||
|             state.editable = false | ||||
| @ -237,10 +446,70 @@ const store = createStore({ | ||||
|             state.newNamePOT = '' | ||||
|             state.newCustomerIDPOT = '' | ||||
|             state.newCustomerPOT = '' | ||||
|             state.newUserPOT = false | ||||
|             state.newUserPOT = '' | ||||
|             state.newDescriptionPOT = '' | ||||
|             state.newNotesPOT = '' | ||||
|             state.newLastViewPOT = '' | ||||
|             state.chosenPOTId = -1 | ||||
|  | ||||
|             // reset the maintenance visit template page variables | ||||
|             state.newNameMVT = '' | ||||
|             state.newCustomerIDMVT = '' | ||||
|             state.newCustomerMVT = '' | ||||
|             state.newUserMVT = '' | ||||
|             state.newTypeMVT = '' | ||||
|             state.newNotesMVT = '' | ||||
|             state.newLastViewMVT = '' | ||||
|             state.chosenMVTId = -1 | ||||
|  | ||||
|             // reset the solution page variables | ||||
|             state.newSolutionNameSol = '' | ||||
|             state.newCustomerIDSol = '' | ||||
|             state.newCustomerSol = '' | ||||
|             state.newAssetNameSol = '' | ||||
|             state.newLastViewSol = '' | ||||
|             state.newTypeSol = '' | ||||
|             state.newDescriptionSol = '' | ||||
|             state.newNotesSol = '' | ||||
|             state.newUserSol = '' | ||||
|             state.chosenSolutionId = -1 | ||||
|  | ||||
|             // reset the issue slip page variables | ||||
|             state.chosenIssueSlipId = -1 | ||||
|             state.newCustomerIdIS = '' | ||||
|             state.newCustomerIS = '' | ||||
|             state.newTicketNoIS = '' | ||||
|             state.newNotesIS = '' | ||||
|             state.newUserIS = '' | ||||
|             state.newOIs = [] | ||||
|             state.newDeliveryAddressIS = '' | ||||
|             state.newSupplierRequestIS = '' | ||||
|             state.newSupplierOfferIS = '' | ||||
|             state.newClientOfferIS = '' | ||||
|             state.newClientOrderIS = '' | ||||
|             state.newSupplierOrderIS = '' | ||||
|             state.newIngressIS = '' | ||||
|             state.newEgressIS = '' | ||||
|             state.newIngressBillIS = '' | ||||
|             state.newEgressBillIS = '' | ||||
|             state.newSupplierRequestDateIS = '' | ||||
|             state.newSupplierOfferDateIS = '' | ||||
|             state.newClientOfferDateIS = '' | ||||
|             state.newClientOrderDateIS = '' | ||||
|             state.newSupplierOrderDateIS = '' | ||||
|             state.newIngressDateIS = '' | ||||
|             state.newEgressDateIS = '' | ||||
|             state.newIngressBillDateIS = '' | ||||
|             state.newEgressBillDateIS = '' | ||||
|  | ||||
|             // reset the issue page variables | ||||
|             state.chosenIssueId = -1 | ||||
|             state.chosenIssueVariantId = -1 | ||||
|             state.newNameII = '' | ||||
|             state.newTypeII = '' | ||||
|             state.newStateII = '' | ||||
|             state.newAmountII = '' | ||||
|             state.newPropertiesII = '' | ||||
|         }, | ||||
|  | ||||
|         // functions to (undo) delete an asset | ||||
| @ -269,14 +538,28 @@ const store = createStore({ | ||||
|             state.onAsset = true | ||||
|             state.onSolutionlistAsset = false | ||||
|  | ||||
|             // set the production order variables | ||||
|             // set the production order and maintenance visit variables | ||||
|             state.onTemplatelist = false | ||||
|             state.onCustomerTemplatelist = false | ||||
|             state.onTemplate = true | ||||
|             state.onInstancelist = false | ||||
|             state.onInstance = false | ||||
|         }, | ||||
|  | ||||
|             // set the solution variables | ||||
|             state.onSolutionlist = false | ||||
|             state.onCustomerSolutionlist = false | ||||
|             state.onSolution = true | ||||
|  | ||||
|             // set the issue slips variables | ||||
|             state.onIssueSliplist = false | ||||
|             state.onCustomerIssueSliplist = false | ||||
|             state.onIssueSlip = true | ||||
|  | ||||
|             // set the issue variables | ||||
|             state.onIssueItemList = false | ||||
|             state.onIssueItemVariant = false | ||||
|             state.onIssueItem = true | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
|  | ||||
|  | ||||
							
								
								
									
										22
									
								
								server/api/addII.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addII.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { insertId, errorMsg } from "../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return insertId | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/addIssueSlip.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addIssueSlip.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { insertId, errorMsg } from "../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return insertId | ||||
| }) | ||||
							
								
								
									
										21
									
								
								server/api/addIssueVariant.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								server/api/addIssueVariant.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| import { errorMsg } from "../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/addMVT.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addMVT.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { insertId, errorMsg } from "../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return insertId | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/addOrderingInfo.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addOrderingInfo.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/addSol.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addSol.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { insertId, 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return insertId | ||||
| }) | ||||
							
								
								
									
										21
									
								
								server/api/addTodoMVT.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								server/api/addTodoMVT.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| import { errorMsg } from "../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
| }) | ||||
							
								
								
									
										21
									
								
								server/api/addTodoSol.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								server/api/addTodoSol.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| import { 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteIV/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteIV/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteIssueItem/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteIssueItem/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteIssueSlip/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteIssueSlip/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteIssueVariant/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteIssueVariant/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteMVTTodo/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteMVTTodo/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteOrderingInfo/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteOrderingInfo/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return  | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteSolTodo/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteSolTodo/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteTodosMVT/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteTodosMVT/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteTodosOI/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteTodosOI/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteTodosSol/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteTodosSol/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/deleteTodosSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/deleteTodosSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getAllIssueVariants.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getAllIssueVariants.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { allIssueVariants, errorMsg } from "../middleware/issues"; | ||||
| 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': 'GET,HEAD,PUT,PATCH,POST,DELETE', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return allIssueVariants | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getIVs/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getIVs/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { issueVariants, errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return issueVariants | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getIssueItem/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getIssueItem/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { issue, errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return issue | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getIssueSlip/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getIssueSlip/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { issueSlip, errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return issueSlip | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getIssueVariant/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getIssueVariant/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { issueVariant, errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return issueVariant | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { mvt, errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return mvt | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getOrderingInfo/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getOrderingInfo/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { orderingInfo, errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return orderingInfo | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedIssueSlipsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedIssueSlipsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedIssueSlipsByClient, errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedIssueSlipsByClient | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedIssueSlipsByTicketNo/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedIssueSlipsByTicketNo/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedIssueSlipsByTicketNo, errorMsg } from "../../middleware/issueSlips"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedIssueSlipsByTicketNo | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedIssuesByIssueName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedIssuesByIssueName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedIssuesByIssueName, errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedIssuesByIssueName | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedIssuesByState/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedIssuesByState/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedIssuesByState, errorMsg } from "../../middleware/issues"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedIssuesByState | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedMVTsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedMVTsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedMVTsByClient, errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedMVTsByClient | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedMVTsByMVT/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedMVTsByMVT/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedMVTsByMVT, errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedMVTsByMVT | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedSolutionsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedSolutionsByClient/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedSolutionsByClient, 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedSolutionsByClient | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSelectedSolutionsBySolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSelectedSolutionsBySolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { selectedSolutionsBySolution, 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return selectedSolutionsBySolution | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { solution, 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return solution | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getTodosMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getTodosMaintenanceVisitTemplate/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { mvtTodosByTemplateId, errorMsg } from "../../middleware/maintenanceVisitTemplates"; | ||||
| 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return mvtTodosByTemplateId | ||||
| }) | ||||
							
								
								
									
										22
									
								
								server/api/getTodosSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/getTodosSolution/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import { solTodosBySolutionId, 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', | ||||
|     }; | ||||
|     setResponseHeaders(event, headers) | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return solTodosBySolutionId | ||||
| }) | ||||
| @ -10,4 +10,5 @@ export default defineEventHandler(async (event) => { | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return errorMsg | ||||
| }) | ||||
|  | ||||
							
								
								
									
										14
									
								
								server/api/updateIssueItem.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateIssueItem.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| import { errorMsg } from "../middleware/issues"; | ||||
|  | ||||
| export default defineEventHandler(async (event) => { | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return errorMsg | ||||
| }) | ||||
							
								
								
									
										14
									
								
								server/api/updateIssueSlip.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateIssueSlip.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| import { errorMsg } from "../middleware/issueSlips"; | ||||
|  | ||||
| export default defineEventHandler(async (event) => { | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return errorMsg | ||||
| }) | ||||
							
								
								
									
										14
									
								
								server/api/updateIssueVariant.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateIssueVariant.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| import { errorMsg } from "../middleware/issues"; | ||||
|  | ||||
| export default defineEventHandler(async (event) => { | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return errorMsg | ||||
| }) | ||||
							
								
								
									
										14
									
								
								server/api/updateMVTTodo.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateMVTTodo.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| import { errorMsg } from "../middleware/maintenanceVisitTemplates"; | ||||
|  | ||||
| export default defineEventHandler(async (event) => { | ||||
|  | ||||
|     if (!(errorMsg === '')) { | ||||
|         throw createError({ | ||||
|             statusCode: 400, | ||||
|             statusMessage: errorMsg, | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     setResponseStatus(event, 200) | ||||
|     return errorMsg | ||||
| }) | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user