equipo programa lsito
This commit is contained in:
parent
97c87117da
commit
d5dddcad8f
@ -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;
|
||||||
|
@ -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({
|
||||||
|
@ -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 } });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user