equipo programa lsito

This commit is contained in:
lemuel 2022-10-23 22:29:55 -05:00
parent 97c87117da
commit d5dddcad8f
5 changed files with 31 additions and 17 deletions

View File

@ -1,4 +1,10 @@
import { Entity, JoinColumn, ManyToOne, PrimaryGeneratedColumn } from 'typeorm'; import {
Column,
Entity,
JoinColumn,
ManyToOne,
PrimaryGeneratedColumn,
} from 'typeorm';
import { Equipo } from '../../equipo/entity/equipo.entity'; import { Equipo } from '../../equipo/entity/equipo.entity';
import { Programa } from '../../institucion-programa/entity/programa.entity'; import { Programa } from '../../institucion-programa/entity/programa.entity';
@ -7,6 +13,12 @@ export class EquipoPrograma {
@PrimaryGeneratedColumn() @PrimaryGeneratedColumn()
id_equipo_programa: number; id_equipo_programa: number;
@Column({ type: Number, nullable: true })
id_equipo: number;
@Column({ type: Number, nullable: true })
id_programa: number;
@ManyToOne(() => Equipo, (equipo) => equipo.programas) @ManyToOne(() => Equipo, (equipo) => equipo.programas)
@JoinColumn({ name: 'id_equipo' }) @JoinColumn({ name: 'id_equipo' })
equipo: Equipo; equipo: Equipo;

View File

@ -8,11 +8,13 @@ import {
} from '@nestjs/common'; } from '@nestjs/common';
import { AuthGuard } from '@nestjs/passport'; import { AuthGuard } from '@nestjs/passport';
import { ApiBearerAuth, ApiBody, ApiOperation, ApiTags } from '@nestjs/swagger'; import { ApiBearerAuth, ApiBody, ApiOperation, ApiTags } from '@nestjs/swagger';
import { Serealize } from '../interceptors/serialize.interceptor';
import { Operador } from '../operador/entity/operador.entity'; import { Operador } from '../operador/entity/operador.entity';
import { EquipoProgramaService } from './equipo-programa.service'; import { EquipoProgramaService } from './equipo-programa.service';
import { ValidarUsuarioService } from '../validar-usuario/validar-usuario.service'; import { ValidarUsuarioService } from '../validar-usuario/validar-usuario.service';
import { CreateEquipoProgramaDto } from './dto/input/create.dto'; import { CreateEquipoProgramaDto } from './dto/input/create.dto';
import { DeleteEquipoProgramaDto } from './dto/input/delete.dto'; import { DeleteEquipoProgramaDto } from './dto/input/delete.dto';
import { MessageOutputDto } from '../dto/output/message.dto';
@Controller('equipo-programa') @Controller('equipo-programa')
@ApiTags('equipo-programa') @ApiTags('equipo-programa')
@ -22,6 +24,7 @@ export class EquipoProgramaController {
private validarUsuarioService: ValidarUsuarioService, private validarUsuarioService: ValidarUsuarioService,
) {} ) {}
@Serealize(MessageOutputDto)
@Post() @Post()
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ @ApiOperation({
@ -44,6 +47,7 @@ export class EquipoProgramaController {
); );
} }
@Serealize(MessageOutputDto)
@Delete() @Delete()
@UseGuards(AuthGuard('jwt')) @UseGuards(AuthGuard('jwt'))
@ApiOperation({ @ApiOperation({

View File

@ -9,12 +9,12 @@ import { InjectRepository } from '@nestjs/typeorm';
import { Repository } from 'typeorm'; import { Repository } from 'typeorm';
import { Equipo } from '../equipo/entity/equipo.entity'; import { Equipo } from '../equipo/entity/equipo.entity';
import { EquipoPrograma } from './entity/equipo-programa.entity'; import { EquipoPrograma } from './entity/equipo-programa.entity';
import { Operador } from '../operador/entity/operador.entity';
import { Programa } from '../institucion-programa/entity/programa.entity'; import { Programa } from '../institucion-programa/entity/programa.entity';
import { FullInformacionEquipoProgramaView } from './entity/views/full-informacion-equipo-programa.view'; import { FullInformacionEquipoProgramaView } from './entity/views/full-informacion-equipo-programa.view';
import { InformacionEquipoProgramaView } from './entity/views/informacion-equipo-programa.view'; import { InformacionEquipoProgramaView } from './entity/views/informacion-equipo-programa.view';
import { EquipoService } from '../equipo/equipo.service'; import { EquipoService } from '../equipo/equipo.service';
import { InstitucionProgramaService } from '../institucion-programa/institucion-programa.service'; import { InstitucionProgramaService } from '../institucion-programa/institucion-programa.service';
import { Operador } from '../operador/entity/operador.entity';
@Injectable() @Injectable()
export class EquipoProgramaService { export class EquipoProgramaService {
@ -36,6 +36,11 @@ export class EquipoProgramaService {
id_programa, id_programa,
); );
// valido que el programa seleccionado no sea "Sin programa"
if (programa.id_programa === 1)
throw new ConflictException(
'No se puede asignar manualmente este programa.',
);
// Valida que el equipo pertenezca a la institución del operador // Valida que el equipo pertenezca a la institución del operador
if ( if (
operador.tipoUsuario.id_tipo_usuario > 2 && operador.tipoUsuario.id_tipo_usuario > 2 &&
@ -46,7 +51,7 @@ export class EquipoProgramaService {
'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.',
); );
// Verifica que no eixsta un registro con estos ids // Verifica que no eixsta un registro con estos ids
return this.findInfoEquipoProgramaByEquipoPrograma(equipo, programa).then( return this.findByEquipoPrograma(equipo, programa).then(
(existeEquipoPrograma) => { (existeEquipoPrograma) => {
// Error si existe // Error si existe
if (existeEquipoPrograma) if (existeEquipoPrograma)
@ -60,9 +65,7 @@ export class EquipoProgramaService {
create(equipo: Equipo, programa: Programa) { create(equipo: Equipo, programa: Programa) {
// Ver si tiene programa "Sin programa" // Ver si tiene programa "Sin programa"
return this.findInfoEquipoProgramaByEquipoPrograma(equipo, { return this.findByEquipoPrograma(equipo, { id_programa: 1 })
id_programa: 1,
})
.then(async (existeEquipoSinPrograma) => { .then(async (existeEquipoSinPrograma) => {
// Si tiene lo elimino // Si tiene lo elimino
if (existeEquipoSinPrograma) if (existeEquipoSinPrograma)
@ -85,9 +88,7 @@ export class EquipoProgramaService {
} }
async delete(operador: Operador, id_equipo_programa: number) { async delete(operador: Operador, id_equipo_programa: number) {
const equipoPrograma = await this.findInfoEquipoProgramaById( const equipoPrograma = await this.findById(id_equipo_programa);
id_equipo_programa,
);
// 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)
@ -114,7 +115,7 @@ export class EquipoProgramaService {
})); }));
} }
findFullInfoEquipoProgramaAllByIdEquipo(id_equipo: number) { findFullInfoAllByIdEquipo(id_equipo: number) {
return this.fullInformacionEquipoProgramaView return this.fullInformacionEquipoProgramaView
.find({ where: { id_equipo } }) .find({ where: { id_equipo } })
.then((infoEquipoProgramas) => { .then((infoEquipoProgramas) => {
@ -134,7 +135,7 @@ export class EquipoProgramaService {
}); });
} }
findInfoEquipoProgramaById(id_equipo_programa: number) { findById(id_equipo_programa: number) {
return this.informacionEquipoProgramaView return this.informacionEquipoProgramaView
.findOne({ where: { id_equipo_programa } }) .findOne({ where: { id_equipo_programa } })
.then((infoEquipoPrograma) => { .then((infoEquipoPrograma) => {
@ -162,10 +163,7 @@ export class EquipoProgramaService {
}); });
} }
findInfoEquipoProgramaByEquipoPrograma( findByEquipoPrograma(equipo: Equipo, programa: Programa | Partial<Programa>) {
equipo: Equipo,
programa: Programa | Partial<Programa>,
) {
return this.repository.findOne({ where: { equipo, programa } }); return this.repository.findOne({ where: { equipo, programa } });
} }
} }

View File

@ -402,7 +402,7 @@ export class EquipoService {
// Busco todos los programas de este equipo // Busco todos los programas de este equipo
const programas = const programas =
await this.equipoProgramaService.findFullInfoEquipoProgramaAllByIdEquipo( await this.equipoProgramaService.findFullInfoAllByIdEquipo(
infoEquipo.id_equipo, infoEquipo.id_equipo,
); );
// Busco todos los tipos de entrada de este equipo // Busco todos los tipos de entrada de este equipo

View File

@ -317,7 +317,7 @@ export class UploadFileService {
false, false,
); );
const existeEquipoPrograma = programa const existeEquipoPrograma = programa
? await this.equipoProgramaService.findInfoEquipoProgramaByEquipoPrograma( ? await this.equipoProgramaService.findByEquipoPrograma(
equipo, equipo,
programa, programa,
) )