danfe 2.0.0
danfe: ^2.0.0 copied to clipboard
Package para parsear e transformar um arquivo de danfe xml em objeto ou buffer para impressao
DANFE #
Este package tem como finalidade ajudar no desenvolvimento e manipulação de documentos fiscais eletrônicos, incluindo DANFE (NFC-E, SAT, NFe) e NFSe Nacional, normalizando os objetos e criando buffers de impressão padrão para dispositivos ESC/POS.
O que este package faz! #
- ✅ DANFE: Carrega um XML em string, verifica se é SAT, NFC-E ou NFe e normaliza um objeto com todas as informações em propriedades genéricas
- ✅ NFSe Nacional: Carrega um XML de NFSe Nacional e normaliza um objeto com todas as informações
- ✅ Impressão: Cria um buffer em List
- ✅ Conversão: Transforma documentos em widgets Flutter, imagens ou JSON para impressão
- ✅ Customização: Permite criar seus próprios layouts de impressão (vide pasta EXAMPLE)
Existe um exemplo completo na pasta example do projeto #
📄 Trabalhando com DANFE (NFC-E, SAT, NFe) #
Parseando seu XML em um objeto do tipo Danfe #
// importando o package
import 'package:danfe/danfe.dart';
Danfe? danfe = DanfeParser.readFromString(xml);
Transformando seu objeto em um buffer para impressão (Utilizando o esc_pos_utils) #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
DanfePrinter danfePrinter = DanfePrinter(PaperSize.mm80); // ou PaperSize.mm58
List<int> _dados = await danfePrinter.bufferDanfe(danfe);
Imprimindo o buffer em uma impressora de rede #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
DanfePrinter danfePrinter = DanfePrinter(PaperSize.mm80); // ou PaperSize.mm58
final profile = await CapabilityProfile.load();
List<int> _dados = await danfePrinter.bufferDanfe(danfe);
NetworkPrinter printer = NetworkPrinter(PaperSize.mm80, profile);
await printer.connect('192.168.5.111', port: 9100);
printer.rawBytes(_dados);
printer.disconnect();
Convertendo DANFE em Widget Flutter #
import 'package:danfe/danfe.dart';
// Converte o DANFE em JSON normativo
DanfePrinter danfePrinter = DanfePrinter(PaperSize.mm80);
String jsonDanfe = danfePrinter.normativeJsonDanfe(danfe);
// Cria o widget
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonDanfe,
paperSize: DanfePaperSize.mm80,
);
Widget danfeWidget = await imageDanfe.toWidget(context);
Convertendo DANFE em Imagem #
import 'package:danfe/danfe.dart';
DanfePrinter danfePrinter = DanfePrinter(PaperSize.mm80);
String jsonDanfe = danfePrinter.normativeJsonDanfe(danfe);
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonDanfe,
paperSize: DanfePaperSize.mm80,
);
Uint8List imageBytes = await imageDanfe.toImage(context);
Imprimindo DANFE diretamente da imagem (ESC/POS) #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
DanfePrinter danfePrinter = DanfePrinter(PaperSize.mm80);
String jsonDanfe = danfePrinter.normativeJsonDanfe(danfe);
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonDanfe,
paperSize: DanfePaperSize.mm80,
);
// Converte para partes de imagem otimizadas para impressão térmica
List<Uint8List> imageParts = await imageDanfe.toEscPosPrinter(
context,
maxHeight: 2000,
maxWidth: 576, // 576 para 80mm, 384 para 58mm
margin: 0,
fixedRatio: 1.0,
);
// Imprime cada parte da imagem
final profile = await CapabilityProfile.load();
final generator = Generator(PaperSize.mm80, profile);
List<int> bytes = [];
for (var imagePart in imageParts) {
final image = decodeImage(imagePart);
if (image != null) {
bytes += generator.imageRaster(image);
}
}
bytes += generator.cut();
// Envia para a impressora
NetworkPrinter printer = NetworkPrinter(PaperSize.mm80, profile);
await printer.connect('192.168.5.111', port: 9100);
printer.rawBytes(bytes);
printer.disconnect();
Imprimindo um layout diferente do padrão criado por você manualmente #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
final CustomPrinter custom = CustomPrinter(PaperSize.mm80); // ou PaperSize.mm58
final profile = await CapabilityProfile.load();
List<int> _dados = await custom.layoutCustom(danfe);
NetworkPrinter printer = NetworkPrinter(PaperSize.mm80, profile);
await printer.connect('192.168.5.111', port: 9100);
printer.rawBytes(_dados);
printer.disconnect();
📄 Trabalhando com NFSe Nacional #
⚠️ IMPORTANTE: Este package suporta apenas NFSe Nacional. A identificação é feita pelo campo
versaoAplicativono XML que deve conter a palavra "Nacional" (case insensitive).
Parseando XML de NFSe Nacional em um objeto #
import 'package:danfe/danfe.dart';
// O XML deve ser de NFSe Nacional (versaoAplicativo contendo "Nacional")
Nfse? nfse = NfseParser.readFromString(xmlNfse);
Verificando se o XML é NFSe Nacional #
import 'package:danfe/danfe.dart';
// Extrai informações básicas sem fazer parse completo
Map<String, String>? info = NfseParser.extractBasicInfo(xmlNfse);
if (info != null) {
print('Tipo: ${info['tipo']}'); // 'NFSe Nacional'
print('Versão: ${info['versao']}');
print('Número: ${info['numero']}');
}
Transformando NFSe em buffer para impressão #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
NfsePrinter nfsePrinter = NfsePrinter(PaperSize.mm80); // ou PaperSize.mm58
List<int> _dados = await nfsePrinter.bufferNfse(nfse);
Imprimindo NFSe em uma impressora de rede #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
NfsePrinter nfsePrinter = NfsePrinter(PaperSize.mm80);
final profile = await CapabilityProfile.load();
List<int> _dados = await nfsePrinter.bufferNfse(nfse);
NetworkPrinter printer = NetworkPrinter(PaperSize.mm80, profile);
await printer.connect('192.168.5.111', port: 9100);
printer.rawBytes(_dados);
printer.disconnect();
Convertendo NFSe em Widget Flutter #
import 'package:danfe/danfe.dart';
// Converte a NFSe em JSON normativo
NfsePrinter nfsePrinter = NfsePrinter(PaperSize.mm80);
String jsonNfse = nfsePrinter.normativeJsonNfse(nfse);
// Cria o widget
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonNfse,
paperSize: DanfePaperSize.mm80,
);
Widget nfseWidget = await imageDanfe.toWidget(context);
Convertendo NFSe em Imagem #
import 'package:danfe/danfe.dart';
NfsePrinter nfsePrinter = NfsePrinter(PaperSize.mm80);
String jsonNfse = nfsePrinter.normativeJsonNfse(nfse);
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonNfse,
paperSize: DanfePaperSize.mm80,
);
Uint8List imageBytes = await imageDanfe.toImage(context);
Imprimindo NFSe diretamente da imagem (ESC/POS) #
import 'package:danfe/danfe.dart';
import 'package:esc_pos_utils_plus/esc_pos_utils_plus.dart';
NfsePrinter nfsePrinter = NfsePrinter(PaperSize.mm80);
String jsonNfse = nfsePrinter.normativeJsonNfse(nfse);
ImageDanfe imageDanfe = ImageDanfe(
jsonData: jsonNfse,
paperSize: DanfePaperSize.mm80,
);
// Converte para partes de imagem otimizadas para impressão térmica
List<Uint8List> imageParts = await imageDanfe.toEscPosPrinter(
context,
maxHeight: 2000,
maxWidth: 576, // 576 para 80mm, 384 para 58mm
margin: 0,
fixedRatio: 1.0,
);
// Imprime cada parte da imagem
final profile = await CapabilityProfile.load();
final generator = Generator(PaperSize.mm80, profile);
List<int> bytes = [];
for (var imagePart in imageParts) {
final image = decodeImage(imagePart);
if (image != null) {
bytes += generator.imageRaster(image);
}
}
bytes += generator.cut();
// Envia para a impressora
NetworkPrinter printer = NetworkPrinter(PaperSize.mm80, profile);
await printer.connect('192.168.5.111', port: 9100);
printer.rawBytes(bytes);
printer.disconnect();
Exemplo de XML NFSe Nacional #
<?xml version="1.0" encoding="UTF-8"?>
<root>
<tipoAmbiente>1</tipoAmbiente>
<versaoAplicativo>SefinNacional_1.5.0</versaoAplicativo>
<NFSe>
<infNFSe Id="NFS...">
<nNFSe>1537</nNFSe>
<emit>
<CNPJ>12345678901234</CNPJ>
<xNome>Empresa Exemplo LTDA</xNome>
<enderNac>
<xLgr>Rua Exemplo</xLgr>
<nro>123</nro>
<xBairro>Centro</xBairro>
<cMun>3550308</cMun>
<UF>SP</UF>
<CEP>01310100</CEP>
</enderNac>
</emit>
<DPS>
<infDPS>
<prest>
<CNPJ>12345678901234</CNPJ>
</prest>
<tomador>
<CNPJ>98765432109876</CNPJ>
<xNome>Cliente Exemplo</xNome>
</tomador>
<serv>
<cServ>
<cTribNac>01.07.00</cTribNac>
<xDescServ>Servico de Exemplo</xDescServ>
</cServ>
</serv>
<valores>
<vServPrest>
<vServ>1000.00</vServ>
</vServPrest>
</valores>
</infDPS>
</DPS>
</infNFSe>
</NFSe>
</root>
📦 Modelos Disponíveis #
DANFE #
Danfe- Modelo principalDadosDanfe- Dados da notaEmit- EmitenteDest- DestinatárioDet- Detalhes/ItensTotal- TotalizadoresPgto- Pagamentos- E outros...
NFSe Nacional #
Nfse- Modelo principalEmitNfse- EmitenteInfDPS- Informações da DPSPrestador- Dados do prestadorTomador- Dados do tomadorServico- Serviços prestadosValores- Valores da NFSeTributos- Tributos aplicados