equipo programa actualizado
This commit is contained in:
parent
d83454af1f
commit
449e2acb5d
@ -11,7 +11,7 @@ export class EquipoPrograma {
|
|||||||
@JoinColumn({ name: 'id_equipo' })
|
@JoinColumn({ name: 'id_equipo' })
|
||||||
equipo: Equipo;
|
equipo: Equipo;
|
||||||
|
|
||||||
@ManyToOne(() => Programa, (programa) => programa.equipos, { eager: true })
|
@ManyToOne(() => Programa, (programa) => programa.equipos)
|
||||||
@JoinColumn({ name: 'id_programa' })
|
@JoinColumn({ name: 'id_programa' })
|
||||||
programa: Programa;
|
programa: Programa;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
|
import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
|
||||||
import { EquipoPrograma } from '../equipo-programa.entity';
|
import { EquipoPrograma } from '../equipo-programa.entity';
|
||||||
|
import { Equipo } from '../../../equipo/entity/equipo.entity';
|
||||||
|
import { Carrito } from '../../../carrito/entity/carrito.entity';
|
||||||
|
import { Modulo } from '../../../modulo/entity/modulo.entity';
|
||||||
|
|
||||||
@ViewEntity({
|
@ViewEntity({
|
||||||
expression: (dataSource: DataSource) =>
|
expression: (dataSource: DataSource) =>
|
||||||
@ -8,15 +11,34 @@ import { EquipoPrograma } from '../equipo-programa.entity';
|
|||||||
.select('ep.id_equipo_programa', 'id_equipo_programa')
|
.select('ep.id_equipo_programa', 'id_equipo_programa')
|
||||||
.addSelect('ep.id_equipo', 'id_equipo')
|
.addSelect('ep.id_equipo', 'id_equipo')
|
||||||
.addSelect('ep.id_programa', 'id_programa')
|
.addSelect('ep.id_programa', 'id_programa')
|
||||||
.from(EquipoPrograma, 'ep'),
|
.addSelect('e.id_carrito', 'id_carrito')
|
||||||
|
.addSelect('c.id_modulo', 'id_modulo')
|
||||||
|
.addSelect('c.id_tipo_carrito', 'id_tipo_carrito')
|
||||||
|
.addSelect('m.id_institucion', 'id_institucion')
|
||||||
|
.from(EquipoPrograma, 'ep')
|
||||||
|
.innerJoin(Equipo, 'e', 'e.id_equipo = ep.id_equipo')
|
||||||
|
.innerJoin(Carrito, 'c', 'c.id_carrito = e.id_carrito')
|
||||||
|
.innerJoin(Modulo, 'm', 'm.id_modulo = c.id_modulo'),
|
||||||
})
|
})
|
||||||
export class InformacionEquipoProgramaView {
|
export class InformacionEquipoProgramaView {
|
||||||
@ViewColumn()
|
@ViewColumn()
|
||||||
id_equipo_programa: number;
|
id_equipo_programa: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_carrito: number;
|
||||||
|
|
||||||
@ViewColumn()
|
@ViewColumn()
|
||||||
id_equipo: number;
|
id_equipo: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_institucion: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_modulo: number;
|
||||||
|
|
||||||
@ViewColumn()
|
@ViewColumn()
|
||||||
id_programa: number;
|
id_programa: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_tipo_carrito: number;
|
||||||
}
|
}
|
||||||
|
@ -37,7 +37,11 @@ export class EquipoProgramaController {
|
|||||||
const operador: Operador = req.user.operador;
|
const operador: Operador = req.user.operador;
|
||||||
|
|
||||||
this.validarUsuarioService.validarAdminOperador(operador);
|
this.validarUsuarioService.validarAdminOperador(operador);
|
||||||
return this.equipoProgramaService.create(body.id_equipo, body.id_programa);
|
return this.equipoProgramaService.asignar(
|
||||||
|
operador,
|
||||||
|
body.id_equipo,
|
||||||
|
body.id_programa,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Delete()
|
@Delete()
|
||||||
|
@ -30,36 +30,45 @@ export class EquipoProgramaService {
|
|||||||
private institucionProgramaService: InstitucionProgramaService,
|
private institucionProgramaService: InstitucionProgramaService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async create(
|
async asignar(operador: Operador, id_equipo: number, id_programa: number) {
|
||||||
// operador: Operador,
|
const equipo = await this.equipoService.findInfoEquipoById(id_equipo);
|
||||||
id_equipo: number | Equipo,
|
const programa = await this.institucionProgramaService.findProgramaById(
|
||||||
id_programa: number | Programa,
|
id_programa,
|
||||||
) {
|
);
|
||||||
const equipo =
|
|
||||||
typeof id_equipo === 'number'
|
|
||||||
? await this.equipoService.findInfoEquipoById(id_equipo)
|
|
||||||
: id_equipo;
|
|
||||||
const programa =
|
|
||||||
typeof id_programa === 'number'
|
|
||||||
? await this.institucionProgramaService.findProgramaById(id_programa)
|
|
||||||
: id_programa;
|
|
||||||
|
|
||||||
return this.informacionEquipoPrograma(
|
// Valida que el equipo pertenezca a la institución del operador
|
||||||
|
if (
|
||||||
|
operador.tipoUsuario.id_tipo_usuario > 2 &&
|
||||||
|
operador.institucion.id_institucion !=
|
||||||
|
equipo.carrito.modulo.institucion.id_institucion
|
||||||
|
)
|
||||||
|
throw new ForbiddenException(
|
||||||
|
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
||||||
|
);
|
||||||
|
// Verifica que no eixsta un registro con estos ids
|
||||||
|
return this.findInfoEquipoProgramaByIdEquipoIdPrograma(
|
||||||
equipo.id_equipo,
|
equipo.id_equipo,
|
||||||
programa.id_programa,
|
programa.id_programa,
|
||||||
)
|
).then((existeEquipoPrograma) => {
|
||||||
.then((existeEquipoPrograma) => {
|
// Error si existe
|
||||||
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.',
|
||||||
);
|
);
|
||||||
return this.informacionEquipoPrograma(equipo.id_equipo, 1);
|
|
||||||
})
|
// Creo registro
|
||||||
.then(async (existeEquipoSinPrograma) => {
|
return this.create(equipo, programa);
|
||||||
if (existeEquipoSinPrograma)
|
|
||||||
await this.repository.delete({
|
|
||||||
id_equipo_programa: existeEquipoSinPrograma.id_equipo_programa,
|
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async create(equipo: Equipo, programa: Programa) {
|
||||||
|
// Ver si tiene programa "Sin programa"
|
||||||
|
return this.findInfoEquipoProgramaByIdEquipoIdPrograma(equipo.id_equipo, 1)
|
||||||
|
.then(async (existeEquipoSinPrograma) => {
|
||||||
|
// Si tiene lo elimino
|
||||||
|
if (existeEquipoSinPrograma)
|
||||||
|
await this.repository.remove(existeEquipoSinPrograma);
|
||||||
|
// Creo el registro
|
||||||
return this.repository.save(
|
return this.repository.save(
|
||||||
this.repository.create({ equipo, programa }),
|
this.repository.create({ equipo, programa }),
|
||||||
);
|
);
|
||||||
@ -70,41 +79,33 @@ export class EquipoProgramaService {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
async createCargaMasiva(equipo: Equipo, programa: Programa) {
|
async createSinPrograma(equipo: Equipo) {
|
||||||
return this.informacionEquipoPrograma(equipo.id_equipo, 1)
|
|
||||||
.then(async (existeEquipoSinPrograma) => {
|
|
||||||
if (existeEquipoSinPrograma)
|
|
||||||
await this.repository.delete({
|
|
||||||
id_equipo_programa: existeEquipoSinPrograma.id_equipo_programa,
|
|
||||||
});
|
|
||||||
return this.repository.save(
|
return this.repository.save(
|
||||||
this.repository.create({ equipo, programa }),
|
this.repository.create({ equipo, programa: { id_programa: 1 } }),
|
||||||
);
|
);
|
||||||
})
|
|
||||||
.then((equipoPrograma) => ({
|
|
||||||
message: `Se asignó el software: ${equipoPrograma.programa.programa}, al equipo con número de inventario: ${equipo.numero_inventario}.`,
|
|
||||||
equipoPrograma,
|
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async delete(operador: Operador, id_equipo_programa: number) {
|
async delete(operador: Operador, id_equipo_programa: number) {
|
||||||
const equipoPrograma = await this.findById(id_equipo_programa);
|
const equipoPrograma = await this.findInfoEquipoProgramaById(
|
||||||
|
id_equipo_programa,
|
||||||
|
);
|
||||||
|
|
||||||
|
// No se puede eliminar "Sin programa" manualmente
|
||||||
|
if (equipoPrograma.programa.id_programa === 1)
|
||||||
|
throw new ConflictException('No se puede eliminar esta opción.');
|
||||||
|
// Valida que el equipo pertenezca a la institución del operador
|
||||||
if (
|
if (
|
||||||
operador.institucion.id_institucion !=
|
operador.institucion.id_institucion !=
|
||||||
equipoPrograma.equipo.carrito.modulo.institucion.id_institucion
|
equipoPrograma.equipo.carrito.modulo.institucion.id_institucion
|
||||||
)
|
)
|
||||||
throw new ForbiddenException(
|
throw new ForbiddenException(
|
||||||
'No puedes eliminar el software de este equipo porque no pertenece a tu institución.',
|
'No puedes modificar la información este equipo porque no pertenece a tu institución.',
|
||||||
);
|
);
|
||||||
|
// Ver 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) => {
|
||||||
if (n === 1) {
|
if (n === 1) await this.createSinPrograma(equipoPrograma.equipo);
|
||||||
if (equipoPrograma.programa.id_programa === 1)
|
|
||||||
throw new ConflictException('No se puede eliminar esta opción.');
|
|
||||||
await this.create(equipoPrograma.equipo, 1);
|
|
||||||
}
|
|
||||||
return this.repository.remove(equipoPrograma);
|
return this.repository.remove(equipoPrograma);
|
||||||
})
|
})
|
||||||
.then((_) => ({
|
.then((_) => ({
|
||||||
@ -112,49 +113,9 @@ export class EquipoProgramaService {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
findById(id_equipo_programa: number) {
|
|
||||||
return this.repository
|
|
||||||
.findOne({
|
|
||||||
join: {
|
|
||||||
alias: 'ep',
|
|
||||||
innerJoinAndSelect: {
|
|
||||||
e: 'ep.equipo',
|
|
||||||
p: 'ep.programa',
|
|
||||||
c: 'e.carrito',
|
|
||||||
m: 'c.modulo',
|
|
||||||
i: 'm.institucion',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
where: { id_equipo_programa },
|
|
||||||
})
|
|
||||||
.then((equipoPrograma) => {
|
|
||||||
if (!equipoPrograma)
|
|
||||||
throw new ConflictException('No existe este id equipo software.');
|
|
||||||
return equipoPrograma;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
findEquipoProgramaByEquipoPrograma(
|
|
||||||
equipo: Equipo,
|
|
||||||
programa: Programa,
|
|
||||||
validarExistencia = true,
|
|
||||||
) {
|
|
||||||
return this.repository
|
|
||||||
.findOne({ where: { equipo, programa } })
|
|
||||||
.then((equipoPrograma) => {
|
|
||||||
if (validarExistencia && equipoPrograma)
|
|
||||||
throw new ConflictException(
|
|
||||||
'Este software ya fue asignado a este equipo.',
|
|
||||||
);
|
|
||||||
return equipoPrograma;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
findFullInfoEquipoProgramaAllByIdEquipo(id_equipo: number) {
|
findFullInfoEquipoProgramaAllByIdEquipo(id_equipo: number) {
|
||||||
return this.fullInformacionEquipoProgramaView
|
return this.fullInformacionEquipoProgramaView
|
||||||
.find({
|
.find({ where: { id_equipo } })
|
||||||
where: { id_equipo },
|
|
||||||
})
|
|
||||||
.then((infoEquipoProgramas) => {
|
.then((infoEquipoProgramas) => {
|
||||||
const equipoProgramas: EquipoPrograma[] = [];
|
const equipoProgramas: EquipoPrograma[] = [];
|
||||||
|
|
||||||
@ -172,9 +133,36 @@ export class EquipoProgramaService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
informacionEquipoPrograma(id_equipo: number, id_programa: number) {
|
findInfoEquipoProgramaById(id_equipo_programa: number) {
|
||||||
return this.informacionEquipoProgramaView.findOne({
|
return this.informacionEquipoProgramaView
|
||||||
where: { id_equipo, id_programa },
|
.findOne({ where: { id_equipo_programa } })
|
||||||
|
.then((infoEquipoPrograma) =>
|
||||||
|
this.repository.create({
|
||||||
|
id_equipo_programa: infoEquipoPrograma.id_equipo_programa,
|
||||||
|
equipo: {
|
||||||
|
id_equipo: infoEquipoPrograma.id_equipo,
|
||||||
|
carrito: {
|
||||||
|
id_carrito: infoEquipoPrograma.id_carrito,
|
||||||
|
modulo: {
|
||||||
|
institucion: {
|
||||||
|
id_institucion: infoEquipoPrograma.id_institucion,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tipoCarrito: {
|
||||||
|
id_tipo_carrito: infoEquipoPrograma.id_tipo_carrito,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
findInfoEquipoProgramaByIdEquipoIdPrograma(
|
||||||
|
id_equipo: number,
|
||||||
|
id_programa: number,
|
||||||
|
) {
|
||||||
|
return this.repository.findOne({
|
||||||
|
where: { equipo: { id_equipo }, programa: { id_programa } },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -82,7 +82,7 @@ export class EquipoService {
|
|||||||
);
|
);
|
||||||
|
|
||||||
return this.equipoProgramaService
|
return this.equipoProgramaService
|
||||||
.create(equipoNuevo, 1)
|
.createSinPrograma(equipoNuevo)
|
||||||
.then((_) => equipoNuevo);
|
.then((_) => equipoNuevo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,28 @@
|
|||||||
|
// import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
|
||||||
|
// import { EquipoPrograma } from '../equipo-programa.entity';
|
||||||
|
// import { Programa } from '../../../institucion-programa/entity/programa.entity';
|
||||||
|
|
||||||
|
// @ViewEntity({
|
||||||
|
// expression: (dataSource: DataSource) =>
|
||||||
|
// dataSource
|
||||||
|
// .createQueryBuilder()
|
||||||
|
// .select('ep.id_equipo_programa', 'id_equipo_programa')
|
||||||
|
// .addSelect('ep.id_equipo', 'id_equipo')
|
||||||
|
// .addSelect('ep.id_programa', 'id_programa')
|
||||||
|
// .addSelect('p.programa', 'programa')
|
||||||
|
// .from(EquipoPrograma, 'ep')
|
||||||
|
// .innerJoin(Programa, 'p', 'p.id_programa = ep.id_programa'),
|
||||||
|
// })
|
||||||
|
// export class FullInformacionEquipoProgramaView {
|
||||||
|
// @ViewColumn()
|
||||||
|
// id_equipo_programa: number;
|
||||||
|
|
||||||
|
// @ViewColumn()
|
||||||
|
// id_equipo: number;
|
||||||
|
|
||||||
|
// @ViewColumn()
|
||||||
|
// id_programa: number;
|
||||||
|
|
||||||
|
// @ViewColumn()
|
||||||
|
// programa: string;
|
||||||
|
// }
|
@ -0,0 +1,22 @@
|
|||||||
|
import { DataSource, ViewEntity, ViewColumn } from 'typeorm';
|
||||||
|
import { InstitucionUsuario } from '../institucion-usuario.entity';
|
||||||
|
|
||||||
|
@ViewEntity({
|
||||||
|
expression: (dataSource: DataSource) =>
|
||||||
|
dataSource
|
||||||
|
.createQueryBuilder()
|
||||||
|
.select('ep.id_equipo_programa', 'id_equipo_programa')
|
||||||
|
.addSelect('ep.id_equipo', 'id_equipo')
|
||||||
|
.addSelect('ep.id_programa', 'id_programa')
|
||||||
|
.from(InstitucionUsuario, 'ep'),
|
||||||
|
})
|
||||||
|
export class InformacionEquipoProgramaView {
|
||||||
|
@ViewColumn()
|
||||||
|
id_equipo_programa: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_equipo: number;
|
||||||
|
|
||||||
|
@ViewColumn()
|
||||||
|
id_programa: number;
|
||||||
|
}
|
@ -321,7 +321,7 @@ export class UploadFileService {
|
|||||||
false,
|
false,
|
||||||
);
|
);
|
||||||
const existeEquipoPrograma = programa
|
const existeEquipoPrograma = programa
|
||||||
? await this.equipoProgramaService.informacionEquipoPrograma(
|
? await this.equipoProgramaService.findInfoEquipoProgramaByIdEquipoIdPrograma(
|
||||||
equipo.id_equipo,
|
equipo.id_equipo,
|
||||||
programa.id_programa,
|
programa.id_programa,
|
||||||
)
|
)
|
||||||
@ -345,7 +345,7 @@ export class UploadFileService {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
await this.equipoProgramaService
|
await this.equipoProgramaService
|
||||||
.createCargaMasiva(equipo, programa)
|
.create(equipo, programa)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
equipo.programas.push(res.equipoPrograma);
|
equipo.programas.push(res.equipoPrograma);
|
||||||
mensajes.push(res.message);
|
mensajes.push(res.message);
|
||||||
|
Loading…
Reference in New Issue
Block a user