Puede suceder que se quiera cambiar el orden para que los artículos aparezcan, por ejemplo, por orden alfabético. 


Para realizar esto, en versiones antiguas como la 4.4.2300 se debe personalizar la vista vTPV_Articulos_Familias, forzando la ordenación dentro de la propia vista. Consulta con el administrador del ERP para llevar a cabo estos pasos, ya que se necesita un perfil técnico para implementarlo.


NOTA:

Existe la posibilidad de personalizar la GRID desde el personalizador, mediante una vista personalizada del TPV objeto.

Consulta en este artículo la información. 


Ya que SQL Server sobrescribe el ORDER BY de las vistas para ejecutarse de forma más eficiente, hay que utilizar un ORDER BY  con offset, disponible desde la versión de SQL Server 2012.


Una vez creada la vista, hay que cambiar el campo SQL de la colección TPV_Articulos_Familias.


IF EXISTS(SELECT 1 FROM sys.views WHERE OBJECT_ID = OBJECT_ID('vPERS_TPV_Articulos_Familias'))
  DROP VIEW vPERS_TPV_Articulos_Familias
GO

CREATE VIEW [dbo].[vPERS_TPV_Articulos_Familias]
AS
-- =============================================
-- #AUTHOR:  
--        AXIUM
-- #NAME:
---        vPERS_TPV_Articulos_Familias
-- #CREATION: 
--        25/01/2021
-- #CLASIFICATION:
--        000-SISTEMA
-- #DESCRIPTION:
--        Personalización necesaria para devolver los campos necesarios para mostrar los artículos por familia ordenados por descrip
-- #PARAMETERS: 
--      
-- #OBSERVATIONS:
--      
-- #CHANGES: 
--      
-- #EXAMPLE: 
--      
-- =============================================
SELECT * FROM 
(
  SELECT 
    A.IdCaja, A.IdArticulo,A.IdFamilia, A.Descrip, A.IdDoc, 0 Precio, I.NombreFichero, dbo.Valor_Parametro('PATHIMAGENES', USER) + '\' + I.NombreFichero as PathImagen, '' as imgData, 1 AS Favoritos 
  FROM  vTPV_Cajas_Favoritos_Asociados A 
    LEFT JOIN vImagenes_Articulos I ON A.IdArticulo = I.IdArticulo and I.Principal = 1 
  WHERE AsociadoACaja = 1 
    UNION ALL
  SELECT 
    F.Idcaja, A.IdArticulo,A.IdFamilia, A.Descrip, A.IdDoc, 0 Precio, I.NombreFichero, dbo.Valor_Parametro('PATHIMAGENES', USER) + '\' + I.NombreFichero as PathImagen, '' as imgData, 0 AS Favoritos
  FROM vTPV_Cajas_Familias_Asociadas F 
    INNER JOIN Articulos A ON A.IdFamilia = F.IdFamilia
    LEFT JOIN vImagenes_Articulos I on A.IdDoc = I.IdDocObjeto AND I.Principal = 1  
  WHERE F.AsociadoACaja = 1 -- el valor correcto es 1
) X ORDER BY Descrip OFFSET 0 ROWS;
GO

ZPERMISOS 'vPERS_TPV_Articulos_Familias'
GO

sp_refreshview 'vPERS_TPV_Articulos_Familias'
GO

update objetos set SQL = 'Select * from vPERS_TPV_Articulos_Familias' where objeto ='TPV_Articulos_Familias'

GO



Es importante tener en cuenta que este código sirve para ordenar los artículos devueltos al pulsar en una familia en el entorno táctil.


Si, por otra parte, se quiere personalizar el orden de las familias, se debe personalizar el procedimiento almacenado pTPV_Articulos_Familias_Personalizado, indicando aquí el orden deseado. Esta opción está disponible desde la versión 4.4.2300 hotfix 32.


A continuación, se muestra un ejemplo para mostrar las familias por orden descendente.


IF EXISTS (SELECT 1 FROM sys.Objects WHERE Object_id = OBJECT_ID('pTPV_Articulos_Familias_Personalizado'))
  DROP PROCEDURE [dbo].[pTPV_Articulos_Familias_Personalizado]
GO

CREATE PROCEDURE [dbo].[pTPV_Articulos_Familias_Personalizado]
  @IdCaja INT, 
  @oXML XML OUTPUT
-- =============================================
-- #AUTOR:    
--        CEESI
-- #NAME:      
--        pTPV_Articulos_Familias_Personalizado
-- #CREATION: 
--        03/03/2021
-- #CLASIFICATION:
--        TPV
-- #DESCRIPTION:  
--        Personalizado de pTPV_Articulos_Familia
-- #PARAMETERS: 
--
-- #OBSERVATIONS:  
--        Se llama desde pTPV_Articulos_Familia
--        Retorno:  0 Error
--              -1 OK y que SÍ siga con el proceso estándar
--              -2 OK y que NO siga con el proceso estándar
-- #CHANGES: 
--            
-- #EXAMPLE: 
--            
-- =============================================
AS

DECLARE @PathImagenes VARCHAR(255)

BEGIN TRY
  
  SELECT @PathImagenes = Valor FROM dbo.funTblValorParametro('PATHIMAGENES')

  SET @oXML = (
    SELECT 
      F.IdFamilia, F.IdDoc, F.Descrip, IdFamiliaPadre, I.NombreFichero, @PathImagenes + '\' + I.NombreFichero AS PathImagen, '' AS imgData, 1 Nivel, 
      CAST((
        SELECT 
          F2.IdFamilia, F2.IdDoc, F2.Descrip,  F2.IdFamiliaPadre, I2.NombreFichero, 
          @PathImagenes + '\' + I2.NombreFichero AS PathImagen, '' AS imgData, 2 Nivel 
        FROM Articulos_Familias F2 
          LEFT JOIN vImagenes_Articulos_Familia I2 ON F2.IdFamilia = I2.IdFamilia AND I2.Principal = 1  
        WHERE 
          F2.IdFamiliaPadre = F.IdFamilia 
          AND F2.NumeroNivel = 2 
          AND EXISTS (SELECT 1 FROM TPV_Cajas_Familias_Asociadas WHERE IdFamilia = F2.IdFamilia AND IdCaja = @IdCaja)
        ORDER BY F2.Descrip DESC
        FOR XML PATH('R')
      ) AS XML) Familias
    FROM Articulos_Familias F 
      LEFT JOIN vImagenes_Articulos_Familia I ON F.IdFamilia = I.IdFamilia AND I.Principal = 1  
    WHERE F.NumeroNivel = 1 AND EXISTS (SELECT 1 FROM TPV_Cajas_Familias_Asociadas WHERE IdFamilia = F.IdFamilia AND IdCaja = @IdCaja)
    ORDER BY F.Descrip DESC
    FOR XML PATH('R'), ROOT('Familias')
  )


  RETURN -2

END TRY

BEGIN CATCH
  IF @@TRANCOUNT >0 BEGIN
    ROLLBACK TRAN 
  END

  DECLARE @CatchError NVARCHAR(MAX)
  SET @CatchError = CASE WHEN ERROR_NUMBER()=3609 OR ERROR_NUMBER()=266 THEN 'Error en procedimiento' ELSE ERROR_MESSAGE() END
  SELECT @oXML = CAST('<Resultado><Respuesta><Estado>error</Estado><Mensaje>' + @CatchError + '</Mensaje></Respuesta><data /><view /></Resultado>' AS XML)

  RETURN 0

END CATCH
GO

ZPermisos 'pTPV_Articulos_Familias_Personalizado'
GO