Para construir o XML da NFe (ou da NFCe) deve ser usada a classe Make::class
NOTA: Esta classe agora recebe os parâmetros dos métodos em forma de stdClass e não mais com variáveis individuais. É importante salientar que os campos do stdClass devem ser nomeados com a EXATA nomenclatura contida no manual ou conforme a nomenclatura das estruturas do TXT, observando as letras maiúsculas e minúsculas.
NOTA: Procure observar a ordem como os métodos devem ser usados. Carregar os dados em sequência errada pode causar problemas, especialmente em nodes dependentes.
Esses stdClass podem ser criados diretamente como demonstrado nos exemplos abaixo, mas também podem ser criados a partir de matrizes.
NOTA: Ajustado para NT 2018.001 v1.00 Usar novos campos dessa NT em produção somente a partir de 29/04/2019.
NOTA: Ajustado para NT 2018.001 v1.10 Usar novos campos dessa NT em produção somente a partir de 29/04/2019.
*NOTA: Ajustado para NT 2020.006 User o novo campo na tgIde() e novo método sefazIntermed() em produção a partir de 05/04/2021.
*NOTA: Ajustado para NT 2020.007 User o novo método sefazAtorInteressado() em produção a partir de 05/04/2021.
Existe um provável ERRO nos XSDs PL_009_V4, fornecidos em 02/01/2019, onde estabelece um comprimento para o campo hashCSRT de 28 digitos base64Binary, quando na verdade são gerados 30 digitos segundo esta formatação.
//criando o stdClass a partir de um array
$array = [
'versao' => '3.10',
'Id' => 'NFe35150271780456000160550010000000021800700082',
'pk_nItem' => null
];
$std = json_decode(json_encode($array));
NOTA: Muitos campos não são obrigatórios. Caso não haja nenhum valor a ser informado, devem ser criados como NULL. NOTA: Caso existam erros na passagem de parâmetros para a classe, será disparada uma Exception e esses erros poderão ser recuperados pelo método getErrors().
Método construtor. Instancia a classe
$nfe = new Make();
Node principal
NOTA: se o parametro $std->Id não for passado a chave será criada e inclusa e poderá ser recuperada no parâmetro chNFe da classe, De outra forma se a chave for passada no parâmetro $std->Id e estiver incorreta, um erro será inserido na proriedade errors.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->versao = '4.00'; //versão do layout (string)
$std->Id = 'NFe35150271780456000160550010000000021800700082'; //se o Id de 44 digitos não for passado será gerado automaticamente
$std->pk_nItem = null; //deixe essa variavel sempre como NULL
$nfe->taginfNFe($std);
Node de identificação da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->cUF = 35;
$std->cNF = '80070008';
$std->natOp = 'VENDA';
$std->indPag = 0; //NÃO EXISTE MAIS NA VERSÃO 4.00
$std->mod = 55;
$std->serie = 1;
$std->nNF = 2;
$std->dhEmi = '2015-02-19T13:48:00-02:00';
$std->dhSaiEnt = null;
$std->tpNF = 1;
$std->idDest = 1;
$std->cMunFG = 3518800;
$std->tpImp = 1;
$std->tpEmis = 1;
$std->cDV = 2;
$std->tpAmb = 2;
$std->finNFe = 1;
$std->indFinal = 0;
$std->indPres = 0;
$std->indIntermed = null;
$std->procEmi = 0;
$std->verProc = '3.10.31';
$std->dhCont = null;
$std->xJust = null;
$nfe->tagide($std);
Node referente a NFe referenciada
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->refNFe = '35150271780456000160550010000253101000253101';
$nfe->tagrefNFe($std);
Node referente a Nota Fiscal referenciada modelo 1 ou 2
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->cUF = 35;
$std->AAMM = 1412;
$std->CNPJ = '52297850000105';
$std->mod = '01';
$std->serie = 3;
$std->nNF = 587878;
$nfe->tagrefNF($std);
Node referente a Nota Fiscal referenciada de produtor rural
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->cUF = 35;
$std->AAMM = 1502;
$std->CNPJ;
$std->CPF;
$std->IE = 'ISENTO';
$std->mod = '04';
$std->serie = 0;
$std->nNF = 5578;
$nfe->tagrefNFP($std);
Node referente aos CTe referenciados
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->refCTe = '35150268252816000146570010000016161002008472';
$nfe->tagrefCTe($std);
Node referente aos ECF referenciados
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->mod = '2C';
$std->nECF = 788;
$std->nCOO = 114;
$nfe->tagrefECF($std);
Node com os dados do emitente
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xNome;
$std->xFant;
$std->IE;
$std->IEST;
$std->IM;
$std->CNAE;
$std->CRT;
$std->CNPJ; //indicar apenas um CNPJ ou CPF
$std->CPF;
$nfe->tagemit($std);
Node com o endereço do emitente
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xLgr;
$std->nro;
$std->xCpl;
$std->xBairro;
$std->cMun;
$std->xMun;
$std->UF;
$std->CEP;
$std->cPais;
$std->xPais;
$std->fone;
$nfe->tagenderEmit($std);
Node com os dados do destinatário
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xNome;
$std->indIEDest;
$std->IE;
$std->ISUF;
$std->IM;
$std->email;
$std->CNPJ; //indicar apenas um CNPJ ou CPF ou idEstrangeiro
$std->CPF;
$std->idEstrangeiro;
$nfe->tagdest($std);
Node de endereço do destinatário
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xLgr;
$std->nro;
$std->xCpl;
$std->xBairro;
$std->cMun;
$std->xMun;
$std->UF;
$std->CEP;
$std->cPais;
$std->xPais;
$std->fone;
$nfe->tagenderDest($std);
NOTA: Ajustado para NT 2018.005 Node indicativo de local de retirada diferente do endereço do emitente
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->CNPJ = '12345678901234'; //indicar apenas um CNPJ ou CPF
$std->CPF = null;
$std->IE = '12345678901';
$std->xNome = 'Beltrano e Cia Ltda';
$std->xLgr = 'Rua Um';
$std->nro = '123';
$std->xCpl = 'sobreloja';
$std->xBairro = 'centro';
$std->cMun = '3550308';
$std->xMun = 'Sao Paulo';
$std->UF = 'SP';
$std->CEP = '01023000';
$std->cPais = '1058';
$std->xPais = 'BRASIL';
$std->fone = '1122225544';
$std->email = '[email protected]';
$nfe->tagretirada($std);
NOTA: Ajustado para NT 2018.005 Node indicativo de local de entrega diferente do endereço do destinatário
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->CNPJ; //indicar um CNPJ ou CPF
$std->CPF = null;
$std->IE = '12345678901';
$std->xNome = 'Beltrano e Cia Ltda';
$std->xLgr = 'Rua Um';
$std->nro = '123';
$std->xCpl = 'sobreloja';
$std->xBairro = 'centro';
$std->cMun = '3550308';
$std->xMun = 'Sao Paulo';
$std->UF = 'SP';
$std->CEP = '01023000';
$std->cPais = '1058';
$std->xPais = 'BRASIL';
$std->fone = '1122225544';
$std->email = '[email protected]';
$nfe->tagentrega($std);
Node de registro de pessoas autorizadas a acessar a NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->CNPJ = '12345678901234'; //indicar um CNPJ ou CPF
$std->CPF = null;
$nfe->tagautXML($std);
Node de dados do produto/serviço
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->cProd;
$std->cEAN;
$std->cBarra;
$std->xProd;
$std->NCM;
$std->cBenef;
$std->EXTIPI;
$std->CFOP;
$std->uCom;
$std->qCom;
$std->vUnCom;
$std->vProd;
$std->cEANTrib;
$std->cBarraTrib;
$std->uTrib;
$std->qTrib;
$std->vUnTrib;
$std->vFrete;
$std->vSeg;
$std->vDesc;
$std->vOutro;
$std->indTot;
$std->xPed;
$std->nItemPed;
$std->nFCI;
$nfe->tagprod($std);
Node opcional com dados de Crédito Presumido, são permitidos até 4 registros por item
Parâmetro | Tipo | Descrição |
---|---|---|
item | inteiro | Número do item da NFe |
cCredPresumido | string | Código de Benefício Fiscal de Crédito Presumido na UF aplicado ao item |
pCredPresumido | numerico | Percentual do Crédito Presumido |
vCredPresumido | numerico | Valor do Crédito Presumido |
$std = new \stdClass();
$std->item = 1;
$std->cCredPresumido = '2222211234';
$std->pCredPresumido = '4';
$std->vCredPresumido = '4';
$make->tagCreditoPresumidoProd($std);
Node de informações adicionais do produto
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->infAdProd = 'informacao adicional do item';
$nfe->taginfAdProd($std);
Node com a Nomenclatura de Valor Aduaneiro e Estatística do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->NVE = 'AA0001';
$nfe->tagNVE($std);
Node de detalhamento do Especificador da Substituição Tributária do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->CEST = '0200100';
$std->indEscala = 'N'; //incluido no layout 4.00
$std->CNPJFab = '12345678901234'; //incluido no layout 4.00
$nfe->tagCEST($std);
Node com o número do RECOPI
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nRECOPI = '12345678901234567890';
$nfe->tagRECOPI($std);
Node com informações da Declaração de Importação do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nDI;
$std->dDI;
$std->xLocDesemb;
$std->UFDesemb;
$std->dDesemb;
$std->tpViaTransp;
$std->vAFRMM;
$std->tpIntermedio;
$std->CNPJ;
$std->CPF; //NT 2023.004 v1.00
$std->UFTerceiro;
$std->cExportador;
$nfe->tagDI($std);
Node de Adições relativas as DI do item
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nDI; //número da DI
$std->nAdicao;
$std->nSeqAdic;
$std->cFabricante;
$std->vDescDI;
$std->nDraw;
$nfe->tagadi($std);
Node com informações de exportação para o item
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nDraw = '82828';
$nfe->tagdetExport($std);
Node com Grupo sobre exportação indireta, deve ser indicado logo após $nfe->tagdetExport($std) pois pertence a essa tag
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nRE = '123456789012';
$std->chNFe = '53170924915365000295550550000001951000001952';
$std->qExport = 1234.123;
$nfe->tagdetExportInd($std);
Node com os dados de rastreabilidade do item da NFe
Método Incluso para atender layout 4.00
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nLote = '11111';
$std->qLote = 200;
$std->dFab = '2018-01-01';
$std->dVal = '2020-01-01';
$std->cAgreg = '1234';
$nfe->tagRastro($std);
Node com o detalhamento de Veículos novos do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->tpOp;
$std->chassi;
$std->cCor;
$std->xCor;
$std->pot;
$std->cilin;
$std->pesoL;
$std->pesoB;
$std->nSerie;
$std->tpComb;
$std->nMotor;
$std->CMT;
$std->dist;
$std->anoMod;
$std->anoFab;
$std->tpPint;
$std->tpVeic;
$std->espVeic;
$std->VIN;
$std->condVeic;
$std->cMod;
$std->cCorDENATRAN;
$std->lota;
$std->tpRest;
$nfe->tagveicProd($std);
NOTA: Ajustado conforme NT 2018.005 Node com o detalhamento de Medicamentos e de matérias-primas farmacêuticas
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->cProdANVISA = '1234567890123'; //incluido no layout 4.00
$std->xMotivoIsencao = 'RDC 238';
$std->vPMC = 102.22;
$nfe->tagmed($std);
Node com informações e detalhamento de Armamento do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nAR; //Indicativo de número da arma
$std->tpArma;
$std->nSerie;
$std->nCano;
$std->descr;
$nfe->tagarma($std);
Node das informações específicas para combustíveis líquidos e lubrificantes do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->cProdANP;
$std->pMixGN; //removido no layout 4.00
$std->descANP; //incluido no layout 4.00
$std->pGLP; //incluido no layout 4.00
$std->pGNn; //incluido no layout 4.00
$std->pGNi; //incluido no layout 4.00
$std->vPart; //incluido no layout 4.00
$std->CODIF;
$std->qTemp;
$std->UFCons;
$std->qBCProd;
$std->vAliqProd;
$std->vCIDE;
$nfe->tagcomb($std);
Node das informações do grupo de “encerrante” disponibilizado por hardware específico acoplado à bomba de Combustível, definido no controle da venda do Posto Revendedor de Combustível. Referente ao item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->nBico;
$std->nBomba;
$std->nTanque;
$std->vEncIni;
$std->vEncFin;
$std->pBio; //NT 2022.001 v1.10
$nfe->tagencerrante($std);
Parte do grupo encerrante, podem haver de 0 até 30 tags desse tipo
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->indImport= 0; //NT 2023.001 v1.00
$std->cUFOrig = 35; //NT 2023.001 v1.00
$std->Orig = 100; //NT 2023.001 v1.00
$nfe->tagOrigComb($std);
Node inicial dos Tributos incidentes no Produto ou Serviço do item da NFe
Parametro | Tipo | Descrição |
---|---|---|
$std | stcClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vTotTrib = 1000.00;
$nfe->tagimposto($std);
NOTA: Ajustado conforme NT 2018.005_1.10 Node com informações do ICMS do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->orig;
$std->CST;
$std->modBC;
$std->vBC;
$std->pICMS;
$std->vICMS;
$std->pFCP;
$std->vFCP;
$std->vBCFCP;
$std->modBCST;
$std->pMVAST;
$std->pRedBCST;
$std->vBCST;
$std->pICMSST;
$std->vICMSST;
$std->vBCFCPST;
$std->pFCPST;
$std->vFCPST;
$std->vICMSDeson;
$std->motDesICMS;
$std->pRedBC;
$std->vICMSOp;
$std->pDif;
$std->vICMSDif;
$std->vBCSTRet;
$std->pST;
$std->vICMSSTRet;
$std->vBCFCPSTRet;
$std->pFCPSTRet;
$std->vFCPSTRet;
$std->pRedBCEfet;
$std->vBCEfet;
$std->pICMSEfet;
$std->vICMSEfet;
$std->vICMSSubstituto; //NT 2020.005 v1.20
$std->vICMSSTDeson; //NT 2020.005 v1.20
$std->motDesICMSST; //NT 2020.005 v1.20
$std->pFCPDif; //NT 2020.005 v1.20
$std->vFCPDif; //NT 2020.005 v1.20
$std->vFCPEfet; //NT 2020.005 v1.20
$std->pRedAdRem; //NT 2023.001-v1.10
$std->qBCMono; //NT 2023.001-v1.10
$std->adRemiICMS; //NT 2023.001-v1.10
$std->vICMSMono; //NT 2023.001-v1.10
$std->adRemICMSRet; //NT 2023.001-v1.10
$std->vICMSMonoRet; //NT 2023.001-v1.10
$std->vICMSMonoDif; //NT 2023.001-v1.10
$std->cBenefRBC; //NT 2019.001 v1.61
$std->indDeduzDeson; //NT 2023.004 v1.00
$nfe->tagICMS($std);
Node com informações da partilha do ICMS entre a UF de origem e UF de destino ou a UF definida na legislação.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->orig = 0;
$std->CST = '90';
$std->modBC = 0;
$std->vBC = 1000.00;
$std->pRedBC = null;
$std->pICMS = 18.00;
$std->vICMS = 180.00;
$std->modBCST = 1000.00;
$std->pMVAST = 40.00;
$std->pRedBCST = null;
$std->vBCST = 1400.00;
$std->pICMSST = 10.00;
$std->vICMSST = 140.00;
$std->pBCOp = 10.00;
$std->UFST = 'RJ';
$nfe->tagICMSPart($std);
NOTA: Ajustado conforme NT 2018.005 e NT 2018.005_1.10 Node Repasse de ICMS ST retido anteriormente em operações interestaduais com repasses através do Substituto Tributário
Parametro | Tipo | Descrição |
---|---|---|
$std | stcClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->orig = 0;
$std->CST = '60';
$std->vBCSTRet = 1000.00;
$std->vICMSSTRet = 190.00;
$std->vBCSTDest = 1000.00;
$std->vICMSSTDest = 1.00;
$std->vBCFCPSTRet = 1000.00;
$std->pFCPSTRet = 1.00;
$std->vFCPSTRet = 10.00;
$std->pST = null;
$std->vICMSSubstituto = null;
$std->pRedBCEfet = null;
$std->vBCEfet = null;
$std->pICMSEfet = null;
$std->vICMSEfet = null;
$nfe->tagICMSST($std);
Node referente Tributação ICMS pelo Simples Nacional do item da NFe
NOTA: Ajustado conforme NT 2018.005_1.10
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->orig = 0;
$std->CSOSN = '101';
$std->pCredSN = 2.00;
$std->vCredICMSSN = 20.00;
$std->modBCST = null;
$std->pMVAST = null;
$std->pRedBCST = null;
$std->vBCST = null;
$std->pICMSST = null;
$std->vICMSST = null;
$std->vBCFCPST = null; //incluso no layout 4.00
$std->pFCPST = null; //incluso no layout 4.00
$std->vFCPST = null; //incluso no layout 4.00
$std->vBCSTRet = null;
$std->pST = null;
$std->vICMSSTRet = null;
$std->vBCFCPSTRet = null; //incluso no layout 4.00
$std->pFCPSTRet = null; //incluso no layout 4.00
$std->vFCPSTRet = null; //incluso no layout 4.00
$std->modBC = null;
$std->vBC = null;
$std->pRedBC = null;
$std->pICMS = null;
$std->vICMS = null;
$std->pRedBCEfet = null;
$std->vBCEfet = null;
$std->pICMSEfet = null;
$std->vICMSEfet = null;
$std->vICMSSubstituto = null;
$nfe->tagICMSSN($std);
Node de informação do ICMS Interestadual do item na NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stcClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vBCUFDest = 100.00;
$std->vBCFCPUFDest = 100.00;
$std->pFCPUFDest = 1.00;
$std->pICMSUFDest = 18.00;
$std->pICMSInter = 12.00;
$std->pICMSInterPart = 80.00;
$std->vFCPUFDest = 1.00;
$std->vICMSUFDest = 14.44;
$std->vICMSUFRemet = 3.56;
$nfe->tagICMSUFDest($std);
Node referente ao IPI do item da NFe
NOTA: clEnq foi removido do layout 4.00 na NT_2016_V1.40
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->clEnq = null;
$std->CNPJProd = null;
$std->cSelo = null;
$std->qSelo = null;
$std->cEnq = '999';
$std->CST = '50';
$std->vIPI = 150.00;
$std->vBC = 1000.00;
$std->pIPI = 15.00;
$std->qUnid = null;
$std->vUnid = null;
$nfe->tagIPI($std);
Node Imposto de Importação do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vBC = 1000.00;
$std->vDespAdu = 100.00;
$std->vII = 220.00;
$std->vIOF = null;
$nfe->tagII($std);
Node PIS do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->CST = '07';
$std->vBC = null;
$std->pPIS = null;
$std->vPIS = null;
$std->qBCProd = null;
$std->vAliqProd = null;
$nfe->tagPIS($std);
Node PIS Substituição Tributária do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vPIS = 16.00;
$std->vBC = 1000.00
$std->pPIS = 1.60;
$std->qBCProd = null;
$std->vAliqProd = null;
$std->indSomaPISST = 0; //0=Valor do PISST não compõe o valor total da NF-e
//1=Valor do PISST compõe o valor total da NF-e
$nfe->tagPISST($std);
Node COFINS do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->CST = '07';
$std->vBC = null;
$std->pCOFINS = null;
$std->vCOFINS = null;
$std->qBCProd = null;
$std->vAliqProd = null;
$nfe->tagCOFINS($std);
Node COFINS Substituição Tributária do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vCOFINS = 289.30;
$std->vBC = 2893.00;
$std->pCOFINS = 10.00;
$std->qBCProd = null;
$std->vAliqProd = null;
$std->indSomaCOFINSST = 0; //0=Valor do COFINS ST não compõe o valor total da NF-e
//1=Valor do COFINS ST compõe o valor total da NF-e
$nfe->tagCOFINSST($std);
Node ISSQN do item da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->vBC = 1000.00;
$std->vAliq = 5.00;
$std->vISSQN = 50.00;
$std->cMunFG = '3518800';
$std->cListServ = '12.23';
$std->vDeducao = null;
$std->vOutro = null;
$std->vDescIncond = null;
$std->vDescCond = null;
$std->vISSRet = null;
$std->indISS = 2;
$std->cServico = '123';
$std->cMun = '3518800';
$std->cPais = '1058';
$std->nProcesso = null;
$std->indIncentivo = 2;
$nfe->tagISSQN($std);
Node referente a informação do Imposto devolvido
NOTA: O motivo da devolução deverá ser informado pela empresa no campo de Informações Adicionais do Produto (tag:infAdProd).
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //item da NFe
$std->pDevol = 2.00;
$std->vIPIDevol = 123.36;
$nfe->tagimpostoDevol($std);
Node dos totais referentes ao ICMS
NOTA: Esta tag não necessita que sejam passados valores, pois a classe irá calcular esses totais e irá usar essa totalização para complementar e gerar esse node, caso nenhum valor seja passado como parâmetro.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vBC;
$std->vICMS;
$std->vICMSDeson;
$std->vBCST;
$std->vST;
$std->vProd;
$std->vFrete;
$std->vSeg;
$std->vDesc;
$std->vII;
$std->vIPI;
$std->vPIS;
$std->vCOFINS;
$std->vOutro;
$std->vNF;
$std->vIPIDevol;
$std->vTotTrib;
$std->vFCP;
$std->vFCPST;
$std->vFCPSTRet;
$std->vFCPUFDest;
$std->vICMSUFDest;
$std->vICMSUFRemet;
$std->qBCMono;
$std->vICMSMono;
$std->qBCMonoReten;
$std->vICMSMonoReten;
$std->qBCMonoRet;
$std->vICMSMonoRet;
$nfe->tagICMSTot($std);
Node de Totais referentes ao ISSQN
NOTA: caso os valores não existam indique "null". Se for indicado 0.00 esse número será incluso no XML o que poderá causar sua rejeição.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vServ = 1000.00;
$std->vBC = 1000.00;
$std->vISS = 10.00;
$std->vPIS = 2.00;
$std->vCOFINS = 6.00;
$std->dCompet = '2017-09-12';
$std->vDeducao = 10.00;
$std->vOutro = 10.00;
$std->vDescIncond = null;
$std->vDescCond = null;
$std->vISSRet = null;
$std->cRegTrib = 5;
$nfe->tagISSQNTot($std);
Node referente a retenções de tributos
Exemplos de atos normativos que definem obrigatoriedade da retenção de contribuições:
a) IRPJ/CSLL/PIS/COFINS - Fonte - Recebimentos de Órgão Público Federal, Lei no 9.430, de 27 de dezembro de 1996, art. 64, Lei no 10.833/2003, art. 34, como normas infralegais, temos como exemplo: IN SRF 480/2004 e IN 539, de 25/04/05.
b) Retenção do Imposto de Renda pelas Fontes Pagadoras, REMUNERAÇÃO DE SERVIÇOS PROFISSIONAIS PRESTADOS POR PESSOA JURÍDICA, Lei no 7.450/85, art. 52
c) IRPJ, CSLL, COFINS e PIS - Serviços Prestados por Pessoas Jurídicas - Retenção na Fonte, Lei no 10.833 de 29.12.2003, art. 30, 31, 32, 35 e 36
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vRetPIS = 100.00;
$std->vRetCOFINS = 100.00;
$std->vRetCSLL = 100.00;
$std->vBCIRRF = 100.00;
$std->vIRRF = 100.00;
$std->vBCRetPrev = 100.00;
$std->vRetPrev = 100.00;
$nfe->tagretTrib($std);
Node indicativo da forma de frete
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->modFrete = 1;
$nfe->tagtransp($std);
Node com os dados da transportadora
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xNome = 'Rodo Fulano';
$std->IE = '12345678901';
$std->xEnder = 'Rua Um, sem numero';
$std->xMun = 'Cotia';
$std->UF = 'SP';
$std->CNPJ = '12345678901234';//só pode haver um ou CNPJ ou CPF, se um deles é especificado o outro deverá ser null
$std->CPF = null;
$nfe->tagtransporta($std);
Node referente a retenção de ICMS do serviço de transporte
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vServ = 240.00;
$std->vBCRet = 240.00;
$std->pICMSRet = 1.00;
$std->vICMSRet = 2.40;
$std->CFOP = '5353';
$std->cMunFG = '3518800';
$nfe->tagretTransp($std);
Node para informação do veículo trator
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->placa = 'ABC1111';
$std->UF = 'RJ';
$std->RNTC = '999999';
$nfe->tagveicTransp($std);
Node para informar os reboques/Dolly
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->placa = 'BCB0897';
$std->UF = 'SP';
$std->RNTC = '123456';
$nfe->tagreboque($std);
Node para informar o vagão usado
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vagao = 'YY452-19';
$nfe->tagvagao($std);
Node para informar a balsa usada
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->balsa = 'BNAV111';
$nfe->tagbalsa($std);
Node com as informações dos volumes transportados
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //indicativo do numero do volume
$std->qVol = 2;
$std->esp = 'caixa';
$std->marca = 'OLX';
$std->nVol = '11111';
$std->pesoL = 10.50;
$std->pesoB = 11.00;
$nfe->tagvol($std);
Node com a identificação dos lacres, referentes ao volume
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->item = 1; //indicativo do numero do volume
$std->nLacre = 'ZZEX425365';
$nfe->taglacres($std);
Node com os dados da fatura
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->nFat = '1233';
$std->vOrig = 1254.22;
$std->vDesc = null;
$std->vLiq = 1254.22;
$nfe->tagfat($std);
Node de informações das duplicatas
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->nDup = '1233-1';
$std->dVenc = '2017-08-22';
$std->vDup = 1254.22;
$nfe->tagdup($std);
Node referente as formas de pagamento OBRIGATÓRIO para NFCe a partir do layout 3.10 e também obrigatório para NFe (modelo 55) a partir do layout 4.00
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->vTroco = null; //incluso no layout 4.00, obrigatório informar para NFCe (65)
$nfe->tagpag($std);
NOTA: usualmente para NFe modelo 55, vTroco é null.
Node com o detalhamento da forma de pagamento OBRIGATÓRIO para NFCe e NFe layout4.00
NOTA: indPag re-incluso no layout 4.00 NT_2016_V1.51 NOTA: tPag 14 - duplicata foi removido do layout 4.00 na NT_2016_V1.51
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->indPag = '0'; //0= Pagamento à Vista 1= Pagamento à Prazo
$std->tPag = '03';
$std->vPag = 200.00; //Obs: deve ser informado o valor pago pelo cliente
$std->CNPJ = '12345678901234';
$std->tBand = '01';
$std->cAut = '3333333';
$std->tpIntegra = 1; //incluso na NT 2015/002
$std->CNPJPag; //NT 2023.004 v1.00
$std->UFPag; //NT 2023.004 v1.00
$std->CNPJReceb; //NT 2023.004 v1.00
$std->idTermPag; //NT 2023.004 v1.00
$nfe->tagdetPag($std);
NOTA: para NFe (modelo 55), temos ...
vPag=0.00 mas pode ter valor se a venda for à vista
tPag é usualmente:
- 15 = Boleto Bancário
- 16 = Depósito Bancário
- 17 = Pagamento Instantâneo (PIX)
- 18 = Transferência bancária, Carteira Digital
- 19 = Programa de fidelidade, Cashback, Crédito Virtual
- 90 = Sem pagamento
- 98 = Regime Especial NFF
- 99 = Outros
Porém podem haver casos que os outros nodes e valores tenham de ser usados.
Node referente aos dados do Intermediador NT 2020.006
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->CNPJ = '12345678901234';
$std->idCadIntTran = 'fulano';
$nfe->tagIntermed($std);
Node referente as informações adicionais da NFe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->infAdFisco = 'informacoes para o fisco';
$std->infCpl = 'informacoes complementares';
$nfe->taginfAdic($std);
Campo de uso livre do contribuinte, Informar o nome do campo no atributo xCampo e o conteúdo do campo no xTexto
NOTA: pode ser usado, por exemplo, para indicar outros destinatários de e-mail, além do próprio destinatário da NFe, como o contador, etc.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xCampo = 'email';
$std->xTexto = '[email protected]';
$nfe->tagobsCont($std);
Campo de uso livre do Fisco. Informar o nome do campo no atributo xCampo e o conteúdo do campo no xTexto
Parametro | Tipo | Descrição |
---|---|---|
$std | stcClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xCampo = 'Info';
$std->xTexto = 'alguma coisa';
$nfe->tagobsFisco($std);
Node com a identificação do processo ou ato concessório
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->nProc 'ks7277272';
$std->indProc = 0;
$nfe->tagprocRef($std);
Node com dados de exportação.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->UFSaidaPais = 'PR';
$std->xLocExporta = 'Paranagua';
$std->xLocDespacho = 'Informação do Recinto Alfandegado';
$nfe->tagexporta($std);
Node com a informação adicional de compra
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xNEmp = 'ajhjs8282828';
$std->xPed = '828288jjshsjhjwj';
$std->xCont = 'contrato 1234';
$nfe->tagcompra($std);
Node com as informações de registro aquisições de cana
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->safra = '2017';
$std->ref = '09/2017';
$std->qTotMes = 20000;
$std->qTotAnt = 18000;
$std->qTotGer = 38000;
$std->vFor = 2500.00;
$std->vTotDed = 500.00;
$std->vLiqFor = 2000.00;
$nfe->tagcana($std);
Node informativo do fornecimento diário de cana
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->dia = 1;
$std->qtde = 1000;
$nfe->tagforDia($std);
Node Grupo Deduções – Taxas e Contribuições da aquisição de cana
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->xDed = 'deducao 1';
$std->vDed = 100.00;
$nfe->tagdeduc($std);
Node das informações suplementares da NFCe.
Não é necessário informar será preenchido automaticamente após a assinatura da NFCe
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->qrcode;
$std->urlChave;
$nfe->taginfNFeSupl($std);
Node da informação referente ao Responsável Técnico NT 2018.005 Esta tag é OPCIONAL mas se for passada todos os campos devem ser passados para a função.
Parâmetro | Tipo | Descrição |
---|---|---|
$std | stdClass | contêm os dados dos campos, nomeados conforme manual |
$std = new stdClass();
$std->CNPJ = '99999999999999'; //CNPJ da pessoa jurídica responsável pelo sistema utilizado na emissão do documento fiscal eletrônico
$std->xContato= 'Fulano de Tal'; //Nome da pessoa a ser contatada
$std->email = '[email protected]'; //E-mail da pessoa jurídica a ser contatada
$std->fone = '1155551122'; //Telefone da pessoa jurídica/física a ser contatada
$std->CSRT = 'G8063VRTNDMO886SFNK5LDUDEI24XJ22YIPO'; //Código de Segurança do Responsável Técnico
$std->idCSRT = '01'; //Identificador do CSRT
$nfe->taginfRespTec($std);
Este método chama o metodo monta(), mantido apenas para compatibilidade.
$xml = $nfe->montaNFe();
Este método executa a montagem do XML
NOTA: irá retornar uma Exception caso existam erros na montagem OU retorna o XML montado caso não hajam erros.
$xml = $nfe->monta();
Este método retorna o XML em uma string, mesmo que existam erros.
$xml = $nfe->getXML();
Este método retorna os erros identificados na passagem dos parâmetros para a classe.
$erros = $nfe->getErrors();
Este método retorna o numero da chave da NFe
$chave = $nfe->getChave();
Este método retorna o modelo de NFe 55 ou 65
$modelo = $nfe->getModelo();