equipo tipo entrada service final
This commit is contained in:
parent
9cb1a2c8ad
commit
a0965b5d49
@ -53,7 +53,7 @@ export class CarreraProgramaService {
|
|||||||
where: { institucionCarrera, programa },
|
where: { institucionCarrera, programa },
|
||||||
})
|
})
|
||||||
.then((existeCarretaPrograma) => {
|
.then((existeCarretaPrograma) => {
|
||||||
// Si encuentro uno saco error
|
// Si encontramos uno sacamos error
|
||||||
if (existeCarretaPrograma)
|
if (existeCarretaPrograma)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'Ya se asignó este programa a esta carrera.',
|
'Ya se asignó este programa a esta carrera.',
|
||||||
|
@ -40,16 +40,15 @@ export class EquipoProgramaService {
|
|||||||
id_programa,
|
id_programa,
|
||||||
);
|
);
|
||||||
|
|
||||||
// Validamos que el programa seleccionado no sea "Sin programa"
|
// Validamos que el programa seleccionado no sea "Sin software"
|
||||||
if (programa.id_programa === 1)
|
if (programa.id_programa === 1)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'No se puede asignar manualmente sin programa.',
|
'No se puede asignar manualmente sin software.',
|
||||||
);
|
);
|
||||||
// Validamos que el equipo pertenezca a la institución del operador
|
// Validamos que el equipo pertenezca a la institución del operador
|
||||||
if (
|
if (
|
||||||
operador.tipoUsuario.id_tipo_usuario > 2 &&
|
|
||||||
operador.institucion.id_institucion !=
|
operador.institucion.id_institucion !=
|
||||||
equipo.carrito.modulo.institucion.id_institucion
|
equipo.carrito.modulo.institucion.id_institucion
|
||||||
)
|
)
|
||||||
throw new ForbiddenException(
|
throw new ForbiddenException(
|
||||||
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
||||||
@ -57,7 +56,7 @@ export class EquipoProgramaService {
|
|||||||
// Buscamos un registro con los datos mandados del client
|
// Buscamos un registro con los datos mandados del client
|
||||||
return this.findByEquipoPrograma(equipo, programa)
|
return this.findByEquipoPrograma(equipo, programa)
|
||||||
.then((existeEquipoPrograma) => {
|
.then((existeEquipoPrograma) => {
|
||||||
// Si encuentro uno saco error
|
// Si encontramos uno sacamos error
|
||||||
if (existeEquipoPrograma)
|
if (existeEquipoPrograma)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'Este software ya fue asignado a este equipo.',
|
'Este software ya fue asignado a este equipo.',
|
||||||
@ -70,7 +69,7 @@ export class EquipoProgramaService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
create(equipo: Equipo, programa: Programa): Promise<EquipoPrograma> {
|
create(equipo: Equipo, programa: Programa): Promise<EquipoPrograma> {
|
||||||
// Verificamos si tiene programa "Sin programa"
|
// Verificamos si tiene programa "Sin software"
|
||||||
return this.findByEquipoPrograma(equipo, { id_programa: 1 }).then(
|
return this.findByEquipoPrograma(equipo, { id_programa: 1 }).then(
|
||||||
async (existeEquipoSinPrograma) => {
|
async (existeEquipoSinPrograma) => {
|
||||||
// Si lo tiene lo eliminamos
|
// Si lo tiene lo eliminamos
|
||||||
@ -105,13 +104,13 @@ export class EquipoProgramaService {
|
|||||||
// No se puede eliminar "Sin programa" manualmente
|
// No se puede eliminar "Sin programa" manualmente
|
||||||
if (equipoPrograma.programa.id_programa === 1)
|
if (equipoPrograma.programa.id_programa === 1)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'No se puede eliminar manualmente sin programa.',
|
'No se puede eliminar manualmente sin software.',
|
||||||
);
|
);
|
||||||
// Buscamos cuantos programas tiene el equipo
|
// Buscamos cuantos programas tiene el equipo
|
||||||
return this.repository
|
return this.repository
|
||||||
.count({ where: { equipo: equipoPrograma.equipo } })
|
.count({ where: { equipo: equipoPrograma.equipo } })
|
||||||
.then(async (n) => {
|
.then(async (n) => {
|
||||||
// Asignar "Sin programa" si es que solo tiene 1, el que se va a eliminar
|
// Asignar "Sin software" si es que solo tiene 1, el que se va a eliminar
|
||||||
if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
|
if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
|
||||||
// Eliminamos registro
|
// Eliminamos registro
|
||||||
return this.repository.remove(equipoPrograma);
|
return this.repository.remove(equipoPrograma);
|
||||||
@ -121,24 +120,11 @@ export class EquipoProgramaService {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> {
|
findByEquipoPrograma(
|
||||||
return this.fullInformacionEquipoProgramaView
|
equipo: Equipo,
|
||||||
.find({ where: { id_equipo } })
|
programa: Programa | Partial<Programa>,
|
||||||
.then((infoEquipoProgramas) => {
|
): Promise<EquipoPrograma> {
|
||||||
const equipoProgramas: EquipoPrograma[] = [];
|
return this.repository.findOne({ where: { equipo, programa } });
|
||||||
|
|
||||||
for (let i = 0; i < infoEquipoProgramas.length; i++)
|
|
||||||
equipoProgramas.push(
|
|
||||||
this.repository.create({
|
|
||||||
id_equipo_programa: infoEquipoProgramas[i].id_equipo_programa,
|
|
||||||
programa: {
|
|
||||||
id_programa: infoEquipoProgramas[i].id_programa,
|
|
||||||
programa: infoEquipoProgramas[i].programa,
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
return equipoProgramas;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
findById(id_equipo_programa: number): Promise<EquipoPrograma> {
|
findById(id_equipo_programa: number): Promise<EquipoPrograma> {
|
||||||
@ -169,10 +155,23 @@ export class EquipoProgramaService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
findByEquipoPrograma(
|
findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoPrograma[]> {
|
||||||
equipo: Equipo,
|
return this.fullInformacionEquipoProgramaView
|
||||||
programa: Programa | Partial<Programa>,
|
.find({ where: { id_equipo } })
|
||||||
): Promise<EquipoPrograma> {
|
.then((infoEquipoProgramas) => {
|
||||||
return this.repository.findOne({ where: { equipo, programa } });
|
const equipoProgramas: EquipoPrograma[] = [];
|
||||||
|
|
||||||
|
for (let i = 0; i < infoEquipoProgramas.length; i++)
|
||||||
|
equipoProgramas.push(
|
||||||
|
this.repository.create({
|
||||||
|
id_equipo_programa: infoEquipoProgramas[i].id_equipo_programa,
|
||||||
|
programa: {
|
||||||
|
id_programa: infoEquipoProgramas[i].id_programa,
|
||||||
|
programa: infoEquipoProgramas[i].programa,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
return equipoProgramas;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,6 +38,7 @@ export class EquipoTipoEntradaController {
|
|||||||
|
|
||||||
this.validarUsuarioService.validarAdminOperador(operador);
|
this.validarUsuarioService.validarAdminOperador(operador);
|
||||||
return this.equipoTipoEntradaService.asignar(
|
return this.equipoTipoEntradaService.asignar(
|
||||||
|
operador,
|
||||||
body.id_equipo,
|
body.id_equipo,
|
||||||
body.id_tipo_entrada,
|
body.id_tipo_entrada,
|
||||||
);
|
);
|
||||||
|
@ -30,37 +30,50 @@ export class EquipoTipoEntradaService {
|
|||||||
private institucionTipoEntradaService: InstitucionTipoEntradaService,
|
private institucionTipoEntradaService: InstitucionTipoEntradaService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async asignar(id_equipo: number, id_tipo_entrada: number) {
|
async asignar(
|
||||||
|
operador: Operador,
|
||||||
|
id_equipo: number,
|
||||||
|
id_tipo_entrada: number,
|
||||||
|
): Promise<{ message: string }> {
|
||||||
const equipo = await this.equipoService.findById(id_equipo);
|
const equipo = await this.equipoService.findById(id_equipo);
|
||||||
const tipoEntrada =
|
const tipoEntrada =
|
||||||
await this.institucionTipoEntradaService.findTipoEntradaById(
|
await this.institucionTipoEntradaService.findTipoEntradaById(
|
||||||
id_tipo_entrada,
|
id_tipo_entrada,
|
||||||
);
|
);
|
||||||
|
|
||||||
// Validamos que no eixsta un registro con estos ids
|
// Validamos que el equipo pertenezca a la institución del operador
|
||||||
return this.findByEquipoTipoEntrada(equipo, tipoEntrada).then(
|
if (
|
||||||
(existeEquipoTipoEntrada) => {
|
operador.institucion.id_institucion !=
|
||||||
// Error si existe saco error
|
equipo.carrito.modulo.institucion.id_institucion
|
||||||
|
)
|
||||||
|
throw new ForbiddenException(
|
||||||
|
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
||||||
|
);
|
||||||
|
// Buscamos un registro con los datos mandados del client
|
||||||
|
return this.findByEquipoTipoEntrada(equipo, tipoEntrada)
|
||||||
|
.then((existeEquipoTipoEntrada) => {
|
||||||
|
// Si encontramos uno sacamos error
|
||||||
if (existeEquipoTipoEntrada)
|
if (existeEquipoTipoEntrada)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'Este tipo de entrada ya fue asignado a este equipo.',
|
'Este conector ya fue asignado a este equipo.',
|
||||||
);
|
);
|
||||||
return this.create(equipo, tipoEntrada);
|
return this.create(equipo, tipoEntrada);
|
||||||
},
|
})
|
||||||
);
|
.then((_) => ({
|
||||||
}
|
message: 'Se asignó correctamente el conector a este equipo.',
|
||||||
|
|
||||||
create(equipo: Equipo, tipoEntrada: TipoEntrada) {
|
|
||||||
// Crear y guradar registro
|
|
||||||
return this.repository
|
|
||||||
.save(this.repository.create({ equipo, tipoEntrada }))
|
|
||||||
.then((equipoTipoEntrada) => ({
|
|
||||||
message: `Se asignó el tipo de entrada: ${tipoEntrada.tipo_entrada}, al equipo con número de inventario: ${equipo.numero_inventario}.`,
|
|
||||||
equipoTipoEntrada,
|
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
delete(operador: Operador, id_equipo_tipo_entrada: number) {
|
create(equipo: Equipo, tipoEntrada: TipoEntrada): Promise<EquipoTipoEntrada> {
|
||||||
|
return this.repository.save(
|
||||||
|
this.repository.create({ equipo, tipoEntrada }),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
delete(
|
||||||
|
operador: Operador,
|
||||||
|
id_equipo_tipo_entrada: number,
|
||||||
|
): Promise<{ message: string }> {
|
||||||
return this.findById(id_equipo_tipo_entrada)
|
return this.findById(id_equipo_tipo_entrada)
|
||||||
.then((equipoTipoEntrada) => {
|
.then((equipoTipoEntrada) => {
|
||||||
// Validamos que el equipo pertenezca a la institución del operador
|
// Validamos que el equipo pertenezca a la institución del operador
|
||||||
@ -71,36 +84,22 @@ export class EquipoTipoEntradaService {
|
|||||||
throw new ForbiddenException(
|
throw new ForbiddenException(
|
||||||
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
||||||
);
|
);
|
||||||
// Eliminar registro
|
// Eliminamos registro
|
||||||
return this.repository.remove(equipoTipoEntrada);
|
return this.repository.remove(equipoTipoEntrada);
|
||||||
})
|
})
|
||||||
.then((_) => ({
|
.then((_) => ({
|
||||||
message: 'Se eliminó correctamente el tipo de entrada de este equipo.',
|
message: 'Se eliminó correctamente el conector de este equipo.',
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
findFullInfoAllByIdEquipo(id_equipo: number) {
|
findByEquipoTipoEntrada(
|
||||||
return this.fullInformacionEquipoTipoEntradaView
|
equipo: Equipo,
|
||||||
.find({ where: { id_equipo } })
|
tipoEntrada: TipoEntrada,
|
||||||
.then((infoEquipoTipoEntradas) => {
|
): Promise<EquipoTipoEntrada> {
|
||||||
const equipoTipoEntradas: EquipoTipoEntrada[] = [];
|
return this.repository.findOne({ where: { equipo, tipoEntrada } });
|
||||||
|
|
||||||
for (let i = 0; i < infoEquipoTipoEntradas.length; i++)
|
|
||||||
equipoTipoEntradas.push(
|
|
||||||
this.repository.create({
|
|
||||||
id_equipo_tipo_entrada:
|
|
||||||
infoEquipoTipoEntradas[i].id_equipo_tipo_entrada,
|
|
||||||
tipoEntrada: {
|
|
||||||
id_tipo_entrada: infoEquipoTipoEntradas[i].id_tipo_entrada,
|
|
||||||
tipo_entrada: infoEquipoTipoEntradas[i].tipo_entrada,
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
return equipoTipoEntradas;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
findById(id_equipo_tipo_entrada: number) {
|
findById(id_equipo_tipo_entrada: number): Promise<EquipoTipoEntrada> {
|
||||||
return this.informacionEquipoTipoEntradaView
|
return this.informacionEquipoTipoEntradaView
|
||||||
.findOne({ where: { id_equipo_tipo_entrada } })
|
.findOne({ where: { id_equipo_tipo_entrada } })
|
||||||
.then((infoEquipoTipoEntrada) => {
|
.then((infoEquipoTipoEntrada) => {
|
||||||
@ -130,7 +129,24 @@ export class EquipoTipoEntradaService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
findByEquipoTipoEntrada(equipo: Equipo, tipoEntrada: TipoEntrada) {
|
findFullInfoAllByIdEquipo(id_equipo: number): Promise<EquipoTipoEntrada[]> {
|
||||||
return this.repository.findOne({ where: { equipo, tipoEntrada } });
|
return this.fullInformacionEquipoTipoEntradaView
|
||||||
|
.find({ where: { id_equipo } })
|
||||||
|
.then((infoEquipoTipoEntradas) => {
|
||||||
|
const equipoTipoEntradas: EquipoTipoEntrada[] = [];
|
||||||
|
|
||||||
|
for (let i = 0; i < infoEquipoTipoEntradas.length; i++)
|
||||||
|
equipoTipoEntradas.push(
|
||||||
|
this.repository.create({
|
||||||
|
id_equipo_tipo_entrada:
|
||||||
|
infoEquipoTipoEntradas[i].id_equipo_tipo_entrada,
|
||||||
|
tipoEntrada: {
|
||||||
|
id_tipo_entrada: infoEquipoTipoEntradas[i].id_tipo_entrada,
|
||||||
|
tipo_entrada: infoEquipoTipoEntradas[i].tipo_entrada,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
return equipoTipoEntradas;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,7 @@ export class MultaService {
|
|||||||
// correctamente esa vez
|
// correctamente esa vez
|
||||||
if (existeMulta) return;
|
if (existeMulta) return;
|
||||||
this.validacionMultaCancelacion(prestamo);
|
this.validacionMultaCancelacion(prestamo);
|
||||||
// Si no se mando un id_institucion_infraccion ni retraso saco error
|
// Si no se mando un id_institucion_infraccion ni retraso sacamos error
|
||||||
if (!id_institucion_infraccion && !retraso)
|
if (!id_institucion_infraccion && !retraso)
|
||||||
throw new ConflictException(
|
throw new ConflictException(
|
||||||
'No se mandó ningún motivo para multar a este alumno.',
|
'No se mandó ningún motivo para multar a este alumno.',
|
||||||
|
@ -301,10 +301,9 @@ export class UploadFileService {
|
|||||||
}
|
}
|
||||||
await this.equipoTipoEntradaService
|
await this.equipoTipoEntradaService
|
||||||
.create(equipo, tipoEntrada)
|
.create(equipo, tipoEntrada)
|
||||||
.then((res) => {
|
.then((equipoTipoEntrada) =>
|
||||||
equipo.tiposEntradas.push(res.equipoTipoEntrada);
|
equipo.tiposEntradas.push(equipoTipoEntrada),
|
||||||
mensajes.push(res.message);
|
);
|
||||||
});
|
|
||||||
}
|
}
|
||||||
for (let j = 0; j < programas.length; j++) {
|
for (let j = 0; j < programas.length; j++) {
|
||||||
const programa =
|
const programa =
|
||||||
|
Loading…
Reference in New Issue
Block a user