Base de conhecimento
Encontre respostas para suas dúvidas em quatro fontes de conhecimento diferentes ao mesmo tempo, simplificando o processo de pesquisa.

Cross Segmentos - TOTVS Backoffice (Linha Protheus) - SIGAFAT - ExecAuto MATA410 (Com Poder DE/EM Terceiros)

time.png Tempo aproximado para leitura: 00:01:30 min

Dúvida

Exemplo de utilização do Execauto MATA410 - Pedidos de Venda com Poder DE/EM Terceiros.


Ambiente
Cross Segmentos - TOTVS Backoffice (Linha Protheus) - SIGAFAT - A partir da release 12.

Solução
Função utilizada para geração de Pedidos de Venda com Poder DE/EM Terceiros via rotina automática (ExecAuto).

OBS: Quando for utilizar o pedido de venda "Tipo B (Beneficiamento)", comentar as variáveis que seriam usadas no tipo do pedido de venda "Tipo N (Normal)" e vice-versa.

 

Exemplo:

#INCLUDE "PROTHEUS.CH"
#INCLUDE "TBICONN.CH"

//===================================================================//
//            PEDIDO DE VENDAS COM PODER DE/EM TERCEIRO              //
//===================================================================//

User Function MyMata410()
// Se tipo B
  //Local cA2Cod     := "000001"     //Código do Fornecedor
  //Local cA2Loja    := "01"         //Loja do Fornecedor

// Se tipo N
  Local cA1Cod     := "000001"     //Código do cliente
  Local cA1Loja    := "01"         //Loja do cliente

Local cDoc       := ""           //Numero do Pedido de Vendas
    Local cE4Codigo  := "001"        //Código da Condição de Pagamento
    Local cFilSA2    := ""
    Local cFilSB1    := ""
    Local cFilSE4    := ""
    Local cFilSF4    := ""
    Local aCabec     := {}
    Local aItens     := {}
    Local aLinha     := {}
    Local lOk        := .T.

    Private lMsErroAuto    := .F.
    Private lAutoErrNoFile := .F.

    //****************************************************************
    //* ABERTURA DO AMBIENTE
    //****************************************************************

    ConOut(Repl("-",80))
    ConOut(PadC("Inclusao de Pedido de Venda com Poder DE/EM Terceiros", 80))

    PREPARE ENVIRONMENT EMPRESA "99" FILIAL "01" MODULO "FAT" TABLES "SC5","SC6","SA1","SA2","SB1","SB2","SF4"

    SA2->(dbSetOrder(1))
    SB1->(dbSetOrder(1))
    SE4->(dbSetOrder(1))
    SF4->(dbSetOrder(1))

    cFilAGG := xFilial("AGG")
    cFilSA2 := xFilial("SA2")
    cFilSB1 := xFilial("SB1")
    cFilSE4 := xFilial("SE4")
    cFilSF4 := xFilial("SF4")

    If lOk

        //****************************************************************
        //* INCLUSAO - INICIO
        //****************************************************************

            ConOut("Teste de Inclusao")
            ConOut("Inicio: " + Time())

                //CABEÇALHO
                cDoc := GetSxeNum("SC5", "C5_NUM")
                RollBAckSx8()
                aCabec   := {}
                aItens   := {}
                aLinha   := {}
                aadd(aCabec, {"C5_NUM"    , cDoc     , Nil})

// Se tipo N
aadd(aCabec, {"C5_TIPO"   , "N"      , Nil}) //Tipo do Pedido 'N - Normal'
              aadd(aCabec, {"C5_CLIENTE", cA1Cod   , Nil})
              aadd(aCabec, {"C5_LOJACLI", cA1Loja  , Nil})
              aadd(aCabec, {"C5_LOJAENT", cA1Loja  , Nil})


// Se tipo B
//aadd(aCabec, {"C5_TIPO"   , "B"      , Nil}) //Tipo do Pedido 'B - Beneficiamento'
              //aadd(aCabec, {"C5_CLIENTE", cA2Cod   , Nil})
              //aadd(aCabec, {"C5_LOJACLI", cA2Loja  , Nil})
              //aadd(aCabec, {"C5_LOJAENT", cA2Loja  , Nil})
               
