This commit is contained in:
parent
9976beada2
commit
16dcc63344
8 changed files with 172 additions and 24 deletions
|
@ -1,6 +1,6 @@
|
|||
import {Component} from '@angular/core';
|
||||
import {RouterOutlet} from '@angular/router';
|
||||
import {HeaderComponent} from '@app/header/header.component';
|
||||
import { Component } from '@angular/core';
|
||||
import { RouterOutlet } from '@angular/router';
|
||||
import { HeaderComponent } from '@app/header/header.component';
|
||||
|
||||
import { NotificationBoxComponent } from './notification-box/notification-box.component';
|
||||
|
||||
|
@ -11,4 +11,5 @@ import { NotificationBoxComponent } from './notification-box/notification-box.co
|
|||
styleUrl: './app.component.scss'
|
||||
})
|
||||
export class AppComponent {
|
||||
|
||||
}
|
||||
|
|
|
@ -1,16 +1,17 @@
|
|||
import {provideHttpClient} from '@angular/common/http';
|
||||
import {ApplicationConfig, provideZoneChangeDetection} from '@angular/core';
|
||||
import {provideAnimationsAsync} from '@angular/platform-browser/animations/async';
|
||||
import {provideRouter} from '@angular/router';
|
||||
import {routes} from '@app/app.routes';
|
||||
import {OpenAPI} from '@core/ems/core/OpenAPI';
|
||||
import {LogLevel, provideAuth} from 'angular-auth-oidc-client';
|
||||
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';
|
||||
import { OpenAPI } from '@core/ems/core/OpenAPI';
|
||||
import { LogLevel, provideAuth } from 'angular-auth-oidc-client';
|
||||
|
||||
OpenAPI.BASE = 'http://localhost:8080';
|
||||
|
||||
export const appConfig: ApplicationConfig = {
|
||||
providers: [
|
||||
provideZoneChangeDetection({eventCoalescing: true}),
|
||||
provideZoneChangeDetection({ eventCoalescing: true }),
|
||||
provideAnimationsAsync(),
|
||||
provideRouter(routes),
|
||||
provideHttpClient(),
|
||||
|
@ -26,6 +27,7 @@ export const appConfig: ApplicationConfig = {
|
|||
useRefreshToken: true,
|
||||
logLevel: LogLevel.Error,
|
||||
},
|
||||
})
|
||||
}),
|
||||
{ provide: MAT_FORM_FIELD_DEFAULT_OPTIONS, useValue: { appearance: 'outline' } }
|
||||
],
|
||||
};
|
||||
|
|
|
@ -1,4 +1,10 @@
|
|||
import {Routes} from '@angular/router';
|
||||
import {DashboardComponent} from '@app/views/dashboard/dashboard.component';
|
||||
import { Routes } from '@angular/router';
|
||||
import { DashboardComponent } from '@app/views/dashboard/dashboard.component';
|
||||
|
||||
export const routes: Routes = [{path: '', component: DashboardComponent, title: 'Home'}];
|
||||
import { EmployeeDetailComponent } from './views/employee-detail/employee-detail.component';
|
||||
|
||||
export const routes: Routes = [
|
||||
{ path: '', component: DashboardComponent, title: 'Home' },
|
||||
{ path: 'employee/new', component: EmployeeDetailComponent, title: 'New Employee' },
|
||||
{ path: 'employee/:id', component: EmployeeDetailComponent, title: 'Edit Employee' }
|
||||
];
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
<p>dashboard works!</p>
|
||||
|
||||
<a href="/employee/new">New Employee</a>
|
||||
<a href="/employee/3">Edit Employee 3</a>
|
||||
<button mat-button (click)="testInfo()">Test Info</button>
|
||||
<button mat-button (click)="testError()">Test Error</button>
|
||||
|
|
53
src/app/views/employee-detail/employee-detail.component.html
Normal file
53
src/app/views/employee-detail/employee-detail.component.html
Normal file
|
@ -0,0 +1,53 @@
|
|||
<form class="employee-detail" [formGroup]="employeeForm" appearance="outline">
|
||||
<div class="employee-detail__info-view">
|
||||
<div class="employee-detail__info-view__base">
|
||||
<mat-form-field>
|
||||
<mat-label>First Name</mat-label>
|
||||
<input matInput formControlName="firstName">
|
||||
</mat-form-field>
|
||||
<mat-form-field>
|
||||
<mat-label>Last Name</mat-label>
|
||||
<input matInput formControlName="lastName">
|
||||
</mat-form-field>
|
||||
<mat-form-field>
|
||||
<mat-label>Postcode</mat-label>
|
||||
<mat-icon matSuffix>money</mat-icon>
|
||||
<input matInput formControlName="postcode">
|
||||
</mat-form-field>
|
||||
<mat-form-field>
|
||||
<mat-label>City</mat-label>
|
||||
<mat-icon matSuffix>location_city</mat-icon>
|
||||
<input matInput formControlName="city">
|
||||
</mat-form-field>
|
||||
<mat-form-field>
|
||||
<mat-label>Street</mat-label>
|
||||
<mat-icon matSuffix>house</mat-icon>
|
||||
<input matInput formControlName="street">
|
||||
</mat-form-field>
|
||||
<mat-form-field>
|
||||
<mat-label>Phone</mat-label>
|
||||
<mat-icon matSuffix>phone</mat-icon>
|
||||
<input matInput formControlName="phone">
|
||||
</mat-form-field>
|
||||
</div>
|
||||
<div class="employee-detail__info-view__qualifications"></div>
|
||||
@if (isNewEmployee) {
|
||||
<p>New Employee View Works</p>
|
||||
}
|
||||
@else {
|
||||
@if ($employee|async;as employee) {
|
||||
<code>{{employee}}</code>
|
||||
}
|
||||
}
|
||||
</div>
|
||||
<div class="employee-detail__action-row">
|
||||
<button mat-flat-button (click)="onAbort()" class="abort">Abort</button>
|
||||
@if (isNewEmployee) {
|
||||
<button mat-flat-button (click)="onCreate()">Create</button>
|
||||
}
|
||||
@else {
|
||||
<button mat-flat-button (click)="onSave()">Save</button>
|
||||
}
|
||||
</div>
|
||||
|
||||
</form>
|
27
src/app/views/employee-detail/employee-detail.component.scss
Normal file
27
src/app/views/employee-detail/employee-detail.component.scss
Normal file
|
@ -0,0 +1,27 @@
|
|||
@use '@angular/material' as mat;
|
||||
|
||||
.employee-detail {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 1rem;
|
||||
|
||||
&__info-view {
|
||||
display: flex;
|
||||
gap: 1rem;
|
||||
|
||||
>* {
|
||||
flex-basis: 0;
|
||||
flex-grow: 1;
|
||||
}
|
||||
|
||||
&__base {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
}
|
||||
}
|
||||
|
||||
&__action-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
}
|
||||
}
|
55
src/app/views/employee-detail/employee-detail.component.ts
Normal file
55
src/app/views/employee-detail/employee-detail.component.ts
Normal file
|
@ -0,0 +1,55 @@
|
|||
import { AsyncPipe } from '@angular/common';
|
||||
import { Component } from '@angular/core';
|
||||
import { FormBuilder, FormGroup, ReactiveFormsModule } from '@angular/forms';
|
||||
import { MatButton } from '@angular/material/button';
|
||||
import { MatFormField, MatLabel, MatSuffix } from '@angular/material/form-field';
|
||||
import { MatIcon } from '@angular/material/icon';
|
||||
import { MatInput } from '@angular/material/input';
|
||||
import { ActivatedRoute } from '@angular/router';
|
||||
import { Employee, EmployeeService } from '@core/ems';
|
||||
import { Observable, of } from 'rxjs';
|
||||
|
||||
@Component({
|
||||
selector: 'app-employee-detail',
|
||||
imports: [AsyncPipe, MatButton, ReactiveFormsModule, MatFormField, MatLabel, MatInput, MatIcon, MatSuffix],
|
||||
templateUrl: './employee-detail.component.html',
|
||||
styleUrl: './employee-detail.component.scss'
|
||||
})
|
||||
export class EmployeeDetailComponent {
|
||||
isNewEmployee: boolean;
|
||||
employeeForm: FormGroup;
|
||||
$employee: Observable<Employee | undefined> = of();
|
||||
constructor(private route: ActivatedRoute, private employeeService: EmployeeService, private formBuilder: FormBuilder) {
|
||||
const idParam = this.route.snapshot.paramMap.get('id');
|
||||
this.isNewEmployee = idParam == null;
|
||||
|
||||
this.employeeForm = this.formBuilder.group<Employee>({
|
||||
id: 0,
|
||||
firstName: '',
|
||||
lastName: '',
|
||||
postcode: '',
|
||||
city: '',
|
||||
street: '',
|
||||
phone: '',
|
||||
skillSet: []
|
||||
});
|
||||
if (this.isNewEmployee) {
|
||||
return;
|
||||
}
|
||||
|
||||
const id = parseInt(idParam as string);
|
||||
this.$employee = this.employeeService.getEmployee({ id });
|
||||
}
|
||||
|
||||
onAbort() {
|
||||
|
||||
}
|
||||
|
||||
onCreate() {
|
||||
|
||||
}
|
||||
|
||||
onSave() {
|
||||
|
||||
}
|
||||
}
|
|
@ -1,5 +1,6 @@
|
|||
<!doctype html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>A</title>
|
||||
|
@ -9,7 +10,9 @@
|
|||
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500&display=swap" rel="stylesheet">
|
||||
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
|
||||
</head>
|
||||
|
||||
<body class="mat-typography">
|
||||
<app-root></app-root>
|
||||
</body>
|
||||
|
||||
</html>
|
||||
|
|
Loading…
Add table
Reference in a new issue