Utilizando la funcionalidad de avisos del ERP, la cual podemos ver en la entrada Avisos - Introducción, podemos definir alertas personalizadas para que aparezcan de la misma forma que los avisos estándar.
Vamos a plantear el siguiente caso:
- El cliente necesita que aparezca un aviso en el sistema cuando se da de alta un artículo de una determinada familia en la base de datos.
Para poder definir que avisos tienen que aparecer y cuando, necesitamos revisar los siguiente puntos:
- Dar de alta una configuración para los avisos
- Crear un proceso para insertar los avisos en el ERP
- Definir como y cuando queremos que se generen estos avisos
Lo primero sería añadir esta configuración, para ello tenemos que ejecutar la siguiente consulta personalizando mínimo los siguiente valores:
- idProcesoAviso: Indicar un id a partir del 1000
- Descrip: Una breve descripción del aviso
- Activado: Para que se marque como activo
- Store: Stored procedure que será la encargada de insertar el aviso
- Habilitado: Para habilitar el aviso
-- idProcesoAviso tiene que ser a partir del 1000 para los personalizados INSERT INTO Avisos_Procesos (IdProcesoAviso,Descrip,Activado,IdEmpleado,Store,Habilitado,GeneraAviso,Clave,IdPlantillaFlujo,Script) SELECT 1001,'Artículo de la familia Geralt insertado',1,0,'PPers_AVISOS_Articulo',1,1,NULL,NULL,NULL
Creamos la stored procedure, en este caso 'PPers_AVISOS_Articulo' que será la encargada de añadir los registros sobre la tabla 'Avisos' llamando a la stored 'Avisos_Insertar', como podemos ver definimos los parámetros de entrada que vayamos a necesitar, en este caso voy a utilizar el idArtículo, la familia, la descripción y las observaciones, ya que estos valores me van a servir para indicar el mensaje que contiene el aviso:
CREATE PROCEDURE [dbo].[PPers_AVISOS_Articulo]
@IdArticulo T_Id_Articulo OUTPUT,
@idFamilia T_Id_Fami_Art OUTPUT,
@Descrip VARCHAR(800) OUTPUT,
@Observaciones T_Descripcion_Larga OUTPUT
AS
DECLARE @idArt T_Id_Articulo
DECLARE @Fecha DATE
DECLARE @VRet BIT
SET @Fecha=GetDate()
EXEC @Vret=Avisos_Insertar 1001, @Descrip, @Observaciones, @Fecha, @Fecha, 0
RETURN @Vret
GO
zpermisos PPers_AVISOS_Articulo --Damos permisos a la stored
Una vez tenemos el proceso y el aviso configurado, tenemos que definir donde queremos que se realice la inserción del aviso, en este caso sería cuando el usuario inserta un artículo de la familia 'Geralt', como podemos ver en la siguiente imagen tengo un trigger de actualización sobre la tabla 'Artículos'.
CREATE TRIGGER [dbo].[Pers_Articulos_ITrig_AvisosArticulos]
ON [dbo].[Articulos]
FOR INSERT
AS
IF EXISTS(SELECT 1 FROM inserted) BEGIN
DECLARE @Ins INT
DECLARE @prt nvarchar(2000)
DECLARE @idArticulo T_Id_Articulo
DECLARE @idFamilia T_Id_Fami_Art
DECLARE @Descrip VARCHAR(800)
DECLARE @Observaciones T_Descripcion_Larga
IF OBJECT_ID('tempdb..#Articulos') IS NOT NULL
DROP TABLE #Articulos
SELECT IdArticulo,IdFamilia,Descrip,Observaciones INTO #Articulos
FROM inserted WHERE IdFamilia = 'Geralt'
WHILE EXISTS(
SELECT IdArticulo,IdFamilia,Descrip,Observaciones FROM #Articulos
) BEGIN
SELECT TOP 1 @IdArticulo = IdArticulo, @idFamilia = idFamilia, @Descrip ='Artículo ( ' +ISNULL(IdArticulo,'') +' - ' +ISNULL(Descrip,'') +' )', @Observaciones = Observaciones
FROM #Articulos
EXEC @Ins=PPers_AVISOS_Articulo @IdArticulo, @idFamilia, @Descrip, @Observaciones
IF @Ins=0 BEGIN
RAISERROR('Error en el proceso de inserción de avisos para artículos de la familia Geralt.',12,1)
END
DELETE FROM #Articulos WHERE IdArticulo = @idArticulo
END
END
GO