Consulta de Promoções - Grupo de Produtos

Regras de negócio

Para realizar uma consulta por grupo de produtos, primeiramente é necessário realizar uma venda com produto promocional por “grupo de Produtos” no ERP para que o desconto em percentual seja aplicado no produto.
OBS: Caso tenha alguma necessidade de configuração do ERP procure “Consultor” ou acesso o link de apoio:
https://ajuda.sankhya.com.br/hc/pt-br/articles/360044600034-Descontos-Promocionais

Dependências

Não possui dependências

Detalhes Técnicos

A entidade utilizada é a Desconto que por sua vez instancia a tabela TGFDES mapeando os campos principais.

Para realizarmos a busca através do Json, utilizamos o serviço "CRUDServiceProvider.loadRecords".

O serviço CRUDServiceProvider.loadRecords é um otimo serviço para ser utilizado para consulta de dados através do JSON.

No exemplo abaixo foram utilizados como filtro os campos GRUPODESCPROD, DTINICIAL e DTFINAL para poder pesquisar as promoções cadastradas por Grupo de produto e por período de vigência da Promoção, porém você pode utilizar outros campos da entidade. .

• GRUPODESCPROD – Grupo de desconto por Produto.
• DTINICIAL – Data Inicial.
• DTFINAL – Data Final.
Para utilizarmos o filtro, basta acrescentar no corpo da requisição o código abaixo utilizando o criteria:
    "criteria": {
        "expression": {
           "$": "this.GRUPODESCPROD = ? AND this.DTINICIAL = ? AND this.DTFINAL = ?"                    
        },
        "parameters": [
           {
             "$": "teste",
             "type": "S"
           },
           {
             "$": "01/01/2021",
             "type": "D"
           },
           {
             "$": "31/01/2021",
             "type": "D"
           }
        ]
    }

Para melhor performance sempre utilize nas suas consultas apenas os campos necessários, para evitar tráfego de dados que não serão utilizados.

Descritivo de campos da entidade

Acesse aqui o dicionário de dados da tabela TGFDES

Exemplo de uso:


URL de chamada: https://api.sankhya.com.br/gateway/v1/mge/service.sbr?serviceName=CRUDServiceProvider.loadRecords&outputType=json

Corpo de requisição
{
  "serviceName": "CRUDServiceProvider.loadRecords",
  "requestBody": {
    "dataSet": {
      "rootEntity": "Desconto",
      "includePresentationFields": "S",
      "offsetPage": "0",
      "criteria": {
        "expression": {
           "$": "this.GRUPODESCPROD = ? AND this.DTINICIAL = ? AND this.DTFINAL = ?"
        },
        "parameters": [
           {
             "$": "teste",
             "type": "S"
           },
           {
             "$": "01/01/2021",
             "type": "D"
           },
           {
             "$": "31/01/2021",
             "type": "D"
           }
        ]
      },
      "entity": {
        "fieldset": {
          "list": "DTINICIAL,DTFINAL,CODPROD,VLRDESC,GRUPODESCPROD,NUPROMOCAO,DESCRPROMOCAO"
        }
      }
    }
  }
}

Retorno em json:

{
    "serviceName": "CRUDServiceProvider.loadRecords",
    "status": "1",
    "pendingPrinting": "false",
    "transactionId": "593D8A841F043D7B6E8DAD2FF1286B72",
    "responseBody": {
        "entities": {
            "total": "1",
            "hasMoreResult": "false",
            "offsetPage": "0",
            "offset": "0",
            "metadata": {
                "fields": {
                    "field": [
                        {
                            "name": "DTINICIAL"
                        },
                        {
                            "name": "DTFINAL"
                        },
                        {
                            "name": "CODPROD"
                        },
                        {
                            "name": "VLRDESC"
                        },
                        {
                            "name": "GRUPODESCPROD"
                        },
                        {
                            "name": "NUPROMOCAO"
                        },
                        {
                            "name": "DESCRPROMOCAO"
                        },
                        {
                            "name": "Produto_DESCRPROD"
                        }
                    ]
                }
            },
            "entity": [
                {
                    "f6": {
                        "$": "LIQUIDA ESTOQUE"
                    },
                    "f7": {
                        "$": "<sem descrição>"
                    },
                    "f0": {
                        "$": "01/01/2021"
                    },
                    "f1": {
                        "$": "31/01/2021"
                    },
                    "f2": {
                        "$": "0"
                    },
                    "f3": {
                        "$": "0"
                    },
                    "f4": {
                        "$": "teste"
                    },
                    "f5": {
                        "$": "16"
                    }
                }
            ]
        }
    }
}
Language
Click Try It! to start a request and see the response here!