Consulta de Promoções - Empresa

Regras de negócio

Para realizar consulta de promoções por empresa é necessário efetuar devidas configurações no ERP conforme configurações do tipo de negociação aplicado e produto cadastrado precificado.A empresa pode, possuir mais de uma tabela de preço, cadastrada para seus produtos, sendo que podem ser concedidos, descontos promocionais com o mesmo período e produto para tabelas diferentes com percentuais diferentes.
Importante: Quando a promoção é por empresa no ERP (isolamento promocional por empresa (Filiais), para cada tipo de chamada da consulta de produtos existem formas diferentes de se contextualizar a empresa para buscar a promoção.
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 CODEMP, DTINICIAL e DTFINAL para poder pesquisar as promoções cadastradas por Empresa e por período de vigência da Promoção, porém você pode utilizar outros campos da entidade. .

• CODEMP – Código da Empresa.
• 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.CODEMP = ? AND this.DTINICIAL = ? AND this.DTFINAL = ?"
                },
                "parameters": [
                   {
                     "$": "1",
                     "type": "I"
                   },
                   {
                     "$": "15/01/2020",
                     "type": "D"
                   },
                   {
                     "$": "31/03/2020",
                     "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.CODEMP = ? AND this.DTINICIAL = ? AND this.DTFINAL = ?"
        },
        "parameters": [
           {
             "$": "1",
             "type": "I"
           },
           {
             "$": "15/01/2020",
             "type": "D"
           },
           {
             "$": "31/03/2020",
             "type": "D"
           }
        ]
      },
      "entity": {
        "fieldset": {
          "list": "DTINICIAL,DTFINAL,CODPROD,VLRDESC,CODEMP,NUPROMOCAO,DESCRPROMOCAO"
        }
      }
    }
  }
}

Retorno em json:

{
    "serviceName": "CRUDServiceProvider.loadRecords",
    "status": "1",
    "pendingPrinting": "false",
    "transactionId": "07827BF346E6056BE30634A6FE479C60",
    "responseBody": {
        "entities": {
            "total": "1",
            "hasMoreResult": "false",
            "offsetPage": "0",
            "offset": "0",
            "metadata": {
                "fields": {
                    "field": [
                        {
                            "name": "DTINICIAL"
                        },
                        {
                            "name": "DTFINAL"
                        },
                        {
                            "name": "CODPROD"
                        },
                        {
                            "name": "VLRDESC"
                        },
                        {
                            "name": "CODEMP"
                        },
                        {
                            "name": "NUPROMOCAO"
                        },
                        {
                            "name": "DESCRPROMOCAO"
                        },
                        {
                            "name": "Produto_DESCRPROD"
                        },
                        {
                            "name": "Empresa_NOMEFANTASIA"
                        }
                    ]
                }
            },
            "entity": {
                "f6": {
                    "$": "CALCULADORA EMPRESA 1"
                },
                "f7": {
                    "$": "CALCULADORA HP12"
                },
                "f8": {
                    "$": "WCS PRESTAÇÃO DE SERVIÇOS"
                },
                "f0": {
                    "$": "15/03/2020"
                },
                "f1": {
                    "$": "31/03/2020"
                },
                "f2": {
                    "$": "542"
                },
                "f3": {
                    "$": "0"
                },
                "f4": {
                    "$": "1"
                },
                "f5": {
                    "$": "301"
                }
            }
        }
    }
}
Language
Click Try It! to start a request and see the response here!