From a336d856e1d098cba370c9a0aa44b2f2658c20ce Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dominik=20S=C3=A4ume?= Date: Thu, 9 Jan 2025 21:15:43 +0100 Subject: [PATCH] Fixs: API Doc, RouterLink, Styling, Layout --- src/app/app.component.html | 5 +- src/app/app.component.scss | 17 + src/app/app.component.ts | 8 +- src/app/app.config.ts | 4 +- src/app/core/auth/auth.service.ts | 13 +- src/app/core/ems/ems.yml | 565 +++++++++--------- src/app/core/ems/services.gen.ts | 282 ++++----- src/app/core/ems/types.gen.ts | 163 +++-- src/app/header/header.component.html | 2 +- .../notification-box.component.ts | 4 +- .../views/dashboard/dashboard.component.html | 8 +- .../views/dashboard/dashboard.component.ts | 8 +- src/styles.scss | 70 ++- 13 files changed, 600 insertions(+), 549 deletions(-) diff --git a/src/app/app.component.html b/src/app/app.component.html index 332550e..92517d4 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -1,3 +1,6 @@ - +
+

{{title.getTitle()}}

+ +
diff --git a/src/app/app.component.scss b/src/app/app.component.scss index e69de29..3f6b34b 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -0,0 +1,17 @@ +app-header { + width: 100%; +} + +main { + flex-grow: 1; + min-width: 100%; + width: fit-content; + box-sizing: border-box; + padding: 2rem; + + @media (min-width: 60rem) { + width: 80%; + min-width: 60rem; + max-width: 80rem; + } +} diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 7b150c3..43a95e3 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -1,6 +1,7 @@ -import {Component} from '@angular/core'; -import {RouterOutlet} from '@angular/router'; -import {HeaderComponent} from '@app/header/header.component'; +import { Component } from '@angular/core'; +import { Title } from '@angular/platform-browser'; +import { RouterOutlet } from '@angular/router'; +import { HeaderComponent } from '@app/header/header.component'; import { NotificationBoxComponent } from './notification-box/notification-box.component'; @@ -11,4 +12,5 @@ import { NotificationBoxComponent } from './notification-box/notification-box.co styleUrl: './app.component.scss' }) export class AppComponent { + constructor(protected title: Title) { } } diff --git a/src/app/app.config.ts b/src/app/app.config.ts index 869359e..a03b899 100644 --- a/src/app/app.config.ts +++ b/src/app/app.config.ts @@ -1,5 +1,6 @@ import {provideHttpClient} from '@angular/common/http'; import {ApplicationConfig, provideZoneChangeDetection} from '@angular/core'; +import { MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field'; import {provideAnimationsAsync} from '@angular/platform-browser/animations/async'; import {provideRouter} from '@angular/router'; import {routes} from '@app/app.routes'; @@ -26,6 +27,7 @@ export const appConfig: ApplicationConfig = { useRefreshToken: true, logLevel: LogLevel.Error, }, - }) + }), + { provide: MAT_FORM_FIELD_DEFAULT_OPTIONS, useValue: { appearance: 'outline' } } ], }; diff --git a/src/app/core/auth/auth.service.ts b/src/app/core/auth/auth.service.ts index fdef309..f543630 100644 --- a/src/app/core/auth/auth.service.ts +++ b/src/app/core/auth/auth.service.ts @@ -1,7 +1,9 @@ -import {Injectable} from '@angular/core'; +import { Injectable } from '@angular/core'; import UserData from '@core/auth/UserData'; -import {OidcSecurityService} from 'angular-auth-oidc-client'; -import {Observable} from 'rxjs'; +import { OidcSecurityService } from 'angular-auth-oidc-client'; +import { Observable } from 'rxjs'; + +import { OpenAPI } from '../ems'; @Injectable({ providedIn: 'root' @@ -11,13 +13,14 @@ export class AuthService { constructor(private readonly oidcSecurityService: OidcSecurityService) { this.$user = new Observable((publish) => { - this.oidcSecurityService.checkAuth().subscribe(({isAuthenticated, userData}) => { + this.oidcSecurityService.checkAuth().subscribe(({ isAuthenticated, userData }) => { publish.next(isAuthenticated ? { username: userData.preferred_username, verified: userData.email_verified } : undefined); }); }); + this.oidcSecurityService.getAccessToken().subscribe(token => OpenAPI.TOKEN = token); } @@ -26,7 +29,7 @@ export class AuthService { } logout() { - this.oidcSecurityService.logoff(); + this.oidcSecurityService.logoff().subscribe(() => { }); } } diff --git a/src/app/core/ems/ems.yml b/src/app/core/ems/ems.yml index e538d12..43571f7 100644 --- a/src/app/core/ems/ems.yml +++ b/src/app/core/ems/ems.yml @@ -1,24 +1,66 @@ openapi: 3.0.1 info: title: Employees Management Micro-Service - description: "\n## Overview\n\nEmployees Management Service API manages the employees\ - \ of HighTec Gmbh including their qualifications. It offers the possibility to\ - \ create, read, update and delete employees and qualifications. Existing employees\ - \ can be assigned new qualifications or have them withdrawn. \nThe API is organized\ - \ around REST. It has predictable resource-oriented URLs, accepts JSON-encoded\ - \ request bodies, returns JSON-encoded responses, uses standard HTTP response\ - \ codes and authentication.\n" + description: "## Overview \n + \ Employees Management Service API manages the employees
+ \ of HighTec Gmbh including their qualifications. It offers the possibility to
+ \ create, read, update and delete employees and qualifications. Existing employees
+ \ can be assigned new qualifications or have them withdrawn.
+ \ The API is organized
+ \ around REST. It has predictable resource-oriented URLs, accepts JSON-encoded
+ \ request bodies, returns JSON-encoded responses, uses standard HTTP response
+ \ codes and authentication." version: 1.1.2 servers: - url: "" security: - bearerAuth: [] paths: + /qualifications: + get: + tags: + - qualification + summary: Get a list of all available qualifications + operationId: getAllQualifications + responses: + "401": + description: not authorized + "200": + description: list of qualifications + content: + application/json: + schema: + type: array + items: + $ref: '#/components/schemas/Qualification' + post: + tags: + - qualification + summary: Creates a new qualification + operationId: createQualification + requestBody: + content: + application/json: + schema: + $ref: '#/components/schemas/NewQualification' + required: true + responses: + "201": + description: created qualification + content: + application/json: + schema: + $ref: '#/components/schemas/Qualification' + "401": + description: not authorized + "400": + description: invalid JSON posted + /qualifications/{id}: put: tags: - - qualification-controller - summary: updates a qualification + - qualification + summary: Updates a qualification operationId: updateQualification parameters: - name: id @@ -31,7 +73,7 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/QualificationPostDTO' + $ref: '#/components/schemas/NewQualification' required: true responses: "200": @@ -39,7 +81,7 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/QualificationPostDTO' + $ref: '#/components/schemas/Qualification' "401": description: not authorized "404": @@ -48,9 +90,9 @@ paths: description: invalid JSON posted delete: tags: - - qualification-controller - summary: deletes a qualification by id - operationId: deleteQualificationByDesignation + - qualification + summary: Deletes a qualification + operationId: deleteQualification parameters: - name: id in: path @@ -67,12 +109,13 @@ paths: description: delete successful "403": description: qualification is in use - /employees/{id}: + + /qualifications/{id}/employees: get: tags: - - employee-controller - summary: find employee by id - operationId: findById + - qualification + summary: Get all employees with a specific qualification + operationId: getAllQualificationEmployees parameters: - name: id in: path @@ -81,50 +124,86 @@ paths: type: integer format: int64 responses: + "401": + description: not authorized "200": - description: employee + description: List of employees who have the desired qualification content: application/json: schema: - $ref: '#/components/schemas/EmployeeResponseDTO' + $ref: '#/components/schemas/QualificationEmployees' + "404": + description: qualification id does not exist + + /employees: + get: + tags: + - employee + summary: Get a list of all available employees + operationId: getAllEmployees + responses: "401": description: not authorized - "404": - description: resource not found - put: + "200": + description: list of employees + content: + application/json: + schema: + type: array + items: + $ref: '#/components/schemas/Employee' + post: tags: - - employee-controller - summary: updates employee by id - operationId: updateEmployee - parameters: - - name: id - in: path - required: true - schema: - type: integer - format: int64 + - employee + summary: Creates a new employee + operationId: createEmployee requestBody: content: application/json: schema: - $ref: '#/components/schemas/EmployeeRequestPutDTO' + $ref: '#/components/schemas/NewEmployee' required: true + responses: + "401": + description: not authorized + "201": + description: created employee + content: + application/json: + schema: + $ref: '#/components/schemas/Employee' + "400": + description: invalid JSON posted + + /employees/{id}: + get: + tags: + - employee + summary: Gets a specific employee + operationId: getEmployee + parameters: + - name: id + in: path + required: true + schema: + type: integer + format: int64 responses: "200": description: employee content: application/json: schema: - $ref: '#/components/schemas/EmployeeResponseDTO' + $ref: '#/components/schemas/Employee' "401": description: not authorized "404": description: resource not found delete: tags: - - employee-controller - summary: deletes a employee by id - operationId: deleteCustomer + - employee + summary: Deletes a specific employee + operationId: DeleteEmployee parameters: - name: id in: path @@ -141,9 +220,9 @@ paths: description: delete successful patch: tags: - - employee-controller - summary: updates employee by id - operationId: patchEmployee + - employee + summary: Updates a employee + operationId: updateEmployee parameters: - name: id in: path @@ -155,7 +234,7 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/EmployeeRequestPutDTO' + $ref: '#/components/schemas/UpdatedEmployee' required: true responses: "200": @@ -163,93 +242,18 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/EmployeeResponseDTO' + $ref: '#/components/schemas/Employee' "401": description: not authorized "404": description: resource not found - /qualifications: - get: - tags: - - qualification-controller - summary: delivers a list of all available qualifications - operationId: findAll - responses: - "401": - description: not authorized - "200": - description: list of qualifications - content: - application/json: - schema: - $ref: '#/components/schemas/QualificationGetDTO' - post: - tags: - - qualification-controller - summary: creates a new qualification with its id and designation - operationId: createQualification - requestBody: - content: - application/json: - schema: - $ref: '#/components/schemas/QualificationPostDTO' - required: true - responses: - "201": - description: created qualification - content: - application/json: - schema: - $ref: '#/components/schemas/QualificationPostDTO' - "401": - description: not authorized - "400": - description: invalid JSON posted - /employees: - get: - tags: - - employee-controller - summary: delivers a list of all employees - operationId: findAll_1 - responses: - "401": - description: not authorized - "200": - description: list of employees - content: - application/json: - schema: - type: array - items: - $ref: '#/components/schemas/EmployeeResponseDTO' - post: - tags: - - employee-controller - summary: creates a new employee - operationId: createEmployee - requestBody: - content: - application/json: - schema: - $ref: '#/components/schemas/EmployeeRequestDTO' - required: true - responses: - "401": - description: not authorized - "201": - description: created employee - content: - application/json: - schema: - $ref: '#/components/schemas/EmployeeResponseDTO' - "400": - description: invalid JSON posted + /employees/{id}/qualifications: get: tags: - - employee-controller - summary: finds all qualifications of an employee by id - operationId: findAllQualificationOfAEmployeeById + - employee + summary: Gets all qualifications of a specific employee + operationId: getAllEmployeeQualifications parameters: - name: id in: path @@ -267,12 +271,12 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/EmployeeNameAndSkillDataDTO' + $ref: '#/components/schemas/EmployeeQualifications' post: tags: - - employee-controller - summary: adds a qualification to an employee by id - operationId: addQualificationToEmployeeById + - employee + summary: Adds a qualification to an employee + operationId: addQualificationToEmployee parameters: - name: id in: path @@ -284,7 +288,7 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/QualificationPostDTO' + $ref: '#/components/schemas/NewQualification' # Nobody knows why Heidemann did this. required: true responses: "401": @@ -298,45 +302,23 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/EmployeeNameAndSkillDataDTO' - /qualifications/{id}/employees: - get: - tags: - - qualification-controller - summary: find employees by qualification id - operationId: findAllEmployeesByQualification - parameters: - - name: id - in: path - required: true - schema: - type: integer - format: int64 - responses: - "401": - description: not authorized - "200": - description: List of employees who have the desired qualification - content: - application/json: - schema: - $ref: '#/components/schemas/EmployeesForAQualificationDTO' - "404": - description: qualification id does not exist - /employees/{eid}/qualifications/{qid}: + $ref: '#/components/schemas/EmployeeQualifications' + + + /employees/{employeeId}/qualifications/{qualificationId}: delete: tags: - - employee-controller - summary: deletes a qualification of an employee by id + - employee + summary: Removes a qualification from an employee operationId: removeQualificationFromEmployee parameters: - - name: eid + - name: employeeId in: path required: true schema: type: integer format: int64 - - name: qid + - name: qualificationId in: path required: true schema: @@ -352,142 +334,155 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/EmployeeNameAndSkillDataDTO' + $ref: '#/components/schemas/EmployeeQualifications' + components: + securitySchemes: + bearerAuth: + type: http + scheme: bearer + bearerFormat: JWT schemas: - QualificationPostDTO: + Qualification: + type: object + properties: + id: + type: integer + format: int64 + skill: + type: string + required: + - id + - skill + NewQualification: + type: object + properties: + skill: + type: string required: - skill - type: object - properties: - skill: - type: string - EmployeeRequestPutDTO: - type: object - properties: - lastName: - type: string - firstName: - type: string - street: - type: string - postcode: - type: string - city: - type: string - phone: - type: string - skillSet: - type: array - items: - type: integer - format: int64 - EmployeeResponseDTO: - required: - - city - - firstName - - lastName - - phone - - postcode - - street - type: object - properties: - id: - type: integer - format: int64 - lastName: - type: string - firstName: - type: string - street: - type: string - postcode: - maxLength: 5 - minLength: 5 - type: string - city: - type: string - phone: - type: string - skillSet: - type: array - items: - $ref: '#/components/schemas/QualificationGetDTO' - QualificationGetDTO: - type: object - properties: - skill: - type: string - id: - type: integer - format: int64 - EmployeeRequestDTO: - required: - - city - - firstName - - lastName - - phone - - postcode - - street - type: object - properties: - lastName: - type: string - firstName: - type: string - street: - type: string - postcode: - maxLength: 5 - minLength: 5 - type: string - city: - type: string - phone: - type: string - skillSet: - type: array - items: - type: integer - format: int64 - EmployeeNameAndSkillDataDTO: - type: object - properties: - id: - type: integer - format: int64 - lastName: - type: string - firstName: - type: string - skillSet: - uniqueItems: true - type: array - items: - $ref: '#/components/schemas/QualificationGetDTO' - EmployeeNameDataDTO: - type: object - properties: - id: - type: integer - format: int64 - lastName: - type: string - firstName: - type: string - EmployeesForAQualificationDTO: + QualificationEmployees: type: object properties: qualification: - $ref: '#/components/schemas/QualificationGetDTO' + $ref: '#/components/schemas/Qualification' employees: uniqueItems: true type: array items: - $ref: '#/components/schemas/EmployeeNameDataDTO' - securitySchemes: - bearerAuth: - type: http - name: bearerAuth - scheme: bearer - bearerFormat: JWT + $ref: '#/components/schemas/QualificationEmployee' + required: + - qualification + - employees + QualificationEmployee: + type: object + properties: + id: + type: integer + format: int64 + lastName: + type: string + firstName: + type: string + required: + - id + - lastName + - firstName + Employee: + type: object + properties: + id: + type: integer + format: int64 + firstName: + type: string + lastName: + type: string + postcode: + maxLength: 5 + minLength: 5 + type: string + city: + type: string + street: + type: string + phone: + type: string + skillSet: + type: array + items: + $ref: '#/components/schemas/Qualification' + required: + - id + - firstName + - lastName + - postcode + - city + - street + - phone + - skillSet + NewEmployee: + type: object + properties: + lastName: + type: string + firstName: + type: string + street: + type: string + postcode: + maxLength: 5 + minLength: 5 + type: string + city: + type: string + phone: + type: string + skillSet: + type: array + items: + type: integer + format: int64 + required: + - firstName + - lastName + - postcode + - city + - street + - phone + - skillSet + UpdatedEmployee: + type: object + properties: + lastName: + type: string + firstName: + type: string + street: + type: string + postcode: + type: string + city: + type: string + phone: + type: string + skillSet: + type: array + items: + type: integer + format: int64 + EmployeeQualifications: + type: object + properties: + id: + type: integer + format: int64 + lastName: + type: string + firstName: + type: string + skillSet: + uniqueItems: true + type: array + items: + $ref: '#/components/schemas/Qualification' diff --git a/src/app/core/ems/services.gen.ts b/src/app/core/ems/services.gen.ts index cf72d2d..4ee6fcc 100644 --- a/src/app/core/ems/services.gen.ts +++ b/src/app/core/ems/services.gen.ts @@ -5,20 +5,55 @@ import { HttpClient } from '@angular/common/http'; import type { Observable } from 'rxjs'; import { OpenAPI } from './core/OpenAPI'; import { request as __request } from './core/request'; -import type { UpdateQualificationData, UpdateQualificationResponse, DeleteQualificationByDesignationData, DeleteQualificationByDesignationResponse, FindAllResponse, CreateQualificationData, CreateQualificationResponse, FindAllEmployeesByQualificationData, FindAllEmployeesByQualificationResponse, FindByIdData, FindByIdResponse, UpdateEmployeeData, UpdateEmployeeResponse, DeleteCustomerData, DeleteCustomerResponse, PatchEmployeeData, PatchEmployeeResponse, FindAll1Response, CreateEmployeeData, CreateEmployeeResponse, FindAllQualificationOfAemployeeByIdData, FindAllQualificationOfAemployeeByIdResponse, AddQualificationToEmployeeByIdData, AddQualificationToEmployeeByIdResponse, RemoveQualificationFromEmployeeData, RemoveQualificationFromEmployeeResponse } from './types.gen'; +import type { GetAllQualificationsResponse, CreateQualificationData, CreateQualificationResponse, UpdateQualificationData, UpdateQualificationResponse, DeleteQualificationData, DeleteQualificationResponse, GetAllQualificationEmployeesData, GetAllQualificationEmployeesResponse, GetAllEmployeesResponse, CreateEmployeeData, CreateEmployeeResponse, GetEmployeeData, GetEmployeeResponse, DeleteEmployeeData, DeleteEmployeeResponse, UpdateEmployeeData, UpdateEmployeeResponse, GetAllEmployeeQualificationsData, GetAllEmployeeQualificationsResponse, AddQualificationToEmployeeData, AddQualificationToEmployeeResponse, RemoveQualificationFromEmployeeData, RemoveQualificationFromEmployeeResponse } from './types.gen'; @Injectable({ providedIn: 'root' }) -export class QualificationControllerService { +export class QualificationService { constructor(public readonly http: HttpClient) { } /** - * updates a qualification + * Get a list of all available qualifications + * @returns Qualification list of qualifications + * @throws ApiError + */ + public getAllQualifications(): Observable { + return __request(OpenAPI, this.http, { + method: 'GET', + url: '/qualifications', + errors: { + 401: 'not authorized' + } + }); + } + + /** + * Creates a new qualification + * @param data The data for the request. + * @param data.requestBody + * @returns Qualification created qualification + * @throws ApiError + */ + public createQualification(data: CreateQualificationData): Observable { + return __request(OpenAPI, this.http, { + method: 'POST', + url: '/qualifications', + body: data.requestBody, + mediaType: 'application/json', + errors: { + 400: 'invalid JSON posted', + 401: 'not authorized' + } + }); + } + + /** + * Updates a qualification * @param data The data for the request. * @param data.id * @param data.requestBody - * @returns QualificationPostDTO updated qualification + * @returns Qualification updated qualification * @throws ApiError */ public updateQualification(data: UpdateQualificationData): Observable { @@ -39,13 +74,13 @@ export class QualificationControllerService { } /** - * deletes a qualification by id + * Deletes a qualification * @param data The data for the request. * @param data.id * @returns void delete successful * @throws ApiError */ - public deleteQualificationByDesignation(data: DeleteQualificationByDesignationData): Observable { + public deleteQualification(data: DeleteQualificationData): Observable { return __request(OpenAPI, this.http, { method: 'DELETE', url: '/qualifications/{id}', @@ -61,48 +96,13 @@ export class QualificationControllerService { } /** - * delivers a list of all available qualifications - * @returns QualificationGetDTO list of qualifications - * @throws ApiError - */ - public findAll(): Observable { - return __request(OpenAPI, this.http, { - method: 'GET', - url: '/qualifications', - errors: { - 401: 'not authorized' - } - }); - } - - /** - * creates a new qualification with its id and designation - * @param data The data for the request. - * @param data.requestBody - * @returns QualificationPostDTO created qualification - * @throws ApiError - */ - public createQualification(data: CreateQualificationData): Observable { - return __request(OpenAPI, this.http, { - method: 'POST', - url: '/qualifications', - body: data.requestBody, - mediaType: 'application/json', - errors: { - 400: 'invalid JSON posted', - 401: 'not authorized' - } - }); - } - - /** - * find employees by qualification id + * Get all employees with a specific qualification * @param data The data for the request. * @param data.id - * @returns EmployeesForAQualificationDTO List of employees who have the desired qualification + * @returns QualificationEmployees List of employees who have the desired qualification * @throws ApiError */ - public findAllEmployeesByQualification(data: FindAllEmployeesByQualificationData): Observable { + public getAllQualificationEmployees(data: GetAllQualificationEmployeesData): Observable { return __request(OpenAPI, this.http, { method: 'GET', url: '/qualifications/{id}/employees', @@ -121,105 +121,15 @@ export class QualificationControllerService { @Injectable({ providedIn: 'root' }) -export class EmployeeControllerService { +export class EmployeeService { constructor(public readonly http: HttpClient) { } /** - * find employee by id - * @param data The data for the request. - * @param data.id - * @returns EmployeeResponseDTO employee + * Get a list of all available employees + * @returns Employee list of employees * @throws ApiError */ - public findById(data: FindByIdData): Observable { - return __request(OpenAPI, this.http, { - method: 'GET', - url: '/employees/{id}', - path: { - id: data.id - }, - errors: { - 401: 'not authorized', - 404: 'resource not found' - } - }); - } - - /** - * updates employee by id - * @param data The data for the request. - * @param data.id - * @param data.requestBody - * @returns EmployeeResponseDTO employee - * @throws ApiError - */ - public updateEmployee(data: UpdateEmployeeData): Observable { - return __request(OpenAPI, this.http, { - method: 'PUT', - url: '/employees/{id}', - path: { - id: data.id - }, - body: data.requestBody, - mediaType: 'application/json', - errors: { - 401: 'not authorized', - 404: 'resource not found' - } - }); - } - - /** - * deletes a employee by id - * @param data The data for the request. - * @param data.id - * @returns void delete successful - * @throws ApiError - */ - public deleteCustomer(data: DeleteCustomerData): Observable { - return __request(OpenAPI, this.http, { - method: 'DELETE', - url: '/employees/{id}', - path: { - id: data.id - }, - errors: { - 401: 'not authorized', - 404: 'resource not found' - } - }); - } - - /** - * updates employee by id - * @param data The data for the request. - * @param data.id - * @param data.requestBody - * @returns EmployeeResponseDTO employee - * @throws ApiError - */ - public patchEmployee(data: PatchEmployeeData): Observable { - return __request(OpenAPI, this.http, { - method: 'PATCH', - url: '/employees/{id}', - path: { - id: data.id - }, - body: data.requestBody, - mediaType: 'application/json', - errors: { - 401: 'not authorized', - 404: 'resource not found' - } - }); - } - - /** - * delivers a list of all employees - * @returns EmployeeResponseDTO list of employees - * @throws ApiError - */ - public findAll1(): Observable { + public getAllEmployees(): Observable { return __request(OpenAPI, this.http, { method: 'GET', url: '/employees', @@ -230,10 +140,10 @@ export class EmployeeControllerService { } /** - * creates a new employee + * Creates a new employee * @param data The data for the request. * @param data.requestBody - * @returns EmployeeResponseDTO created employee + * @returns Employee created employee * @throws ApiError */ public createEmployee(data: CreateEmployeeData): Observable { @@ -250,13 +160,79 @@ export class EmployeeControllerService { } /** - * finds all qualifications of an employee by id + * Gets a specific employee * @param data The data for the request. * @param data.id - * @returns EmployeeNameAndSkillDataDTO employee with a list of his qualifications + * @returns Employee employee * @throws ApiError */ - public findAllQualificationOfAemployeeById(data: FindAllQualificationOfAemployeeByIdData): Observable { + public getEmployee(data: GetEmployeeData): Observable { + return __request(OpenAPI, this.http, { + method: 'GET', + url: '/employees/{id}', + path: { + id: data.id + }, + errors: { + 401: 'not authorized', + 404: 'resource not found' + } + }); + } + + /** + * Deletes a specific employee + * @param data The data for the request. + * @param data.id + * @returns void delete successful + * @throws ApiError + */ + public deleteEmployee(data: DeleteEmployeeData): Observable { + return __request(OpenAPI, this.http, { + method: 'DELETE', + url: '/employees/{id}', + path: { + id: data.id + }, + errors: { + 401: 'not authorized', + 404: 'resource not found' + } + }); + } + + /** + * Updates a employee + * @param data The data for the request. + * @param data.id + * @param data.requestBody + * @returns Employee employee + * @throws ApiError + */ + public updateEmployee(data: UpdateEmployeeData): Observable { + return __request(OpenAPI, this.http, { + method: 'PATCH', + url: '/employees/{id}', + path: { + id: data.id + }, + body: data.requestBody, + mediaType: 'application/json', + errors: { + 401: 'not authorized', + 404: 'resource not found' + } + }); + } + + /** + * Gets all qualifications of a specific employee + * @param data The data for the request. + * @param data.id + * @returns EmployeeQualifications employee with a list of his qualifications + * @throws ApiError + */ + public getAllEmployeeQualifications(data: GetAllEmployeeQualificationsData): Observable { return __request(OpenAPI, this.http, { method: 'GET', url: '/employees/{id}/qualifications', @@ -271,14 +247,14 @@ export class EmployeeControllerService { } /** - * adds a qualification to an employee by id + * Adds a qualification to an employee * @param data The data for the request. * @param data.id * @param data.requestBody - * @returns EmployeeNameAndSkillDataDTO employee with a list of his qualifications + * @returns EmployeeQualifications employee with a list of his qualifications * @throws ApiError */ - public addQualificationToEmployeeById(data: AddQualificationToEmployeeByIdData): Observable { + public addQualificationToEmployee(data: AddQualificationToEmployeeData): Observable { return __request(OpenAPI, this.http, { method: 'POST', url: '/employees/{id}/qualifications', @@ -296,20 +272,20 @@ export class EmployeeControllerService { } /** - * deletes a qualification of an employee by id + * Removes a qualification from an employee * @param data The data for the request. - * @param data.eid - * @param data.qid - * @returns EmployeeNameAndSkillDataDTO employee with a list of his qualifications + * @param data.employeeId + * @param data.qualificationId + * @returns EmployeeQualifications employee with a list of his qualifications * @throws ApiError */ public removeQualificationFromEmployee(data: RemoveQualificationFromEmployeeData): Observable { return __request(OpenAPI, this.http, { method: 'DELETE', - url: '/employees/{eid}/qualifications/{qid}', + url: '/employees/{employeeId}/qualifications/{qualificationId}', path: { - eid: data.eid, - qid: data.qid + employeeId: data.employeeId, + qualificationId: data.qualificationId }, errors: { 401: 'not authorized', diff --git a/src/app/core/ems/types.gen.ts b/src/app/core/ems/types.gen.ts index 1809b3d..720562e 100644 --- a/src/app/core/ems/types.gen.ts +++ b/src/app/core/ems/types.gen.ts @@ -1,10 +1,47 @@ // This file is auto-generated by @hey-api/openapi-ts -export type QualificationPostDTO = { +export type Qualification = { + id: number; skill: string; }; -export type EmployeeRequestPutDTO = { +export type NewQualification = { + skill: string; +}; + +export type QualificationEmployees = { + qualification: Qualification; + employees: Array; +}; + +export type QualificationEmployee = { + id: number; + lastName: string; + firstName: string; +}; + +export type Employee = { + id: number; + firstName: string; + lastName: string; + postcode: string; + city: string; + street: string; + phone: string; + skillSet: Array; +}; + +export type NewEmployee = { + lastName: string; + firstName: string; + street: string; + postcode: string; + city: string; + phone: string; + skillSet: Array<(number)>; +}; + +export type UpdatedEmployee = { lastName?: string; firstName?: string; street?: string; @@ -14,127 +51,83 @@ export type EmployeeRequestPutDTO = { skillSet?: Array<(number)>; }; -export type EmployeeResponseDTO = { - id?: number; - lastName: string; - firstName: string; - street: string; - postcode: string; - city: string; - phone: string; - skillSet?: Array; -}; - -export type QualificationGetDTO = { - skill?: string; - id?: number; -}; - -export type EmployeeRequestDTO = { - lastName: string; - firstName: string; - street: string; - postcode: string; - city: string; - phone: string; - skillSet?: Array<(number)>; -}; - -export type EmployeeNameAndSkillDataDTO = { +export type EmployeeQualifications = { id?: number; lastName?: string; firstName?: string; - skillSet?: Array; + skillSet?: Array; }; -export type EmployeeNameDataDTO = { - id?: number; - lastName?: string; - firstName?: string; +export type GetAllQualificationsResponse = (Array); + +export type CreateQualificationData = { + requestBody: NewQualification; }; -export type EmployeesForAQualificationDTO = { - qualification?: QualificationGetDTO; - employees?: Array; -}; +export type CreateQualificationResponse = (Qualification); export type UpdateQualificationData = { id: number; - requestBody: QualificationPostDTO; + requestBody: NewQualification; }; -export type UpdateQualificationResponse = (QualificationPostDTO); +export type UpdateQualificationResponse = (Qualification); -export type DeleteQualificationByDesignationData = { +export type DeleteQualificationData = { id: number; }; -export type DeleteQualificationByDesignationResponse = (void); +export type DeleteQualificationResponse = (void); -export type FindAllResponse = (QualificationGetDTO); - -export type CreateQualificationData = { - requestBody: QualificationPostDTO; -}; - -export type CreateQualificationResponse = (QualificationPostDTO); - -export type FindAllEmployeesByQualificationData = { +export type GetAllQualificationEmployeesData = { id: number; }; -export type FindAllEmployeesByQualificationResponse = (EmployeesForAQualificationDTO); +export type GetAllQualificationEmployeesResponse = (QualificationEmployees); -export type FindByIdData = { +export type GetAllEmployeesResponse = (Array); + +export type CreateEmployeeData = { + requestBody: NewEmployee; +}; + +export type CreateEmployeeResponse = (Employee); + +export type GetEmployeeData = { id: number; }; -export type FindByIdResponse = (EmployeeResponseDTO); +export type GetEmployeeResponse = (Employee); + +export type DeleteEmployeeData = { + id: number; +}; + +export type DeleteEmployeeResponse = (void); export type UpdateEmployeeData = { id: number; - requestBody: EmployeeRequestPutDTO; + requestBody: UpdatedEmployee; }; -export type UpdateEmployeeResponse = (EmployeeResponseDTO); +export type UpdateEmployeeResponse = (Employee); -export type DeleteCustomerData = { +export type GetAllEmployeeQualificationsData = { id: number; }; -export type DeleteCustomerResponse = (void); +export type GetAllEmployeeQualificationsResponse = (EmployeeQualifications); -export type PatchEmployeeData = { +export type AddQualificationToEmployeeData = { id: number; - requestBody: EmployeeRequestPutDTO; + requestBody: NewQualification; }; -export type PatchEmployeeResponse = (EmployeeResponseDTO); - -export type FindAll1Response = (Array); - -export type CreateEmployeeData = { - requestBody: EmployeeRequestDTO; -}; - -export type CreateEmployeeResponse = (EmployeeResponseDTO); - -export type FindAllQualificationOfAemployeeByIdData = { - id: number; -}; - -export type FindAllQualificationOfAemployeeByIdResponse = (EmployeeNameAndSkillDataDTO); - -export type AddQualificationToEmployeeByIdData = { - id: number; - requestBody: QualificationPostDTO; -}; - -export type AddQualificationToEmployeeByIdResponse = (EmployeeNameAndSkillDataDTO); +export type AddQualificationToEmployeeResponse = (EmployeeQualifications); export type RemoveQualificationFromEmployeeData = { - eid: number; - qid: number; + employeeId: number; + qualificationId: number; }; -export type RemoveQualificationFromEmployeeResponse = (EmployeeNameAndSkillDataDTO); \ No newline at end of file +export type RemoveQualificationFromEmployeeResponse = (EmployeeQualifications); \ No newline at end of file diff --git a/src/app/header/header.component.html b/src/app/header/header.component.html index c713f4a..5b37ea5 100644 --- a/src/app/header/header.component.html +++ b/src/app/header/header.component.html @@ -4,7 +4,7 @@ badge EMS @for (route of routes; track route) { - {{ route.title }} + {{ route.title }} } @if (auth.$user|async; as user) { diff --git a/src/app/notification-box/notification-box.component.ts b/src/app/notification-box/notification-box.component.ts index 693cc2b..4d97c90 100644 --- a/src/app/notification-box/notification-box.component.ts +++ b/src/app/notification-box/notification-box.component.ts @@ -1,13 +1,13 @@ import { animate, style, transition, trigger } from '@angular/animations'; import { Component, OnInit } from '@angular/core'; -import { MatCard, MatCardContent } from '@angular/material/card'; +import { MatCardModule } from '@angular/material/card'; import { Notification, NotificationService } from '@core/notification/notification.service'; const NOTIFICATION_TTL = 3000; @Component({ selector: 'app-notification-box', - imports: [MatCard, MatCardContent], + imports: [MatCardModule], animations: [ trigger('slideInOut', [ transition(':enter', [ diff --git a/src/app/views/dashboard/dashboard.component.html b/src/app/views/dashboard/dashboard.component.html index 2e49c07..cbd75c0 100644 --- a/src/app/views/dashboard/dashboard.component.html +++ b/src/app/views/dashboard/dashboard.component.html @@ -1,4 +1,4 @@ -

dashboard works!

- - - +New Employee +Edit Employee 3 + + diff --git a/src/app/views/dashboard/dashboard.component.ts b/src/app/views/dashboard/dashboard.component.ts index 9455e38..a021d25 100644 --- a/src/app/views/dashboard/dashboard.component.ts +++ b/src/app/views/dashboard/dashboard.component.ts @@ -1,11 +1,11 @@ import { Component } from '@angular/core'; -import { MatButton } from '@angular/material/button'; - -import { NotificationService, NotificationType } from '../../core/notification/notification.service'; +import { MatButtonModule } from '@angular/material/button'; +import { RouterLink } from '@angular/router'; +import { NotificationService, NotificationType } from '@core/notification/notification.service'; @Component({ selector: 'app-dashboard', - imports: [MatButton], + imports: [MatButtonModule, RouterLink], templateUrl: './dashboard.component.html', styleUrl: './dashboard.component.scss' }) diff --git a/src/styles.scss b/src/styles.scss index e040c88..8d888d1 100644 --- a/src/styles.scss +++ b/src/styles.scss @@ -1,9 +1,9 @@ @use '@angular/material' as mat; - html, body { height: 100%; + min-height: 100%; margin: 0; background: var(--mat-sys-surface); @@ -14,8 +14,68 @@ body { color-scheme: light dark; font-family: var(--mat-sys-label-medium-font); - @include mat.theme((color: mat.$azure-palette, - typography: Roboto, - density: 0)); - + @include mat.theme(( + color: mat.$azure-palette, + typography: Roboto, + density: 0 + )); +} + +app-root { + height: 100%; + width: 100%; + display: flex; + flex-direction: column; + align-items: center; +} + +.mdc-button { + &.abort, + &.error, + &.warn { + $ripple: var(color-mix(in srgb, var(--mat-sys-on-error) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)); + $fg: var(--mat-sys-on-error); + $bg: var(--mat-sys-error); + $fg-container: var(--mat-sys-on-error-container); + $bg-container: var(--mat-sys-error-container); + + @include mat.button-overrides(( + // default + text-label-text-color: $bg, + text-ripple-color: $ripple, + text-state-layer-color: $bg, + // filled + filled-label-text-color: $fg, + filled-container-color: $bg, + filled-ripple-color: $ripple, + filled-state-layer-color: $fg, + )); + @include mat.fab-overrides(( + // default + container-color: $fg-container, + foreground-color: $fg-container, + state-layer-color: $fg-container, + ripple-color: $ripple, + // mini + small-container-color: $fg-container, + small-foreground-color: $fg-container, + small-state-layer-color: $fg-container, + small-ripple-color: $ripple + )); + } +} + +.mdc-fab.shadowless { + @include mat.fab-overrides(( + // default + container-elevation-shadow: transparent, + hover-container-elevation-shadow: transparent, + pressed-container-elevation-shadow: transparent, + focus-container-elevation-shadow: transparent, + // mini + small-container-elevation-shadow: transparent, + small-hover-container-elevation-shadow: transparent, + small-pressed-container-elevation-shadow: transparent, + small-focus-container-elevation-shadow: transparent, + )); }