added client employee and department pages
This commit is contained in:
		
							
								
								
									
										6
									
								
								app.vue
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								app.vue
									
									
									
									
									
								
							| @ -16,12 +16,16 @@ | |||||||
|  |  | ||||||
| <style> | <style> | ||||||
|  |  | ||||||
|  | * { | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| html, template, body, #__nuxt, #__layout { | html, template, body, #__nuxt, #__layout { | ||||||
|   height: 100vh; |   height: 100vh; | ||||||
|   width: 100vw; |   width: 100vw; | ||||||
|   height: 100%; |   height: 100%; | ||||||
|   width: 100%; |   width: 100%; | ||||||
|     margin: 0; |  | ||||||
|   background-color: #212121; |   background-color: #212121; | ||||||
|   font-size: 1rem; |   font-size: 1rem; | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| <template> | <template> | ||||||
|   <section :class="['information', darkMode ? 'section-darkmode' : 'section-lightmode']"> |   <section :class="[darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|     <h2 :class="['client-name', darkMode ? 'h2-darkmode' : 'h2-lightmode']">Client name</h2> |     <pre :class="['title', darkMode ? 'title-darkmode' : 'title-lightmode']">Client name</pre> | ||||||
|     <div class="data-field" id="client-id"> |     <div class="data-field" id="client-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="client-data"> |     <div class="client-data"> | ||||||
|       <div class="contact"> |       <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"> |         <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> |           <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']">...</pre> | ||||||
| @ -22,7 +22,7 @@ | |||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <div class="address"> |       <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="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']">Street:</pre> | ||||||
| @ -44,7 +44,7 @@ | |||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="notes"> |     <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> |       <pre :class="['data', darkMode ? 'data-darkmode' : 'data-lightmode']" id="notes">...</pre> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
| @ -65,138 +65,102 @@ export default { | |||||||
|      |      | ||||||
|      |      | ||||||
| <style scoped> | <style scoped> | ||||||
| .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 { background-color: #2c2c2c; } | ||||||
| .section-darkmode { | .section-lightmode { background-color: #ffffff; } | ||||||
|     background-color: #2c2c2c; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .section-lightmode { |  | ||||||
|     background-color: #fff; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| .client-name { | .title { | ||||||
|   align-self: stretch; |  | ||||||
|   padding: 1.25rem 0; |   padding: 1.25rem 0; | ||||||
|   letter-spacing: 5%; |   letter-spacing: 0.05rem; | ||||||
|   text-decoration-line: underline; |   text-decoration-line: underline; | ||||||
|   font: italic 400 1rem/187.5% Overpass, -apple-system, Roboto, Helvetica, |   font: italic 400 1rem/1.875rem Overpass, sans-serif; | ||||||
|     sans-serif; |  | ||||||
| }  | }  | ||||||
|  | .title-darkmode { color: #ffffff; }  | ||||||
|  | .title-lightmode { color: #000000; } | ||||||
|  |  | ||||||
| .h2-darkmode { |  | ||||||
|     color: #fff; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .h2-lightmode { |  | ||||||
|     color: #000; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .data-field { | .data-field { | ||||||
|   display: flex; |   display: flex; | ||||||
|  |   flex: auto; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|  |   padding: 0 1.875rem; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: flex-start; |   justify-content: flex-start; | ||||||
|   width: 100%; |  | ||||||
|   padding: 0 1.875rem; |  | ||||||
|   gap: 1.25rem; |   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 { | .label { | ||||||
|   letter-spacing: 5%; |   letter-spacing: 0.03rem; | ||||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; |   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .pre-darkmode { | pre { | ||||||
|     color: #fff; |   margin: 0; | ||||||
| } |  | ||||||
|  |  | ||||||
| .pre-lightmode { |  | ||||||
|     color: #000; |  | ||||||
| } | } | ||||||
|  | .pre-darkmode { color: #ffffff; }  | ||||||
|  | .pre-lightmode { color: #000000; } | ||||||
|  |  | ||||||
| .data { | .data { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|   align-items: flex-start; |  | ||||||
|   padding: 0 0.625rem; |   padding: 0 0.625rem; | ||||||
|   border-radius: 0.3125rem; |   border-radius: 0.3125rem; | ||||||
|   box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; |   box-shadow: 0.0625rem 0.0625rem 0.25rem 0rem rgba(0, 0, 0, 0.25) inset; | ||||||
|   background-color: #212121; |   background-color: #212121; | ||||||
|  |   align-items: center; | ||||||
|  |   justify-content: flex-start; | ||||||
|   letter-spacing: 5%; |   letter-spacing: 5%; | ||||||
|   font: 400 0.75rem/250% Overpass, sans-serif; |   font: 400 0.75rem/250% Overpass, sans-serif; | ||||||
| }  | }  | ||||||
|  |  | ||||||
| .data-darkmode { | .data-darkmode { | ||||||
|   background-color: #212121; |   background-color: #212121; | ||||||
|     color: #fff; |   color: #ffffff; | ||||||
| }  | }  | ||||||
|  |  | ||||||
| .data-lightmode { | .data-lightmode { | ||||||
|     background-color: #EBEBEB; |   background-color: #ebebeb; | ||||||
|     color: #000; |   color: #000000; | ||||||
| }  | }  | ||||||
|  |  | ||||||
| .data#notes { |  | ||||||
|   align-self: stretch; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .client-data { | .client-data { | ||||||
|   display: flex; |   display: flex; | ||||||
|  |   flex: auto; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|  |   padding: 1.25rem 1.875rem; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: flex-start; |   justify-content: stretch; | ||||||
|   align-self: stretch; |   gap: 0.625rem | ||||||
|   padding: 0 0.625rem; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .contact, | .contact, .address { | ||||||
| .address { |  | ||||||
|   display: flex; |   display: flex; | ||||||
|  |   flex: auto; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   line-height: normal; |   gap: 0.625rem; | ||||||
|   width: 50%; |  | ||||||
|   padding: 1.25rem 0.625rem; |  | ||||||
|   border-radius: 0.3125rem; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .area-title { | .area-title { | ||||||
|   letter-spacing: 5%; |   letter-spacing: 0.03rem; | ||||||
|   font: 400 0.875rem/1.875rem Overpass, sans-serif; |   font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .h3-darkmode { | .h3-darkmode { color: #ffffff; }  | ||||||
|     color: #fff; | .h3-lightmode { color: #000000; } | ||||||
| } |  | ||||||
|  |  | ||||||
| .h3-lightmode { |  | ||||||
|     color: #000; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| .street-address { | .street-address { | ||||||
| @ -205,15 +169,17 @@ export default { | |||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-self: stretch; |   align-self: stretch; | ||||||
|   padding: 0 1.875rem 0 0; |  | ||||||
|   gap: 0.625rem; |   gap: 0.625rem; | ||||||
| } | } | ||||||
|  |  | ||||||
| .notes { | .notes { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|  |   padding: 0.625rem 1.875rem; | ||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   align-self: stretch; |   gap: 0.625rem; | ||||||
|   padding: 0.625rem 1.875rem 0.625rem 1.25rem; | } | ||||||
| }</style> | #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> | <template> | ||||||
|     <div :class="['data', darkMode ? 'div-darkmode' : 'div-lightmode']"> |     <section :class="['data', darkMode ? 'section-darkmode' : 'section-lightmode']"> | ||||||
|         <table class="data-table" id="client-table"> |         <table class="data-table" id="client-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 :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> | ||||||
|                 <th |  | ||||||
|                     :class="['Name', darkMode ? 'th-darkmode' : 'th-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |  | ||||||
|                     Name</th> |  | ||||||
|             </tr> |             </tr> | ||||||
|             <tr :class="['table-row', darkMode ? 'tr-darkmode' : 'tr-lightmode']" id="row-1"> |             <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 :class="['ID', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'ID-darkmode' : 'ID-lightmode']">...</td> | ||||||
|                     ...</td> |                 <td :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']">...</td> | ||||||
|                 <td |  | ||||||
|                     :class="['Name', darkMode ? 'td-darkmode' : 'td-lightmode', darkMode ? 'Name-darkmode' : 'Name-lightmode']"> |  | ||||||
|                     ...</td> |  | ||||||
|             </tr> |             </tr> | ||||||
|         </table> |         </table> | ||||||
|     </div> |     </section> | ||||||
| </template> | </template> | ||||||
|    |    | ||||||
|    |    | ||||||
| @ -47,12 +41,12 @@ export default { | |||||||
|     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); | ||||||
| } | } | ||||||
|  |  | ||||||
| .div-darkmode { | .section-darkmode { | ||||||
|     background-color: #2c2c2c; |     background-color: #2c2c2c; | ||||||
| } | } | ||||||
|  |  | ||||||
| .div-lightmode { | .section-lightmode { | ||||||
|     background-color: #fff; |     background-color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
| .data-table { | .data-table { | ||||||
| @ -89,8 +83,7 @@ export default { | |||||||
|     border-top: 0.0625rem solid #8e8e8e; |     border-top: 0.0625rem solid #8e8e8e; | ||||||
| } | } | ||||||
|  |  | ||||||
| th, | th, td { | ||||||
| td { |  | ||||||
|     height: 1.875rem; |     height: 1.875rem; | ||||||
|     text-align: left; |     text-align: left; | ||||||
|     padding: 0; |     padding: 0; | ||||||
| @ -98,14 +91,12 @@ td { | |||||||
|     font: 400 0.875rem/1.875rem Overpass, sans-serif; |     font: 400 0.875rem/1.875rem Overpass, sans-serif; | ||||||
| } | } | ||||||
|  |  | ||||||
| .th-darkmode, | .th-darkmode, .td-darkmode { | ||||||
| .td-darkmode { |  | ||||||
|     color: #ffffff; |     color: #ffffff; | ||||||
| } | } | ||||||
|  |  | ||||||
| .th-lightmode, | .th-lightmode, .td-lightmode { | ||||||
| .td-lightmode { |     color: #000000; | ||||||
|     color: #000; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| th { | th { | ||||||
|  | |||||||
| @ -7,6 +7,11 @@ | |||||||
|       <ClientTable v-if="onCustomerlist"/> |       <ClientTable v-if="onCustomerlist"/> | ||||||
|       <Client v-if="onCustomer"/> |       <Client v-if="onCustomer"/> | ||||||
|       <ClientQuickAccess 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> |     </div> | ||||||
|   </section> |   </section> | ||||||
| </template> | </template> | ||||||
| @ -18,8 +23,11 @@ import { ref } from 'vue'; | |||||||
| import ClientTable from "../components/server/ClientTable.vue"; | import ClientTable from "../components/server/ClientTable.vue"; | ||||||
| import Client from "../components/server/Client.vue"; | import Client from "../components/server/Client.vue"; | ||||||
| import ClientQuickAccess from "../components/server/ClientQuickAccess.vue"; | import ClientQuickAccess from "../components/server/ClientQuickAccess.vue"; | ||||||
| //import ClientEmployees from "../components/server/ClientEmployees.vue"; | import ClientEmployeeList from "../components/server/ClientEmployeeList.vue"; | ||||||
| //import ClientEmployee from "../components/server/ClientEmployee.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({ | definePageMeta({ | ||||||
|   layout: 'default' |   layout: 'default' | ||||||
| @ -30,6 +38,10 @@ const darkMode = ref(true) | |||||||
| // to render the right components | // to render the right components | ||||||
| const onCustomerlist = ref(true) | const onCustomerlist = ref(true) | ||||||
| const onCustomer = ref(true) | const onCustomer = ref(true) | ||||||
|  | const onEmployeelist = ref(true) | ||||||
|  | const onEmployee = ref(true) | ||||||
|  | const onDepartmentlist = ref(true) | ||||||
|  | const onDepartment = ref(true) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <script> | <script> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user