aadd(aCabec, {"C5_CONDPAG", cE4Codigo, Nil})
                CONOUT("Passou pelo Array do Cabecalho")

                //ITENS
                aLinha := {}
                aadd(aLinha,{"C6_ITEM"   , "01"         , Nil}) //Item do pedido
                aadd(aLinha,{"C6_PRODUTO", "000001"     , Nil})
                aadd(aLinha,{"C6_QTDVEN" , 1            , Nil})
                aadd(aLinha,{"C6_PRCVEN" , 100          , Nil})
                aadd(aLinha,{"C6_PRUNIT" , 100          , Nil})
                aadd(aLinha,{"C6_VALOR"  , 100          , Nil})
                aadd(aLinha,{"C6_TES"    , "501"        , Nil})
          aadd(aLinha,{"C6_IDENTB6", "000077"   , Nil}) //*Código identificador do Poder/EM Terceiro se a TES for de devolução (F4_PODER3 = 'D - Devolução')
                aadd(aLinha,{"C6_NFORI"  , "000222"     , Nil}) //*NF de Origem se a TES deve ser preenchido se for de devolução (F4_PODER3 = 'D - Devolução')
                aadd(aLinha,{"C6_SERIORI", "1"          , Nil}) //*Serie da NF de Origem deve ser preenchido se a TES for de devolução (F4_PODER3 = 'D - Devolução')
                aadd(aLinha,{"C6_ITEMORI", "0001"       , Nil}) //*Item da NF de Origem deve ser preenchido se a TES for de devolução (F4_PODER3 = 'D - Devolução')
// *Se a TES não for de devolução, passar em branco no lugar do conteúdo, assim: ""
             
aadd(aItens, aLinha)
                CONOUT("Passou pelo Array dos itens")

                CONOUT("Iniciando a gravacao")
                MSExecAuto({|a, b, c, d| MATA410(a, b, c, d)}, aCabec, aItens, 3, .F.)

                If !lMsErroAuto
                    ConOut("Incluido com sucesso! Pedido: " + cDoc)
                Else
                    ConOut("Erro na inclusao!")
                    MOSTRAERRO()
                EndIf

            ConOut("Fim: " + Time())
            ConOut(Repl("-",80))

    EndIf

    RESET ENVIRONMENT

 

Esse artigo foi útil?
Usuários que acharam isso útil: 0 de 0

0 Comentários

Por favor, entre para comentar.
X Fechar

Olá ,

Há pendência referente a um de seus produtos contratados para a empresa ().

Entre em contato com o Centro de Serviços TOTVS para tratativa.

Ligue! 4003-0015 opção 4 e 9 ou registre uma solicitação para CST – Cobrança – Verificação de pendências financeiras . clique aqui.

TOTVS

X Fechar

Olá ,

Seu contato não está cadastrado no Portal do Cliente como um perfil autorizado a solicitar consultoria telefônica.

Por gentileza, acione o administrador do Portal de sua empresa para: (1)configurar o seu acesso ou (2)buscar um perfil autorizado para registro desse atendimento.

Em caso de dúvidas sobre a identificação do contato administrador do Portal, ligue (11) 4003-0015, opção 7 e, em seguida, opção 4 para buscar o suporte com o time de Assessoria ao Portal do Cliente. . clique aqui.

TOTVS

X Fechar

Olá ,

Para o atendimento de "Consultoria Telefônica" você deverá estar de acordo com o Faturamento.

TOTVS

X Fechar

Olá,

Algo inesperado ocorreu, e o usuario nao foi reconhecido ou você nao se encontra logado

Por favor realize um novo login

Em caso de dúvidas, entre em contato com o administrador do Portal de Clientes de sua empresa para verificação do seu usuário, ou Centro de Serviços TOTVS.

Ligue! 4003-0015 opção 4 e 9 ou registre uma solicitação para CST – Cadastros . clique aqui.

TOTVS

Chat _

Preencha os campos abaixo para iniciar o atendimento:

Chat _