import { AfterViewInit, Component, ElementRef, OnInit, ViewChild } from '@angular/core'; import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms'; import { MatButton } from '@angular/material/button'; import { MatCard, MatCardHeader, MatCardTitle, MatCardContent, MatCardActions, MatCardSubtitle, } from '@angular/material/card'; import { MatCheckbox } from '@angular/material/checkbox'; import { MatOption } from '@angular/material/core'; import { MatDialog } from '@angular/material/dialog'; import { MatFormField, MatLabel } from '@angular/material/form-field'; import { MatInput } from '@angular/material/input'; import { MatSelect } from '@angular/material/select'; import { ActivatedRoute, Router } from '@angular/router'; import { Device } from '../../core/device'; import { Section } from '../../core/section'; import { ToasterService } from '../../core/toaster.service'; import { ConfirmDialogComponent } from '../../shared/confirm-dialog/confirm-dialog.component'; import { LocalTimePipe } from '../../shared/local-time.pipe'; import { DeviceService } from '../device.service'; @Component({ selector: 'app-device-detail', templateUrl: './device-detail.component.html', styleUrls: ['./device-detail.component.css'], standalone: true, imports: [ MatCard, MatCardHeader, MatCardTitle, MatCardContent, ReactiveFormsModule, MatFormField, MatLabel, MatInput, MatSelect, MatOption, MatCheckbox, MatCardActions, MatButton, MatCardSubtitle, LocalTimePipe, ], }) export class DeviceDetailComponent implements OnInit, AfterViewInit { @ViewChild('nameElement', { static: true }) nameElement?: ElementRef; form: FormGroup<{ name: FormControl; section: FormControl; enabled: FormControl; }>; sections: Section[] = []; item: Device = new Device(); constructor( private route: ActivatedRoute, private router: Router, private dialog: MatDialog, private toaster: ToasterService, private ser: DeviceService, ) { // Create form this.form = new FormGroup({ name: new FormControl('', { nonNullable: true }), section: new FormControl(null), enabled: new FormControl(false, { nonNullable: true }), }); } ngOnInit() { this.route.data.subscribe((value) => { const data = value as { item: Device; sections: Section[] }; this.showItem(data.item); this.sections = data.sections; }); } showItem(item: Device) { this.item = item; this.form.setValue({ name: this.item.name ?? '', section: this.item.section.id ? this.item.section.id : '', enabled: this.item.enabled, }); } ngAfterViewInit() { setTimeout(() => { if (this.nameElement !== undefined) { this.nameElement.nativeElement.focus(); } }, 0); } save() { this.ser.saveOrUpdate(this.getItem()).subscribe({ next: () => { this.toaster.show('Success', ''); this.router.navigateByUrl('/devices'); }, error: (error) => { this.toaster.show('Error', error); }, }); } delete() { this.ser.delete(this.item.id as string).subscribe({ next: () => { this.toaster.show('Success', ''); this.router.navigateByUrl('/devices'); }, error: (error) => { this.toaster.show('Error', error); }, }); } confirmDelete(): void { const dialogRef = this.dialog.open(ConfirmDialogComponent, { width: '250px', data: { title: 'Delete Device?', content: 'Are you sure? This cannot be undone.' }, }); dialogRef.afterClosed().subscribe((result: boolean) => { if (result) { this.delete(); } }); } getItem(): Device { const formModel = this.form.value; this.item.name = formModel.name ?? ''; this.item.section.id = formModel.section ?? ''; this.item.enabled = formModel.enabled ?? true; return this.item; } }