added client employee and department pages
This commit is contained in:
		
							
								
								
									
										22
									
								
								app.vue
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								app.vue
									
									
									
									
									
								
							| @ -16,15 +16,19 @@ | ||||
|  | ||||
| <style> | ||||
|  | ||||
|   html, template, body, #__nuxt, #__layout { | ||||
|     height: 100vh; | ||||
|     width: 100vw; | ||||
|     height: 100%; | ||||
|     width: 100%; | ||||
|     margin: 0; | ||||
|     background-color: #212121; | ||||
|     font-size: 1rem; | ||||
|   } | ||||
| * { | ||||
|   box-sizing: border-box; | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| html, template, body, #__nuxt, #__layout { | ||||
|   height: 100vh; | ||||
|   width: 100vw; | ||||
|   height: 100%; | ||||
|   width: 100%; | ||||
|   background-color: #212121; | ||||
|   font-size: 1rem; | ||||
| } | ||||
|  | ||||
|  | ||||
| </style> | ||||
| @ -1,13 +1,13 @@ | ||||
| <template> | ||||
|   <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <h2 :class="['client-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Client name</h2> | ||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Client name</pre> | ||||
|     <div class="data-field" id="client-id"> | ||||
|       <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">ID:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|     </div> | ||||
|     <div class="client-data"> | ||||
|       <div class="contact"> | ||||
|         <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Contact:</h3> | ||||
|         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Contact:</pre> | ||||
|         <div class="data-field" id="contact-person"> | ||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Contact person:</pre> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
| @ -22,7 +22,7 @@ | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="address"> | ||||
|         <h3 :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Address:</h3> | ||||
|         <pre :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Address:</pre> | ||||
|         <div class="street-address"> | ||||
|           <div class="data-field" id="street-name"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Street:</pre> | ||||
| @ -44,7 +44,7 @@ | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="notes"> | ||||
|       <h3  :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</h3> | ||||
|       <pre  :class="['area-title', darkMode ? 'h3-darkmode' : 'h3-lightmode']">Notes:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|     </div> | ||||
|   </section> | ||||
| @ -65,138 +65,102 @@ export default { | ||||
|      | ||||
|      | ||||
| <style scoped> | ||||
| .information { | ||||
|  | ||||
|  | ||||
| section { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   align-items: flex-start; | ||||
|   justify-content: center; | ||||
|   width: 100%; | ||||
|   padding: 1.25rem 1.875rem; | ||||
|   border-radius: 0.625rem; | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
| }  | ||||
|  | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .section-lightmode { | ||||
|     background-color: #fff; | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
| .client-name { | ||||
|   align-self: stretch; | ||||
| .title { | ||||
|   padding: 1.25rem 0; | ||||
|   letter-spacing: 5%; | ||||
|   letter-spacing: 0.05rem; | ||||
|   text-decoration-line: underline; | ||||
|   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, | ||||
|     sans-serif; | ||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
|  | ||||
| .h2-darkmode { | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .h2-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
|  | ||||
| .data-field { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: row; | ||||
|   padding: 0 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   width: 100%; | ||||
|   padding: 0 1.875rem; | ||||
|   gap: 1.25rem; | ||||
|   border-radius: 0.625rem; | ||||
| } | ||||
|  | ||||
| .data-field#client-id { | ||||
|   padding: 0.625rem 1.875rem; | ||||
| } | ||||
|  | ||||
| .data-field#street-name { | ||||
|   width: 70%; | ||||
| } | ||||
|  | ||||
| .data-field#street-no { | ||||
|   width: 30%; | ||||
| }  | ||||
| .data-field#client-id { padding: 0.625rem 1.875rem; } | ||||
| .data-field#street-name { flex: 3; }  | ||||
|  | ||||
| .label { | ||||
|   letter-spacing: 5%; | ||||
|   letter-spacing: 0.03rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .pre-lightmode { | ||||
|     color: #000; | ||||
| pre { | ||||
|   margin: 0; | ||||
| } | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
|  | ||||
| .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; | ||||
|   background-color: #212121; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   letter-spacing: 5%; | ||||
|   font: 400 0.75rem/250% Overpass, sans-serif; | ||||
| }  | ||||
|  | ||||
| .data-darkmode { | ||||
|     background-color: #212121; | ||||
|     color: #fff; | ||||
|   background-color: #212121; | ||||
|   color: #ffffff; | ||||
| }  | ||||
|  | ||||
| .data-lightmode { | ||||
|     background-color: #EBEBEB; | ||||
|     color: #000; | ||||
|   background-color: #ebebeb; | ||||
|   color: #000000; | ||||
| }  | ||||
|  | ||||
| .data#notes { | ||||
|   align-self: stretch; | ||||
| } | ||||
|  | ||||
| .client-data { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: row; | ||||
|   padding: 1.25rem 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   align-self: stretch; | ||||
|   padding: 0 0.625rem; | ||||
|   justify-content: stretch; | ||||
|   gap: 0.625rem | ||||
| } | ||||
|  | ||||
| .contact, | ||||
| .address { | ||||
| .contact, .address { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: column; | ||||
|   align-items: flex-start; | ||||
|   justify-content: center; | ||||
|   line-height: normal; | ||||
|   width: 50%; | ||||
|   padding: 1.25rem 0.625rem; | ||||
|   border-radius: 0.3125rem; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .area-title { | ||||
|   letter-spacing: 5%; | ||||
|   letter-spacing: 0.03rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .h3-darkmode { | ||||
|     color: #fff; | ||||
| } | ||||
|  | ||||
| .h3-lightmode { | ||||
|     color: #000; | ||||
| } | ||||
| .h3-darkmode { color: #ffffff; }  | ||||
| .h3-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
| .street-address { | ||||
| @ -205,15 +169,17 @@ export default { | ||||
|   align-items: center; | ||||
|   justify-content: space-between; | ||||
|   align-self: stretch; | ||||
|   padding: 0 1.875rem 0 0; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .notes { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   padding: 0.625rem 1.875rem; | ||||
|   align-items: flex-start; | ||||
|   justify-content: center; | ||||
|   align-self: stretch; | ||||
|   padding: 0.625rem 1.875rem 0.625rem 1.25rem; | ||||
| }</style> | ||||
|   gap: 0.625rem; | ||||
| } | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										143
									
								
								components/server/ClientDepartment.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								components/server/ClientDepartment.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,143 @@ | ||||
| <template> | ||||
|     <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|       <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Department name</pre> | ||||
|       <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']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="client-id"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client ID:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="head"> | ||||
|             <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Head:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="notes"> | ||||
|             <pre  :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|             <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|       </div> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
| name: "ClientDepartment", | ||||
| }; | ||||
| </script>    | ||||
|  | ||||
|  | ||||
|  | ||||
| <style scoped> | ||||
|  | ||||
| * {  | ||||
| box-sizing: border-box; | ||||
| margin: 0;  | ||||
| } | ||||
|  | ||||
|  | ||||
| section { | ||||
| display: flex; | ||||
| flex-direction: column; | ||||
| padding: 1.25rem 1.875rem; | ||||
| border-radius: 0.625rem; | ||||
| box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| align-items: stretch; | ||||
| justify-content: center; | ||||
| }  | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
| .title { | ||||
| padding: 1.25rem 0; | ||||
| letter-spacing: 0.04rem; | ||||
| text-decoration-line: underline; | ||||
| font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-group { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| width: 100%; | ||||
| flex-direction: row; | ||||
| padding: 0.625rem 0; | ||||
| align-items: center; | ||||
| justify-content: stretch; | ||||
| } | ||||
|  | ||||
|  | ||||
| .data-field { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| width: 30%; | ||||
| flex-direction: row; | ||||
| padding: 0.625rem 1.875rem; | ||||
| align-items: center; | ||||
| justify-content: flex-start; | ||||
| gap: 1.25rem; | ||||
| }  | ||||
| #head { width: 40%; } | ||||
|  | ||||
| .label { | ||||
| letter-spacing: 0.02rem; | ||||
| font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
|  | ||||
| .data { | ||||
| display: flex; | ||||
| flex-direction: row; | ||||
| padding: 0 0.625rem; | ||||
| border-radius: 0.3125rem; | ||||
| box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
| background-color: #212121; | ||||
| align-items: center; | ||||
| justify-content: flex-start; | ||||
| letter-spacing: 0.02rem; | ||||
| font: 400 0.75rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .data-darkmode { | ||||
| background-color: #212121; | ||||
| color: #ffffff; | ||||
| }  | ||||
| .data-lightmode { | ||||
| background-color: #ebebeb; | ||||
| color: #000000; | ||||
| }  | ||||
|  | ||||
|  | ||||
| .notes { | ||||
| display: flex; | ||||
| flex: auto; | ||||
| flex-direction: column; | ||||
| padding: 1.25rem 1.875rem 0.625rem; | ||||
| align-items: flex-start; | ||||
| justify-content: center; | ||||
| gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .area-title { | ||||
| letter-spacing: 0.03rem; | ||||
| font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										117
									
								
								components/server/ClientDepartmentEmployeeList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								components/server/ClientDepartmentEmployeeList.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,117 @@ | ||||
|  | ||||
| <template> | ||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> | ||||
|         <table class="data-table" id="client-employee-table"> | ||||
|             <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 :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> | ||||
|                 <th :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']">Job Title</th> | ||||
|                 <th :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">Pronouns</th> | ||||
|             </tr> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|                 <td :class="['JobTitle', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'JobTitle-darkmode' : 'JobTitle-lightmode']">...</td> | ||||
|                 <td :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "ClientDepartmentEmployeeList", | ||||
| }; | ||||
| </script>    | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .label { | ||||
|     padding: 1.25rem 0; | ||||
|     letter-spacing: 0.04rem; | ||||
|     text-decoration-line: underline; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #ffffff; } | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
|     table-layout: fixed; | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|     height: 3.125rem; | ||||
|     padding: 0.625rem; | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } | ||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } | ||||
|  | ||||
| th, td { | ||||
|     height: 1.875rem; | ||||
|     width: 35%; | ||||
|     padding: 0; | ||||
|     text-align: left; | ||||
|     border-left: none; | ||||
|     letter-spacing: 0.02rem; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } | ||||
| .th-darkmode, .td-darkmode {  | ||||
|     color: #ffffff; | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
| .th-lightmode, .td-lightmode {  | ||||
|     color: #000000; | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .ID { width: 20%; } | ||||
| .Pronouns { width: 10%; } | ||||
|  | ||||
| .Pronouns-darkmode { border-right: none; } | ||||
| .Pronouns-lightmode { border-right: none; } | ||||
|  | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										112
									
								
								components/server/ClientDepartmentList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								components/server/ClientDepartmentList.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,112 @@ | ||||
| <template> | ||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Departments:</div> | ||||
|         <table class="data-table" id="client-employee-table"> | ||||
|             <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 :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 :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|                 <td :class="['DHead', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'DHead-darkmode' : 'DHead-lightmode']">...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "ClientDepartmentList", | ||||
| }; | ||||
| </script>    | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .label { | ||||
|     padding: 1.25rem 0; | ||||
|     letter-spacing: 0.04rem; | ||||
|     text-decoration-line: underline; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #ffffff; } | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
|     table-layout: fixed; | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|     height: 3.125rem; | ||||
|     padding: 0.625rem; | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } | ||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } | ||||
|  | ||||
| th, td { | ||||
|     height: 1.875rem; | ||||
|     width: 40%; | ||||
|     padding: 0; | ||||
|     text-align: left; | ||||
|     border-left: none; | ||||
|     letter-spacing: 0.02rem; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } | ||||
| .th-darkmode, .td-darkmode {  | ||||
|     color: #ffffff; | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
| .th-lightmode, .td-lightmode {  | ||||
|     color: #000000; | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .ID { width: 20%; } | ||||
|  | ||||
| .DHead { border-right: none; } | ||||
|  | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										191
									
								
								components/server/ClientEmployee.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										191
									
								
								components/server/ClientEmployee.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,191 @@ | ||||
| <template> | ||||
|   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Employee name</pre> | ||||
|     <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> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="first-name"> | ||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">First Name/-s:</pre> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="last-name"> | ||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Last Name/-s:</pre> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </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']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="pronouns"> | ||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Pronouns:</pre> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|         <div class="data-field" id="preferred-name"> | ||||
|           <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Preferred Name:</pre> | ||||
|           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="data-group" id="employment-data"> | ||||
|       <div class="data-field" id="client-id"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Client ID:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|       <div class="data-field" id="department"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Department:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|       <div class="data-field" id="job-title"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Job Title:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </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 :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|       <div class="data-field" id="mail"> | ||||
|         <pre :class="['label', darkMode ? 'pre-darkmode' : 'pre-lightmode']">E-Mail:</pre> | ||||
|         <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="notes"> | ||||
|       <pre  :class="['area-title', darkMode ? 'pre-darkmode' : 'pre-lightmode']">Notes:</pre> | ||||
|       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
|  | ||||
|  | ||||
|  | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "ClientEmployee", | ||||
| }; | ||||
| </script>    | ||||
|    | ||||
|    | ||||
|    | ||||
| <style scoped> | ||||
|  | ||||
| * {  | ||||
|   box-sizing: border-box; | ||||
|   margin: 0;  | ||||
| } | ||||
|  | ||||
|  | ||||
| section { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   padding: 1.25rem 1.875rem; | ||||
|   border-radius: 0.625rem; | ||||
|   box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
| }  | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
| .title { | ||||
|   padding: 1.25rem 0; | ||||
|   letter-spacing: 0.04rem; | ||||
|   text-decoration-line: underline; | ||||
|   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .title-darkmode { color: #ffffff; }  | ||||
| .title-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-group { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   width: 100%; | ||||
|   flex-direction: row; | ||||
|   padding: 1.25rem 0; | ||||
|   align-items: center; | ||||
|   justify-content: stretch; | ||||
| } | ||||
| #personal-data { | ||||
|   flex-direction: column; | ||||
|   align-items: stretch; | ||||
|   justify-content: center; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
| #full-name, #other { padding: 0; } | ||||
|  | ||||
|  | ||||
| .data-field { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   width: 20%; | ||||
|   flex-direction: row; | ||||
|   padding: 0 1.875rem; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   gap: 1.25rem; | ||||
| }  | ||||
| #first-name, #last-name, #department, #job-title, #phone { width: 40%; } | ||||
| #preferred-name, #mail { width: 60%; } | ||||
|  | ||||
| .label { | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .pre-darkmode { color: #ffffff; }  | ||||
| .pre-lightmode { color: #000000; } | ||||
|  | ||||
| .data { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   padding: 0 0.625rem; | ||||
|   border-radius: 0.3125rem; | ||||
|   box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||
|   background-color: #212121; | ||||
|   align-items: center; | ||||
|   justify-content: flex-start; | ||||
|   letter-spacing: 0.02rem; | ||||
|   font: 400 0.75rem/1.875rem Overpass, sans-serif; | ||||
| }  | ||||
| .data-darkmode { | ||||
|   background-color: #212121; | ||||
|   color: #ffffff; | ||||
| }  | ||||
| .data-lightmode { | ||||
|   background-color: #ebebeb; | ||||
|   color: #000000; | ||||
| }  | ||||
|  | ||||
|  | ||||
| .notes { | ||||
|   display: flex; | ||||
|   flex: auto; | ||||
|   flex-direction: column; | ||||
|   padding: 1.25rem 1.875rem 0.625rem; | ||||
|   align-items: flex-start; | ||||
|   justify-content: center; | ||||
|   gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .area-title { | ||||
|   letter-spacing: 0.03rem; | ||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| #notes { align-self: stretch; } | ||||
|  | ||||
| </style> | ||||
							
								
								
									
										116
									
								
								components/server/ClientEmployeeList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								components/server/ClientEmployeeList.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,116 @@ | ||||
| <template> | ||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <div :class="['label', darkMode ? 'label-darkmode' : 'label-lightmode']">Employees:</div> | ||||
|         <table class="data-table" id="client-employee-table"> | ||||
|             <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 :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> | ||||
|                 <th :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']">Department / Job Title</th> | ||||
|                 <th :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">Pronouns</th> | ||||
|             </tr> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|                 <td :class="['Department', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Department-darkmode' : 'Department-lightmode']">...</td> | ||||
|                 <td :class="['Pronouns', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Pronouns-darkmode' : 'Pronouns-lightmode']">...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| <script setup> | ||||
| import { ref } from 'vue'; | ||||
|  | ||||
| const darkMode = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|   name: "ClientEmployeeList", | ||||
| }; | ||||
| </script>    | ||||
|  | ||||
|    | ||||
| <style scoped> | ||||
| .data { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     align-items: flex-start; | ||||
|     justify-content: center; | ||||
|     align-self: stretch; | ||||
|     padding: 1.25rem 1.875rem; | ||||
|     border-radius: 0.625rem; | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
| .section-darkmode { background-color: #2c2c2c; } | ||||
| .section-lightmode { background-color: #ffffff; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .label { | ||||
|     padding: 1.25rem 0; | ||||
|     letter-spacing: 0.04rem; | ||||
|     text-decoration-line: underline; | ||||
|     font: 400 1rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| .label-darkmode { color: #ffffff; } | ||||
| .label-lightmode { color: #000000; } | ||||
|  | ||||
|  | ||||
|  | ||||
| .data-table { | ||||
|     width: 100%; | ||||
|     padding: 0 0.625rem; | ||||
|     table-layout: fixed; | ||||
|     border-collapse: collapse; | ||||
| } | ||||
|  | ||||
|  | ||||
| .table-row { | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     align-items: center; | ||||
|     height: 3.125rem; | ||||
|     padding: 0.625rem; | ||||
|     gap: 0.625rem; | ||||
| } | ||||
|  | ||||
| .tr-head-darkmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #000000; | ||||
| } | ||||
| .tr-head-lightmode { | ||||
|     border-top: none; | ||||
|     border-bottom: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
| .tr-darkmode { border-top: 0.0625rem solid #000000; } | ||||
| .tr-lightmode { border-top: 0.0625rem solid #8e8e8e; } | ||||
|  | ||||
| th, td { | ||||
|     height: 1.875rem; | ||||
|     width: 35%; | ||||
|     padding: 0; | ||||
|     text-align: left; | ||||
|     border-left: none; | ||||
|     letter-spacing: 0.02rem; | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
| th { font: 700 0.875rem/1.875rem Overpass, sans-serif; } | ||||
| .th-darkmode, .td-darkmode {  | ||||
|     color: #ffffff; | ||||
|     border-right: 0.0625rem solid #000000; | ||||
| } | ||||
| .th-lightmode, .td-lightmode {  | ||||
|     color: #000000; | ||||
|     border-right: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| .ID { width: 20%; } | ||||
| .Pronouns { width: 10%; } | ||||
|  | ||||
| .Pronouns-darkmode { border-right: none; } | ||||
| .Pronouns-lightmode { border-right: none; } | ||||
|  | ||||
|  | ||||
| </style> | ||||
| @ -1,22 +1,16 @@ | ||||
| <template> | ||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> | ||||
|     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||
|         <table class="data-table" id="client-table"> | ||||
|             <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 | ||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     Name</th> | ||||
|                 <th :class="['ID', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">ID</th> | ||||
|                 <th :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">Name</th> | ||||
|             </tr> | ||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> | ||||
|                 <td :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td | ||||
|                     :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> | ||||
|                     ...</td> | ||||
|                 <td :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||
|                 <td :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||
|             </tr> | ||||
|         </table> | ||||
|     </div> | ||||
|     </section> | ||||
| </template> | ||||
|    | ||||
|    | ||||
| @ -47,12 +41,12 @@ export default { | ||||
|     box-shadow: 0.25rem 0.25rem 0.25rem 0rem rgba(0, 0, 0, 0.25); | ||||
| } | ||||
|  | ||||
| .div-darkmode { | ||||
| .section-darkmode { | ||||
|     background-color: #2c2c2c; | ||||
| } | ||||
|  | ||||
| .div-lightmode { | ||||
|     background-color: #fff; | ||||
| .section-lightmode { | ||||
|     background-color: #ffffff; | ||||
| } | ||||
|  | ||||
| .data-table { | ||||
| @ -89,8 +83,7 @@ export default { | ||||
|     border-top: 0.0625rem solid #8e8e8e; | ||||
| } | ||||
|  | ||||
| th, | ||||
| td { | ||||
| th, td { | ||||
|     height: 1.875rem; | ||||
|     text-align: left; | ||||
|     padding: 0; | ||||
| @ -98,14 +91,12 @@ td { | ||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||
| } | ||||
|  | ||||
| .th-darkmode, | ||||
| .td-darkmode { | ||||
| .th-darkmode, .td-darkmode { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| .th-lightmode, | ||||
| .td-lightmode { | ||||
|     color: #000; | ||||
| .th-lightmode, .td-lightmode { | ||||
|     color: #000000; | ||||
| } | ||||
|  | ||||
| th { | ||||
|  | ||||
| @ -7,6 +7,11 @@ | ||||
|       <ClientTable v-if="onCustomerlist"/> | ||||
|       <Client v-if="onCustomer"/> | ||||
|       <ClientQuickAccess v-if="onCustomer"/> | ||||
|       <ClientEmployeeList v-if="onEmployeelist"/> | ||||
|       <ClientEmployee v-if="onEmployee"/> | ||||
|       <ClientDepartmentList v-if="onDepartmentlist"/> | ||||
|       <ClientDepartment v-if="onDepartment"/> | ||||
|       <ClientDepartmentEmployeeList v-if="onDepartment"/> | ||||
|     </div> | ||||
|   </section> | ||||
| </template> | ||||
| @ -18,8 +23,11 @@ import { ref } from 'vue'; | ||||
| import ClientTable from "../components/server/ClientTable.vue"; | ||||
| import Client from "../components/server/Client.vue"; | ||||
| import ClientQuickAccess from "../components/server/ClientQuickAccess.vue"; | ||||
| //import ClientEmployees from "../components/server/ClientEmployees.vue"; | ||||
| //import ClientEmployee from "../components/server/ClientEmployee.vue"; | ||||
| import ClientEmployeeList from "../components/server/ClientEmployeeList.vue"; | ||||
| import ClientEmployee from "../components/server/ClientEmployee.vue"; | ||||
| import ClientDepartmentList from '~/components/server/ClientDepartmentList.vue'; | ||||
| import ClientDepartment from '~/components/server/ClientDepartment.vue'; | ||||
| import ClientDepartmentEmployeeList from '~/components/server/ClientDepartmentEmployeeList.vue'; | ||||
|  | ||||
| definePageMeta({ | ||||
|   layout: 'default' | ||||
| @ -30,6 +38,10 @@ const darkMode = ref(true) | ||||
| // to render the right components | ||||
| const onCustomerlist = ref(true) | ||||
| const onCustomer = ref(true) | ||||
| const onEmployeelist = ref(true) | ||||
| const onEmployee = ref(true) | ||||
| const onDepartmentlist = ref(true) | ||||
| const onDepartment = ref(true) | ||||
| </script> | ||||
|  | ||||
| <script> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user