Merge pull request 'finished customer pages' (#26) from clientPages into main
Reviewed-on: jo.kuehner/TueIT_App#26
This commit is contained in:
		
							
								
								
									
										89
									
								
								backend/controller/departments.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								backend/controller/departments.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,89 @@ | |||||||
|  | import { | ||||||
|  |     getDepartmentById, | ||||||
|  |     getDepartmentsByCustomerId, | ||||||
|  |     updateDepartmentById, | ||||||
|  |     insertDepartment, | ||||||
|  |     getSelectedDepartmentsByName, | ||||||
|  |     deleteDepartmentById, | ||||||
|  |     getDepartmentByName | ||||||
|  | } from "../models/departmentsModel.js"; | ||||||
|  |  | ||||||
|  | //get single department by id | ||||||
|  | export const showDepartmentById = (req, res) => { | ||||||
|  |     getDepartmentById(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get single department by name | ||||||
|  | export const showDepartmentByName = (req, res) => { | ||||||
|  |     getDepartmentByName(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get departments by customer id | ||||||
|  | export const showDepartmentByCustomerId = (req, res) => { | ||||||
|  |     getDepartmentsByCustomerId(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Update department | ||||||
|  | export const updateDepartment = (req, res) => { | ||||||
|  |     const data = req.body; | ||||||
|  |     updateDepartmentById(data, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //create new department | ||||||
|  | export const createDepartment = (req, res) => { | ||||||
|  |     const data = req.body; | ||||||
|  |     insertDepartment(data, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected departments by name | ||||||
|  | export const showSelectedDepartmentsByName = (req, res) => { | ||||||
|  |     getSelectedDepartmentsByName(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Delete department | ||||||
|  | export const deleteDepartment = (req, res) => { | ||||||
|  |     const id = req.params.id; | ||||||
|  |     deleteDepartmentById(id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
							
								
								
									
										101
									
								
								backend/controller/employees.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								backend/controller/employees.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,101 @@ | |||||||
|  | import { | ||||||
|  |     getEmployeeById, | ||||||
|  |     getEmployeesByCustomerId, | ||||||
|  |     updateEmployeeById, | ||||||
|  |     insertEmployee, | ||||||
|  |     getSelectedEmployeesByName, | ||||||
|  |     deleteEmployeeById, | ||||||
|  |     getSelectedEmployeesByDepartment, | ||||||
|  |     getSelectedEmployeesByDepartmentName, | ||||||
|  | } from "../models/employeesModel.js"; | ||||||
|  |  | ||||||
|  | //get single employee by id | ||||||
|  | export const showEmployeeById = (req, res) => { | ||||||
|  |     getEmployeeById(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get employees by customer id | ||||||
|  | export const showEmployeeByCustomerId = (req, res) => { | ||||||
|  |     getEmployeesByCustomerId(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get employees by customer id | ||||||
|  | export const showEmployeeByDepartmentId = (req, res) => { | ||||||
|  |     getSelectedEmployeesByDepartment(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Update employee | ||||||
|  | export const updateEmployee = (req, res) => { | ||||||
|  |     const data = req.body; | ||||||
|  |     updateEmployeeById(data, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //create new employee | ||||||
|  | export const createEmployee = (req, res) => { | ||||||
|  |     const data = req.body; | ||||||
|  |     insertEmployee(data, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected employees by name | ||||||
|  | export const showSelectedEmployeesByName = (req, res) => { | ||||||
|  |     getSelectedEmployeesByName(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected employees by name | ||||||
|  | export const showSelectedEmployeesByDepartmentName = (req, res) => { | ||||||
|  |     getSelectedEmployeesByDepartmentName(req.params.id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Delete employee | ||||||
|  | export const deleteEmployee = (req, res) => { | ||||||
|  |     const id = req.params.id; | ||||||
|  |     deleteEmployeeById(id, (err, results) => { | ||||||
|  |         if (err) { | ||||||
|  |             res.send(err); | ||||||
|  |         } else { | ||||||
|  |             res.json(results); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }; | ||||||
| @ -56,7 +56,7 @@ export const getConfigItemByCustomerId = async (customerId, result) => { | |||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Update customer to Database | // Update config item to Database | ||||||
| export const updateConfigItemById = async (data, result) => { | export const updateConfigItemById = async (data, result) => { | ||||||
|   const id = data.primaryID; |   const id = data.primaryID; | ||||||
|   try { |   try { | ||||||
|  | |||||||
| @ -63,7 +63,8 @@ export const getCustomerByMaintenanceVisitId = async (id, result) => { | |||||||
| //insert customer to databased | //insert customer to databased | ||||||
| export const insertCustomer = async (data, result) => { | export const insertCustomer = async (data, result) => { | ||||||
|     try { |     try { | ||||||
|         const results = await ownConn.query(`INSERT INTO customers(customername, contactperson, EMail, phonenumber, address, postcode, city, notes) VALUES(?, ?, ?, ?, ?, ?, ?, ?)`, [data.customername, data.contactperson, data.EMail, data.phonenumber, data.address, data.postcode, data.city, data.notes]) |         const results = await ownConn.query(`INSERT INTO customers(customername, contactperson, EMail, secondEMail, thirdEMail, phonenumber, secondPhonenumber, thirdPhonenumber, street, no, postcode, city, secondStreet, secondNo, secondPostcode, secondCity, thirdStreet, thirdNo, thirdPostcode, thirdCity, notes) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [data.customername, data.contactperson, data.EMail, data.secondEMail, data.thirdEMail, data.phonenumber, data.secondPhonenumber, data.thirdPhonenumber, data.street, data.no,  data.postcode, data.city, data.secondStreet, data.secondNo, data.secondPostcode, data.secondCity, data.thirdStreet, data.thirdNo, data.thirdPostcode, data.thirdCity, data.notes]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|         result(null, results); |         result(null, results); | ||||||
|     } |     } | ||||||
|     catch (err) { |     catch (err) { | ||||||
| @ -105,8 +106,9 @@ export const getCustomerByName = async (id, result) => { | |||||||
| export const updateCustomerById = async (data, result) => { | export const updateCustomerById = async (data, result) => { | ||||||
|     const id = data.customerID; |     const id = data.customerID; | ||||||
|     try { |     try { | ||||||
|         let sql = `UPDATE customers SET customername = ?, contactperson = ?, EMail = ?, phonenumber = ?, address = ?,  postcode = ?, city = ?, notes = ? WHERE customerID = ?`; |         let sql = `UPDATE customers SET customername = ?, contactperson = ?, EMail = ?, secondEMail = ?, thirdEMail = ?, phonenumber = ?, secondPhonenumber = ?, thirdPhonenumber = ?, street = ?, no = ?, postcode = ?, city = ?, secondStreet = ?, secondNo = ?, secondPostcode = ?, secondCity = ?, thirdStreet = ?, thirdNo = ?, thirdPostcode = ?, thirdCity = ?,  notes = ? WHERE customerID = ?`; | ||||||
|         const results = await ownConn.query(sql, [data.customername, data.contactperson, data.EMail, data.phonenumber, data.address, data.postcode, data.city, data.notes, id]); |         const results = await ownConn.query(sql, [data.customername, data.contactperson, data.EMail, data.secondEMail, data.thirdEMail, data.phonenumber, data.secondPhonenumber, data.thirdPhonenumber, data.street, data.no,  data.postcode, data.city, data.secondStreet, data.secondNo, data.secondPostcode, data.secondCity, data.thirdStreet, data.thirdNo, data.thirdPostcode, data.thirdCity, data.notes, id]); | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|         result(null, results); |         result(null, results); | ||||||
|     } |     } | ||||||
|     catch (err) { |     catch (err) { | ||||||
| @ -122,6 +124,7 @@ export const deleteCustomerById = async (id, result) => { | |||||||
|     try { |     try { | ||||||
|         let sql = `DELETE FROM customers WHERE customerID = ?`; |         let sql = `DELETE FROM customers WHERE customerID = ?`; | ||||||
|         const results = await ownConn.query(sql, [id]) |         const results = await ownConn.query(sql, [id]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|         result(null, results); |         result(null, results); | ||||||
|     } |     } | ||||||
|     catch (err) { |     catch (err) { | ||||||
|  | |||||||
							
								
								
									
										102
									
								
								backend/models/departmentsModel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								backend/models/departmentsModel.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,102 @@ | |||||||
|  | import ownConn from "../dbConfig.js"; | ||||||
|  |  | ||||||
|  | //get single department by id | ||||||
|  | export const getDepartmentById = async (id, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customerdepartment WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.execute(sql, [id]) | ||||||
|  |         result(null, results[0]); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get departments by customer id | ||||||
|  | export const getDepartmentsByCustomerId = async (customerId, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customerdepartment WHERE customerID = ? ORDER BY name ASC`; | ||||||
|  |         const results = await ownConn.query(sql, [customerId]) | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Update department to Database | ||||||
|  | export const updateDepartmentById = async (data, result) => { | ||||||
|  |     const id = data.primaryID; | ||||||
|  |     try { | ||||||
|  |         let sql = `UPDATE customerdepartment SET name = ?, head = ?, notes = ? WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.query(sql, [data.name, data.head, data.notes, id]); | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //insert department to databased | ||||||
|  | export const insertDepartment = async (data, result) => { | ||||||
|  |     try { | ||||||
|  |         const results = await ownConn.query(`INSERT INTO customerdepartment(customerID, customername, name, head, notes) VALUES(?, ?, ?, ?, ?)`, [data.customerID, data.customername, data.name, data.head, data.notes]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected departments by name | ||||||
|  | export const getSelectedDepartmentsByName = async (selected, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customerdepartment WHERE LOWER(name) LIKE '%${selected.toLowerCase()}%' ORDER BY name ASC`; | ||||||
|  |         const results = await ownConn.execute(sql) | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Delete department to Database | ||||||
|  | export const deleteDepartmentById = async (id, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `DELETE FROM customerdepartment WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.query(sql, [id]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get single department by name | ||||||
|  | export const getDepartmentByName = async (id, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customerdepartment  WHERE name = ?`; | ||||||
|  |         const results = await ownConn.execute(sql, [id]) | ||||||
|  |         result(null, results[0]); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
							
								
								
									
										116
									
								
								backend/models/employeesModel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								backend/models/employeesModel.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,116 @@ | |||||||
|  | import ownConn from "../dbConfig.js"; | ||||||
|  |  | ||||||
|  | //get single employee by id | ||||||
|  | export const getEmployeeById = async (id, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customeremployees WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.execute(sql, [id]) | ||||||
|  |         result(null, results[0]); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get employees by customer id | ||||||
|  | export const getEmployeesByCustomerId = async (customerId, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customeremployees WHERE customerID = ? ORDER BY name ASC`; | ||||||
|  |         const results = await ownConn.query(sql, [customerId]) | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Update employee to Database | ||||||
|  | export const updateEmployeeById = async (data, result) => { | ||||||
|  |     const id = data.primaryID; | ||||||
|  |     try { | ||||||
|  |         let sql = `UPDATE customeremployees SET name = ?, pronouns = ?, title = ?, firstName = ?, lastName = ?, preferredName = ?, department = ?, departmentID = ?, jobTitle = ?, phonenumber = ?, eMail = ?, notes = ? WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.query(sql, [data.name, data.pronouns, data.title, data.firstName, data.lastName, data.preferredName, data.department, data.departmentID, data.jobTitle, data.phonenumber, data.eMail, data.notes, id]); | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //insert employee to databased | ||||||
|  | export const insertEmployee = async (data, result) => { | ||||||
|  |     try { | ||||||
|  |         const results = await ownConn.query(`INSERT INTO customeremployees(customerID, customername, name, pronouns, title, firstName, lastName, preferredName, department, departmentID, jobTitle, phonenumber, eMail, notes) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [data.customerID, data.customername, data.name, data.pronouns, data.title, data.firstName, data.lastName, data.preferredName, data.department, data.departmentID, data.jobTitle, data.phonenumber, data.eMail, data.notes]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected employees by name | ||||||
|  | export const getSelectedEmployeesByName = async (selected, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customeremployees WHERE LOWER(name) LIKE '%${selected.toLowerCase()}%' ORDER BY name ASC`; | ||||||
|  |         const results = await ownConn.execute(sql) | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get all selected employees by department name | ||||||
|  | export const getSelectedEmployeesByDepartmentName = async (selected, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customeremployees WHERE LOWER(department) LIKE '%${selected.toLowerCase()}%' ORDER BY department 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 employees by departmentID | ||||||
|  | export const getSelectedEmployeesByDepartment = async (selected, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `SELECT * FROM customeremployees WHERE departmentID = ? 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); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Delete employee to Database | ||||||
|  | export const deleteEmployeeById = async (id, result) => { | ||||||
|  |     try { | ||||||
|  |         let sql = `DELETE FROM customeremployees WHERE primaryID = ?`; | ||||||
|  |         const results = await ownConn.query(sql, [id]) | ||||||
|  |         results.insertId = results.insertId.toString(); | ||||||
|  |         result(null, results); | ||||||
|  |     } | ||||||
|  |     catch (err) { | ||||||
|  |         // Manage Errors | ||||||
|  |         console.log("SQL error : ", err); | ||||||
|  |         result(err, null); | ||||||
|  |     } | ||||||
|  | }; | ||||||
| @ -113,6 +113,27 @@ import { | |||||||
|     deleteCustomer, |     deleteCustomer, | ||||||
| } from "../controller/customers.js"; | } from "../controller/customers.js"; | ||||||
|  |  | ||||||
|  | import { | ||||||
|  |     showDepartmentById, | ||||||
|  |     showDepartmentByCustomerId, | ||||||
|  |     updateDepartment, | ||||||
|  |     createDepartment, | ||||||
|  |     showSelectedDepartmentsByName, | ||||||
|  |     deleteDepartment, | ||||||
|  |     showDepartmentByName | ||||||
|  | } from "../controller/departments.js"; | ||||||
|  |  | ||||||
|  | import { | ||||||
|  |     showEmployeeById, | ||||||
|  |     showEmployeeByCustomerId, | ||||||
|  |     showEmployeeByDepartmentId, | ||||||
|  |     updateEmployee, | ||||||
|  |     createEmployee, | ||||||
|  |     showSelectedEmployeesByName, | ||||||
|  |     showSelectedEmployeesByDepartmentName, | ||||||
|  |     deleteEmployee, | ||||||
|  | } from "../controller/employees.js"; | ||||||
|  |  | ||||||
| import { | import { | ||||||
|     signUp, |     signUp, | ||||||
|     updatePasswordById, |     updatePasswordById, | ||||||
| @ -370,6 +391,55 @@ router.post("/customers", createCustomer); | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // routes with departments: | ||||||
|  | //get single department by id | ||||||
|  | router.get("/department/:id", showDepartmentById); | ||||||
|  |  | ||||||
|  | //get single department by name | ||||||
|  | router.get("/departmentByName/:id", showSelectedDepartmentsByName); | ||||||
|  |  | ||||||
|  | //get departments by customerid | ||||||
|  | router.get("/departmentByCustomerID/:id", showDepartmentByCustomerId); | ||||||
|  |  | ||||||
|  | // Update department | ||||||
|  | router.put("/department", updateDepartment); | ||||||
|  |  | ||||||
|  | // Create New department | ||||||
|  | router.post("/departments", createDepartment); | ||||||
|  |  | ||||||
|  | //get single department by name | ||||||
|  | router.get("/departmentName/:id", showDepartmentByName); | ||||||
|  |  | ||||||
|  | // Delete department | ||||||
|  | router.delete("/departments/:id", deleteDepartment); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // routes with employees: | ||||||
|  | //get single employee by id | ||||||
|  | router.get("/employee/:id", showEmployeeById); | ||||||
|  |  | ||||||
|  | //get employees by name | ||||||
|  | router.get("/employeeByName/:id", showSelectedEmployeesByName); | ||||||
|  |  | ||||||
|  | //get employees by department name | ||||||
|  | router.get("/employeeByDepartmentName/:id", showSelectedEmployeesByDepartmentName); | ||||||
|  |  | ||||||
|  | //get employees by customerid | ||||||
|  | router.get("/employeeByCustomerID/:id", showEmployeeByCustomerId); | ||||||
|  |  | ||||||
|  | //get employees by departmentid | ||||||
|  | router.get("/employeeByDeprtmentID/:id", showEmployeeByDepartmentId); | ||||||
|  |  | ||||||
|  | // Update employee | ||||||
|  | router.put("/employee", updateEmployee); | ||||||
|  |  | ||||||
|  | // Create New employee | ||||||
|  | router.post("/employees", createEmployee); | ||||||
|  |  | ||||||
|  | // Delete employee | ||||||
|  | router.delete("/employees/:id", deleteEmployee); | ||||||
|  |  | ||||||
|  |  | ||||||
| // routes with config items: | // routes with config items: | ||||||
| // get all config items | // get all config items | ||||||
| router.get("/configItems", showConfigItems); | router.get("/configItems", showConfigItems); | ||||||
|  | |||||||
							
								
								
									
										127
									
								
								components/ClientSearch.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								components/ClientSearch.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,127 @@ | |||||||
|  | <template> | ||||||
|  |     <section :class="['fixed-customer-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Customer:</div> | ||||||
|  |         <pre :class="['data', darkMode ? 'pre-darkmode' : 'pre-lightmode']">{{ customer.customername }}</pre> | ||||||
|  |     </section> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <script setup> | ||||||
|  | import { ref, onMounted, watch } from 'vue'; | ||||||
|  | import { useStore } from 'vuex'; | ||||||
|  | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
|  | const store = useStore(); | ||||||
|  | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
|  | const customer = ref({}); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  |  | ||||||
|  | const darkMode = ref(''); | ||||||
|  |  | ||||||
|  | const getSession = async () => { | ||||||
|  |     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
|  |     if (loggedInUserDarkModeBool == 1) { | ||||||
|  |         darkMode.value = true; | ||||||
|  |     } else { | ||||||
|  |         darkMode.value = false; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // get customer from id | ||||||
|  | const getCustomerById = async () => { | ||||||
|  |     try { | ||||||
|  |         const response = await Axios.get( | ||||||
|  |             `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerById/${chosenCustomerId.value}` | ||||||
|  |         ); | ||||||
|  |         customer.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getItem(item) { | ||||||
|  |     if (process.client) { | ||||||
|  |         return localStorage.getItem(item) | ||||||
|  |     } else { | ||||||
|  |         return undefined | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | watch(modeChanged, getSession) | ||||||
|  |  | ||||||
|  | onMounted(async () => { | ||||||
|  |     getSession(); | ||||||
|  |     await getCustomerById(); | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |     name: "ClientSearch", | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <style scoped> | ||||||
|  | .fixed-customer-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: 4.188em; | ||||||
|  |     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; | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @ -42,7 +42,6 @@ | |||||||
|     <div class="buttons"> |     <div class="buttons"> | ||||||
|       <input type="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="login-button" value="Login" |       <input type="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="login-button" value="Login" | ||||||
|         @click="handleLogin"> |         @click="handleLogin"> | ||||||
|       <!-- <input type="button" :class="[darkMode ? 'button-darkmode' : 'button-lightmode']" id="signup-button" value="Signup" @click="testFunctionSignup"> --> |  | ||||||
|     </div> |     </div> | ||||||
|   </form> |   </form> | ||||||
| </template> | </template> | ||||||
| @ -90,21 +89,7 @@ const handleLogin = async () => { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   try { |   try { | ||||||
|     /*let res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/login`, requestBody); |  | ||||||
|  |  | ||||||
|     const sessionToken = useCookie('token', {maxAge: 604800, sameSite: true}); |  | ||||||
|     sessionToken.value = res.data.token; |  | ||||||
|     Axios.defaults.headers.common['Authorization'] = `${username}`; |  | ||||||
|     const userToken = useCookie('user', {maxAge: 604800, sameSite: true}); |  | ||||||
|     userToken.value = username; |  | ||||||
|     // something to do with the res? |  | ||||||
|     console.log(sessionToken) |  | ||||||
|     console.log(res.data.message) |  | ||||||
|  |  | ||||||
|     // sucessfully logged in |  | ||||||
|     router.push('/home')*/ |  | ||||||
|     let resBody = await signIn(credentials, { callbackUrl: '/home' }) |     let resBody = await signIn(credentials, { callbackUrl: '/home' }) | ||||||
|     // let resBody = await signIn(credentials, { callbackUrl: await delayRedirect(callbackUrl, delayInSeconds * 1000) }); |  | ||||||
|     try { |     try { | ||||||
|       const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/login`); |       const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/login`); | ||||||
|       setItem('logged-in-bool', true); |       setItem('logged-in-bool', true); | ||||||
| @ -139,68 +124,6 @@ const handleLogin = async () => { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| // const testFunctionSignup = async () => { |  | ||||||
| //   isError.value = false; |  | ||||||
| //   errorMsg.value = ''; |  | ||||||
|  |  | ||||||
| //   const username = 'adm_tueit' |  | ||||||
| //   const password = 'SvF=?bfEx7_hV,cMEu4m' |  | ||||||
| //   const password_repeat = 'SvF=?bfEx7_hV,cMEu4m' |  | ||||||
| //   const fullName = 'administrator' |  | ||||||
| //   const email = 'support@tueit.de' |  | ||||||
| //   const phonenumber = '' |  | ||||||
| //   const address = '' |  | ||||||
| //   const city = '' |  | ||||||
| //   const postcode = '' |  | ||||||
| //   const adminBool = true |  | ||||||
| //   const technician1Bool = false |  | ||||||
| //   const technician2Bool = false |  | ||||||
| //   const technicianMonitoringBool = false |  | ||||||
| //   const merchantBool = false |  | ||||||
| //   const internBool = true |  | ||||||
|  |  | ||||||
| //   const requestBody = { |  | ||||||
| //     username: username, |  | ||||||
| //     password: password, |  | ||||||
| //     password_repeat: password_repeat, |  | ||||||
| //     fullName: fullName, |  | ||||||
| //     email: email, |  | ||||||
| //     phonenumber: phonenumber, |  | ||||||
| //     address: address, |  | ||||||
| //     city: city, |  | ||||||
| //     postcode: postcode, |  | ||||||
| //     adminBool: adminBool, |  | ||||||
| //     technician1Bool: technician1Bool, |  | ||||||
| //     technician2Bool: technician2Bool, |  | ||||||
| //     technicianMonitoringBool: technicianMonitoringBool, |  | ||||||
| //     merchantBool: merchantBool, |  | ||||||
| //     internBool: internBool, |  | ||||||
| //   } |  | ||||||
|  |  | ||||||
| //   try { |  | ||||||
|  |  | ||||||
| //     let res = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/signup`, requestBody); |  | ||||||
|  |  | ||||||
| //     // something to do with the res? |  | ||||||
| //     // console.log(res) |  | ||||||
|  |  | ||||||
| //   } catch (err) { |  | ||||||
| //     // handle the error  |  | ||||||
| //     console.log(err.response.statusText) |  | ||||||
| //     isError.value = true; |  | ||||||
| //     errorMsg.value = err.response.statusText; |  | ||||||
| //   } |  | ||||||
| // } |  | ||||||
|  |  | ||||||
| const getSession = async () => { |  | ||||||
|   // const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |  | ||||||
|   // if (loggedInUserDarkModeBool == 1) { |  | ||||||
|   //   darkMode.value = true; |  | ||||||
|   // } else { |  | ||||||
|   //   darkMode.value = false; |  | ||||||
|   // } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function getItem(item) { | function getItem(item) { | ||||||
|   if (process.client) { |   if (process.client) { | ||||||
|     return localStorage.getItem(item) |     return localStorage.getItem(item) | ||||||
| @ -210,7 +133,6 @@ function getItem(item) { | |||||||
| } | } | ||||||
|  |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   getSession(); |  | ||||||
|   document.addEventListener('keyup', handleKeyUp); |   document.addEventListener('keyup', handleKeyUp); | ||||||
|   document.getElementById('username-input').value = ''; |   document.getElementById('username-input').value = ''; | ||||||
|   document.getElementById('password-input').value = ''; |   document.getElementById('password-input').value = ''; | ||||||
| @ -230,12 +152,6 @@ const handleKeyUp = (event) => { | |||||||
| <script> | <script> | ||||||
| export default { | export default { | ||||||
|   name: "LoginForm", |   name: "LoginForm", | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // isError: false, |  | ||||||
|       // errorMsg: '', |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | |||||||
| @ -153,7 +153,6 @@ import { useStore } from 'vuex'; | |||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
|  |  | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
| const editable = computed(() => store.state.editable); | const editable = computed(() => store.state.editable); | ||||||
| @ -395,7 +394,6 @@ export default { | |||||||
|     background-color: #fff; |     background-color: #fff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| .asset-name { | .asset-name { | ||||||
|     align-self: stretch; |     align-self: stretch; | ||||||
|     padding: 1rem 0; |     padding: 1rem 0; | ||||||
|  | |||||||
| @ -59,7 +59,6 @@ import { computed } from 'vue'; | |||||||
|  |  | ||||||
| // get accesss to the store | // get accesss to the store | ||||||
| const store = useStore() | const store = useStore() | ||||||
|  |  | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
| const goToChosenAsset = (id) => { | const goToChosenAsset = (id) => { | ||||||
|  | |||||||
| @ -1,65 +1,628 @@ | |||||||
| <template> | <template> | ||||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> |   <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Customer name</pre> |     <div> | ||||||
|  |       <h2 v-if="!editable" :class="['customer-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ cust.customername }} | ||||||
|  |       </h2> | ||||||
|  |       <input v-if="editable" v-model="cust.customername" @change="updateCustomer()" | ||||||
|  |         :class="['data', 'customer-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|  |     </div> | ||||||
|  |     <div class="data-field" id="customer-id"> | ||||||
|  |       <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||||
|  |       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.customerID }}</pre> | ||||||
|  |     </div> | ||||||
|  |     <div class="customer-data"> | ||||||
|  |       <div class="contact"> | ||||||
|  |         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Contacts:</pre> | ||||||
|  |         <div class="data-field" id="contact-person"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Contact person:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.contactperson }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.contactperson" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="first-e-mail"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. E-Mail:</pre> | ||||||
|  |           <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.EMail }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.EMail" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="first-phone"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Phone number:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.phonenumber }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.phonenumber" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="data-field" id="second-e-mail"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. E-Mail:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondEMail }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.secondEMail" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="second-phone"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Phone number:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondPhonenumber }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.secondPhonenumber" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="data-field" id="third-e-mail"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. E-Mail:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdEMail }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.thirdEMail" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="third-phone"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Phone number:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdPhonenumber }}</pre> | ||||||
|  |           <input v-if="editable" v-model="cust.thirdPhonenumber" @change="updateCustomer()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="address"> | ||||||
|  |         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Addresses:</pre> | ||||||
|  |         <div class="street-address"> | ||||||
|  |           <div class="data-field" id="street-name"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Street:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.street }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.street" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="street-no"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. No.:</pre> | ||||||
|  |             <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.no }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.no" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="postcode-city"> | ||||||
|  |           <div class="data-field" id="postal-code"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Postcode:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.postcode }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.postcode" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. City:</pre> | ||||||
|  |             <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.city }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.city" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="street-address"> | ||||||
|  |           <div class="data-field" id="street-name"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Street:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondStreet }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.secondStreet" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="street-no"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. No.:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondNo }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.secondNo" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="postcode-city"> | ||||||
|  |           <div class="data-field" id="postal-code"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Postcode:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondPostcode }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.secondPostcode" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. City:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.secondCity }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.secondCity" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="street-address"> | ||||||
|  |           <div class="data-field" id="street-name"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Street:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdStreet }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.thirdStreet" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="street-no"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. No.:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdNo }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.thirdNo" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="postcode-city"> | ||||||
|  |           <div class="data-field" id="postal-code"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Postcode:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdPostcode }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.thirdPostcode" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. City:</pre> | ||||||
|  |             <pre v-if="!editable" | ||||||
|  |               :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ cust.thirdCity }}</pre> | ||||||
|  |             <input v-if="editable" v-model="cust.thirdCity" @change="updateCustomer()" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="notes"> | ||||||
|  |       <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> | ||||||
|  |       <input v-model="cust.notes" :readonly="!editable" @change="updateCustomer()" | ||||||
|  |         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|  |     </div> | ||||||
|  |   </section> | ||||||
|  |   <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |     <div> | ||||||
|  |       <input v-model="newCustomername" | ||||||
|  |         :class="['data', 'customer-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|  |     </div> | ||||||
|     <div class="data-field" id="customer-id"> |     <div class="data-field" id="customer-id"> | ||||||
|       <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> |       <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']">...</pre> | ||||||
|     </div> |     </div> | ||||||
|     <div class="customer-data"> |     <div class="customer-data"> | ||||||
|       <div class="contact"> |       <div class="contact"> | ||||||
|         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Contact:</pre> |         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Contacts:</pre> | ||||||
|         <div class="data-field" id="contact-person"> |         <div class="data-field" id="contact-person"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Contact person:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Contact person:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <input v-model="newContactperson" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="e-mail"> |         <div class="data-field" id="first-e-mail"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">E-Mail:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. E-Mail:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <input v-model="newEMail" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="phone"> |         <div class="data-field" id="first-phone"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Phone number:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Phone number:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <input v-model="newPhonenumber" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="data-field" id="second-e-mail"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. E-Mail:</pre> | ||||||
|  |           <input v-model="newSecondEMail" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="second-phone"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Phone number:</pre> | ||||||
|  |           <input v-model="newSecondPhonenumber" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="data-field" id="third-e-mail"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. E-Mail:</pre> | ||||||
|  |           <input v-model="newThirdEMail" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="third-phone"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Phone number:</pre> | ||||||
|  |           <input v-model="newThirdPhonenumber" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <div class="address"> |       <div class="address"> | ||||||
|         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Address:</pre> |         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Addresses:</pre> | ||||||
|         <div class="street-address"> |         <div class="street-address"> | ||||||
|           <div class="data-field" id="street-name"> |           <div class="data-field" id="street-name"> | ||||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Street:</pre> |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Street:</pre> | ||||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |             <input v-model="newStreet" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|           </div> |           </div> | ||||||
|           <div class="data-field" id="street-no"> |           <div class="data-field" id="street-no"> | ||||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">No.:</pre> |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. No.:</pre> | ||||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |             <input v-model="newNo" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="postal-code"> |         <div class="postcode-city"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Postcode:</pre> |           <div class="data-field" id="postal-code"> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. Postcode:</pre> | ||||||
|  |             <input v-model="newPostcode" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">1. City:</pre> | ||||||
|  |             <input v-model="newCity" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="city"> |           | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">City:</pre> |         <div class="street-address"> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <div class="data-field" id="street-name"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Street:</pre> | ||||||
|  |             <input v-model="newSecondStreet" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="street-no"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. No.:</pre> | ||||||
|  |             <input v-model="newSecondNo" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="postcode-city"> | ||||||
|  |           <div class="data-field" id="postal-code"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. Postcode:</pre> | ||||||
|  |             <input v-model="newSecondPostcode" | ||||||
|  |               :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">2. City:</pre> | ||||||
|  |             <input v-model="newSecondCity" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |           | ||||||
|  |         <div class="street-address"> | ||||||
|  |           <div class="data-field" id="street-name"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Street:</pre> | ||||||
|  |             <input v-model="newThirdStreet" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="street-no"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. No.:</pre> | ||||||
|  |             <input v-model="newThirdNo" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="postcode-city"> | ||||||
|  |           <div class="data-field" id="postal-code"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. Postcode:</pre> | ||||||
|  |             <input v-model="newThirdPostcode" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|  |           <div class="data-field" id="city"> | ||||||
|  |             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">3. City:</pre> | ||||||
|  |             <input v-model="newThirdCity" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="notes"> |     <div class="notes"> | ||||||
|       <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> |       <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> | ||||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> |       <input v-model="newNotes" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
|  |   <section v-if="addBool" id="saveNewItem"> | ||||||
|  |     <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addCustomer()">Save</button> | ||||||
|  |   </section> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
|  | const editable = computed(() => store.state.editable); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const deleteBool = computed(() => store.state.deleteBool); | ||||||
|  | const addBool = computed(() => store.state.new); | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  | const cust = ref({}); | ||||||
|  | const customers = ref([]); | ||||||
|  |  | ||||||
|  | const newCustomername = ref(''); | ||||||
|  | const newCustomerID = ref(''); | ||||||
|  | const newContactperson = ref(''); | ||||||
|  | const newEMail = ref(''); | ||||||
|  | const newSecondEMail = ref(''); | ||||||
|  | const newThirdEMail = ref(''); | ||||||
|  | const newPhonenumber = ref(''); | ||||||
|  | const newSecondPhonenumber = ref(''); | ||||||
|  | const newThirdPhonenumber = ref(''); | ||||||
|  | const newStreet = ref(''); | ||||||
|  | const newNo = ref(''); | ||||||
|  | const newPostcode = ref(''); | ||||||
|  | const newCity = ref(''); | ||||||
|  | const newSecondStreet = ref(''); | ||||||
|  | const newSecondNo = ref(''); | ||||||
|  | const newSecondPostcode = ref(''); | ||||||
|  | const newSecondCity = ref(''); | ||||||
|  | const newThirdStreet = ref(''); | ||||||
|  | const newThirdNo = ref(''); | ||||||
|  | const newThirdPostcode = ref(''); | ||||||
|  | const newThirdCity = ref(''); | ||||||
|  | const newNotes = ref(''); | ||||||
|  |  | ||||||
|  | // get customer from id | ||||||
|  | const getCustomerById = async () => { | ||||||
|  |   if (!addBool.value) { | ||||||
|  |     try { | ||||||
|  |       const response = await Axios.get( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerById/${chosenCustomerId.value}` | ||||||
|  |       ); | ||||||
|  |       cust.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //update data | ||||||
|  | const updateCustomer = async () => { | ||||||
|  |   if (cust.value.customername.trim() === "") { | ||||||
|  |     alert("Please add a customer name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if customer name already exists | ||||||
|  |     customers.value.forEach(c => { | ||||||
|  |       if (c.customername === cust.value.customername) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 2) { | ||||||
|  |       alert("This customer name already exists. Please choose an unique customer name or modify respectively delete the old one!"); | ||||||
|  |       cust.value.customername = ''; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validateEMail(cust.value.EMail)) { | ||||||
|  |       alert("Please add a valid first email!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePhonenumber(cust.value.phonenumber)) { | ||||||
|  |       alert("Please add a valid first phonenumber!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validateEMail(cust.value.secondEMail)) { | ||||||
|  |       alert("Please add a valid second email!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePhonenumber(cust.value.secondPhonenumber)) { | ||||||
|  |       alert("Please add a valid second phonenumber!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validateEMail(cust.value.thirdEMail)) { | ||||||
|  |       alert("Please add a valid third email!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePhonenumber(cust.value.thirdPhonenumber)) { | ||||||
|  |       alert("Please add a valid third phonenumber!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePostcode(cust.value.postcode)) { | ||||||
|  |       alert("Please add a valid first postcode!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePostcode(cust.value.secondPostcode)) { | ||||||
|  |       alert("Please add a valid second postcode!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validatePostcode(cust.value.thirdPostcode)) { | ||||||
|  |       alert("Please add a valid third postcode!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (cust.value.contactperson.trim() === "") { | ||||||
|  |       alert("Please add a contactperson!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (cust.value.street.trim() === "") { | ||||||
|  |       alert("Please add a first street!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (cust.value.no.trim() === "") { | ||||||
|  |       alert("Please add a first number!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (cust.value.city.trim() === "") { | ||||||
|  |       alert("Please add a first city!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     try { | ||||||
|  |       await Axios.put( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateCustomer`, | ||||||
|  |         { | ||||||
|  |           customerID: cust.value.customerID, | ||||||
|  |           customername: cust.value.customername, | ||||||
|  |           contactperson: cust.value.contactperson, | ||||||
|  |           EMail: cust.value.EMail, | ||||||
|  |           secondEMail: cust.value.secondEMail, | ||||||
|  |           thirdEMail: cust.value.thirdEMail, | ||||||
|  |           phonenumber: cust.value.phonenumber, | ||||||
|  |           secondPhonenumber: cust.value.secondPhonenumber, | ||||||
|  |           thirdPhonenumber: cust.value.thirdPhonenumber, | ||||||
|  |           street: cust.value.street, | ||||||
|  |           no: cust.value.no, | ||||||
|  |           postcode: cust.value.postcode, | ||||||
|  |           city: cust.value.city, | ||||||
|  |           secondStreet: cust.value.secondStreet, | ||||||
|  |           secondNo: cust.value.secondNo, | ||||||
|  |           secondPostcode: cust.value.secondPostcode, | ||||||
|  |           secondCity: cust.value.secondCity, | ||||||
|  |           thirdStreet: cust.value.thirdStreet, | ||||||
|  |           thirdNo: cust.value.thirdNo, | ||||||
|  |           thirdPostcode: cust.value.thirdPostcode, | ||||||
|  |           thirdCity: cust.value.thirdCity, | ||||||
|  |           notes: cust.value.notes, | ||||||
|  |         } | ||||||
|  |       ) | ||||||
|  |       await getCustomerById(); | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // add new customer | ||||||
|  | const addCustomer = async () => { | ||||||
|  |   // check if all input data is valid | ||||||
|  |   if (newCustomername.value.trim() === "") { | ||||||
|  |     alert("Please add a customer name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if customer name already exists | ||||||
|  |     customers.value.forEach(c => { | ||||||
|  |       if (c.customername === newCustomername.value) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 1) { | ||||||
|  |       alert("This customer name already exists. Please choose an unique customer name or modify respectively delete the old one!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   if (!validateEMail(newEMail.value)) { | ||||||
|  |     alert("Please add a valid first email!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePhonenumber(newPhonenumber.value)) { | ||||||
|  |     alert("Please add a valid first phonenumber!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validateEMail(newSecondEMail.value)) { | ||||||
|  |     alert("Please add a valid second email!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePhonenumber(newSecondPhonenumber.value)) { | ||||||
|  |     alert("Please add a valid second phonenumber!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validateEMail(newThirdEMail.value)) { | ||||||
|  |     alert("Please add a valid third email!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePhonenumber(newThirdPhonenumber.value)) { | ||||||
|  |     alert("Please add a valid third phonenumber!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePostcode(newPostcode.value)) { | ||||||
|  |     alert("Please add a valid first postcode!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePostcode(newSecondPostcode.value)) { | ||||||
|  |     alert("Please add a valid second postcode!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (!validatePostcode(newThirdPostcode.value)) { | ||||||
|  |     alert("Please add a valid third postcode!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (newContactperson.value.trim() === "") { | ||||||
|  |     alert("Please add a contactperson!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (newStreet.value.trim() === "") { | ||||||
|  |     alert("Please add a first street!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (newNo.value.trim() === "") { | ||||||
|  |     alert("Please add a first number!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (newCity.value.trim() === "") { | ||||||
|  |     alert("Please add a first city!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addCustomer`, | ||||||
|  |       { | ||||||
|  |         customername: newCustomername.value, | ||||||
|  |         contactperson: newContactperson.value, | ||||||
|  |         EMail: newEMail.value, | ||||||
|  |         secondEMail: newSecondEMail.value, | ||||||
|  |         thirdEMail: newThirdEMail.value, | ||||||
|  |         phonenumber: newPhonenumber.value, | ||||||
|  |         secondPhonenumber: newSecondPhonenumber.value, | ||||||
|  |         thirdPhonenumber: newThirdPhonenumber.value, | ||||||
|  |         street: newStreet.value, | ||||||
|  |         no: newNo.value, | ||||||
|  |         postcode: newPostcode.value, | ||||||
|  |         city: newCity.value, | ||||||
|  |         secondStreet: newSecondStreet.value, | ||||||
|  |         secondNo: newSecondNo.value, | ||||||
|  |         secondPostcode: newSecondPostcode.value, | ||||||
|  |         secondCity: newSecondCity.value, | ||||||
|  |         thirdStreet: newThirdStreet.value, | ||||||
|  |         thirdNo: newThirdNo.value, | ||||||
|  |         thirdPostcode: newThirdPostcode.value, | ||||||
|  |         thirdCity: newThirdCity.value, | ||||||
|  |         notes: newNotes.value, | ||||||
|  |       }); | ||||||
|  |     store.commit('resetStore'); | ||||||
|  |     store.commit('changeToCustomerlist'); | ||||||
|  |   } 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 confirmDeleteCustomer = async () => { | ||||||
|  |   if (deleteBool.value === true) { | ||||||
|  |     if (confirm("Do you really want to delete this customer? It cannot be undone!")) { | ||||||
|  |       try { | ||||||
|  |         await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteCustomer/${chosenCustomerId.value}`); | ||||||
|  |         store.commit('undoDelete'); | ||||||
|  |         store.commit('resetStore'); | ||||||
|  |         store.commit('changeToCustomerlist'); | ||||||
|  |       } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |       } | ||||||
|  |     } else { | ||||||
|  |       store.commit('undoDelete'); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // include delay to avoid 503 error | ||||||
|  | const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||||
|  |   setTimeout(() => { | ||||||
|  |     fetchDataFunc(); | ||||||
|  |   }, 1500); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // to validate the email address | ||||||
|  | const validateEMail = (email) => { | ||||||
|  |   const emailRegex = new RegExp(/^[A-Za-z0-9_!#$%&'*+\/=?`{|}~^.-]+@[A-Za-z0-9.-]+$/, "gm"); | ||||||
|  |   if (email === "") { | ||||||
|  |     return true | ||||||
|  |   } | ||||||
|  |   return emailRegex.test(email); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // to validate the phonenumber | ||||||
|  | const validatePhonenumber = (number) => { | ||||||
|  |   const mobilephonenumberRegex = new RegExp(/^(((((00|\+){1,2})49([ \-/]?|[ \()/]?))|0)[1]([0-2]|[4-7])([0-9]{1})([ \-/]?|[ \()/]?)([0-9]{8}))$/, "gm"); | ||||||
|  |   const landlineRegex = new RegExp(/^0(30|40|69|89|20[12389]|21[24]|228|234|335|340|3[3-9][15]|906|[2-9][1-9]1|3(?:3(?:[0237][127]|0[3-6]|2[89]|3[458]|[46][1246]|7[589]|8[1256]|9[145])|4(?:[2347][135]|[34]7|[69][146]|48|62|76|93)|5(?:[04679][14]|[238][135]|[2469]2|[4789]6|[278]8|63|73|37|29)|6(?:[024689][13]|[03789]5|06|2[2489]|3[1246]|44|47|7[1279]|82|86)|7(?:[236][135]|2[2467]|37|4[145]|62|64|7[1-4])|8(?:[234678]1|3[468]|4[347]|6[035-9]|7[467]|83|86)|9(?:[236][135]|[04689]4|[04789]1|[03468]7|02|09|28|4[369]|6[2689]|73|76|96|98))|3[3-9][0-9]{3}|13[078]|180[235]|18[01]|19[0-9]{3}|[789]00|[2-9][0-9]{3})([0-9]{1,})$/, "gm"); | ||||||
|  |   if (number === "") { | ||||||
|  |     return true | ||||||
|  |   } | ||||||
|  |   if (mobilephonenumberRegex.test(number)) { | ||||||
|  |     return true | ||||||
|  |   } else if (landlineRegex.test(number)) { | ||||||
|  |     return true; | ||||||
|  |   } | ||||||
|  |   return false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // to validate the postcode | ||||||
|  | const validatePostcode = (postcode) => { | ||||||
|  |   const postcodeRegex = new RegExp(/^\d{5}$/); | ||||||
|  |   if (postcode === "") { | ||||||
|  |     return true | ||||||
|  |   } | ||||||
|  |   return postcodeRegex.test(postcode); | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -78,10 +641,13 @@ function getItem(item) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | watch(deleteBool, confirmDeleteCustomer); | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|   await getSession(); |   getSession(); | ||||||
|  |   await getCustomerById(); | ||||||
|  |   triggerBackendCallsWithDelay(getCustomers); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -93,14 +659,14 @@ export default { | |||||||
|  |  | ||||||
|  |  | ||||||
| <style scoped> | <style scoped> | ||||||
| section { | .information { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|  |   align-items: stretch; | ||||||
|  |   justify-content: center; | ||||||
|   padding: 1.25rem 1.875rem; |   padding: 1.25rem 1.875rem; | ||||||
|   border-radius: 0.625rem; |   border-radius: 0.625rem; | ||||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); |   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||||
|   align-items: stretch; |  | ||||||
|   justify-content: center; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .section-darkmode { | .section-darkmode { | ||||||
| @ -111,39 +677,51 @@ section { | |||||||
|   background-color: #ffffff; |   background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .customer-name { | ||||||
| .title { |   align-self: stretch; | ||||||
|   padding: 1.25rem 0; |   padding: 1rem 0; | ||||||
|   letter-spacing: 0.05rem; |   margin: 1rem; | ||||||
|  |   letter-spacing: 5%; | ||||||
|   text-decoration-line: underline; |   text-decoration-line: underline; | ||||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; |   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, | ||||||
|  |     sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-darkmode { | .customer-name-input { | ||||||
|   color: #ffffff; |   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; | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-lightmode { | .h2-darkmode { | ||||||
|   color: #000000; |   color: #fff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .h2-lightmode { | ||||||
|  |   color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data-field { | .data-field { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex: auto; |  | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|   padding: 0.8rem 1.875rem; |  | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: flex-start; |   justify-content: flex-start; | ||||||
|  |   width: 100%; | ||||||
|  |   padding: 0.8rem 1.875rem; | ||||||
|   gap: 1.25rem; |   gap: 1.25rem; | ||||||
|  |   border-radius: 0.625rem; | ||||||
| } | } | ||||||
|  |  | ||||||
| .data-field#customer-id { | .data-field#customer-id { | ||||||
|   padding: 0.625rem 1.875rem; |   padding: 0.625rem 1.875rem; | ||||||
| } | } | ||||||
|  |  | ||||||
| .data-field#street-name { | .data-field#street-no { | ||||||
|   flex: 3; |   padding-left: 3.2rem; | ||||||
| } | } | ||||||
|  |  | ||||||
| .label { | .label { | ||||||
| @ -151,6 +729,14 @@ section { | |||||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; |   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .h2-input-darkmode { | ||||||
|  |   background-color: #212121; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .h2-input-lightmode { | ||||||
|  |   background-color: #EBEBEB; | ||||||
|  | } | ||||||
|  |  | ||||||
| pre { | pre { | ||||||
|   margin: 0; |   margin: 0; | ||||||
| } | } | ||||||
| @ -163,6 +749,42 @@ pre { | |||||||
|   color: #000000; |   color: #000000; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data { | .data { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
| @ -186,7 +808,6 @@ pre { | |||||||
|   color: #000000; |   color: #000000; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| .customer-data { | .customer-data { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex: auto; |   flex: auto; | ||||||
| @ -221,7 +842,8 @@ pre { | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| .street-address { | .street-address, | ||||||
|  | .postcode-city { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|   align-items: center; |   align-items: center; | ||||||
| @ -242,4 +864,8 @@ pre { | |||||||
| #notes { | #notes { | ||||||
|   align-self: stretch; |   align-self: stretch; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |   border: none; | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
| @ -1,25 +1,58 @@ | |||||||
| <template> | <template> | ||||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> |   <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Department name</pre> |     <h2 v-if="!editable" :class="['department-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ dep.name | ||||||
|  |       }}</h2> | ||||||
|  |     <input v-if="editable" v-model="dep.name" @change="updateDepartment()" | ||||||
|  |       :class="['data', 'department-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|  |     <div class="data-group"> | ||||||
|  |       <div class="data-field" id="id"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||||
|  |         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ dep.primaryID }}</pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-field" id="customer-id"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||||
|  |         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ dep.customername }}</pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-field" id="head"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> | ||||||
|  |         <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ dep.head }}</pre> | ||||||
|  |         <input v-if="editable" v-model="dep.head" @change="updateDepartment()" | ||||||
|  |           :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="notes"> | ||||||
|  |       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||||
|  |       <input v-model="dep.notes" :readonly="!editable" @change="updateDepartment()" | ||||||
|  |         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|  |     </div> | ||||||
|  |   </section> | ||||||
|  |   <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |     <input v-model="newName" | ||||||
|  |       :class="['data', 'department-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|     <div class="data-group"> |     <div class="data-group"> | ||||||
|       <div class="data-field" id="id"> |       <div class="data-field" id="id"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> |         <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']">...</pre> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-field" id="customer-id"> |       <div class="data-field" id="customer-id"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ chosenCustomerId }}</pre> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-field" id="head"> |       <div class="data-field" id="head"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <input v-model="newHead" | ||||||
|  |           :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="notes"> |     <div class="notes"> | ||||||
|       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> |       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> |       <input v-model="newNotes" | ||||||
|  |         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
|  |   <section v-if="addBool" id="saveNewItem"> | ||||||
|  |     <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addDepartment()">Save</button> | ||||||
|  |   </section> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -28,11 +61,156 @@ | |||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  | const editable = computed(() => store.state.editable); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const chosenDepartmentId = computed(() => store.state.chosenDepartmentId); | ||||||
|  | const deleteBool = computed(() => store.state.deleteBool); | ||||||
|  | const addBool = computed(() => store.state.new); | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  | const dep = ref({}); | ||||||
|  | const departments = ref({}); | ||||||
|  | const customer = ref({}); | ||||||
|  |  | ||||||
|  | const newName = ref(''); | ||||||
|  | const newHead = ref(''); | ||||||
|  | const newNotes = ref(''); | ||||||
|  |  | ||||||
|  | // get department from id | ||||||
|  | const getDepartmentById = async () => { | ||||||
|  |   if (!addBool.value) { | ||||||
|  |     try { | ||||||
|  |       const response = await Axios.get( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getDepartment/${chosenDepartmentId.value}` | ||||||
|  |       ); | ||||||
|  |       dep.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //update data | ||||||
|  | const updateDepartment = async () => { | ||||||
|  |   if (dep.value.name.trim() === "") { | ||||||
|  |     alert("Please add a department name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if department name already exists | ||||||
|  |     departments.value.forEach(d => { | ||||||
|  |       if (d.name === dep.value.name) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 2) { | ||||||
|  |       alert("This department name already exists. Please choose an unique department name or modify respectively delete the old one!"); | ||||||
|  |       dep.value.name = ''; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     try { | ||||||
|  |       await Axios.put( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateDepartment`, | ||||||
|  |         { | ||||||
|  |           primaryID: dep.value.primaryID, | ||||||
|  |           name: dep.value.name, | ||||||
|  |           head: dep.value.head, | ||||||
|  |           notes: dep.value.notes, | ||||||
|  |         } | ||||||
|  |       ) | ||||||
|  |       await getDepartmentById(); | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // add new department | ||||||
|  | const addDepartment = async () => { | ||||||
|  |   // check if all input data is valid | ||||||
|  |   if (newName.value.trim() === "") { | ||||||
|  |     alert("Please add an department name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if department name already exists | ||||||
|  |     departments.value.forEach(c => { | ||||||
|  |       if (c.name === newName.value) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 1) { | ||||||
|  |       alert("This department name already exists. Please choose an unique department name or modify respectively delete the old one!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addDepartment`, | ||||||
|  |       { | ||||||
|  |         customerID: chosenCustomerId.value, | ||||||
|  |         customername: customer.value.customername, | ||||||
|  |         name: newName.value, | ||||||
|  |         head: newHead.value, | ||||||
|  |         notes: newNotes.value, | ||||||
|  |       }); | ||||||
|  |     store.commit('resetStoreNotCustomer'); | ||||||
|  |     store.commit('changeToDepartmentlist'); | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // get customer from id | ||||||
|  | const getCustomerById = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get( | ||||||
|  |       `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerById/${chosenCustomerId.value}` | ||||||
|  |     ); | ||||||
|  |     customer.value = response.data; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | //get all departments | ||||||
|  | const getDepartments = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedDepartmentByCustomer/${chosenCustomerId.value}` | ||||||
|  |     ); | ||||||
|  |     departments.value = response.data; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const confirmDeleteDepartment = async () => { | ||||||
|  |     if (deleteBool.value === true) { | ||||||
|  |         if (confirm("Do you really want to delete this department? It cannot be undone!")) { | ||||||
|  |             try { | ||||||
|  |                 await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteDepartment/${chosenDepartmentId.value}`); | ||||||
|  |             } catch (err) { | ||||||
|  |                 console.log(err.response.statusText); | ||||||
|  |             } | ||||||
|  |             store.commit('undoDelete'); | ||||||
|  |             store.commit('resetStoreNotCustomer'); | ||||||
|  |             store.commit('changeToDepartmentlist'); | ||||||
|  |         } else { | ||||||
|  |             store.commit('undoDelete'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // include delay to avoid 503 error | ||||||
|  | const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||||
|  |     setTimeout(() => { | ||||||
|  |         fetchDataFunc(); | ||||||
|  |     }, 1500); | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -51,10 +229,14 @@ function getItem(item) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession); | ||||||
|  | watch(deleteBool, confirmDeleteDepartment); | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|   await getSession(); |   getSession(); | ||||||
|  |   await getDepartmentById(); | ||||||
|  |   triggerBackendCallsWithDelay(getCustomerById); | ||||||
|  |   triggerBackendCallsWithDelay(getDepartments); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -72,15 +254,15 @@ export default { | |||||||
|   margin: 0; |   margin: 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .information { | ||||||
| section { |  | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|  |   align-items: flex-start; | ||||||
|  |   justify-content: center; | ||||||
|  |   width: 100%; | ||||||
|   padding: 1.25rem 1.875rem; |   padding: 1.25rem 1.875rem; | ||||||
|   border-radius: 0.625rem; |   border-radius: 0.625rem; | ||||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); |   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||||
|   align-items: stretch; |  | ||||||
|   justify-content: center; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .section-darkmode { | .section-darkmode { | ||||||
| @ -91,23 +273,44 @@ section { | |||||||
|   background-color: #ffffff; |   background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |   border: none; | ||||||
|  | } | ||||||
|  |  | ||||||
| .title { | .department-name-input { | ||||||
|   padding: 1.25rem 0; |   padding: 1rem 0; | ||||||
|   letter-spacing: 0.04rem; |   margin: 1rem; | ||||||
|  |   font-size: initial; | ||||||
|  |   letter-spacing: 5%; | ||||||
|   text-decoration-line: underline; |   text-decoration-line: underline; | ||||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; |   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, | ||||||
|  |     sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-darkmode { | .department-name { | ||||||
|   color: #ffffff; |   align-self: stretch; | ||||||
|  |   padding: 1rem 0; | ||||||
|  |   letter-spacing: 5%; | ||||||
|  |   text-decoration-line: underline; | ||||||
|  |   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, | ||||||
|  |     sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-lightmode { | .h2-darkmode { | ||||||
|   color: #000000; |   color: #fff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .h2-lightmode { | ||||||
|  |   color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .h2-input-darkmode { | ||||||
|  |   background-color: #212121; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .h2-input-lightmode { | ||||||
|  |   background-color: #EBEBEB; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data-group { | .data-group { | ||||||
|   display: flex; |   display: flex; | ||||||
| @ -180,6 +383,7 @@ section { | |||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   gap: 0.625rem; |   gap: 0.625rem; | ||||||
|  |   width: 50%; | ||||||
| } | } | ||||||
|  |  | ||||||
| .area-title { | .area-title { | ||||||
| @ -190,4 +394,40 @@ section { | |||||||
| #notes { | #notes { | ||||||
|   align-self: stretch; |   align-self: stretch; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
| @ -16,19 +16,30 @@ | |||||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> |                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||||
|                     Pronouns</th> |                     Pronouns</th> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> |             <tr v-for="empl in employees" :key="empl.primaryID" | ||||||
|  |                 :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> |                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||||
|                     ...</td> |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenEmployee(empl.primaryID)"> | ||||||
|  |                         {{ empl.primaryID }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|                     ...</td> |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenEmployee(empl.primaryID)"> | ||||||
|  |                         {{ empl.name }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']"> |                     :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']"> | ||||||
|                     ...</td> |                     {{ empl.jobTitle }}</td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> |                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||||
|                     ...</td> |                     {{ empl.pronouns }}</td> | ||||||
|             </tr> |             </tr> | ||||||
|         </table> |         </table> | ||||||
|     </section> |     </section> | ||||||
| @ -39,12 +50,35 @@ | |||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const chosenDepartmentId = computed(() => store.state.chosenDepartmentId); | ||||||
|  | const employeesByCustomer = ref([]); | ||||||
|  | const employees = ref([]); | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  |  | ||||||
|  | const goToChosenEmployee = (id) => { | ||||||
|  |     store.commit('setChosenCustomerEmployee', id); | ||||||
|  |     store.commit('changeToCustomerEmployee'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get employees by the selected customer | ||||||
|  | const getEmployees = async () => { | ||||||
|  |     try { | ||||||
|  |         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustEmployeeByCustomer/${chosenCustomerId.value}`); | ||||||
|  |         employeesByCustomer.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |     // filter those with the chosen department id | ||||||
|  |     employees.value = employeesByCustomer.value.filter(empl => empl.departmentID === chosenDepartmentId.value); | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
|     if (loggedInUserDarkModeBool == 1) { |     if (loggedInUserDarkModeBool == 1) { | ||||||
| @ -65,7 +99,8 @@ function getItem(item) { | |||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|     await getSession(); |     getSession(); | ||||||
|  |     await getEmployees(); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -96,7 +131,17 @@ export default { | |||||||
|     background-color: #ffffff; |     background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #nuxt-link { | ||||||
|  |     text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-darkmode { | ||||||
|  |     color: white; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-lightmode { | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
| .label { | .label { | ||||||
|     padding: 1.25rem 0; |     padding: 1.25rem 0; | ||||||
|  | |||||||
| @ -1,16 +1,44 @@ | |||||||
| <template> | <template> | ||||||
|  |     <section v-if="searchable" :class="['department-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |         <div :class="['instanceLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Name</div> | ||||||
|  |         <input v-model="nameSearchFilter" @change="filterDepartmentsByName()" | ||||||
|  |             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |     </section> | ||||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> |     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Departments:</div> |         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Departments:</div> | ||||||
|         <table class="data-table" id="customer-employee-table"> |         <table class="data-table" id="customer-employee-table"> | ||||||
|             <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> |             <tr :class="['table-row', darkMode ? 'tr-head-darkmode' : 'tr-head-lightmode']" id="table-head"> | ||||||
|                 <th :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">ID</th> |                 <th | ||||||
|                 <th :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> |                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||||
|                 <th :class="['DHead', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'DHead-darkmode' : 'DHead-lightmode']">Head</th> |                     ID</th> | ||||||
|  |                 <th | ||||||
|  |                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|  |                     Name</th> | ||||||
|  |                 <th | ||||||
|  |                     :class="['DHead', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'DHead-darkmode' : 'DHead-lightmode']"> | ||||||
|  |                     Head</th> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> |             <tr v-for="dep in departments" :key="dep.primaryID" | ||||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> |                 :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> |                 <td | ||||||
|                 <td :class="['DHead', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'DHead-darkmode' : 'DHead-lightmode']">...</td> |                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||||
|  |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenDepartment(dep.primaryID)"> | ||||||
|  |                         {{ dep.primaryID }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|  |                 <td | ||||||
|  |                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|  |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenDepartment(dep.primaryID)"> | ||||||
|  |                         {{ dep.name }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|  |                 <td | ||||||
|  |                     :class="['DHead', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'DHead-darkmode' : 'DHead-lightmode']"> | ||||||
|  |                     {{ dep.head }}</td> | ||||||
|             </tr> |             </tr> | ||||||
|         </table> |         </table> | ||||||
|     </section> |     </section> | ||||||
| @ -21,11 +49,39 @@ | |||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const searchable = computed(() => store.state.searchable); | ||||||
|  | const nameSearchFilter = ref(''); | ||||||
|  | const departments = ref([]); | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref(''); | ||||||
|  | const departmentByName = ref([]); | ||||||
|  |  | ||||||
|  | const goToChosenDepartment = (id) => { | ||||||
|  |     store.commit('setChosenCustomerDepartment', id); | ||||||
|  |     store.commit('changeToDepartment'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get department by the selected customer | ||||||
|  | const getDepartments = async () => { | ||||||
|  |     try { | ||||||
|  |         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedDepartmentByCustomer/${chosenCustomerId.value}`); | ||||||
|  |         departments.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // update search term | ||||||
|  | const updateSearchTerm = async () => { | ||||||
|  |     nameSearchFilter.value = ''; | ||||||
|  |     await getDepartments(); | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -36,6 +92,27 @@ const getSession = async () => { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | //get all departments based on the searched name | ||||||
|  | const filterDepartmentsByName = async () => { | ||||||
|  |     if (nameSearchFilter.value === '') { | ||||||
|  |         await getDepartments(); | ||||||
|  |     } else { | ||||||
|  |         try { | ||||||
|  |             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedDepartmentByName/${nameSearchFilter.value}`); | ||||||
|  |             departmentByName.value = response.data; | ||||||
|  |             departments.value = filterObjectsWithMatchingIds(departments.value, departmentByName.value); | ||||||
|  |         } catch (err) { | ||||||
|  |             console.log(err.response.statusText); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const filterObjectsWithMatchingIds = (arr1, arr2) => { | ||||||
|  |     return arr1.filter(obj1 => { | ||||||
|  |         return arr2.some(obj2 => obj2.primaryID === obj1.primaryID); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
| function getItem(item) { | function getItem(item) { | ||||||
|     if (process.client) { |     if (process.client) { | ||||||
|         return localStorage.getItem(item) |         return localStorage.getItem(item) | ||||||
| @ -44,16 +121,18 @@ function getItem(item) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | watch(searchable, updateSearchTerm); | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|     await getSession(); |     getSession(); | ||||||
|  |     await getDepartments(); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <script> | <script> | ||||||
| export default { | export default { | ||||||
|   name: "CustomerDepartmentList", |     name: "CustomerDepartmentList", | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -69,10 +148,75 @@ export default { | |||||||
|     border-radius: 0.625rem; |     border-radius: 0.625rem; | ||||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); |     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||||
| } | } | ||||||
| .section-darkmode { background-color: #2c2c2c; } |  | ||||||
| .section-lightmode { background-color: #ffffff; } | .section-darkmode { | ||||||
|  |     background-color: #2c2c2c; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .section-lightmode { | ||||||
|  |     background-color: #ffffff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .department-search { | ||||||
|  |     display: flex; | ||||||
|  |     align-items: center; | ||||||
|  |     padding: 0.625em 1.875em; | ||||||
|  |     gap: 1.25em; | ||||||
|  |     width: 30.125em; | ||||||
|  |     height: 3.125em; | ||||||
|  |     box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25); | ||||||
|  |     border-radius: 0.625em; | ||||||
|  |     box-sizing: border-box; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |     border: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #nuxt-link { | ||||||
|  |     text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-darkmode { | ||||||
|  |     color: white; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-lightmode { | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .data-darkmode { | ||||||
|  |     background-color: #212121; | ||||||
|  |     color: #fff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .data-lightmode { | ||||||
|  |     background-color: #EBEBEB; | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .dataInput { | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: row; | ||||||
|  |     align-items: flex-start; | ||||||
|  |     padding: 0 0.625rem; | ||||||
|  |     border-radius: 0.3125rem; | ||||||
|  |     box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||||
|  |     letter-spacing: 5%; | ||||||
|  |     font: 400 0.75rem/250% Overpass, sans-serif; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .instanceLabel { | ||||||
|  |     width: 5.5625em; | ||||||
|  |     height: 1.875em; | ||||||
|  |     font-family: "Overpass"; | ||||||
|  |     font-style: normal; | ||||||
|  |     font-weight: 400; | ||||||
|  |     font-size: 0.875em; | ||||||
|  |     line-height: 1.875; | ||||||
|  |     letter-spacing: 0.05em; | ||||||
|  | } | ||||||
|  |  | ||||||
| .label { | .label { | ||||||
|     padding: 1.25rem 0; |     padding: 1.25rem 0; | ||||||
| @ -80,8 +224,14 @@ export default { | |||||||
|     text-decoration-line: underline; |     text-decoration-line: underline; | ||||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; |     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
| .label-darkmode { color: #ffffff; } |  | ||||||
| .label-lightmode { color: #000000; } | .label-darkmode { | ||||||
|  |     color: #ffffff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .label-lightmode { | ||||||
|  |     color: #000000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -106,14 +256,22 @@ export default { | |||||||
|     border-top: none; |     border-top: none; | ||||||
|     border-bottom: 0.0625rem solid #000000; |     border-bottom: 0.0625rem solid #000000; | ||||||
| } | } | ||||||
|  |  | ||||||
| .tr-head-lightmode { | .tr-head-lightmode { | ||||||
|     border-top: none; |     border-top: none; | ||||||
|     border-bottom: 0.0625rem solid #8e8e8e; |     border-bottom: 0.0625rem solid #8e8e8e; | ||||||
| } | } | ||||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } |  | ||||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } |  | ||||||
|  |  | ||||||
| th, td { | .tr-darkmode { | ||||||
|  |     border-top: 0.0625rem solid #000000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .tr-lightmode { | ||||||
|  |     border-top: 0.0625rem solid #8e8e8e; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | th, | ||||||
|  | td { | ||||||
|     height: 1.875rem; |     height: 1.875rem; | ||||||
|     width: 40%; |     width: 40%; | ||||||
|     padding: 0; |     padding: 0; | ||||||
| @ -122,19 +280,28 @@ th, td { | |||||||
|     letter-spacing: 0.02rem; |     letter-spacing: 0.02rem; | ||||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; |     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } |  | ||||||
| .th-darkmode, .td-darkmode {  | th { | ||||||
|  |     font: 700 0.875rem/1.875rem Overpass, sans-serif; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .th-darkmode, | ||||||
|  | .td-darkmode { | ||||||
|     color: #ffffff; |     color: #ffffff; | ||||||
|     border-right: 0.0625rem solid #000000; |     border-right: 0.0625rem solid #000000; | ||||||
| } | } | ||||||
| .th-lightmode, .td-lightmode {  |  | ||||||
|  | .th-lightmode, | ||||||
|  | .td-lightmode { | ||||||
|     color: #000000; |     color: #000000; | ||||||
|     border-right: 0.0625rem solid #8e8e8e; |     border-right: 0.0625rem solid #8e8e8e; | ||||||
| } | } | ||||||
|  |  | ||||||
| .ID { width: 20%; } | .ID { | ||||||
|  |     width: 20%; | ||||||
| .DHead { border-right: none; } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .DHead { | ||||||
|  |     border-right: none; | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
| @ -1,19 +1,113 @@ | |||||||
| <template> | <template> | ||||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> |   <section v-if="!addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Employee name</pre> |     <h2 v-if="!editable" :class="['customer-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">{{ empl.name }} | ||||||
|  |     </h2> | ||||||
|  |     <input v-if="editable" v-model="empl.name" @change="updateEmployee()" | ||||||
|  |       :class="['data', 'customer-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|     <div class="data-group" id="personal-data"> |     <div class="data-group" id="personal-data"> | ||||||
|       <div class="data-group" id="full-name"> |       <div class="data-group" id="full-name"> | ||||||
|         <div class="data-field" id="ntitle"> |         <div class="data-field" id="ntitle"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Title/-s:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Title/-s:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.title }}</pre> | ||||||
|  |           <input v-if="editable" v-model="empl.title" @change="updateEmployee()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="first-name"> |         <div class="data-field" id="first-name"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">First Name/-s:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">First Name/-s:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.firstName }}</pre> | ||||||
|  |           <input v-if="editable" v-model="empl.firstName" @change="updateEmployee()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="last-name"> |         <div class="data-field" id="last-name"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Last Name/-s:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Last Name/-s:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.lastName }}</pre> | ||||||
|  |           <input v-if="editable" v-model="empl.lastName" @change="updateEmployee()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-group" id="other"> | ||||||
|  |         <div class="data-field" id="id"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||||
|  |           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.primaryID }}</pre> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="pronouns"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Pronouns:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.pronouns }}</pre> | ||||||
|  |           <input v-if="editable" v-model="empl.pronouns" @change="updateEmployee()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="preferred-name"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Preferred Name:</pre> | ||||||
|  |           <pre v-if="!editable" | ||||||
|  |             :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.preferredName }}</pre> | ||||||
|  |           <input v-if="editable" v-model="empl.preferredName" @change="updateEmployee()" | ||||||
|  |             :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="data-group" id="employment-data"> | ||||||
|  |       <div class="data-field" id="customer-id"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||||
|  |         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.customerID }}</pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-field" id="department"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Department:</pre> | ||||||
|  |         <pre v-if="!editable" | ||||||
|  |           :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.department }}</pre> | ||||||
|  |         <select v-if="editable" id="customersDropDownChosenCI" v-model="empl.department" @change="updateDepartmentID()" | ||||||
|  |           :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||||
|  |           <option v-for="depart in departments" :key="depart.primaryID"> | ||||||
|  |             {{ depart.name }} | ||||||
|  |           </option> | ||||||
|  |         </select> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-field" id="job-title"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Job Title:</pre> | ||||||
|  |         <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.jobTitle }}</pre> | ||||||
|  |         <input v-if="editable" v-model="empl.jobTitle" @change="updateEmployee()" | ||||||
|  |           :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="data-group" id="contact-data"> | ||||||
|  |       <div class="data-field" id="phone"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Phone No.:</pre> | ||||||
|  |         <pre v-if="!editable" | ||||||
|  |           :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.phonenumber }}</pre> | ||||||
|  |         <input v-if="editable" v-model="empl.phonenumber" @change="updateEmployee()" | ||||||
|  |           :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |       </div> | ||||||
|  |       <div class="data-field" id="mail"> | ||||||
|  |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">E-Mail:</pre> | ||||||
|  |         <pre v-if="!editable" :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ empl.eMail }}</pre> | ||||||
|  |         <input v-if="editable" v-model="empl.eMail" @change="updateEmployee()" | ||||||
|  |           :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="notes"> | ||||||
|  |       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||||
|  |       <input v-model="empl.notes" :readonly="!editable" @change="updateEmployee()" | ||||||
|  |         :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|  |     </div> | ||||||
|  |   </section> | ||||||
|  |   <section v-if="addBool" :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |     <input v-model="newName" | ||||||
|  |       :class="['data', 'customer-name-input', darkMode ? 'h2-darkmode' : 'h2-lightmode', darkMode ? 'h2-input-darkmode' : 'h2-input-lightmode', 'input']"> | ||||||
|  |     <div class="data-group" id="personal-data"> | ||||||
|  |       <div class="data-group" id="full-name"> | ||||||
|  |         <div class="data-field" id="ntitle"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Title/-s:</pre> | ||||||
|  |           <input v-model="newTitle" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="first-name"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">First Name/-s:</pre> | ||||||
|  |           <input v-model="newFirstName" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |         </div> | ||||||
|  |         <div class="data-field" id="last-name"> | ||||||
|  |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Last Name/-s:</pre> | ||||||
|  |           <input v-model="newLastName" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-group" id="other"> |       <div class="data-group" id="other"> | ||||||
| @ -23,56 +117,302 @@ | |||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="pronouns"> |         <div class="data-field" id="pronouns"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Pronouns:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Pronouns:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <input v-model="newPronouns" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|         <div class="data-field" id="preferred-name"> |         <div class="data-field" id="preferred-name"> | ||||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Preferred Name:</pre> |           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Preferred Name:</pre> | ||||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |           <input v-model="newPreferedName" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="data-group" id="employment-data"> |     <div class="data-group" id="employment-data"> | ||||||
|       <div class="data-field" id="customer-id"> |       <div class="data-field" id="customer-id"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Customer ID:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">{{ chosenCustomerId }}</pre> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-field" id="department"> |       <div class="data-field" id="department"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Department:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Department:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <select id="customersDropDownChosenCI" v-model="newDepartment" @change="updateNewDepartmentID()" | ||||||
|  |           :class="[darkMode ? 'select-darkmode' : 'select-lightmode']"> | ||||||
|  |           <option v-for="depart in departments" :key="depart.primaryID"> | ||||||
|  |             {{ depart.name }} | ||||||
|  |           </option> | ||||||
|  |         </select> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-field" id="job-title"> |       <div class="data-field" id="job-title"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Job Title:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Job Title:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <input v-model="newJobTitle" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="data-group" id="contact-data"> |     <div class="data-group" id="contact-data"> | ||||||
|       <div class="data-field" id="phone"> |       <div class="data-field" id="phone"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Phone No.:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Phone No.:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <input v-model="newPhonenumber" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|       </div> |       </div> | ||||||
|       <div class="data-field" id="mail"> |       <div class="data-field" id="mail"> | ||||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">E-Mail:</pre> |         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">E-Mail:</pre> | ||||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> |         <input v-model="newEMail" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="notes"> |     <div class="notes"> | ||||||
|       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> |       <pre :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> |       <input v-model="newNotes" :class="['data', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes"> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
|  |   <section v-if="addBool" id="saveNewItem"> | ||||||
|  |     <button :class="[darkMode ? 'saveNewItem-darkmode' : 'saveNewItem-lightmode']" @click="addEmployee()">Save</button> | ||||||
|  |   </section> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
|  | const editable = computed(() => store.state.editable); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const chosenCustomerEmployeeId = computed(() => store.state.chosenCustomerEmployeeId); | ||||||
|  | const deleteBool = computed(() => store.state.deleteBool); | ||||||
|  | const addBool = computed(() => store.state.new); | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  | const empl = ref({}); | ||||||
|  | const department = ref({}); | ||||||
|  | const customer = ref({}); | ||||||
|  | const employees = ref([]); | ||||||
|  | const departments = ref([]); | ||||||
|  |  | ||||||
|  | const newName = ref(''); | ||||||
|  | const newPronouns = ref(''); | ||||||
|  | const newTitle = ref(''); | ||||||
|  | const newFirstName = ref(''); | ||||||
|  | const newLastName = ref(''); | ||||||
|  | const newPreferedName = ref(''); | ||||||
|  | const newDepartment = ref(''); | ||||||
|  | const newDepartmentID = ref(''); | ||||||
|  | const newJobTitle = ref(''); | ||||||
|  | const newPhonenumber = ref(''); | ||||||
|  | const newEMail = ref(''); | ||||||
|  | const newNotes = ref(''); | ||||||
|  |  | ||||||
|  | // get employee from id | ||||||
|  | const getEmployeeById = async () => { | ||||||
|  |   if (!addBool.value) { | ||||||
|  |     try { | ||||||
|  |       const response = await Axios.get( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustEmployee/${chosenCustomerEmployeeId.value}` | ||||||
|  |       ); | ||||||
|  |       empl.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // get customer from id | ||||||
|  | const getCustomerById = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get( | ||||||
|  |       `https://${clientsideConfig.url}:${clientsideConfig.port}/api/getCustomerById/${chosenCustomerId.value}` | ||||||
|  |     ); | ||||||
|  |     customer.value = response.data; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //update data | ||||||
|  | const updateEmployee = async () => { | ||||||
|  |   if (empl.value.name.trim() === "") { | ||||||
|  |     alert("Please add an employee name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if employee name already exists | ||||||
|  |     employees.value.forEach(e => { | ||||||
|  |       if (e.name === empl.value.name) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 2) { | ||||||
|  |       alert("This employee name already exists. Please choose an unique employee name or modify respectively delete the old one!"); | ||||||
|  |       empl.value.name = ''; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (empl.value.department.trim() === "") { | ||||||
|  |       alert("Please choose an department!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     if (!validateEMail(empl.value.eMail)) { | ||||||
|  |       alert("Please add a valid email!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     try { | ||||||
|  |       await Axios.put( | ||||||
|  |         `https://${clientsideConfig.url}:${clientsideConfig.port}/api/updateCustEmployee`, | ||||||
|  |         { | ||||||
|  |           primaryID: empl.value.primaryID, | ||||||
|  |           name: empl.value.name, | ||||||
|  |           pronouns: empl.value.pronouns, | ||||||
|  |           title: empl.value.title, | ||||||
|  |           firstName: empl.value.firstName, | ||||||
|  |           lastName: empl.value.lastName, | ||||||
|  |           preferredName: empl.value.preferredName, | ||||||
|  |           department: empl.value.department, | ||||||
|  |           departmentID: empl.value.departmentID, | ||||||
|  |           jobTitle: empl.value.jobTitle, | ||||||
|  |           phonenumber: empl.value.phonenumber, | ||||||
|  |           eMail: empl.value.eMail, | ||||||
|  |           notes: empl.value.notes, | ||||||
|  |         } | ||||||
|  |       ) | ||||||
|  |       await getEmployeeById(); | ||||||
|  |     } catch (err) { | ||||||
|  |       console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // add new employee | ||||||
|  | const addEmployee = async () => { | ||||||
|  |   // check if all input data is valid | ||||||
|  |   if (newName.value.trim() === "") { | ||||||
|  |     alert("Please add an employee name!"); | ||||||
|  |     return; | ||||||
|  |   } else { | ||||||
|  |     var counter = 0; | ||||||
|  |     // check if employee name already exists | ||||||
|  |     employees.value.forEach(c => { | ||||||
|  |       if (c.name === newName.value) { | ||||||
|  |         counter += 1; | ||||||
|  |       } | ||||||
|  |     }); | ||||||
|  |     if (counter == 1) { | ||||||
|  |       alert("This employee name already exists. Please choose an unique employee name or modify respectively delete the old one!"); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   if (!validateEMail(newEMail.value)) { | ||||||
|  |     alert("Please add a valid email!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   if (newDepartment.value.trim() === "") { | ||||||
|  |     alert("Please choose a department!"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.post(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/addCustEmployee`, | ||||||
|  |       { | ||||||
|  |         customerID: chosenCustomerId.value, | ||||||
|  |         customername: customer.value.customername, | ||||||
|  |         name: newName.value, | ||||||
|  |         pronouns: newPronouns.value, | ||||||
|  |         title: newTitle.value, | ||||||
|  |         firstName: newFirstName.value, | ||||||
|  |         lastName: newLastName.value, | ||||||
|  |         preferredName: newPreferedName.value, | ||||||
|  |         department: newDepartment.value, | ||||||
|  |         departmentID: newDepartmentID.value, | ||||||
|  |         jobTitle: newJobTitle.value, | ||||||
|  |         phonenumber: newPhonenumber.value, | ||||||
|  |         eMail: newEMail.value, | ||||||
|  |         notes: newNotes.value, | ||||||
|  |       }); | ||||||
|  |     store.commit('resetStoreNotCustomer'); | ||||||
|  |     store.commit('changeToCustomerEmployeelist'); | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // to validate the email address | ||||||
|  | const validateEMail = (email) => { | ||||||
|  |   const emailRegex = new RegExp(/^[A-Za-z0-9_!#$%&'*+\/=?`{|}~^.-]+@[A-Za-z0-9.-]+$/, "gm"); | ||||||
|  |   if (email === "") { | ||||||
|  |     return true | ||||||
|  |   } | ||||||
|  |   return emailRegex.test(email); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all employees | ||||||
|  | const getEmployees = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustEmployeeByCustomer/${chosenCustomerEmployeeId.value}` | ||||||
|  |     ); | ||||||
|  |     employees.value = response.data; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const confirmDeleteEmployee = async () => { | ||||||
|  |   if (deleteBool.value === true) { | ||||||
|  |     if (confirm("Do you really want to delete this employee? It cannot be undone!")) { | ||||||
|  |       try { | ||||||
|  |         await Axios.delete(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/deleteCustEmployee/${chosenCustomerEmployeeId.value}`); | ||||||
|  |         store.commit('undoDelete'); | ||||||
|  |         store.commit('resetStoreNotCustomer'); | ||||||
|  |         store.commit('changeToCustomerEmployeelist'); | ||||||
|  |       } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |       } | ||||||
|  |     } else { | ||||||
|  |       store.commit('undoDelete'); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all departments | ||||||
|  | const getDepartments = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedDepartmentByCustomer/${chosenCustomerId.value}`); | ||||||
|  |     departments.value = response.data; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // update departmentid if department was changed | ||||||
|  | const updateDepartmentID = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getDprtmntByName/${empl.value.department}`); | ||||||
|  |     department.value = response.data; | ||||||
|  |     empl.value.departmentID = department.value.primaryID; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  |   await updateEmployee(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // update departmentid if department was changed | ||||||
|  | const updateNewDepartmentID = async () => { | ||||||
|  |   try { | ||||||
|  |     const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getDprtmntByName/${newDepartment.value}`); | ||||||
|  |     newDepartmentID.value = response.data.primaryID; | ||||||
|  |   } catch (err) { | ||||||
|  |     console.log(err.response.statusText); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // include delay to avoid 503 error | ||||||
|  | const triggerBackendCallsWithDelay = async (fetchDataFunc) => { | ||||||
|  |   setTimeout(() => { | ||||||
|  |     fetchDataFunc(); | ||||||
|  |   }, 2000); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // include delay to avoid 503 error | ||||||
|  | const triggerBackendCallsWithSmallDelay = async (fetchDataFunc) => { | ||||||
|  |   setTimeout(() => { | ||||||
|  |     fetchDataFunc(); | ||||||
|  |   }, 500); | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -92,9 +432,14 @@ function getItem(item) { | |||||||
| } | } | ||||||
|  |  | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  | watch(deleteBool, confirmDeleteEmployee); | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|   await getSession(); |   getSession(); | ||||||
|  |   await getEmployeeById(); | ||||||
|  |   triggerBackendCallsWithSmallDelay(getDepartments); | ||||||
|  |   triggerBackendCallsWithDelay(getCustomerById); | ||||||
|  |   triggerBackendCallsWithDelay(getEmployees); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -112,15 +457,15 @@ export default { | |||||||
|   margin: 0; |   margin: 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .information { | ||||||
| section { |  | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|  |   width: 100%; | ||||||
|  |   align-items: flex-start; | ||||||
|  |   justify-content: center; | ||||||
|   padding: 1.25rem 1.875rem; |   padding: 1.25rem 1.875rem; | ||||||
|   border-radius: 0.625rem; |   border-radius: 0.625rem; | ||||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); |   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||||
|   align-items: stretch; |  | ||||||
|   justify-content: center; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .section-darkmode { | .section-darkmode { | ||||||
| @ -131,23 +476,97 @@ section { | |||||||
|   background-color: #ffffff; |   background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .h2-input-darkmode { | ||||||
|  |   background-color: #212121; | ||||||
|  | } | ||||||
|  |  | ||||||
| .title { | .h2-input-lightmode { | ||||||
|   padding: 1.25rem 0; |   background-color: #EBEBEB; | ||||||
|   letter-spacing: 0.04rem; | } | ||||||
|  |  | ||||||
|  | .customer-name { | ||||||
|  |   align-self: stretch; | ||||||
|  |   padding: 1rem 0; | ||||||
|  |   margin: 1rem; | ||||||
|  |   letter-spacing: 5%; | ||||||
|   text-decoration-line: underline; |   text-decoration-line: underline; | ||||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; |   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, | ||||||
|  |     sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-darkmode { | .saveNewItem-darkmode { | ||||||
|   color: #ffffff; |   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); | ||||||
| } | } | ||||||
|  |  | ||||||
| .title-lightmode { | .saveNewItem-lightmode { | ||||||
|   color: #000000; |   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; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |   border: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .customer-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-darkmode { | ||||||
|  |   color: #fff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .h2-lightmode { | ||||||
|  |   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; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data-group { | .data-group { | ||||||
|   display: flex; |   display: flex; | ||||||
| @ -241,6 +660,7 @@ section { | |||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   gap: 0.625rem; |   gap: 0.625rem; | ||||||
|  |   width: 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
| .area-title { | .area-title { | ||||||
|  | |||||||
| @ -1,4 +1,14 @@ | |||||||
| <template> | <template> | ||||||
|  |     <section v-if="searchable" :class="['employee-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |         <div :class="['instanceLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Name</div> | ||||||
|  |         <input v-model="nameSearchFilter" @change="filterEmployeesByName()" | ||||||
|  |             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |     </section> | ||||||
|  |     <section v-if="filtered" :class="['employee-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |         <div :class="['instanceLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Department</div> | ||||||
|  |         <input v-model="departmentSearchFilter" @change="filterEmployeesByDepartment()" | ||||||
|  |             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |     </section> | ||||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> |     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> |         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> | ||||||
|         <table class="data-table" id="customer-employee-table"> |         <table class="data-table" id="customer-employee-table"> | ||||||
| @ -16,19 +26,35 @@ | |||||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> |                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||||
|                     Pronouns</th> |                     Pronouns</th> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> |             <tr v-for="empl in employees" :key="empl.primaryID" | ||||||
|  |                 :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> |                     :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||||
|                     ...</td> |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenEmployee(empl.primaryID)"> | ||||||
|  |                         {{ empl.primaryID }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|                     ...</td> |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenEmployee(empl.primaryID)"> | ||||||
|  |                         {{ empl.name }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']"> |                     :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']"> | ||||||
|                     ...</td> |                     <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                         :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                         @click="goToChosenDepartment(empl.departmentID)"> | ||||||
|  |                         {{ empl.department }} | ||||||
|  |                     </nuxt-link> | ||||||
|  |                 </td> | ||||||
|                 <td |                 <td | ||||||
|                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> |                     :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']"> | ||||||
|                     ...</td> |                     {{ empl.pronouns }}</td> | ||||||
|             </tr> |             </tr> | ||||||
|         </table> |         </table> | ||||||
|     </section> |     </section> | ||||||
| @ -39,11 +65,90 @@ | |||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  | const chosenCustomerId = computed(() => store.state.chosenCustomerId); | ||||||
|  | const searchable = computed(() => store.state.searchable); | ||||||
|  | const filtered = computed(() => store.state.filtered); | ||||||
|  | const departmentSearchFilter = ref(''); | ||||||
|  | const nameSearchFilter = ref(''); | ||||||
|  | const employees = ref([]); | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  | const employeeByDepartment = ref([]); | ||||||
|  | const employeeByName = ref([]); | ||||||
|  |  | ||||||
|  | const goToChosenEmployee = (id) => { | ||||||
|  |     store.commit('setChosenCustomerEmployee', id); | ||||||
|  |     store.commit('changeToCustomerEmployee'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const goToChosenDepartment = (id) => { | ||||||
|  |     store.commit('setChosenCustomerDepartment', id); | ||||||
|  |     store.commit('changeToDepartment'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //get employees by the selected customer | ||||||
|  | const getEmployees = async () => { | ||||||
|  |     try { | ||||||
|  |         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustEmployeeByCustomer/${chosenCustomerId.value}`); | ||||||
|  |         employees.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // update search term | ||||||
|  | const updateSearchTerm = async () => { | ||||||
|  |     nameSearchFilter.value = ''; | ||||||
|  |     await getEmployees(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // update filter term | ||||||
|  | const updateFilterTerm = async () => { | ||||||
|  |     departmentSearchFilter.value = ''; | ||||||
|  |     await getEmployees(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all employees based on the searched name | ||||||
|  | const filterEmployeesByName = async () => { | ||||||
|  |     if (nameSearchFilter.value === '') { | ||||||
|  |         await getEmployees(); | ||||||
|  |     } else { | ||||||
|  |         try { | ||||||
|  |             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustEmployeeByName/${nameSearchFilter.value}`); | ||||||
|  |             employeeByName.value = response.data; | ||||||
|  |             employees.value = filterObjectsWithMatchingIds(employees.value, employeeByName.value); | ||||||
|  |         } catch (err) { | ||||||
|  |             console.log(err.response.statusText); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all employees based on the searched department | ||||||
|  | const filterEmployeesByDepartment = async () => { | ||||||
|  |     if (departmentSearchFilter.value === '') { | ||||||
|  |         await getEmployees(); | ||||||
|  |     } else { | ||||||
|  |         try { | ||||||
|  |             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustEmployeeByDprtmntName/${departmentSearchFilter.value}`); | ||||||
|  |             employeeByDepartment.value = response.data; | ||||||
|  |             employees.value = filterObjectsWithMatchingIds(employees.value, employeeByDepartment.value); | ||||||
|  |         } catch (err) { | ||||||
|  |             // console.log(err.response.statusText); | ||||||
|  |             console.log(err); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const filterObjectsWithMatchingIds = (arr1, arr2) => { | ||||||
|  |     return arr1.filter(obj1 => { | ||||||
|  |         return arr2.some(obj2 => obj2.primaryID === obj1.primaryID); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -63,9 +168,12 @@ function getItem(item) { | |||||||
| } | } | ||||||
|  |  | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  | watch(searchable, updateSearchTerm); | ||||||
|  | watch(filtered, updateFilterTerm); | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|     await getSession(); |     getSession(); | ||||||
|  |     await getEmployees(); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -113,7 +221,66 @@ export default { | |||||||
|     color: #000000; |     color: #000000; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .data-darkmode { | ||||||
|  |     background-color: #212121; | ||||||
|  |     color: #fff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .data-lightmode { | ||||||
|  |     background-color: #EBEBEB; | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .employee-search { | ||||||
|  |     display: flex; | ||||||
|  |     align-items: center; | ||||||
|  |     padding: 0.625em 1.875em; | ||||||
|  |     gap: 1.25em; | ||||||
|  |     width: 30.125em; | ||||||
|  |     height: 3.125em; | ||||||
|  |     box-shadow: 0.25em 0.25em 0.25em rgba(0, 0, 0, 0.25); | ||||||
|  |     border-radius: 0.625em; | ||||||
|  |     box-sizing: border-box; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |     border: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #nuxt-link { | ||||||
|  |     text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-darkmode { | ||||||
|  |     color: white; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-lightmode { | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .dataInput { | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: row; | ||||||
|  |     align-items: flex-start; | ||||||
|  |     padding: 0 0.625rem; | ||||||
|  |     border-radius: 0.3125rem; | ||||||
|  |     box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||||
|  |     letter-spacing: 5%; | ||||||
|  |     font: 400 0.75rem/250% Overpass, sans-serif; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .instanceLabel { | ||||||
|  |     width: 5.5625em; | ||||||
|  |     height: 1.875em; | ||||||
|  |     font-family: "Overpass"; | ||||||
|  |     font-style: normal; | ||||||
|  |     font-weight: 400; | ||||||
|  |     font-size: 0.875em; | ||||||
|  |     line-height: 1.875; | ||||||
|  |     letter-spacing: 0.05em; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data-table { | .data-table { | ||||||
|     width: 100%; |     width: 100%; | ||||||
|  | |||||||
| @ -1,4 +1,10 @@ | |||||||
| <template> | <template> | ||||||
|  |     <section v-if="customerSearchable" | ||||||
|  |         :class="['customer-search', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|  |         <div :class="['customerLabel', darkMode ? 'label-darkmode' : 'label-lightmode']">Name</div> | ||||||
|  |         <input v-model="customerSearchFilter" @change="searchCustomer()" | ||||||
|  |             :class="['dataInput', 'input', darkMode ? 'data-darkmode' : 'data-lightmode']"> | ||||||
|  |     </section> | ||||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> |     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|         <table class="data-table" id="customer-table"> |         <table class="data-table" id="customer-table"> | ||||||
|             <tbody> |             <tbody> | ||||||
| @ -11,13 +17,24 @@ | |||||||
|                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |                         :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|                         Name</th> |                         Name</th> | ||||||
|                 </tr> |                 </tr> | ||||||
|                 <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> |                 <tr v-for="cust in customerList" :key="cust.customerID" | ||||||
|  |                     :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||||
|                     <td |                     <td | ||||||
|                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> |                         :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||||
|                         ...</td> |                         <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                             @click="goToChosenCustomer(cust.customerID)"> | ||||||
|  |                             {{ cust.customerID }} | ||||||
|  |                         </nuxt-link> | ||||||
|  |                     </td> | ||||||
|                     <td |                     <td | ||||||
|                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |                         :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||||
|                         ...</td> |                         <nuxt-link to="/customers" id="nuxt-link" class="button" | ||||||
|  |                             :class="[darkMode ? 'button-darkmode' : 'button-lightmode', darkMode ? 'nuxt-link-darkmode' : 'nuxt-link-lightmode']" | ||||||
|  |                             @click="goToChosenCustomer(cust.customerID)"> | ||||||
|  |                             {{ cust.customername }} | ||||||
|  |                         </nuxt-link> | ||||||
|  |                     </td> | ||||||
|                 </tr> |                 </tr> | ||||||
|             </tbody> |             </tbody> | ||||||
|         </table> |         </table> | ||||||
| @ -27,13 +44,53 @@ | |||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted, watch } from 'vue'; | import { ref, onMounted, watch } from 'vue'; | ||||||
|  | import Axios from '../axios.config.js'; | ||||||
|  | import clientsideConfig from '../../clientsideConfig.js'; | ||||||
| import { useStore } from 'vuex'; | import { useStore } from 'vuex'; | ||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
|  | const goToChosenCustomer = (id) => { | ||||||
|  |     store.commit('setChosenCustomer', id); | ||||||
|  |     store.commit('changeToCustomer'); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const darkMode = ref('') | const darkMode = ref('') | ||||||
|  | const customerSearchable = computed(() => store.state.searchable); | ||||||
|  | const customerSearchFilter = ref(''); | ||||||
|  | const customerList = ref([]); | ||||||
|  |  | ||||||
|  | // update search term | ||||||
|  | const updateSearchTerm = async () => { | ||||||
|  |     customerSearchFilter.value = ''; | ||||||
|  |     await getCustomers(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all customers | ||||||
|  | const getCustomers = async () => { | ||||||
|  |     try { | ||||||
|  |         const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getAllCustomers`); | ||||||
|  |         customerList.value = response.data; | ||||||
|  |     } catch (err) { | ||||||
|  |         console.log(err.response.statusText); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //get all customers based on the searched customers name | ||||||
|  | const searchCustomer = async () => { | ||||||
|  |     if (customerSearchFilter.value === '') { | ||||||
|  |         await getCustomers(); | ||||||
|  |     } else { | ||||||
|  |         try { | ||||||
|  |             const response = await Axios.get(`https://${clientsideConfig.url}:${clientsideConfig.port}/api/getSelectedCustomersByName/${customerSearchFilter.value}`); | ||||||
|  |             customerList.value = response.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             console.log(err.response.statusText); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |     const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -53,9 +110,11 @@ function getItem(item) { | |||||||
| } | } | ||||||
|  |  | ||||||
| watch(modeChanged, getSession) | watch(modeChanged, getSession) | ||||||
|  | watch(customerSearchable, updateSearchTerm); | ||||||
|  |  | ||||||
| onMounted(async () => { | onMounted(async () => { | ||||||
|     await getSession(); |     getSession(); | ||||||
|  |     await getCustomers(); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @ -88,6 +147,74 @@ export default { | |||||||
|     background-color: #ffffff; |     background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .customer-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; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .input { | ||||||
|  |     border: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .customerLabel { | ||||||
|  |     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; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #nuxt-link { | ||||||
|  |     text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-darkmode { | ||||||
|  |     color: white; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .nuxt-link-lightmode { | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .data-darkmode { | ||||||
|  |     background-color: #212121; | ||||||
|  |     color: #fff; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .data-lightmode { | ||||||
|  |     background-color: #EBEBEB; | ||||||
|  |     color: #000; | ||||||
|  | } | ||||||
|  |  | ||||||
| .data-table { | .data-table { | ||||||
|     width: 100%; |     width: 100%; | ||||||
|     padding: 0 0.625rem; |     padding: 0 0.625rem; | ||||||
|  | |||||||
| @ -176,7 +176,7 @@ const goToChosenAsset = async (name) => { | |||||||
|     store.commit('changeToAsset'); |     store.commit('changeToAsset'); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| //get all instances based on the searched state | //get all instances based on the searched name | ||||||
| const filterPOIByName = async () => { | const filterPOIByName = async () => { | ||||||
|     if (nameSearchFilter.value === '') { |     if (nameSearchFilter.value === '') { | ||||||
|         await getProductionOrderInstances(); |         await getProductionOrderInstances(); | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| <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"> | <mxfile host="Electron" modified="2024-03-26T21:49:41.086Z" 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="AqTSSHc8H4ak1GACwEHF" version="22.0.3" type="device" pages="2"> | ||||||
|   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> |   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> | ||||||
|     <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"> |     <mxGraphModel dx="411" 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> |       <root> | ||||||
|         <mxCell id="0" /> |         <mxCell id="0" /> | ||||||
|         <mxCell id="1" parent="0" /> |         <mxCell id="1" parent="0" /> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-1" value="customers" 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=#94FF4D;" parent="1" vertex="1"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-1" value="customers" 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=#94FF4D;" parent="1" vertex="1"> | ||||||
|           <mxGeometry x="1060" y="-1240" width="120" height="300" as="geometry" /> |           <mxGeometry x="1060" y="-1240" width="120" height="600" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="WukdXvazNq34soQIU5Al-126" value="customerID*" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="WukdXvazNq34soQIU5Al-126" value="customerID*" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="30" width="120" height="30" as="geometry" /> |           <mxGeometry y="30" width="120" height="30" as="geometry" /> | ||||||
| @ -19,21 +19,51 @@ | |||||||
|         <mxCell id="g533v6kp8f2wI3S2lvbX-2" value="EMail" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="g533v6kp8f2wI3S2lvbX-2" value="EMail" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="120" width="120" height="30" as="geometry" /> |           <mxGeometry y="120" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="g533v6kp8f2wI3S2lvbX-1" value="phonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-7" value="secondEMail" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="150" width="120" height="30" as="geometry" /> |           <mxGeometry y="150" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-4" value="<div>address</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-8" value="thirdEMail" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="180" width="120" height="30" as="geometry" /> |           <mxGeometry y="180" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-16" value="postcode" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="g533v6kp8f2wI3S2lvbX-1" value="phonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="210" width="120" height="30" as="geometry" /> |           <mxGeometry y="210" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-15" value="city" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-10" value="secondPhonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="240" width="120" height="30" as="geometry" /> |           <mxGeometry y="240" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="jym2pQnfcZ--NBFUidHV-1" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-9" value="thirdPhonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="270" width="120" height="30" as="geometry" /> |           <mxGeometry y="270" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|  |         <mxCell id="DauqCNUrC7Z9yIe88X-r-4" value="<div>address</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="300" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="DauqCNUrC7Z9yIe88X-r-16" value="postcode" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="330" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="DauqCNUrC7Z9yIe88X-r-15" value="city" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="360" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="jym2pQnfcZ--NBFUidHV-1" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="390" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-1" value="<div>secondAddress</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="420" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-2" value="<div>secondPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="450" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-3" value="<div>secondCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="480" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-4" value="thirdAddress" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="510" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-5" value="<div>thirdPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="540" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-6" value="<div>thirdCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="570" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-18" value="masterMaintenanceVisits" 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"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-18" value="masterMaintenanceVisits" 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="470" y="-560" width="140" height="270" as="geometry" /> |           <mxGeometry x="470" y="-560" width="140" height="270" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
| @ -341,7 +371,7 @@ | |||||||
|           <mxGeometry y="300" width="140" height="30" as="geometry" /> |           <mxGeometry y="300" width="140" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="-K6vikdffkJQkB35vOLp-1" value="users" 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;" parent="1" vertex="1"> |         <mxCell id="-K6vikdffkJQkB35vOLp-1" value="users" 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;" parent="1" vertex="1"> | ||||||
|           <mxGeometry y="-1570" width="150" height="540" as="geometry" /> |           <mxGeometry y="-1570" width="150" height="510" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="-K6vikdffkJQkB35vOLp-2" value="id" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="-K6vikdffkJQkB35vOLp-2" value="id" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="30" width="150" height="30" as="geometry" /> |           <mxGeometry y="30" width="150" height="30" as="geometry" /> | ||||||
| @ -379,21 +409,18 @@ | |||||||
|         <mxCell id="ioDwbpDVXUhE7vu6D29p-8" value="adminBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="ioDwbpDVXUhE7vu6D29p-8" value="adminBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="360" width="150" height="30" as="geometry" /> |           <mxGeometry y="360" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="ioDwbpDVXUhE7vu6D29p-9" value="technician1Bool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="ioDwbpDVXUhE7vu6D29p-10" value="technicianBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="390" width="150" height="30" as="geometry" /> |           <mxGeometry y="390" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="ioDwbpDVXUhE7vu6D29p-10" value="technician2Bool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="ioDwbpDVXUhE7vu6D29p-12" value="readerBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="420" width="150" height="30" as="geometry" /> |           <mxGeometry y="420" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="ioDwbpDVXUhE7vu6D29p-11" value="technicianMonitoringBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="YxEx8JsSJKZlR_KfoIc3-1" value="darkModeBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="450" width="150" height="30" as="geometry" /> |           <mxGeometry y="450" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="ioDwbpDVXUhE7vu6D29p-12" value="merchantBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="ESQ1TkVnqClHsEl95Prr-1" value="language" 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;" vertex="1" parent="-K6vikdffkJQkB35vOLp-1"> | ||||||
|           <mxGeometry y="480" width="150" height="30" as="geometry" /> |           <mxGeometry y="480" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="UjUgOsnL5tA5fsC7Xk2_-1" value="internBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |  | ||||||
|           <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"> |         <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="840" as="geometry" /> |           <mxGeometry x="2040" y="-560" width="140" height="840" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| <mxfile host="Electron" modified="2024-03-26T21:49:41.086Z" 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="AqTSSHc8H4ak1GACwEHF" version="22.0.3" type="device" pages="2"> | <mxfile host="Electron" modified="2024-04-06T12:57:42.412Z" 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="LeSh1zP1QTatGoux1_Wi" version="22.0.3" type="device" pages="2"> | ||||||
|   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> |   <diagram name="Seite-1" id="VLuSDTVFFHJCdRpH-1WC"> | ||||||
|     <mxGraphModel dx="411" 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="1020" 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> |       <root> | ||||||
|         <mxCell id="0" /> |         <mxCell id="0" /> | ||||||
|         <mxCell id="1" parent="0" /> |         <mxCell id="1" parent="0" /> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-1" value="customers" 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=#94FF4D;" parent="1" vertex="1"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-1" value="customers" 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=#94FF4D;" parent="1" vertex="1"> | ||||||
|           <mxGeometry x="1060" y="-1240" width="120" height="600" as="geometry" /> |           <mxGeometry x="1060" y="-1240" width="120" height="690" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="WukdXvazNq34soQIU5Al-126" value="customerID*" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="WukdXvazNq34soQIU5Al-126" value="customerID*" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="30" width="120" height="30" as="geometry" /> |           <mxGeometry y="30" width="120" height="30" as="geometry" /> | ||||||
| @ -34,36 +34,45 @@ | |||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-9" value="thirdPhonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-9" value="thirdPhonenumber" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="270" width="120" height="30" as="geometry" /> |           <mxGeometry y="270" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-4" value="<div>address</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-4" value="<div>street</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="300" width="120" height="30" as="geometry" /> |           <mxGeometry y="300" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-16" value="postcode" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="8YviqBC1L0ecwHDw8wwW-1" value="<div>no</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="330" width="120" height="30" as="geometry" /> |           <mxGeometry y="330" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-15" value="city" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-16" value="postcode" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="360" width="120" height="30" as="geometry" /> |           <mxGeometry y="360" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="jym2pQnfcZ--NBFUidHV-1" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-15" value="city" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="390" width="120" height="30" as="geometry" /> |           <mxGeometry y="390" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-1" value="<div>secondAddress</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="8YviqBC1L0ecwHDw8wwW-2" value="<div>secondStreet</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="420" width="120" height="30" as="geometry" /> |           <mxGeometry y="420" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-2" value="<div>secondPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="8YviqBC1L0ecwHDw8wwW-3" value="<div>secondNo</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="450" width="120" height="30" as="geometry" /> |           <mxGeometry y="450" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-3" value="<div>secondCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-2" value="<div>secondPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="480" width="120" height="30" as="geometry" /> |           <mxGeometry y="480" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-4" value="thirdAddress" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-3" value="<div>secondCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="510" width="120" height="30" as="geometry" /> |           <mxGeometry y="510" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-5" value="<div>thirdPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-1" value="<div>thirdStreet</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="540" width="120" height="30" as="geometry" /> |           <mxGeometry y="540" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="EQ1vHiXafF4bEUqPIK37-6" value="<div>thirdCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> |         <mxCell id="EQ1vHiXafF4bEUqPIK37-4" value="thirdNo" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|           <mxGeometry y="570" width="120" height="30" as="geometry" /> |           <mxGeometry y="570" width="120" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-5" value="<div>thirdPostcode</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="600" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="EQ1vHiXafF4bEUqPIK37-6" value="<div>thirdCity</div>" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="630" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="jym2pQnfcZ--NBFUidHV-1" 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="DauqCNUrC7Z9yIe88X-r-1" vertex="1"> | ||||||
|  |           <mxGeometry y="660" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|         <mxCell id="DauqCNUrC7Z9yIe88X-r-18" value="masterMaintenanceVisits" 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"> |         <mxCell id="DauqCNUrC7Z9yIe88X-r-18" value="masterMaintenanceVisits" 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="470" y="-560" width="140" height="270" as="geometry" /> |           <mxGeometry x="470" y="-560" width="140" height="270" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
| @ -418,7 +427,7 @@ | |||||||
|         <mxCell id="YxEx8JsSJKZlR_KfoIc3-1" value="darkModeBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> |         <mxCell id="YxEx8JsSJKZlR_KfoIc3-1" value="darkModeBool" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="450" width="150" height="30" as="geometry" /> |           <mxGeometry y="450" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|         <mxCell id="ESQ1TkVnqClHsEl95Prr-1" value="language" 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;" vertex="1" parent="-K6vikdffkJQkB35vOLp-1"> |         <mxCell id="ESQ1TkVnqClHsEl95Prr-1" value="language" 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="-K6vikdffkJQkB35vOLp-1" vertex="1"> | ||||||
|           <mxGeometry y="480" width="150" height="30" as="geometry" /> |           <mxGeometry y="480" width="150" height="30" as="geometry" /> | ||||||
|         </mxCell> |         </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"> |         <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"> | ||||||
| @ -922,6 +931,94 @@ | |||||||
|         <mxCell id="MZUjV4dI-UfRvC4hdJyc-36" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;" parent="1" source="WukdXvazNq34soQIU5Al-49" target="WukdXvazNq34soQIU5Al-58" edge="1"> |         <mxCell id="MZUjV4dI-UfRvC4hdJyc-36" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;" parent="1" source="WukdXvazNq34soQIU5Al-49" target="WukdXvazNq34soQIU5Al-58" edge="1"> | ||||||
|           <mxGeometry relative="1" as="geometry" /> |           <mxGeometry relative="1" as="geometry" /> | ||||||
|         </mxCell> |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-1" value="customeremployees" 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=#94FF4D;" parent="1" vertex="1"> | ||||||
|  |           <mxGeometry x="2140" y="-1380" width="120" height="480" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-24" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="30" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-2" value="customerID" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="60" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-3" value="customername" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="90" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-5" value="name" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="120" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-6" value="pronouns" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="150" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-8" value="title" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="180" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-9" value="firstName" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="210" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-10" value="lastName" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="240" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-11" value="<div>preferredName</div>" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="270" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-26" value="<div>department</div>" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="300" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-45" value="<div>departmentID</div>" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="330" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-12" value="<div>jobTitle</div>" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="360" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-13" value="phonenumber" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="390" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-7" value="eMail" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="420" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-14" 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="ZQnjGdimb5Qvt3okSkAT-1" vertex="1"> | ||||||
|  |           <mxGeometry y="450" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-25" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;" parent="1" source="WukdXvazNq34soQIU5Al-126" target="ZQnjGdimb5Qvt3okSkAT-2" edge="1"> | ||||||
|  |           <mxGeometry relative="1" as="geometry"> | ||||||
|  |             <Array as="points"> | ||||||
|  |               <mxPoint x="1380" y="-1195" /> | ||||||
|  |               <mxPoint x="1380" y="-1305" /> | ||||||
|  |             </Array> | ||||||
|  |           </mxGeometry> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-27" value="customerdepartment" 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=#94FF4D;" parent="1" vertex="1"> | ||||||
|  |           <mxGeometry x="2330" y="-1380" width="120" height="210" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-28" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="30" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-29" value="customerID" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="60" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-30" value="customername" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="90" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-31" value="name" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="120" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-32" value="head" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="150" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-41" 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="ZQnjGdimb5Qvt3okSkAT-27" vertex="1"> | ||||||
|  |           <mxGeometry y="180" width="120" height="30" as="geometry" /> | ||||||
|  |         </mxCell> | ||||||
|  |         <mxCell id="ZQnjGdimb5Qvt3okSkAT-44" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;" parent="1" target="ZQnjGdimb5Qvt3okSkAT-29" edge="1"> | ||||||
|  |           <mxGeometry relative="1" as="geometry"> | ||||||
|  |             <mxPoint x="1190" y="-1185" as="sourcePoint" /> | ||||||
|  |             <mxPoint x="2150" y="-1295" as="targetPoint" /> | ||||||
|  |             <Array as="points"> | ||||||
|  |               <mxPoint x="1390" y="-1185" /> | ||||||
|  |               <mxPoint x="1390" y="-1295" /> | ||||||
|  |               <mxPoint x="2330" y="-1295" /> | ||||||
|  |             </Array> | ||||||
|  |           </mxGeometry> | ||||||
|  |         </mxCell> | ||||||
|       </root> |       </root> | ||||||
|     </mxGraphModel> |     </mxGraphModel> | ||||||
|   </diagram> |   </diagram> | ||||||
|  | |||||||
| @ -51,8 +51,8 @@ | |||||||
|             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Solutions</pre> |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Solutions</pre> | ||||||
|         </Transition> |         </Transition> | ||||||
|       </button> |       </button> | ||||||
|       <button v-if="attachmentsIcon" :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" |       <button v-if="attachmentsIcon && false" | ||||||
|         id="attachments"> |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="attachments"> | ||||||
|         <div class="icon" id="attachments-icon"> |         <div class="icon" id="attachments-icon"> | ||||||
|           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|             src="/icons/actionbar-icons/Attachments-Icon.svg" /> |             src="/icons/actionbar-icons/Attachments-Icon.svg" /> | ||||||
| @ -62,7 +62,8 @@ | |||||||
|             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Attachments</pre> |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Attachments</pre> | ||||||
|         </Transition> |         </Transition> | ||||||
|       </button> |       </button> | ||||||
|       <button v-if="sellIcon" :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="sell"> |       <button v-if="sellIcon && false" :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" | ||||||
|  |         id="sell"> | ||||||
|         <div class="icon" id="sell-icon"> |         <div class="icon" id="sell-icon"> | ||||||
|           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|             src="/icons/actionbar-icons/Sell-Icon.svg" /> |             src="/icons/actionbar-icons/Sell-Icon.svg" /> | ||||||
| @ -72,8 +73,8 @@ | |||||||
|             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Sell</pre> |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Sell</pre> | ||||||
|         </Transition> |         </Transition> | ||||||
|       </button> |       </button> | ||||||
|       <button v-if="archiveIcon" :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" |       <button v-if="archiveIcon && false" | ||||||
|         id="archive"> |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="archive"> | ||||||
|         <div class="icon" id="archive-icon"> |         <div class="icon" id="archive-icon"> | ||||||
|           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|             src="/icons/actionbar-icons/Archive-Icon.svg" /> |             src="/icons/actionbar-icons/Archive-Icon.svg" /> | ||||||
| @ -106,6 +107,30 @@ | |||||||
|             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Instance</pre> |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Instance</pre> | ||||||
|         </Transition> |         </Transition> | ||||||
|       </button> |       </button> | ||||||
|  |       <button v-if="addEmployeeIcon && !loggedInUserReaderBool" | ||||||
|  |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="new-employee" | ||||||
|  |         @click="addEmployee"> | ||||||
|  |         <div class="icon" id="new-icon"> | ||||||
|  |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|  |             src="/icons/actionbar-icons/Add-New-Icon.svg" /> | ||||||
|  |         </div> | ||||||
|  |         <Transition name="fade"> | ||||||
|  |           <pre v-if="isExpanded" | ||||||
|  |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">New</pre> | ||||||
|  |         </Transition> | ||||||
|  |       </button> | ||||||
|  |       <button v-if="addDepartmentIcon && !loggedInUserReaderBool" | ||||||
|  |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="new-department" | ||||||
|  |         @click="addDepartment"> | ||||||
|  |         <div class="icon" id="new-icon"> | ||||||
|  |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|  |             src="/icons/actionbar-icons/Add-New-Icon.svg" /> | ||||||
|  |         </div> | ||||||
|  |         <Transition name="fade"> | ||||||
|  |           <pre v-if="isExpanded" | ||||||
|  |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">New</pre> | ||||||
|  |         </Transition> | ||||||
|  |       </button> | ||||||
|       <router-link v-if="addSolutionIcon && !loggedInUserReaderBool" to="/solutions" class="button" |       <router-link v-if="addSolutionIcon && !loggedInUserReaderBool" to="/solutions" class="button" | ||||||
|         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="solutions-button"> |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="solutions-button"> | ||||||
|         <button :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="new-solution" |         <button :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="new-solution" | ||||||
| @ -120,8 +145,9 @@ | |||||||
|           </Transition> |           </Transition> | ||||||
|         </button> |         </button> | ||||||
|       </router-link> |       </router-link> | ||||||
|       <button v-if="notAllInstancesIcon && !addIcon" :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" |       <button v-if="notAllInstancesIcon && !addIcon" | ||||||
|         id="allInstances" @click="changeToAllInstances"> |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="allInstances" | ||||||
|  |         @click="changeToAllInstances"> | ||||||
|         <div class="icon" id="instances-icon"> |         <div class="icon" id="instances-icon"> | ||||||
|           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|             src="/icons/actionbar-icons/Instances-Icon.svg" /> |             src="/icons/actionbar-icons/Instances-Icon.svg" /> | ||||||
| @ -131,6 +157,30 @@ | |||||||
|             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">See all</pre> |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">See all</pre> | ||||||
|         </Transition> |         </Transition> | ||||||
|       </button> |       </button> | ||||||
|  |       <button v-if="departmentsIcon && !loggedInUserReaderBool" | ||||||
|  |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="departments" | ||||||
|  |         @click="changeToDepartments"> | ||||||
|  |         <div class="icon" id="departments-icon"> | ||||||
|  |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|  |             src="/icons/actionbar-icons/Departments-Icon.svg" /> | ||||||
|  |         </div> | ||||||
|  |         <Transition name="fade"> | ||||||
|  |           <pre v-if="isExpanded" | ||||||
|  |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Departments</pre> | ||||||
|  |         </Transition> | ||||||
|  |       </button> | ||||||
|  |       <button v-if="employeesIcon && !loggedInUserReaderBool" | ||||||
|  |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="employees" | ||||||
|  |         @click="changeToEmployees"> | ||||||
|  |         <div class="icon" id="employees-icon"> | ||||||
|  |           <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|  |             src="/icons/actionbar-icons/Employees-Icon.svg" /> | ||||||
|  |         </div> | ||||||
|  |         <Transition name="fade"> | ||||||
|  |           <pre v-if="isExpanded" | ||||||
|  |             :class="['label', loggedInUserDarkModeBoolean ? 'label-darkmode' : 'label-lightmode']">Employees</pre> | ||||||
|  |         </Transition> | ||||||
|  |       </button> | ||||||
|       <button v-if="editIcon && !loggedInUserReaderBool" |       <button v-if="editIcon && !loggedInUserReaderBool" | ||||||
|         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="edit" |         :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="edit" | ||||||
|         @click="toggleEditable"> |         @click="toggleEditable"> | ||||||
| @ -177,6 +227,8 @@ import { computed } from 'vue'; | |||||||
| const changeToSet = computed(() => store.state.changeToSet); | const changeToSet = computed(() => store.state.changeToSet); | ||||||
| const addIcon = computed(() => store.state.addIcon); | const addIcon = computed(() => store.state.addIcon); | ||||||
| const addInstanceIcon = computed(() => store.state.addInstanceIcon); | const addInstanceIcon = computed(() => store.state.addInstanceIcon); | ||||||
|  | const addEmployeeIcon = computed(() => store.state.addEmployeeIcon); | ||||||
|  | const addDepartmentIcon = computed(() => store.state.addDepartmentIcon); | ||||||
| const addSolutionIcon = computed(() => store.state.addSolutionIcon); | const addSolutionIcon = computed(() => store.state.addSolutionIcon); | ||||||
| const solutionIcon = computed(() => store.state.solutionIcon); | const solutionIcon = computed(() => store.state.solutionIcon); | ||||||
| const filterIcon = computed(() => store.state.filterIcon); | const filterIcon = computed(() => store.state.filterIcon); | ||||||
| @ -186,6 +238,8 @@ const attachmentsIcon = computed(() => store.state.attachmentsIcon); | |||||||
| const sellIcon = computed(() => store.state.sellIcon); | const sellIcon = computed(() => store.state.sellIcon); | ||||||
| const archiveIcon = computed(() => store.state.archiveIcon); | const archiveIcon = computed(() => store.state.archiveIcon); | ||||||
| const editIcon = computed(() => store.state.editIcon); | const editIcon = computed(() => store.state.editIcon); | ||||||
|  | const departmentsIcon = computed(() => store.state.departmentsIcon); | ||||||
|  | const employeesIcon = computed(() => store.state.employeesIcon); | ||||||
| const editUserIcon = computed(() => store.state.editUserIcon); | const editUserIcon = computed(() => store.state.editUserIcon); | ||||||
| const deleteIcon = computed(() => store.state.deleteIcon); | const deleteIcon = computed(() => store.state.deleteIcon); | ||||||
| const notAllInstancesIcon = computed(() => store.state.notAllInstancesIcon); | const notAllInstancesIcon = computed(() => store.state.notAllInstancesIcon); | ||||||
| @ -230,9 +284,25 @@ const addInstance = () => { | |||||||
|   store.commit('addInstance'); |   store.commit('addInstance'); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | const addDepartment = () => { | ||||||
|  |   store.commit('addDepartment'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const addEmployee = () => { | ||||||
|  |   store.commit('addEmployee'); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const changeToSolutions = () => { | const changeToSolutions = () => { | ||||||
|   store.commit('changeToSolutionlistAsset'); |   store.commit('changeToSolutionlistAsset'); | ||||||
| } | }; | ||||||
|  |  | ||||||
|  | const changeToDepartments = () => { | ||||||
|  |   store.commit('changeToDepartmentlist'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const changeToEmployees = () => { | ||||||
|  |   store.commit('changeToCustomerEmployeelist'); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const changeToInstancelist = () => { | const changeToInstancelist = () => { | ||||||
|   store.commit('deactivateSearch'); |   store.commit('deactivateSearch'); | ||||||
|  | |||||||
| @ -77,7 +77,8 @@ | |||||||
|           </Transition> |           </Transition> | ||||||
|         </router-link> |         </router-link> | ||||||
|         <router-link to="/customers" class="button" |         <router-link to="/customers" class="button" | ||||||
|           :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" id="customers-button"> |           :class="[loggedInUserDarkModeBoolean ? 'button-darkmode' : 'button-lightmode']" @click="defaultCustomerPage()" | ||||||
|  |           id="customers-button"> | ||||||
|           <div class="icon" id="customers-icon"> |           <div class="icon" id="customers-icon"> | ||||||
|             <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" |             <img :class="[loggedInUserDarkModeBoolean ? 'img-darkmode' : 'img-lightmode']" loading="lazy" | ||||||
|               src="/icons/navbar-icons/Customers-Icon.svg" /> |               src="/icons/navbar-icons/Customers-Icon.svg" /> | ||||||
| @ -143,6 +144,11 @@ const defaultEmployeesPage = () => { | |||||||
|   store.commit('changeToEmployeelist') |   store.commit('changeToEmployeelist') | ||||||
| } | } | ||||||
|  |  | ||||||
|  | const defaultCustomerPage = () => { | ||||||
|  |   store.commit('resetStore'); | ||||||
|  |   store.commit('changeToCustomerlist') | ||||||
|  | } | ||||||
|  |  | ||||||
| const ToggleSidebar = () => { | const ToggleSidebar = () => { | ||||||
|   isExpanded.value = !isExpanded.value; |   isExpanded.value = !isExpanded.value; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -1,17 +1,20 @@ | |||||||
| <template> | <template> | ||||||
|   <section id="content"> |   <section id="content"> | ||||||
|     <div id="content-header"> |     <div id="content-header"> | ||||||
|       <h1 :class="[loggedInUserDarkModeBoolean ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Customers</h1> |       <router-link to="/customers" class="button" id="customers-button" @click="defaultCustomerPage()"> | ||||||
|  |         <h1 :class="[loggedInUserDarkModeBoolean ? 'h1-darkmode' : 'h1-lightmode']" id="page-name">Customers</h1> | ||||||
|  |       </router-link> | ||||||
|     </div> |     </div> | ||||||
|     <div id="content-body"> |     <div id="content-body"> | ||||||
|       <CustomerTable v-if="onCustomerlist" /> |       <CustomerTable v-if="onCustomerlist" /> | ||||||
|       <Customer v-if="onCustomer" /> |       <Customer v-if="onCustomer" /> | ||||||
|       <CustomerQuickAccess v-if="onCustomer" /> |       <!-- <CustomerQuickAccess v-if="onCustomer" /> --> | ||||||
|       <CustomerEmployeeList v-if="onEmployeelist" /> |       <ClientSearch v-if="onCustomerEmployeelist || onDepartmentlist" /> | ||||||
|       <CustomerEmployee v-if="onEmployee" /> |       <CustomerEmployeeList v-if="onCustomerEmployeelist" /> | ||||||
|  |       <CustomerEmployee v-if="onCustomerEmployee" /> | ||||||
|       <CustomerDepartmentList v-if="onDepartmentlist" /> |       <CustomerDepartmentList v-if="onDepartmentlist" /> | ||||||
|       <CustomerDepartment v-if="onDepartment" /> |       <CustomerDepartment v-if="onDepartment" /> | ||||||
|       <CustomerDepartmentEmployeeList v-if="onDepartment" /> |       <CustomerDepartmentEmployeeList v-if="onDepartment && !addBool" /> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
| </template> | </template> | ||||||
| @ -22,6 +25,7 @@ import { ref, onMounted, watch } from 'vue'; | |||||||
| import CustomerTable from "../components/server/CustomerTable.vue"; | import CustomerTable from "../components/server/CustomerTable.vue"; | ||||||
| import Customer from "../components/server/Customer.vue"; | import Customer from "../components/server/Customer.vue"; | ||||||
| import CustomerQuickAccess from "../components/server/CustomerQuickAccess.vue"; | import CustomerQuickAccess from "../components/server/CustomerQuickAccess.vue"; | ||||||
|  | import ClientSearch from "../components/ClientSearch.vue"; | ||||||
| import CustomerEmployeeList from "../components/server/CustomerEmployeeList.vue"; | import CustomerEmployeeList from "../components/server/CustomerEmployeeList.vue"; | ||||||
| import CustomerEmployee from "../components/server/CustomerEmployee.vue"; | import CustomerEmployee from "../components/server/CustomerEmployee.vue"; | ||||||
| import CustomerDepartmentList from '~/components/server/CustomerDepartmentList.vue'; | import CustomerDepartmentList from '~/components/server/CustomerDepartmentList.vue'; | ||||||
| @ -31,6 +35,14 @@ import { useStore } from 'vuex'; | |||||||
| import { computed } from 'vue'; | import { computed } from 'vue'; | ||||||
|  |  | ||||||
| const store = useStore(); | const store = useStore(); | ||||||
|  | const addBool = computed(() => store.state.new); | ||||||
|  |  | ||||||
|  | const onCustomerlist = computed(() => store.state.onCustomerlist); | ||||||
|  | const onCustomer = computed(() => store.state.onCustomer); | ||||||
|  | const onCustomerEmployeelist = computed(() => store.state.onCustomerEmployeelist); | ||||||
|  | const onCustomerEmployee = computed(() => store.state.onCustomerEmployee); | ||||||
|  | const onDepartmentlist = computed(() => store.state.onDepartmentlist); | ||||||
|  | const onDepartment = computed(() => store.state.onDepartment); | ||||||
| const modeChanged = computed(() => store.state.updateDarkMode); | const modeChanged = computed(() => store.state.updateDarkMode); | ||||||
|  |  | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
| @ -38,15 +50,12 @@ definePageMeta({ | |||||||
|   title: 'Customers' |   title: 'Customers' | ||||||
| }) | }) | ||||||
|  |  | ||||||
| const loggedInUserDarkModeBoolean = ref(''); | const defaultCustomerPage = () => { | ||||||
|  |   store.commit('resetStore'); | ||||||
|  |   store.commit('changeToCustomerlist') | ||||||
|  | } | ||||||
|  |  | ||||||
| // to render the right components | const loggedInUserDarkModeBoolean = ref(''); | ||||||
| const onCustomerlist = ref(true) |  | ||||||
| const onCustomer = ref(true) |  | ||||||
| const onEmployeelist = ref(true) |  | ||||||
| const onEmployee = ref(true) |  | ||||||
| const onDepartmentlist = ref(true) |  | ||||||
| const onDepartment = ref(true) |  | ||||||
|  |  | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); |   const loggedInUserDarkModeBool = getItem('logged-in-user-darkMode'); | ||||||
| @ -106,9 +115,14 @@ export default { | |||||||
|   height: 3.125rem; |   height: 3.125rem; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .button { | ||||||
|  |   text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
| #page-name { | #page-name { | ||||||
|   letter-spacing: 5%; |   letter-spacing: 5%; | ||||||
|   font: 400 1.5rem/125% Overpass, -apple-system, Roboto, Helvetica, sans-serif; |   font: 400 1.5rem/125% Overpass, -apple-system, Roboto, Helvetica, sans-serif; | ||||||
|  |   text-decoration: underline; | ||||||
| } | } | ||||||
|  |  | ||||||
| .h1-darkmode { | .h1-darkmode { | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
|     </div> |     </div> | ||||||
|     <div id="content-body"> |     <div id="content-body"> | ||||||
|       <Dashboard /> |       <Dashboard /> | ||||||
|       <QuickAccess /> |       <!-- <QuickAccess /> --> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
| </template> | </template> | ||||||
|  | |||||||
							
								
								
									
										478
									
								
								plugins/vuex.js
									
									
									
									
									
								
							
							
						
						
									
										478
									
								
								plugins/vuex.js
									
									
									
									
									
								
							| @ -24,6 +24,10 @@ const store = createStore({ | |||||||
|             attachmentsIcon: false, |             attachmentsIcon: false, | ||||||
|             sellIcon: false, |             sellIcon: false, | ||||||
|             archiveIcon: false, |             archiveIcon: false, | ||||||
|  |             departmentsIcon: false, | ||||||
|  |             addEmployeeIcon: false, | ||||||
|  |             addDepartmentIcon: false, | ||||||
|  |             employeesIcon: false, | ||||||
|             editIcon: false, |             editIcon: false, | ||||||
|             editUserIcon: false, |             editUserIcon: false, | ||||||
|             deleteIcon: false, |             deleteIcon: false, | ||||||
| @ -149,6 +153,16 @@ const store = createStore({ | |||||||
|             newCityEmp: '', |             newCityEmp: '', | ||||||
|             newPostcodeEmp: '', |             newPostcodeEmp: '', | ||||||
|  |  | ||||||
|  |             onCustomerlist: true, | ||||||
|  |             onCustomer: false, | ||||||
|  |             onCustomerEmployeelist: false, | ||||||
|  |             onCustomerEmployee: false, | ||||||
|  |             onDepartmentlist: false, | ||||||
|  |             onDepartment: false, | ||||||
|  |             chosenCustomerId: -1, | ||||||
|  |             chosenCustomerEmployeeId: -1, | ||||||
|  |             chosenDepartmentId: -1, | ||||||
|  |  | ||||||
|             loggedInUserId: '', |             loggedInUserId: '', | ||||||
|             loggedInUserUsername: '', |             loggedInUserUsername: '', | ||||||
|             loggedInUserRegistered: '', |             loggedInUserRegistered: '', | ||||||
| @ -262,6 +276,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -282,6 +300,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -302,6 +324,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -322,6 +348,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -345,6 +375,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -366,6 +400,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -387,6 +425,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -408,6 +450,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = true |             state.notAllInstancesIcon = true | ||||||
| @ -429,6 +475,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = true |             state.archiveIcon = true | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = true |             state.notAllInstancesIcon = true | ||||||
| @ -465,6 +515,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -484,6 +538,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -503,6 +561,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -524,6 +586,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -543,6 +609,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -562,6 +632,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -584,6 +658,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -604,6 +682,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = true |             state.archiveIcon = true | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -624,6 +706,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = true |             state.sellIcon = true | ||||||
|             state.archiveIcon = true |             state.archiveIcon = true | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -645,6 +731,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -664,6 +754,174 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = true |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = true | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |  | ||||||
|  |         // functions to change the customer pages | ||||||
|  |         changeToCustomerlist(state) { | ||||||
|  |             state.onCustomerlist = true | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|  |  | ||||||
|  |             state.addIcon = true | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = false | ||||||
|  |             state.searchIcon = true | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = false | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |         changeToCustomer(state) { | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = true | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|  |  | ||||||
|  |             state.addIcon = false | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = false | ||||||
|  |             state.searchIcon = false | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = true | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = true | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = true | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |         changeToCustomerEmployeelist(state) { | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = true | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|  |  | ||||||
|  |             state.addIcon = false | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = true | ||||||
|  |             state.searchIcon = true | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = true | ||||||
|  |             state.employeesIcon = false | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = false | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |         changeToCustomerEmployee(state) { | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = true | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|  |  | ||||||
|  |             state.addIcon = false | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = false | ||||||
|  |             state.searchIcon = false | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = true | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |         changeToDepartmentlist(state) { | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = true | ||||||
|  |             state.onDepartment = false | ||||||
|  |  | ||||||
|  |             state.addIcon = false | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = false | ||||||
|  |             state.searchIcon = true | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = true | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|  |             state.editUserIcon = false | ||||||
|  |             state.deleteIcon = false | ||||||
|  |             state.notAllInstancesIcon = false | ||||||
|  |         }, | ||||||
|  |         changeToDepartment(state) { | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = true | ||||||
|  |  | ||||||
|  |             state.addIcon = false | ||||||
|  |             state.addSolutionIcon = false | ||||||
|  |             state.solutionIcon = false | ||||||
|  |             state.addInstanceIcon = false | ||||||
|  |             state.filterIcon = false | ||||||
|  |             state.searchIcon = false | ||||||
|  |             state.instancesIcon = false | ||||||
|  |             state.attachmentsIcon = false | ||||||
|  |             state.sellIcon = false | ||||||
|  |             state.archiveIcon = false | ||||||
|  |             state.editIcon = true | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = false |             state.editUserIcon = false | ||||||
|             state.deleteIcon = true |             state.deleteIcon = true | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -681,6 +939,10 @@ const store = createStore({ | |||||||
|             state.sellIcon = false |             state.sellIcon = false | ||||||
|             state.archiveIcon = false |             state.archiveIcon = false | ||||||
|             state.editIcon = false |             state.editIcon = false | ||||||
|  |             state.departmentsIcon = false | ||||||
|  |             state.addDepartmentIcon = false | ||||||
|  |             state.addEmployeeIcon = false | ||||||
|  |             state.employeesIcon = false | ||||||
|             state.editUserIcon = true |             state.editUserIcon = true | ||||||
|             state.deleteIcon = false |             state.deleteIcon = false | ||||||
|             state.notAllInstancesIcon = false |             state.notAllInstancesIcon = false | ||||||
| @ -976,6 +1238,17 @@ const store = createStore({ | |||||||
|             state.chosenEmployeeId = id |             state.chosenEmployeeId = id | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|  |         // function to set the chosen customer and its employees and departments | ||||||
|  |         setChosenCustomer(state, id) { | ||||||
|  |             state.chosenCustomerId = id | ||||||
|  |         }, | ||||||
|  |         setChosenCustomerEmployee(state, id) { | ||||||
|  |             state.chosenCustomerEmployeeId = id | ||||||
|  |         }, | ||||||
|  |         setChosenCustomerDepartment(state, id) { | ||||||
|  |             state.chosenDepartmentId = id | ||||||
|  |         }, | ||||||
|  |  | ||||||
|         // function to reset the pages |         // function to reset the pages | ||||||
|         resetStore(state) { |         resetStore(state) { | ||||||
|             state.editable = false |             state.editable = false | ||||||
| @ -1128,6 +1401,169 @@ const store = createStore({ | |||||||
|             state.newTypeMVI = '' |             state.newTypeMVI = '' | ||||||
|             state.newTimeSpentMVI = '' |             state.newTimeSpentMVI = '' | ||||||
|             state.newNotesMVI = '' |             state.newNotesMVI = '' | ||||||
|  |  | ||||||
|  |             // reset the customer page variables | ||||||
|  |             state.chosenCustomerId = -1 | ||||||
|  |             state.chosenCustomerEmployeeId = -1 | ||||||
|  |             state.chosenDepartmentId = -1 | ||||||
|  |         }, | ||||||
|  |  | ||||||
|  |          // function to reset the pages except chosen customer id | ||||||
|  |          resetStoreNotCustomer(state) { | ||||||
|  |             state.editable = false | ||||||
|  |             state.editableUser = false | ||||||
|  |             state.filtered = false | ||||||
|  |             state.searchable = false | ||||||
|  |             state.deleteBool = false | ||||||
|  |             state.chosenAssetId = -1 | ||||||
|  |             state.filteredByCustomer = '' | ||||||
|  |             state.filteredUserTerm = false | ||||||
|  |             state.new = false | ||||||
|  |             state.customerChanged = false | ||||||
|  |             state.changedCustomerId = -1 | ||||||
|  |  | ||||||
|  |             // reset the asset page variables | ||||||
|  |             state.newAssetName = '' | ||||||
|  |             state.newCustomerID = '' | ||||||
|  |             state.newCustomer = '' | ||||||
|  |             state.newLocation = '' | ||||||
|  |             state.newRemoteLocation = '' | ||||||
|  |             state.newType = '' | ||||||
|  |             state.newDescription = '' | ||||||
|  |             state.newNotes = '' | ||||||
|  |             state.newState = '' | ||||||
|  |             state.newLastView = '' | ||||||
|  |             state.newUser = '' | ||||||
|  |             state.hardwareBool = false | ||||||
|  |             state.newModel = '' | ||||||
|  |             state.newSerialnumber = '' | ||||||
|  |             state.newCPU = '' | ||||||
|  |             state.newRAM = '' | ||||||
|  |             state.newStorageConfiguration = '' | ||||||
|  |             state.newMiscellaneous = '' | ||||||
|  |             state.softwareBool = false | ||||||
|  |             state.newSoftware = '' | ||||||
|  |             state.newVersion = '' | ||||||
|  |             state.newLicense = '' | ||||||
|  |  | ||||||
|  |             // reset the production order template page variables | ||||||
|  |             state.newNamePOT = '' | ||||||
|  |             state.newCustomerIDPOT = '' | ||||||
|  |             state.newCustomerPOT = '' | ||||||
|  |             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 maintenance visit and production order instance page variables | ||||||
|  |             state.chosenMITId = -1 | ||||||
|  |             state.chosenPOIId = -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 = '' | ||||||
|  |  | ||||||
|  |             // reset the employee page variables | ||||||
|  |             state.chosenEmployeeId = -1 | ||||||
|  |             state.newUsernameEmp = '' | ||||||
|  |             state.newPasswordEmp = '' | ||||||
|  |             state.newPasswordRepeatedEmp = '' | ||||||
|  |             state.newFullNameEmp = '' | ||||||
|  |             state.newEmailEmp = '' | ||||||
|  |             state.newPhonenumberEmp = '' | ||||||
|  |             state.newAddressEmp = '' | ||||||
|  |             state.newCityEmp = '' | ||||||
|  |             state.newPostcodeEmp = '' | ||||||
|  |  | ||||||
|  |             // reset the poi page variables | ||||||
|  |             state.newNamePOI = '' | ||||||
|  |             state.newTemplateIDPOI = '' | ||||||
|  |             state.newCustomerIDPOI = '' | ||||||
|  |             state.newCustomerPOI = '' | ||||||
|  |             state.newAssetPOI = '' | ||||||
|  |             state.newStatePOI = '' | ||||||
|  |             state.newCreationDatePOI = '' | ||||||
|  |             state.newCompletionDatePOI = '' | ||||||
|  |             state.newUserPOI = '' | ||||||
|  |             state.newTemplateDescriptionPOI = '' | ||||||
|  |             state.newTemplateNotesPOI = '' | ||||||
|  |             state.newTimeSpentPOI = '' | ||||||
|  |             state.newNotesPOI = '' | ||||||
|  |  | ||||||
|  |             // reset the mvi page variables | ||||||
|  |             state.newNameMVI = '' | ||||||
|  |             state.newTemplateIDMVI = '' | ||||||
|  |             state.newMaintenanceTypeMVI = '' | ||||||
|  |             state.newStateMVI = '' | ||||||
|  |             state.newCreationDateMVI = ''  | ||||||
|  |             state.newCompletionDateMVI = '' | ||||||
|  |             state.newUserMVI = '' | ||||||
|  |             state.newCustomerIDMVI = ''  | ||||||
|  |             state.newCustomerMVI = '' | ||||||
|  |             state.newTemplateNotesMVI = '' | ||||||
|  |             state.newTypeMVI = '' | ||||||
|  |             state.newTimeSpentMVI = '' | ||||||
|  |             state.newNotesMVI = '' | ||||||
|  |  | ||||||
|  |             // reset the customer page variables | ||||||
|  |             state.chosenCustomerEmployeeId = -1 | ||||||
|  |             state.chosenDepartmentId = -1 | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|         // function to logout  |         // function to logout  | ||||||
| @ -1195,6 +1631,14 @@ const store = createStore({ | |||||||
|             // set the employee variables |             // set the employee variables | ||||||
|             state.onEmployeelist = false |             state.onEmployeelist = false | ||||||
|             state.onEmployee = true |             state.onEmployee = true | ||||||
|  |  | ||||||
|  |             //set the customers variables | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = true | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|         // function to get to the add page of instances |         // function to get to the add page of instances | ||||||
| @ -1211,6 +1655,40 @@ const store = createStore({ | |||||||
|             state.onInstancelist = false |             state.onInstancelist = false | ||||||
|             state.onInstance = true |             state.onInstance = true | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|  |         // function to get to the add page of customer employees | ||||||
|  |         addEmployee(state) { | ||||||
|  |             state.new = true | ||||||
|  |             state.editable = false | ||||||
|  |             state.editableUser = false | ||||||
|  |             state.filtered = false | ||||||
|  |             state.searchable = false | ||||||
|  |  | ||||||
|  |             // set the customer employees variables | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = true | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = false | ||||||
|  |         }, | ||||||
|  |  | ||||||
|  |         // function to get to the add page of customer departments | ||||||
|  |         addDepartment(state) { | ||||||
|  |             state.new = true | ||||||
|  |             state.editable = false | ||||||
|  |             state.editableUser = false | ||||||
|  |             state.filtered = false | ||||||
|  |             state.searchable = false | ||||||
|  |  | ||||||
|  |             // set the customer departments variables | ||||||
|  |             state.onCustomerlist = false | ||||||
|  |             state.onCustomer = false | ||||||
|  |             state.onCustomerEmployeelist = false | ||||||
|  |             state.onCustomerEmployee = false | ||||||
|  |             state.onDepartmentlist = false | ||||||
|  |             state.onDepartment = true | ||||||
|  |         }, | ||||||
|     }, |     }, | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								server/api/addCustEmployee.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addCustEmployee.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | import { errorMsg } from "../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/addCustomer.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/addCustomer.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { insertId, errorMsg } from "../middleware/customers"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return insertId | ||||||
|  | }) | ||||||
							
								
								
									
										22
									
								
								server/api/addDepartment.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								server/api/addDepartment.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | import { errorMsg } from "../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/deleteCustEmployee/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/deleteCustEmployee/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/deleteCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/deleteCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { errorMsg } from "../../middleware/customers"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/deleteDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/deleteDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { errorMsg } from "../../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getCustEmployee/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getCustEmployee/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { customerEmployee, errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return customerEmployee | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getCustomerById/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getCustomerById/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { customerById, errorMsg } from "../../middleware/customers"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return customerById | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { department, errorMsg } from "../../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return department | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getDprtmntByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getDprtmntByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { departmentObject, errorMsg } from "../../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return departmentObject | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedCustEmployeeByCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedCustEmployeeByCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedCustomerEmployeesByCustomer, errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedCustomerEmployeesByCustomer | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedCustEmployeeByDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedCustEmployeeByDepartment/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedCustomerEmployeesByDepartment, errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedCustomerEmployeesByDepartment | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedCustEmployeeByDprtmntName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedCustEmployeeByDprtmntName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedCustomerEmployeesByDepartmentName, errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedCustomerEmployeesByDepartmentName | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedCustEmployeeByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedCustEmployeeByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedCustomerEmployeesByName, errorMsg } from "../../middleware/customerEmployees"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedCustomerEmployeesByName | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedCustomersByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedCustomersByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedCustomersByName, errorMsg } from "../../middleware/customers"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedCustomersByName | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedDepartmentByCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedDepartmentByCustomer/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedDepartmentsByCustomer, errorMsg } from "../../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedDepartmentsByCustomer | ||||||
|  | }) | ||||||
							
								
								
									
										23
									
								
								server/api/getSelectedDepartmentByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								server/api/getSelectedDepartmentByName/[id].ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { selectedDepartmentsByName, errorMsg } from "../../middleware/departments"; | ||||||
|  | import { OutgoingMessage } from 'http'; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const headers: Record<string, Parameters<OutgoingMessage['setHeader']>[1]> = { | ||||||
|  |         'Access-Control-Allow-Origin': 'https://tueitapp.tueit.de', | ||||||
|  |         'Access-Control-Allow-Headers': 'authorization, content-type', | ||||||
|  |         'Access-Control-Allow-Methods': 'OPTIONS,GET,HEAD,PUT,PATCH,POST,DELETE', | ||||||
|  |         'Access-Control-Allow-Credentials': 'true', | ||||||
|  |     }; | ||||||
|  |     setResponseHeaders(event, headers) | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return selectedDepartmentsByName | ||||||
|  | }) | ||||||
							
								
								
									
										14
									
								
								server/api/updateCustEmployee.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateCustEmployee.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | import { errorMsg } from "../middleware/customerEmployees"; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return errorMsg | ||||||
|  | }) | ||||||
							
								
								
									
										14
									
								
								server/api/updateCustomer.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateCustomer.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | import { errorMsg } from "../middleware/customers"; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return errorMsg | ||||||
|  | }) | ||||||
							
								
								
									
										14
									
								
								server/api/updateDepartment.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								server/api/updateDepartment.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | import { errorMsg } from "../middleware/departments"; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     if (!(errorMsg === '')) { | ||||||
|  |         throw createError({ | ||||||
|  |             statusCode: 400, | ||||||
|  |             statusMessage: errorMsg, | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     setResponseStatus(event, 200) | ||||||
|  |     return errorMsg | ||||||
|  | }) | ||||||
							
								
								
									
										277
									
								
								server/middleware/customerEmployees.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										277
									
								
								server/middleware/customerEmployees.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,277 @@ | |||||||
|  | import axios, { AxiosError } from 'axios'; | ||||||
|  | import serversideConfig from '../../serversideConfig'; | ||||||
|  | import https from 'https'; | ||||||
|  |  | ||||||
|  | let customerEmployee = {}; | ||||||
|  | let errorMsg = ''; | ||||||
|  | let selectedCustomerEmployeesByCustomer = []; | ||||||
|  | let selectedCustomerEmployeesByName = []; | ||||||
|  | let selectedCustomerEmployeesByDepartment = []; | ||||||
|  | let selectedCustomerEmployeesByDepartmentName = []; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const agent = new https.Agent({ | ||||||
|  |         rejectUnauthorized: false, | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     const axiosInstance = axios.create({ | ||||||
|  |         headers: { | ||||||
|  |             'Content-Type': 'application/json', | ||||||
|  |             Accept: "*", | ||||||
|  |         }, | ||||||
|  |         httpsAgent: agent | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getCustEmployee")) { | ||||||
|  |         // get customer employee object from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/employee/${itemId}`); | ||||||
|  |             customerEmployee = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedCustEmployeeByName")) { | ||||||
|  |         // get all customer employees by name from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/employeeByName/${itemId}`); | ||||||
|  |             selectedCustomerEmployeesByName = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedCustEmployeeByDprtmntName")) { | ||||||
|  |         // get all customer employees by department name from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/employeeByDepartmentName/${itemId}`); | ||||||
|  |             selectedCustomerEmployeesByDepartmentName = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedCustEmployeeByCustomer")) { | ||||||
|  |         // get all customer employees from a customer from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/employeeByCustomerID/${itemId}`); | ||||||
|  |             selectedCustomerEmployeesByCustomer = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedCustEmployeeByDepartment")) { | ||||||
|  |         // get all customer employees by department from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/employeeByDeprtmentID/${itemId}`); | ||||||
|  |             selectedCustomerEmployeesByDepartment = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/updateCustEmployee")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // update the customer employee in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.put(`https://${serversideConfig.url}:${serversideConfig.port}/employee`, body); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/addCustEmployee")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // add the customer employee in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.post(`https://${serversideConfig.url}:${serversideConfig.port}/employees`, body); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/deleteCustEmployee")) { | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         // delete the customer employee in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.delete(`https://${serversideConfig.url}:${serversideConfig.port}/employees/${itemId}`); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | export { customerEmployee, selectedCustomerEmployeesByDepartmentName, selectedCustomerEmployeesByCustomer, selectedCustomerEmployeesByName, selectedCustomerEmployeesByDepartment, errorMsg }; | ||||||
| @ -4,6 +4,9 @@ import https from 'https'; | |||||||
|  |  | ||||||
| let customers = []; | let customers = []; | ||||||
| let customerObject = []; | let customerObject = []; | ||||||
|  | let selectedCustomersByName = []; | ||||||
|  | let customerById = {}; | ||||||
|  | let insertId = -1; | ||||||
| let errorMsg = ''; | let errorMsg = ''; | ||||||
|  |  | ||||||
| export default defineEventHandler(async (event) => { | export default defineEventHandler(async (event) => { | ||||||
| @ -79,6 +82,159 @@ export default defineEventHandler(async (event) => { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getCustomerById")) { | ||||||
|  |         // get customer  object from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/customer/${itemId}`); | ||||||
|  |             customerById = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedCustomersByName")) { | ||||||
|  |         // get selected custoemrs object by customer from backend | ||||||
|  |         let filteredCustomer = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         filteredCustomer = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/selectedCustomers/${filteredCustomer}`); | ||||||
|  |             selectedCustomersByName = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/updateCustomer")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // update the customer in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.put(`https://${serversideConfig.url}:${serversideConfig.port}/customers`, body); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/deleteCustomer")) { | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         // delete the customer in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.delete(`https://${serversideConfig.url}:${serversideConfig.port}/customers/${itemId}`); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/addCustomer")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // add the customer in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.post(`https://${serversideConfig.url}:${serversideConfig.port}/customers`, body); | ||||||
|  |             insertId = res.data.insertId | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
| }) | }) | ||||||
|  |  | ||||||
| export { customers, customerObject, errorMsg }; | export { customers, selectedCustomersByName, insertId, customerById, customerObject, errorMsg }; | ||||||
							
								
								
									
										244
									
								
								server/middleware/departments.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								server/middleware/departments.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | |||||||
|  | import axios, { AxiosError } from 'axios'; | ||||||
|  | import serversideConfig from '../../serversideConfig'; | ||||||
|  | import https from 'https'; | ||||||
|  |  | ||||||
|  | let department = {}; | ||||||
|  | let errorMsg = ''; | ||||||
|  | let selectedDepartmentsByCustomer = []; | ||||||
|  | let selectedDepartmentsByName = []; | ||||||
|  | let departmentObject = {}; | ||||||
|  |  | ||||||
|  | export default defineEventHandler(async (event) => { | ||||||
|  |  | ||||||
|  |     const agent = new https.Agent({ | ||||||
|  |         rejectUnauthorized: false, | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     const axiosInstance = axios.create({ | ||||||
|  |         headers: { | ||||||
|  |             'Content-Type': 'application/json', | ||||||
|  |             Accept: "*", | ||||||
|  |         }, | ||||||
|  |         httpsAgent: agent | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getDepartment")) { | ||||||
|  |         // get department object from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/department/${itemId}`); | ||||||
|  |             department = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedDepartmentByCustomer")) { | ||||||
|  |         // get all departments from a customer from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/departmentByCustomerID/${itemId}`); | ||||||
|  |             selectedDepartmentsByCustomer = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getDprtmntByName")) { | ||||||
|  |         // get department  object from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/departmentName/${itemId}`); | ||||||
|  |             departmentObject = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/getSelectedDepartmentByName")) { | ||||||
|  |         // get all departments by name from backend | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.get(`https://${serversideConfig.url}:${serversideConfig.port}/departmentByName/${itemId}`); | ||||||
|  |             selectedDepartmentsByName = res.data; | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/updateDepartment")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // update the department in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.put(`https://${serversideConfig.url}:${serversideConfig.port}/department`, body); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/addDepartment")) { | ||||||
|  |         const body = await readBody(event) | ||||||
|  |         // add the department in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.post(`https://${serversideConfig.url}:${serversideConfig.port}/departments`, body); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (event.path.startsWith("/api/deleteDepartment")) { | ||||||
|  |         let itemId = null; | ||||||
|  |         const path = event._path; | ||||||
|  |         const pathSegments = path.split('/'); | ||||||
|  |         itemId = pathSegments[pathSegments.length - 1]; | ||||||
|  |  | ||||||
|  |         // delete the department in the backend | ||||||
|  |         try { | ||||||
|  |             let res = await axiosInstance.delete(`https://${serversideConfig.url}:${serversideConfig.port}/departments/${itemId}`); | ||||||
|  |         } catch (err) { | ||||||
|  |             if (axios.isAxiosError(err)) { | ||||||
|  |                 const axiosError = err as AxiosError; | ||||||
|  |  | ||||||
|  |                 if (axiosError.response) { | ||||||
|  |                     // Axios error | ||||||
|  |                     console.error(axiosError.response.data.message); | ||||||
|  |                     errorMsg = axiosError.response.data.message; | ||||||
|  |                 } else if (axiosError.request) { | ||||||
|  |                     console.log(err) | ||||||
|  |                     // If error was caused by the request | ||||||
|  |                     console.error(axiosError.request); | ||||||
|  |                 } else { | ||||||
|  |                     // Other errors | ||||||
|  |                     console.error('Error', axiosError.message); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 // No AxiosError | ||||||
|  |                 console.error('Error', err); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | export { department, departmentObject, selectedDepartmentsByCustomer, selectedDepartmentsByName, errorMsg }; | ||||||
		Reference in New Issue
	
	Block a user