Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 | 1x | import { Injectable, signal } from "@angular/core";
import { ProjectRequest } from "./project.interfaces";
import { form, required, validate } from "@angular/forms/signals";
@Injectable({ providedIn: 'root' })
export class ProjectDetailsValidationService {
private readonly initialValuesProjectDetails: ProjectRequest = {
name: '',
client: '',
summary: '',
priority: 'Media',
health: 'Descubrimiento',
progress: 0,
methodology: 'Kanban',
createdDate: '',
startDate: '',
dueDate: '',
userCreated: { userId: '', role: '' },
teamMembers: [],
tags: []
};
private readonly projectDetailsModel = signal<ProjectRequest>(this.initialValuesProjectDetails);
private readonly projectDetailsForm = form(this.projectDetailsModel, (schemaPath) => {
required(schemaPath.name, {message: 'El nombre de proyecto es requerido'});
required(schemaPath.client, {message: 'El cliente es requerido'});
required(schemaPath.summary, {message: 'Resumen del proyecto es requerdio'});
required(schemaPath.priority, {message: 'La prioridad del proyecto es requerida'});
required(schemaPath.health, {message: 'El estado del proyecto es requerida'});
required(schemaPath.methodology, {message: 'La metodologia del proyecto es requerida'});
required(schemaPath.createdDate, {message: 'Created date is required'});
required(schemaPath.startDate, {message: 'Una fecha de inicio es requerida'});
required(schemaPath.dueDate, {message: 'Un fecha de entrega es requerida'});
validate(schemaPath.dueDate, (ctx) => {
const value = ctx.value();
if (!value) {
return [];
}
const today = new Date();
today.setHours(0, 0, 0, 0);
const selectedDate = new Date(value);
selectedDate.setHours(0, 0, 0, 0);
if (selectedDate < today) {
return [{
kind: 'datePast',
message: 'La fecha no puede ser anterior al día de hoy'
}];
}
return [];
});
required(schemaPath.userCreated.role, {message: 'Asignarse un rol es requerido'});
});
formDisable(){
this.projectDetailsForm().disabled()
}
resetFormDetails() {
this.projectDetailsModel.set(this.initialValuesProjectDetails);
this.projectDetailsForm.name().reset();
this.projectDetailsForm.client().reset();
this.projectDetailsForm.summary().reset();
this.projectDetailsForm.priority().reset();
this.projectDetailsForm.health().reset();
this.projectDetailsForm.methodology().reset();
this.projectDetailsForm.createdDate().reset();
this.projectDetailsForm.startDate().reset();
this.projectDetailsForm.dueDate().reset();
this.projectDetailsForm.userCreated.role().reset();
}
markAllFieldsAsTouchedDetails() {
this.projectDetailsForm.name().markAsTouched();
this.projectDetailsForm.client().markAsTouched();
this.projectDetailsForm.summary().markAsTouched();
this.projectDetailsForm.priority().markAsTouched();
this.projectDetailsForm.health().markAsTouched();
this.projectDetailsForm.methodology().markAsTouched();
this.projectDetailsForm.createdDate().markAsTouched();
this.projectDetailsForm.startDate().markAsTouched();
this.projectDetailsForm.dueDate().markAsTouched();
}
getProjectDetailsForm() {
return this.projectDetailsForm;
}
getProjectDetailsModel() {
return this.projectDetailsModel;
}
setProjectDetailsModel(details: ProjectRequest) {
this.projectDetailsModel.set(details);
}
} |