texlive[46053] Master/texmf-dist: factura (12dec17)

commits+karl at tug.org commits+karl at tug.org
Tue Dec 12 23:35:59 CET 2017


Revision: 46053
          http://tug.org/svn/texlive?view=revision&revision=46053
Author:   karl
Date:     2017-12-12 23:35:59 +0100 (Tue, 12 Dec 2017)
Log Message:
-----------
factura (12dec17)

Modified Paths:
--------------
    trunk/Master/texmf-dist/doc/latex/factura/README
    trunk/Master/texmf-dist/doc/latex/factura/factura-beispiel-rechnung.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-cotizacion.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-firma.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-fondo.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-membrete.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.pdf
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte1.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte2.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte3.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura.pdf
    trunk/Master/texmf-dist/source/latex/factura/factura.dtx
    trunk/Master/texmf-dist/source/latex/factura/factura.ins
    trunk/Master/texmf-dist/tex/latex/factura/factura.cls
    trunk/Master/texmf-dist/tex/latex/factura/factura.def

Added Paths:
-----------
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-aux.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura01.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura02.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura03.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura04.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura05.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura06.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura07.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura08.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura09.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura10.tex

Removed Paths:
-------------
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura1.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura2.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura3.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura4.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura5.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura6.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura7.tex
    trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura8.tex

Modified: trunk/Master/texmf-dist/doc/latex/factura/README
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/README	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/README	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,4 +1,4 @@
-<factura>
+<factura>
 
 * Brief description in english *
 
@@ -13,7 +13,8 @@
 
 La clase de LaTeX 'factura' está diseñada para su uso en la República
 Bolivariana de Venezuela, conforme a los requerimientos fijados por las
-providencias del SENIAT, válidas para la fecha de este paquete.
+providencias del SENIAT, válidas para la fecha en la que se publicó
+este paquete.
 
 Con la clase 'factura' se pueden elaborar facturas en formas libres
 fiscales, se pueden elaborar cotizaciones y reportes de servicios.
@@ -32,7 +33,7 @@
 $ xelatex factura-ejemplo-firma.tex
 $ pdflatex factura-ejemplo-prefactura.tex
 $ pdflatex factura-ejemplo-cotizacion.tex
-$ pdflatex factura-ejemplo-factura1.tex
+$ pdflatex factura-ejemplo-factura01.tex
 ... hasta el último
 $ pdflatex factura-ejemplo-reporte1.tex
 ... hasta el último

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-beispiel-rechnung.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-beispiel-rechnung.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-beispiel-rechnung.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,19 +24,23 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Adaptado a otra legislación.
+%%  Adaptado a otra legislación
+%%  (prefactura) Escribimos una prefactura
+%%  (nospanish) Sin cargar babel en castellano, ‘lmodern’ ni la codificación T1 para la tipografías
+%%  (\Condiciones) Con condiciones del documento
 %%</desc>
 %%
 \documentclass[
@@ -44,6 +48,7 @@
 nospanish,
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 \usepackage[official]{eurosym}
 \usepackage[ngerman]{babel}
@@ -86,9 +91,6 @@
 \renewcommand{\@EstiloNumControl}{}
 \makeatother
 
-\FondoFactura{factura-ejemplo-fondo}
-
-\Fecha{06-11-2017}
 \Num{1}
 \Nombre{Jacinto de Ayala y San Vicente}
 \CI{V-987.654.321}
@@ -95,6 +97,11 @@
 \Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
 \Telefono{+58 (987) 654.32.10}
 \Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\FondoFactura{factura-ejemplo-fondo}
+
 \Condiciones{Die Zahlungsbedingungen}
 \Resumen{Zusammenfassung}
 
@@ -108,6 +115,9 @@
 
 \Descripcion{Lange Beschreibung.}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-aux.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-aux.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-aux.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,74 @@
+%%
+%% This is file `factura-ejemplo-aux.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `aux')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Helper file; not to be compiled standalone, only to be included on examples.
+%% Archivo auxiliar; no para ser compilado sino para ser incluido en los ejemplos.
+%%
+\usepackage{xspace,catchfilebetweentags,regexpatch}
+\def\optcolor{\color{blue}}
+\def\macrocolor{\color{purple}}
+\makeatletter
+\catcode`\%=11
+\catcode`\|=14
+\newcommand{\Ejemplo}{|
+ \newpage
+ \ClearShipoutPictureBG
+ \newgeometry{vmargin={2cm,2cm},hmargin={2cm,2cm},footskip=0pt,headheight=0pt,headsep=0pt,footnotesep=0pt}|
+ \thispagestyle{empty}|
+ \catcode`\<=12
+ \catcode`\>=12
+ \CatchFileBetweenDelims{\DescEjemplo}{\jobname.tex}{<desc>}{</desc>}[\catcode37=11\catcode13=14\makeatletter]|
+ \catcode`\%=11
+ \makeatletter
+ \regexpatchcmd*{\DescEjemplo}{\cC.\cO[*]*}{\c{begingroup}\c{macrocolor}\c{ttfamily}\c{string}\0\c{endgroup}\c{xspace}}{}{}|
+ \regexpatchcmd*{\DescEjemplo}{(\()(\cL[a-zG]*)(\))}{(\c{begingroup}\c{optcolor}\c{ttfamily}\2\c{endgroup})}{}{}|
+ \xpatchcmd*{\DescEjemplo}{%% }{\item}{}{}|
+ \xpatchcmd*{\DescEjemplo}{%%}{}{}{}|
+ \makeatother
+ {\bfseries Descripci\'on de este ejemplo {\slshape \jobname.tex}:}
+ \begin{itemize}
+  \DescEjemplo
+ \end{itemize}
+ \catcode`\<=13
+ \catcode`\>=13
+ }
+\catcode`\%=14
+\catcode`\|=12
+\makeatother
+%% 
+%%
+%% End of file `factura-ejemplo-aux.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-aux.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-cotizacion.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-cotizacion.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-cotizacion.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,25 +24,27 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Escribimos una cotización (cotizacion),
-%%  Escribe la denominación (“COTIZACIÓN”) pero sin número (sinnumero),
-%%  No totaliza, para que el cliente tenga un presupuesto por distintos ítems que luego elegirá entre ellos, es decir, una lista de precios. (sintotales),
-%%  Con el fondo de la imprenta agregado (\FondoFactura),
-%%  Agregando la firma escaneada en la factura, es decir, en la cotización (\FirmaFactura),
-%%  Sin resumen,
-%%  Con descripción larga (\Descripcion).
+%%  (cotizacion) Escribimos una cotización
+%%  (sinnumero) Escribe la denominación (“COTIZACIÓN”) pero sin número
+%%  (sintotales) No totaliza, para que el cliente tenga un presupuesto por distintos ítems que luego elegirá entre ellos, es decir, una lista de precios
+%%  (\FondoFactura) Con el fondo de la imprenta agregado
+%%  (\FirmaFactura) Agregando la firma escaneada en la factura, es decir, en la cotización
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  (\Descripcion) Con descripción larga
 %%</desc>
 %%
 \documentclass[
@@ -49,17 +51,13 @@
 cotizacion,
 sinnumero, % sin esta opción aparecerá el número de la cotización.
 sintotales,
-% dosfirmas, % para poner las dos firmas
-% sinfirmas, % para no poner firmas
+% dosfirmas, % para poner las dos firmas.
+% sinfirmas, % para no poner firmas.
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 
-\FondoFactura{factura-ejemplo-fondo}
-\FirmaFactura{\includegraphics[width=5cm]{factura-ejemplo-firma.pdf}}[0pt][21pt]
-
-% \Denom{PRESUPUESTO} % También podemos cambiar el nombre del documento
-\Fecha{06-11-2017}
 \Num{1}
 \RazonSocial{Ayala San Vicente Usureros}
 \RIF{Y-12.345.678-9}
@@ -67,6 +65,13 @@
 \Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
 \Telefono{+58 (987) 654.32.10}
 \Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\FondoFactura{factura-ejemplo-fondo}
+\FirmaFactura{\includegraphics[width=5cm]{factura-ejemplo-firma.pdf}}[0pt][21pt]
+
+% \Denom{PRESUPUESTO} % También podemos cambiar el nombre del documento.
 \Condiciones{Las condiciones del documento...}
 
 \begin{document}
@@ -77,8 +82,11 @@
  \Item{1}{otro ítem más con IVA general}{1200}
 \end{factura}
 
-\Descripcion{Descripción larga del servicio}
+\Descripcion{La descripción larga}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura01.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura01.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura01.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,79 @@
+%%
+%% This is file `factura-ejemplo-factura01.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factuno')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  Todo con los valores por omisión
+%%  (\Condiciones) Con condiciones del documento
+%%  (\Resumen) Con resumen
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\Condiciones{Las condiciones del documento...}
+\Resumen{El resumen opcional}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general}{1000}
+ \Item{4}{otro ítem con IVA general}{100}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura01.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura01.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura02.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura02.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura02.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,110 @@
+%%
+%% This is file `factura-ejemplo-factura02.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factdos')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  (numitem) Con la columna para enumerar los ítems
+%%  (descuentos) Con la columna para descuentos individuales
+%%  (dcu) Primero la descripción, luego la cantidad, luego el precio unitario
+%%  (sinlineasve) Sin líneas verticales externas
+%%  (centradesc) Centra la descripción en los elementos en la factura
+%%  (unafirma) Sólo la firma del emisor
+%%  Usando \Nombre y \CI en lugar de \RazonSocial y \RIF
+%%  Sin especificar la persona de contacto
+%%  (\SepVertical) Alterando la separación mínima vertical entre los elementos
+%%  (\SepDatosResumen) Alterando la separación horizontal entre los datos del cliente y el resumen
+%%  (\SepEncabezado) Alterando el margen interno desde el contorno hasta el texto en el encabezado
+%%  (\SepItemsExtra) Agregando una separación extra entre los ítems en la factura
+%%  (\SepDescripcion) Alterando la distancia desde el contorno hasta el texto en la descripción
+%%  (\LineaDescripcion) Alterando la línea de la descripción, la curvatura en la esquina y la sombra
+%%  (\Condiciones) Con condiciones del documento
+%%  (\Resumen) Con resumen
+%%  Con artículos gravados con todos los IVA
+%%  (\ItemX) Agregando un ítem sin precio
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+numitem,
+descuentos,
+dcu,
+sinlineasve,
+centradesc,
+unafirma,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\Nombre{Jacinto de Ayala y San Vicente}
+\CI{V-987.654.321}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\SepVertical{0.75cm}
+\SepDatosResumen{1cm}
+\SepEncabezado{16pt}
+\SepItemsExtra{5pt}
+\SepDescripcion{16pt}
+\LineaDescripcion{1pt}{20pt}{3pt}
+
+\Condiciones{Las condiciones del documento...}
+\Resumen{El resumen opcional}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general, con descuento}{1000}{8}
+ \ItemR{1}{ítem con IVA reducido, con descuento}{1000}{5}
+ \ItemA{1}{ítem con IVA adicional, con descuento}{1000}{10}
+ \ItemE{1}{ítem exento de impuesto, con descuento}{1000}
+ \ItemX{1}{línea sin precio}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura02.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura02.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura03.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura03.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura03.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,105 @@
+%%
+%% This is file `factura-ejemplo-factura03.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `facttres')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  (agrupado) Agrupados los totales por tipo y no por gravamen
+%%  (sinlineasvi) Sin líneas verticales internas
+%%  (conlineasha) Separado cada ítem con una línea horizontal
+%%  (expandecuadro) Expande el cuadro de la factura con espacio en blanco
+%%  (linea) Con línea protectora del espacio en blanco
+%%  (impdesc) Con el tipo de impuesto como parte de la descripción y no de los precios
+%%  (sinfirmas) Sin firmas
+%%  (\FormatoFecha) Cambiando el separador de la fecha para que salga escrita dd/mm/yyyy
+%%  (\DescuentoE y \DescuentoG) Con descuentos totales en porcentajes para exentos y gravables con IVA general
+%%  (\SepVertical) Alterando la separación mínima vertical entre los elementos
+%%  (\SepEncabezado) Alterando el margen interno desde el contorno hasta el texto en el encabezado
+%%  (\LineaEncabezado) Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  Con artículos gravados con todos los IVA
+%%  Sin descripción larga
+%%</desc>
+%%
+\documentclass[
+agrupado,
+sinlineasvi,
+conlineasha,
+expandecuadro,
+linea,
+impdesc,
+sinfirmas,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+\FormatoFecha{ddmmyyyy}{/}
+\Fecha{06-11-2017}
+
+\DescuentoE{15}
+\DescuentoG{20}
+\SepVertical{0.75cm}
+\SepEncabezado{16pt}
+\LineaEncabezado{1pt}{20pt}{3pt}
+
+\Condiciones{Las condiciones del documento...}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general}{1000}
+ \ItemR{1}{ítem con IVA reducido}{1000}
+ \ItemA{1}{ítem con IVA adicional}{1000}
+ \ItemE{1}{ítem exento de impuesto}{1000}
+\end{factura}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura03.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura03.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura04.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura04.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura04.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,101 @@
+%%
+%% This is file `factura-ejemplo-factura04.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factcuatro')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  (filas) Totalización en modo de filas
+%%  (duc) Primero la descripción, luego el precio unitario, luego la cantidad
+%%  (sinlineasvi) Sin líneas verticales internas
+%%  (sinlineashi) Sin líneas horizontales internas
+%%  (expandecuadro) Expande el cuadro de la factura con espacio en blanco
+%%  Usando \Nombre y \CI en lugar de \RazonSocial y \RIF
+%%  Sin especificar la persona de contacto
+%%  Sin especificar el e-mail del cliente
+%%  (\Fecha*) Suministrando la fecha según formato de datetime2 sin alterar cómo sale escrita
+%%  (\SepItemsExtra) Agregando una separación extra entre los ítems en la factura
+%%  (\Letra***) Cambiando varias de las tipografías
+%%  Sin condiciones del documento
+%%  Sin resumen
+%%  (\NotaPrevia) Con nota previa
+%%  (\ItemX) Agregando un ítem sin precio
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+filas,
+duc,
+sinlineasvi,
+sinlineashi,
+expandecuadro,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\Nombre{Jacinto de Ayala y San Vicente}
+\CI{V-987.654.321}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+
+\Fecha*{2017}{11}{06}
+
+\SepItemsExtra{5pt}
+\LetraDescripcion{\fontsize{20}{30}}
+\LetraTitEnc{\fontsize{15}{20}\bfseries}
+\LetraFirmas{\fontsize{16}{20}\itshape}
+\LetraCondiciones{\fontsize{18}{28}\bfseries}
+
+\NotaPrevia{\hfill LA NOTA PREVIA}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general}{1000}
+ \Item{4}{otro ítem con IVA general}{100}
+ \ItemX{1}{línea sin precio}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura04.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura04.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura05.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura05.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura05.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,109 @@
+%%
+%% This is file `factura-ejemplo-factura05.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factcinco')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  Escribimos factura y reporte, pero sólo producimos la factura
+%%  (sincantidad) Cuadro de la factura sin la columna de cantidades
+%%  (iva) Con la columna para el IVA
+%%  (filas) Totalización en modo de filas
+%%  (denom) Escribe la denominación (“FACTURA”) y el número
+%%  (conlineasha) Separado cada ítem con una línea horizontal
+%%  (sinexpandir) Sin expandir el cuadro de la factura ni la descripción
+%%  (todosiva) Forzando a totalizar todos los IVA así no existan productos gravados con ellos
+%%  Sin especificar el teléfono del cliente
+%%  (\Emisor) Especificando el nombre del emisor de la factura
+%%  (\Conforme) Especificando el nombre de quien firma la copia de la factura como recibida
+%%  (\FormatoFecha) Suministrando la fecha según el formato yyyymmdd pero que salga escrita dd.mm.yyyy
+%%  (\SepDatosResumen) Alterando la separación horizontal entre los datos del cliente y el resumen
+%%  (\Condiciones) Con condiciones del documento
+%%  (\Resumen) Con resumen
+%%  (\ItemX) Agregando un ítem sin precio
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+sincantidad,
+iva,
+filas,
+denom,
+conlineasha,
+sinexpandir,
+todosiva,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\Num{1}
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Email{jacinto at ayala.sv}
+\Emisor{Lázaro de la Vega}
+\Conforme{\Contacto}
+
+\FormatoFecha[yyyymmdd]{ddmmyyyy}{.}
+\Fecha{20171106}
+
+\SepDatosResumen{1cm}
+\Condiciones{Las condiciones del documento...}
+\Resumen{El resumen opcional}
+
+\begin{document}
+
+\begin{factura}
+ \Item{ítem sin cantidad, con IVA general}{1000}
+ \ItemA{ítem sin cantidad, con IVA adicional}{1000}
+ \ItemX{línea sin precio}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+\begin{reporte}
+ El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
+\end{reporte}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura05.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura05.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura06.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura06.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura06.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,107 @@
+%%
+%% This is file `factura-ejemplo-factura06.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factseis')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  (numitem) Con la columna para enumerar los ítems
+%%  (denom) Escribe la denominación (“FACTURA”) y el número
+%%  (sinlineasve) Sin líneas verticales externas
+%%  (sinlineashe) Sin líneas horizontales externas
+%%  (todosiva) Forzando a totalizar todos los IVA así no existan productos gravados con ellos
+%%  Sin especificar el teléfono del cliente
+%%  Sin especificar el e-mail del cliente
+%%  (\Conforme) Especificando el nombre de quien firma la copia de la factura como recibida
+%%  (\FormatoFecha) Cambiando el formato para que la fecha salga escrita en el formato default de datetime2 pero cambiando el separador yyyy/mm/dd
+%%  (\SepEncabezado) Alterando el margen interno desde el contorno hasta el texto en el encabezado
+%%  (\SepDescripcion) Alterando la distancia desde el contorno hasta el texto en la descripción
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  Escribimos un ítem cuya descripción ocupa más que una línea
+%%  (\Descripcion) Con descripción larga
+%%  Con etiquetas y referencias
+%%</desc>
+%%
+\documentclass[
+numitem,
+denom,
+sinlineasve,
+sinlineashe,
+todosiva,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\Num{1}
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Conforme{Ramela San Vicente}
+
+\FormatoFecha{default}{/}
+\Fecha{06-11-2017}
+
+\SepEncabezado{16pt}
+\SepDescripcion{16pt}
+
+\Condiciones{Las condiciones del documento...}
+
+\begin{document}
+
+\begin{factura}
+ \Item{2}{ítem con IVA general}{1000}\label{primeritem}
+ \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}{1000}
+\end{factura}
+
+\Descripcion{
+
+ En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, dando un subtotal por este elemento de \Moneda\subtref{primeritem}; el descuento en ese artículo es del \dctoref{primeritem}\%, dando un total de \Moneda\ptref{primeritem}, y esta gravado con IVA de \ivaref{primeritem}\%.
+
+ La base imponible total de esta factura es de \Moneda\numprint\BIG; el IVA es de \Moneda\numprint\AlicuotaG, el descuento presidencial en el IVA es de \Moneda\numprint\AlicuotaGDesc, y el total final es de \Moneda\numprint\Total.
+
+ % Estas son todas las macros para las totalizaciones: \BIG, \BIR, \BIA, \BIE, \AlicuotaG, \AlicuotaGDesc, \AlicuotaR, \AlicuotaA, \SubtG, \SubtR, \SubtA, \SubtE, \DescG, \DescR, \DescA, \DescE.
+}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura06.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura06.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura07.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura07.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura07.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,117 @@
+%%
+%% This is file `factura-ejemplo-factura07.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factsiete')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  (descuentos) Con la columna para descuentos individuales
+%%  (subtotal) Con la columna extra para subtotal
+%%  (filas) Totalización en modo de filas
+%%  (centrado) Centrados los totales en el modo de filas
+%%  (denom) Escribe la denominación (“FACTURA”) y el número
+%%  (sinmarcas) Cuando la descripción de un ítem ocupa más que una línea, no pone el carácter que indica continuación en la siguiente línea ni los caracteres en las columnas vacías
+%%  (todosiva) Forzando a totalizar todos los IVA así no existan productos gravados con ellos
+%%  Redefiniendo el texto para la cantidad (redefiniendo macro \@@Cantidad)
+%%  (\GeometriaFactura) Cambiando la geometría del papel de la factura
+%%  (\SepVertical) Alterando la separación mínima vertical entre los elementos
+%%  (\SepFilas) Alterando la separación horizontal y vertical entre los totales en el modo de filas
+%%  (\LineaEncabezado) Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra
+%%  (\LineaDescripcion) Alterando la línea de la descripción, la curvatura en la esquina y la sombra
+%%  (\LineaFirmas) Alterando la longitud de las líneas para firmar y su grosor
+%%  (\PosFecha, \PosFirmas y \PosDenom) Alterando la posición de la fecha, las firmas y de la denominación del documento
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  Escribimos un ítem cuya descripción ocupa más que una línea
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+descuentos,
+subtotal,
+filas,
+centrado,
+denom,
+sinmarcas,
+todosiva,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\Num{1}
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\makeatletter
+ \renewcommand{\@@Cantidad}{Cant.}
+\makeatother
+
+\GeometriaFactura{legalpaper,vmargin={5cm,5.5cm},hmargin={1cm,1cm},footskip=0pt,headsep=0pt,headheight=0pt}
+\SepVertical{0.75cm}
+\SepFilas{1cm}{10pt}
+\LineaEncabezado{1pt}{20pt}{3pt}
+\LineaDescripcion{1pt}{20pt}{3pt}
+\LineaFirmas{6.5cm}{2pt}
+% Puede usarse \PosFecha* o \PosDenom*, \PosControl* o \PosCondiciones* para que el texto se despliegue en la posición 'Y' dada pero hacia arriba y no hacia abajo. \PosFirmas no acepta eso.
+\PosFecha{-0cm}{-1.5cm}
+\PosFirmas{1cm}{1cm}{-3cm}
+\PosDenom{-0cm}{4.3cm}
+
+\Condiciones{Las condiciones del documento...}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general, con descuento}{1000}{8}
+ \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}[otro ítem con IVA general (esta descripción es sólo para el .csv)]{1000}{20}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura07.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura07.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura08.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura08.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura08.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,114 @@
+%%
+%% This is file `factura-ejemplo-factura08.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factocho')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  Escribimos factura y reporte, pero sólo producimos la factura
+%%  (sinexpandir) Sin expandir el cuadro de la factura ni la descripción
+%%  (siniva) Sin IVA
+%%  (csv) Escribe un archivo CSV con la información numérica de la factura
+%%  Sin especificar fecha para que tome la del día
+%%  Redefiniendo el formato de la fecha (redefiniendo macros \@@Fecha y \@EstiloFecha)
+%%  (\Descuento*) Con descuentos totales en moneda aplicables por igual a todos los tipos de elementos existentes
+%%  (\Letra***) Cambiando varias de las tipografías
+%%  (\Condiciones) Con condiciones del documento
+%%  (\Resumen) Con resumen
+%%  (\NotaInterna) Con nota interna
+%%  (\Descripcion) Con descripción larga
+%%  (\FirmaReporte) Agregando la firma escaneada en el reporte
+%%</desc>
+%%
+\documentclass[
+sinexpandir,
+siniva,
+csv,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+% \Fecha{06-11-2017}
+
+\makeatletter
+ \renewcommand{\@@Fecha}{\slshape FECHA:}
+ \renewcommand{\@EstiloFechas}{\@LetraFecha\bfseries\@@Fecha\space{\color{blue}\@Fecha}}
+\makeatother
+
+\Descuento*{300}
+\LetraItems{\fontsize{20}{30}}
+\LetraNumeros{\fontsize{20}{30}}
+\LetraTipoIVA{\fontsize{20}{30}\bfseries}
+\LetraTitTotales{\fontsize{20}{30}\slshape}
+\LetraNumTotales{\fontsize{20}{30}}
+\LetraTitColumnas{\fontsize{15}{20}}
+\LetraTitTotal{\fontsize{20}{30}\bfseries\slshape}
+\LetraNumTotal{\fontsize{20}{30}\bfseries}
+\tabcolsep7pt
+
+\Condiciones{Las condiciones del documento...}
+\Resumen{El resumen opcional}
+\NotaInterna{LA NOTA INTERNA}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general}{1000}
+ \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}[otro ítem con IVA general (esta descripción es sólo para el .csv)]{1000}{20}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+\begin{reporte}
+ El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
+ \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
+\end{reporte}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura08.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura08.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura09.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura09.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura09.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,103 @@
+%%
+%% This is file `factura-ejemplo-factura09.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factnueve')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  Escribimos en el reverso de la factura
+%%  (G) Escribiendo una letra ‘G’ en los ítems gravados con IVA general así sea el único gravamen a facturar
+%%  (electro) Con descuento en IVA al pagar por medios electrónicos
+%%  Sin especificar fecha para que tome la del día
+%%  (\Credito) Especificando la cantidad días para el crédito
+%%  (\SepNotaPrevia) Alterando el margen interno desde el contorno hasta el texto en la nota previa
+%%  (\SepCondiciones) Especificando la distancia desde el contorno hasta el texto de las condiciones, predeterminadamente sin contorno
+%%  (\LineaCondiciones) Agregando el contorno para las condiciones que predeterminadamente está deshabilitado
+%%  (\Condiciones) Con condiciones del documento
+%%  Haciendo mención a las fechas y al crédito en las condiciones
+%%  (\NotaPrevia) Con nota previa
+%%  Con nota interna predeterminada por usar opción ‘electro’
+%%  (\NotaExterna) Con nota externa
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+G,
+electro,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+% \Fecha{06-11-2017}
+\Credito{21}
+
+\SepNotaPrevia{16pt}
+\SepCondiciones{16pt}
+\LineaCondiciones{0.4pt}{4pt}{3pt}
+
+\Condiciones{La factura se emitió el \DTMusedate{FechaEmision} con crédito de \Credito{} dias, siendo su fecha de vencimiento el \DTMusedate{FechaVencimiento}.}
+\NotaPrevia{\hfill LA NOTA PREVIA}
+\NotaExterna{LA NOTA EXTERNA}
+
+\begin{document}
+
+\begin{factura}
+ \Item{1}{ítem con IVA general}{1000}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+\begin{reverso}
+esquina superior izquierda del reverso\hfill esquina superior derecha del reverso\par
+\vfill
+esquina inferior izquierda del reverso\hfill esquina inferior derecha del reverso
+\end{reverso}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura09.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura09.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura1.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura1.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura1.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,71 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura1.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factuno')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Todo con los valores por omisión,
-%%  Con resumen (\Resumen),
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass{factura}
-
-\usepackage[utf8]{inputenc}
-
-\Fecha{06-11-2017}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Condiciones{Las condiciones del documento...}
-\Resumen{El resumen opcional}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general}{1000}
- \Item{4}{otro ítem con IVA general}{100}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura1.tex'.

Added: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura10.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura10.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura10.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -0,0 +1,99 @@
+%%
+%% This is file `factura-ejemplo-factura10.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% factura.dtx  (with options: `factdiez')
+%% 
+%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
+%% 
+%% This work may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3c of this license or (at your option) any later
+%% version. This version of this license is in
+%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
+%% and the latest version of this license is in
+%%  http://www.latex-project.org/lppl.txt
+%% and version 1.3c or later is part of all distributions of
+%% LaTeX version 2008/05/04 or later.
+%% 
+%% This work has the LPPL maintenance status `maintained'.
+%% 
+%% The Current Maintainer of this work is Emilio Lazo Zaia.
+%% 
+%% This work consists of the files README and factura.dtx
+%% with its derived files factura.ins, factura.cls, factura.def,
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
+%% 
+%% Descripción de este ejemplo:
+%%<desc>
+%%  Escribimos una factura
+%%  Escribimos en el reverso de la factura
+%%  (sinlineasv) Sin lineas verticales
+%%  (sinlineash) Sin lineas horizontales
+%%  (electro) Con descuento en IVA al pagar por medios electrónicos
+%%  (vencimiento) Con fecha de vencimiento explícita así no haya crédito
+%%  (\GeometriaReverso) Cambiando la geometría del reverso de la factura
+%%  (\LineaNotaPrevia) Alterando la línea de la nota previa, para desaparecerla
+%%  (\Condiciones) Con condiciones del documento
+%%  (\NotaPrevia) Con nota previa
+%%  Con nota interna predeterminada por usar opción ‘electro’
+%%  (\Descripcion) Con descripción larga
+%%</desc>
+%%
+\documentclass[
+sinlineasv,
+sinlineash,
+electro,
+vencimiento,
+]{factura}
+
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
+\usepackage[utf8]{inputenc}
+
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\GeometriaReverso{vmargin={4cm,4cm},hmargin={4cm,4cm},footskip=0pt,headsep=0pt,headheight=0pt}
+\LineaNotaPrevia{0pt}
+
+\Condiciones{Las condiciones del documento...}
+\NotaPrevia{\hfill LA NOTA PREVIA}
+
+\begin{document}
+
+\begin{factura}
+  \Item{1}{ítem con IVA general}{2000000}
+\end{factura}
+
+\Descripcion{La descripción larga}
+
+\begin{reverso}
+esquina superior izquierda del reverso\hfill esquina superior derecha del reverso\par
+\vfill
+esquina inferior izquierda del reverso\hfill esquina inferior derecha del reverso
+\end{reverso}
+
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
+\end{document}
+%% 
+%%
+%% End of file `factura-ejemplo-factura10.tex'.


Property changes on: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura10.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura2.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura2.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura2.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,100 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura2.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factdos')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Con la columna para enumerar los ítems (numitem),
-%%  Con descuentos individuales (descuentos),
-%%  Primero la descripción, luego la cantidad, luego el precio unitario (dcu),
-%%  Sin líneas verticales externas (sinlineasve),
-%%  Centra la descripción en los elementos en la factura (centradesc),
-%%  Sólo la firma del emisor (unafirma),
-%%  Alterando la separación mínima vertical entre los elementos (\SepElementos),
-%%  Alterando la separación horizontal en el encabezado y la distancia desde el contorno hasta el texto (\SepEncabez),
-%%  Agregando una separación extra entre los ítems en la factura (\SepItemsExtra),
-%%  Alterando la la distancia desde el contorno hasta el texto en la descripción (\SepDescrip),
-%%  Alterando la línea de la descripción, la curvatura en la esquina y la sombra (\LineaDescrip),
-%%  Usando “\Nombre” y “\CI” en lugar de “\RazonSocial” y “\RIF”,
-%%  Con resumen (\Resumen),
-%%  Agregando un ítem sin precio (\ItemX),
-%%  Con artículos gravados con todos los IVA,
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-numitem,
-descuentos,
-dcu,
-sinlineasve,
-% sinlineasv, % sin ninguna línea vertical
-centradesc,
-unafirma,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\SepElementos{0.75cm}
-\SepEncabez{1cm}{16pt}
-\SepItemsExtra{8pt}
-\SepDescrip{16pt}
-\LineaDescrip{1pt}{20pt}{3pt}
-
-\Fecha{06-11-2017}
-\Nombre{Jacinto de Ayala y San Vicente}
-\CI{V-987.654.321}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Condiciones{Las condiciones del documento...}
-\Resumen{El resumen opcional}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general, con descuento}{1000}{8}
- \ItemR{1}{ítem con IVA reducido, con descuento}{1000}{5}
- \ItemA{1}{ítem con IVA adicional, con descuento}{1000}{10}
- \ItemE{1}{ítem exento de impuesto, con descuento}{1000}
- \ItemX{1}{línea sin precio}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura2.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura3.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura3.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura3.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,96 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura3.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `facttres')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Agrupados los totales por gravámenes (agrupado),
-%%  Sin líneas verticales internas (sinlineasvi),
-%%  Separado cada ítem con una línea horizontal (conlineasha),
-%%  Expande el cuadro de la factura con espacio en blanco (exparriba),
-%%  Con línea protectora del espacio en blanco (linea),
-%%  Con el tipo de impuesto como parte de la descripción y no de los precios (impdesc),
-%%  Sin firmas (sinfirmas),
-%%  Alterando la separación mínima vertical entre los elementos (\SepElementos),
-%%  Alterando la separación horizontal en el encabezado y la distancia desde el contorno hasta el texto (\SepEncabez),
-%%  Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra (\LineaEncabez),
-%%  Con descuentos totales en porcentajes para exentos y gravables con IVA general (\DescuentoE y \DescuentoG),
-%%  Sin resumen,
-%%  Con artículos gravados con todos los IVA,
-%%  Sin descripción larga.
-%%</desc>
-%%
-\documentclass[
-agrupado,
-sinlineasvi,
-% sinlineasv, % sin ninguna línea vertical
-conlineasha,
-exparriba,
-linea,
-impdesc,
-sinfirmas,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\SepElementos{0.75cm}
-\SepEncabez{1cm}{16pt}
-\LineaEncabez{1pt}{20pt}{3pt}
-
-\Fecha{06-11-2017}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Condiciones{Las condiciones del documento...}
-\DescuentoE{15}
-\DescuentoG{20}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general}{1000}
- \ItemR{1}{ítem con IVA reducido}{1000}
- \ItemA{1}{ítem con IVA adicional}{1000}
- \ItemE{1}{ítem exento de impuesto}{1000}
-\end{factura}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura3.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura4.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura4.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura4.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,96 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura4.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factcuatro')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Totalización en modo de filas (filas),
-%%  Centrados los totales en el modo de filas (centrado),
-%%  Primero la descripción, luego el precio unitario, luego la cantidad (duc),
-%%  Sin líneas verticales internas (sinlineasvi),
-%%  Sin líneas horizontales internas (sinlineashi),
-%%  Expande el cuadro de la factura con espacio en blanco (exparriba),
-%%  Sin condiciones del documento (sincondiciones),
-%%  Agregando una separación extra entre los ítems en la factura (\SepItemsExtra),
-%%  Cambiando varias de las tipografías (\Letra***),
-%%  Usando “\Nombre” y “\CI” en lugar de “\RazonSocial” y “\RIF”,
-%%  Sin especificar la persona de contacto,
-%%  Sin especificar el e-mail del cliente,
-%%  Sin resumen,
-%%  Agregando un ítem sin precio (\ItemX),
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-filas,
-centrado,
-duc,
-sinlineasvi,
-% sinlineasv, % sin ninguna línea vertical
-sinlineashi,
-% sinlineash, % sin ninguna línea horizontal
-exparriba,
-sincondiciones,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\SepItemsExtra{8pt}
-\LetraDescripcion{\fontsize{20}{30}}
-\LetraTitEnc{\fontsize{15}{20}\bfseries}
-\LetraFirmas{\fontsize{16}{20}\itshape}
-\LetraCondiciones{\fontsize{18}{28}\bfseries}
-
-\Fecha{06-11-2017}
-\Nombre{Jacinto de Ayala y San Vicente}
-\CI{V-987.654.321}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general}{1000}
- \Item{4}{otro ítem con IVA general}{100}
- \ItemX{1}{línea sin precio}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura4.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura5.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura5.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura5.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,96 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura5.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factcinco')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Escribimos factura y reporte, pero sólo producimos la factura,
-%%  Cuadro de la factura sin la columna de cantidades (sincantidad),
-%%  Totalización en modo de filas (filas),
-%%  Escribe la denominación (“FACTURA”) y el número (denom),
-%%  Separado cada ítem con una línea horizontal (conlineasha),
-%%  Sin expandir el cuadro de la factura ni la descripción (sinexpandir),
-%%  Obligando a especificar todos los IVA así no existan productos gravados con ellos (todosiva),
-%%  Especificando el nombre del emisor de la factura (\Emisor),
-%%  Especificando el nombre de quien firma la copia de la factura como recibida (\Conforme),
-%%  Con resumen (\Resumen),
-%%  Agregando un ítem sin precio (\ItemX),
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-sincantidad,
-filas,
-denom,
-conlineasha,
-sinexpandir,
-todosiva,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\Fecha{06-11-2017}
-\Num{1}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Emisor{Lázaro de la Vega}
-\Conforme{\mostrar{@Contacto}}
-\Condiciones{Las condiciones del documento...}
-\Resumen{El resumen opcional}
-
-\begin{document}
-
-\begin{factura}
- \Item{ítem sin cantidad, con IVA general}{1000}
- \ItemA{ítem sin cantidad, con IVA adicional}{1000}
- \ItemX{línea sin precio}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\begin{reporte}
- El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
- \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
-\end{reporte}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura5.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura6.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura6.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura6.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,100 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura6.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factseis')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Con la columna para enumerar los ítems (numitem),
-%%  Escribe la denominación (“FACTURA”) y el número (denom),
-%%  Sin líneas verticales externas (sinlineasve),
-%%  Sin líneas horizontales externas (sinlineashe),
-%%  Escribimos un ítem cuya descripción ocupa más que una línea,
-%%  Obligando a especificar todos los IVA así no existan productos gravados con ellos (todosiva),
-%%  Especificando 'G' en los ítems gravados con IVA general (G),
-%%  Escribe un archivo CSV con la información numérica de la factura (csv),
-%%  Redefiniendo el formato de la fecha (redefiniendo macros \@@Fecha y \@EstiloFecha),
-%%  Especificando el nombre de quien firma la copia de la factura como recibida (\Conforme),
-%%  Con etiquetas y referencias,
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-numitem,
-denom,
-sinlineasve,
-% sinlineasv, % sin ninguna línea vertical
-sinlineashe,
-% sinlineash, % sin ninguna línea horizontal
-todosiva,
-G,
-csv,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\makeatletter
- \renewcommand{\@@Fecha}{\slshape FECHA:}
- \renewcommand{\@EstiloFecha}{\@LetraFecha\bfseries\@@Fecha\space{\color{blue}\@Fecha}}
-\makeatother
-
-\Fecha{06-11-2017}
-\Num{1}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Conforme{Ramela San Vicente}
-\Condiciones{Las condiciones del documento...}
-
-\begin{document}
-
-\begin{factura}
- \Item{2}{ítem con IVA general}{1000}\label{primeritem}
- \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}{1000}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio.
-
- En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, el descuento porcentual de ese artículo es \dctoref{primeritem}, dando un total de \Moneda\ptref{primeritem}. El IVA de este ítem es de \Moneda\numprint\AlicuotaG; luego se facturó otro artículo más, dando un total final de \Moneda\numprint\Total.
- % También podemos usar \dctoref{primeritem} para la referencia al descuento, y en cuanto a las totalizaciones: \BIE, \BIR, \BIA, \AlicuotaR, \AlicuotaA, \SubtG, \SubtE, \SubtR, \SubtA, \DescG, \DescE, \DescR, \DescA para los demás totales.
-}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura6.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura7.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura7.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura7.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,106 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura7.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factsiete')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Con descuentos individuales (descuentos),
-%%  Con columna extra para subtotal (subtotal),
-%%  Totalización en modo de filas (filas),
-%%  Escribimos un ítem cuya descripción ocupa más que una línea,
-%%  Cuando la descripción de un ítem ocupa más que una línea, no pone el carácter que indica continuación en la siguiente línea ni los caracteres en las columnas vacías (sinmarcas),
-%%  Obligando a especificar todos los IVA así no existan productos gravados con ellos (todosiva),
-%%  Cambiando la geometría del papel de la factura (\GeometriaFactura),
-%%  Alterando la separación mínima vertical entre los elementos (\SepElementos),
-%%  Alterando la separación horizontal en el encabezado y la distancia desde el contorno hasta el texto (\SepEncabez),
-%%  Alterando la la distancia desde el contorno hasta el texto en la descripción (\SepDescrip),
-%%  Alterando la separación horizontal y vertical entre los totales en el modo de filas (\SepFilas),
-%%  Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra (\LineaEncabez),
-%%  Alterando la línea de la descripción, la curvatura en la esquina y la sombra (\LineaDescrip),
-%%  Alterando la longitud de las líneas para firmar y su grosor (\LineaFirmas),
-%%  Alterando la posición de la fecha, las firmas y de la denominación del documento (\PosFecha, \PosFirmas y \PosDenom),
-%%  Redefiniendo el texto para la cantidad (redefiniendo macro \@@Cantidad),
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-descuentos,
-subtotal,
-filas,
-sinmarcas,
-todosiva,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\GeometriaFactura{legalpaper,vmargin={5cm,5.5cm},hmargin={1cm,1cm},footskip=0pt,headsep=0pt,headheight=0pt}
-\SepElementos{0.75cm}
-\SepEncabez{1cm}{16pt}
-\SepDescrip{16pt}
-\SepFilas{1cm}{10pt}
-\LineaEncabez{1pt}{20pt}{3pt}
-\LineaDescrip{1pt}{20pt}{3pt}
-\LineaFirmas{6.5cm}{2pt}
-\PosFecha{-0cm}{-1.5cm}
-\PosFirmas{1cm}{1cm}{-3cm}
-\PosDenom{-0cm}{4.3cm}
-
-\makeatletter
- \renewcommand{\@@Cantidad}{Cant.}
-\makeatother
-
-\Fecha{06-11-2017}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Condiciones{Las condiciones del documento...}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general, con descuento}{1000}{8}
- \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}{1000}{20}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura7.tex'.

Deleted: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura8.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura8.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-factura8.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -1,93 +0,0 @@
-%%
-%% This is file `factura-ejemplo-factura8.tex',
-%% generated with the docstrip utility.
-%%
-%% The original source files were:
-%%
-%% factura.dtx  (with options: `factocho')
-%% 
-%% Copyright 2017 Emilio Lazo Zaia <emiliolazozaia at gmail.com>
-%% 
-%% This work may be distributed and/or modified under the
-%% conditions of the LaTeX Project Public License, either
-%% version 1.3c of this license or (at your option) any later
-%% version. This version of this license is in
-%%  http://www.latex-project.org/lppl/lppl-1-3c.{html|txt|tex|pdf}
-%% and the latest version of this license is in
-%%  http://www.latex-project.org/lppl.txt
-%% and version 1.3c or later is part of all distributions of
-%% LaTeX version 2008/05/04 or later.
-%% 
-%% This work has the LPPL maintenance status `maintained'.
-%% 
-%% The Current Maintainer of this work is Emilio Lazo Zaia.
-%% 
-%% This work consists of the files README and factura.dtx
-%% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
-%% 
-%% Descripción de este ejemplo:
-%%<desc>
-%%  Escribimos una factura,
-%%  Escribimos factura y reporte, pero sólo producimos la factura,
-%%  Sin expandir el cuadro de la factura ni la descripción (sinexpandir),
-%%  Sin IVA (siniva),
-%%  Cambiando varias de las tipografías (\Letra***),
-%%  Con descuentos totales en moneda aplicables por igual a todos los tipos de elementos existentes (\Descuento***),
-%%  Con resumen (\Resumen),
-%%  Con descripción larga (\Descripcion).
-%%</desc>
-%%
-\documentclass[
-sinexpandir,
-siniva,
-]{factura}
-
-\usepackage[utf8]{inputenc}
-
-\LetraItems{\fontsize{20}{30}}
-\LetraNumeros{\fontsize{20}{30}}
-\LetraTipoIVA{\fontsize{20}{30}\bfseries}
-\LetraTitTotales{\fontsize{20}{30}\slshape}
-\LetraNumTotales{\fontsize{20}{30}}
-\LetraTitCuadro{\fontsize{15}{20}}
-\LetraTitTotal{\fontsize{20}{30}\bfseries\slshape}
-\LetraNumTotal{\fontsize{20}{30}\bfseries}
-\tabcolsep7pt
-
-\Fecha{06-11-2017}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Condiciones{Las condiciones del documento...}
-\Descuento*{300}
-\Resumen{El resumen opcional}
-
-\begin{document}
-
-\begin{factura}
- \Item{1}{ítem con IVA general}{1000}
-\end{factura}
-
-\Descripcion{Descripción larga del servicio}
-
-\begin{reporte}
- El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
- \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
-\end{reporte}
-
-\end{document}
-%% 
-%%
-%% End of file `factura-ejemplo-factura8.tex'.

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-firma.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-firma.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-firma.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,15 +24,16 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% (PSTricks code generated with LaTeXDraw 2.0.8)
 %% (Compilar con XeLaTeX)

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-fondo.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-fondo.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-fondo.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,15 +24,16 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 \documentclass[12pt]{article}
 \usepackage[utf8]{inputenc}

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-membrete.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-membrete.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-membrete.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,15 +24,16 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 \documentclass[12pt]{article}
 \usepackage[utf8]{inputenc}

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.pdf
===================================================================
(Binary files differ)

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-prefactura.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,41 +24,43 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Escribimos una prefactura (prefactura),
-%%  Expande el cuadro de la factura con espacio en blanco (exparriba),
-%%  Con línea protectora del espacio en blanco (linea),
-%%  Con el fondo de la imprenta agregado (\FondoFactura),
-%%  Con descuentos totales en porcentaje aplicables por igual a todos los tipos de elementos existentes (\Descuento),
-%%  Sin resumen,
-%%  Con descripción larga (\Descripcion).
+%%  (prefactura) Escribimos una prefactura
+%%  (expandecuadro) Expande el cuadro de la factura con espacio en blanco
+%%  (linea) Con línea protectora del espacio en blanco
+%%  (\Descuento) Con descuentos totales en porcentaje aplicables por igual a todos los tipos de elementos existentes
+%%  (\FondoFactura) Con el fondo de la imprenta agregado
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  (\Descripcion) Con descripción larga
 %%</desc>
 %%
 \documentclass[
 prefactura,
-exparriba,
+expandecuadro,
 linea,
-% dosfirmas, % para poner las dos firmas
-% unafirma, % para poner la firma del emisor
+% dosfirmas, % para poner las dos firmas.
+% unafirma, % para poner la firma del emisor.
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 
-\FondoFactura{factura-ejemplo-fondo}
-
-\Fecha{06-11-2017}
 \Num{1}
+% \NumControl{1001}
+% \NumSerieControl{9}
 \RazonSocial{Ayala San Vicente Usureros}
 \RIF{Y-12.345.678-9}
 \Contacto{Jacinto de Ayala}
@@ -65,8 +67,12 @@
 \Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
 \Telefono{+58 (987) 654.32.10}
 \Email{jacinto at ayala.sv}
+
+\Fecha{06-11-2017}
+
+\Descuento{18}
+\FondoFactura{factura-ejemplo-fondo}
 \Condiciones{Las condiciones del documento...}
-\Descuento{18}
 
 \begin{document}
 
@@ -75,8 +81,11 @@
  \ItemR{1}{ítem con IVA reducido}{1000}
 \end{factura}
 
-\Descripcion{Descripción larga del servicio}
+\Descripcion{La descripción larga}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte1.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte1.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte1.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,36 +24,54 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Escribimos una factura,
-%%  Escribimos un reporte,
-%%  Generamos factura y reporte (conreporte),
-%%  Especificamos el fondo (membrete) del reporte, sólo para la primera página (\FondoReporte),
-%%  Estableciendo un margen superior distinto para la primera página del reporte por presencia de membrete (\InicioReporte),
-%%  Establecemos el título del reporte sin que salga en las cabeceras (\TituloReporte),
-%%  Especificando el nombre del emisor de la factura (\Emisor),
-%%  Sin especificar el proveedor, así toma el emisor de la factura como el nombre del proveedor,
-%%  Sin resumen,
-%%  Con descripción larga (\Descripcion).
+%%  Escribimos una factura
+%%  Escribimos en el reverso de la factura
+%%  Escribimos un reporte
+%%  (sinreverso) Escribimos el reverso de la factura pero sólo producimos su anverso
+%%  (conreporte) Generamos factura y reporte
+%%  (\Emisor) Especificando el nombre del emisor de la factura
+%%  Sin especificar el proveedor, así toma el emisor de la factura como el nombre del proveedor
+%%  (\FondoReporte) Especificamos el fondo o membrete del reporte, sólo para la primera página
+%%  (\InicioReporte) Estableciendo un margen superior distinto para la primera página del reporte por presencia de membrete
+%%  (\TituloReporte) Establecemos el título del reporte sin que salga en las cabeceras
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  (\Descripcion) Con descripción larga
+%%  (\FirmaReporte) Agregando en el reporte la línea para firmar a mano
 %%</desc>
 %%
 \documentclass[
+sinreverso,
 conreporte,
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 
+\Num{1}
+\RazonSocial{Ayala San Vicente Usureros}
+\RIF{Y-12.345.678-9}
+\Contacto{Jacinto de Ayala}
+\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+\Telefono{+58 (987) 654.32.10}
+\Email{jacinto at ayala.sv}
+\Emisor{Lázaro de la Vega}
+
+\Fecha{06-11-2017}
+
 \FondoReporte{factura-ejemplo-membrete}
 \InicioReporte{2.2cm}
 \TituloReporte{El título del reporte}
@@ -67,15 +85,6 @@
 % \EstiloPagReporte[empty]{soloarriba}
 % \EstiloPagReporte{soloarriba}
 
-\Fecha{06-11-2017}
-\Num{1}
-\RazonSocial{Ayala San Vicente Usureros}
-\RIF{Y-12.345.678-9}
-\Contacto{Jacinto de Ayala}
-\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-\Telefono{+58 (987) 654.32.10}
-\Email{jacinto at ayala.sv}
-\Emisor{Lázaro de la Vega}
 \Condiciones{Las condiciones del documento...}
 
 \begin{document}
@@ -84,12 +93,22 @@
  \Item{1}{ítem con IVA general}{1000}
 \end{factura}
 
-\Descripcion{Descripción larga del servicio}
+\Descripcion{La descripción larga}
 
+\begin{reverso}
+esquina superior izquierda del reverso\hfill esquina superior derecha del reverso\par
+\vfill
+esquina inferior izquierda del reverso\hfill esquina inferior derecha del reverso
+\end{reverso}
+
 \begin{reporte}
  El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
+ \vspace{1.5cm}\FirmaReporte
 \end{reporte}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte2.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte2.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte2.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,28 +24,31 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Escribimos una factura,
-%%  Escribimos un reporte,
-%%  Escribimos factura y reporte, pero sólo producimos el reporte (soloreporte),
-%%  Cambiando la geometría del papel del reporte (\GeometriaReporte),
-%%  Especificamos el fondo (membrete) del reporte para todas las páginas (\FondoReporte*),
-%%  Establecemos el título del reporte para que salga en las cabeceras (\TituloReporte*),
-%%  Agregando la firma escaneada en el reporte (\FirmaReporte),
-%%  Sin resumen,
-%%  Con etiquetas y referencias,
-%%  Con descripción larga (\Descripcion).
+%%  Escribimos una factura
+%%  Escribimos un reporte
+%%  (soloreporte) Escribimos factura y reporte, pero sólo producimos el reporte
+%%  (\Proveedor) Especificando el nombre del proveedor para el encabezado del reporte
+%%  (\GeometriaReporte) Cambiando la geometría del papel del reporte
+%%  (\FondoReporte*) Especificamos el fondo o membrete del reporte para todas las páginas
+%%  (\TituloReporte*) Establecemos el título del reporte para que salga en las cabeceras
+%%  (\Condiciones) Con condiciones del documento
+%%  Sin resumen
+%%  (\Descripcion) Con descripción larga
+%%  Con etiquetas y referencias
+%%  (\FirmaReporte) Agregando la firma escaneada en el reporte
 %%</desc>
 %%
 \documentclass[
@@ -52,16 +55,9 @@
 soloreporte,
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 
-\GeometriaReporte{letterpaper,vmargin={4.4cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
-\FondoReporte*{factura-ejemplo-membrete}
-\TituloReporte*{El título del reporte}
-% \EstiloPagReporte[empty]{soloabajo}
-% \EstiloPagReporte{solonumpag}
-% \EstiloPagReporte{soloabajo}
-
-\Fecha{06-11-2017}
 \Num{1}
 \RazonSocial{Ayala San Vicente Usureros}
 \RIF{Y-12.345.678-9}
@@ -70,6 +66,16 @@
 \Telefono{+58 (987) 654.32.10}
 \Email{jacinto at ayala.sv}
 \Proveedor{Lázaro de la Vega y San Román}
+
+\Fecha{06-11-2017}
+
+\GeometriaReporte{vmargin={4.4cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
+\FondoReporte*{factura-ejemplo-membrete}
+\TituloReporte*{El título del reporte}
+% \EstiloPagReporte[empty]{soloabajo}
+% \EstiloPagReporte{solonumpag}
+% \EstiloPagReporte{soloabajo}
+
 \Condiciones{Las condiciones del documento...}
 
 \begin{document}
@@ -79,15 +85,22 @@
  \Item{4}{otro ítem con IVA general}{100}
 \end{factura}
 
-\Descripcion{Descripción larga del servicio}
+\Descripcion{La descripción larga}
 
 \begin{reporte}
  El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
 
- En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, el descuento porcentual de ese artículo es \dctoref{primeritem}, dando un total de \Moneda\ptref{primeritem}. El IVA de este ítem es de \Moneda\numprint\AlicuotaG; luego se facturó otro artículo más, dando un total final de \Moneda\numprint\Total.
- % También podemos usar \dctoref{primeritem} para la referencia al descuento, y en cuanto a las totalizaciones: \BIE, \BIR, \BIA, \AlicuotaR, \AlicuotaA, \SubtG, \SubtE, \SubtR, \SubtA, \DescG, \DescE, \DescR, \DescA para los demás totales.
+ En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, dando un subtotal por este elemento de \Moneda\subtref{primeritem}; el descuento en ese artículo es del \dctoref{primeritem}\%, dando un total de \Moneda\ptref{primeritem}, y esta gravado con IVA de \ivaref{primeritem}\%.
+
+ La base imponible total de esta factura es de \Moneda\numprint\BIG; el IVA es de \Moneda\numprint\AlicuotaG, el descuento presidencial en el IVA es de \Moneda\numprint\AlicuotaGDesc, y el total final es de \Moneda\numprint\Total.
+
+ % Estas son todas las macros para las totalizaciones: \BIG, \BIR, \BIA, \BIE, \AlicuotaG, \AlicuotaGDesc, \AlicuotaR, \AlicuotaA, \SubtG, \SubtR, \SubtA, \SubtE, \DescG, \DescR, \DescA, \DescE.
+ \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
 \end{reporte}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte3.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte3.tex	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/doc/latex/factura/factura-ejemplo-reporte3.tex	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,27 +24,31 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 %% Descripción de este ejemplo:
 %%<desc>
-%%  Escribimos un reporte,
-%%  Generamos solamente un reporte (soloreporte),
-%%  El reporte se imprime en las dos caras del papel (twoside),
-%%  Sin especificar fondo de reporte,
-%%  Establecemos el título del reporte sin que salga en las cabeceras (\TituloReporte),
-%%  Personalizamos la información de la cabecera del reporte y mostramos el nombre del proveedor allí (\InfoPagina),
-%%  Cambiamos el estilo de página para que la información del reporte aparezca como pie de página (\EstiloPagReporte),
-%%  Agregando en el reporte la línea para firmar a mano (\FirmaReporte),
-%%  Sin descripción larga.
+%%  No escribimos factura ni usamos las macros que definen valores para su uso
+%%  Escribimos un reporte
+%%  (soloreporte) Generamos solamente un reporte
+%%  (twoside) El reporte se imprime en las dos caras del papel
+%%  Sin especificar la persona de contacto
+%%  (\Proveedor) Especificando el nombre del proveedor para el encabezado del reporte
+%%  Sin especificar fondo de reporte
+%%  (\TituloReporte) Establecemos el título del reporte sin que salga en las cabeceras
+%%  (\InfoPagina) Personalizamos la información de la cabecera del reporte y mostramos el nombre del proveedor allí
+%%  (\EstiloPagReporte) Cambiamos el estilo de página para que la información del reporte aparezca como pie de página
+%%  Sin descripción larga
+%%  (\FirmaReporte) Agregando la firma escaneada en el reporte
 %%</desc>
 %%
 \documentclass[
@@ -52,10 +56,16 @@
 twoside,
 ]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 
+\RazonSocial{Ayala San Vicente Usureros}
+\Proveedor{Lázaro de la Vega y San Román}
+
+\Fecha{06-11-2017}
+
 \TituloReporte{El título del reporte}
-\InfoPagina{La cabecera o pie del reporte - \mostrar{@Proveedor}}
+\InfoPagina{La cabecera o pie del reporte - \Proveedor}
 % \EstiloPagReporte{soloabajo}
 % \EstiloPagReporte[soloabajo]{plain}
 % \EstiloPagReporte[empty]{plain}
@@ -68,17 +78,16 @@
 % \EstiloPagReporte[empty]{soloarriba}
 % \EstiloPagReporte{soloarriba}
 
-\Fecha{06-11-2017}
-\RazonSocial{Ayala San Vicente Usureros}
-\Proveedor{Lázaro de la Vega y San Román}
-
 \begin{document}
 
 \begin{reporte}
  El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
- \vspace{1.5cm}\FirmaReporte
+ \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]{el que firma}[5cm][0.5cm]
 \end{reporte}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
 %% 
 %%

Modified: trunk/Master/texmf-dist/doc/latex/factura/factura.pdf
===================================================================
(Binary files differ)

Modified: trunk/Master/texmf-dist/source/latex/factura/factura.dtx
===================================================================
--- trunk/Master/texmf-dist/source/latex/factura/factura.dtx	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/source/latex/factura/factura.dtx	2017-12-12 22:35:59 UTC (rev 46053)
@@ -19,15 +19,16 @@
 %
 % This work consists of the files README and factura.dtx
 % with its derived files factura.ins, factura.cls, factura.def,
-% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-% and factura-beispiel-rechnung.tex.
+% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %<*internalbatchfile>
 \def\nameofplainTeX{plain}
 \ifx\fmtname\nameofplainTeX
@@ -57,15 +58,16 @@
 
 This work consists of the files README and factura.dtx
 with its derived files factura.ins, factura.cls, factura.def,
-factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-and factura-beispiel-rechnung.tex.
+factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 
 \endpreamble
 \keepsilent
@@ -86,14 +88,16 @@
 \Msg{\jobname.ins written.}
 %</internalbatchfile>
 %<*batchfile>
-\def\factuno{factura-ejemplo-factura1.tex}
-\def\factdos{factura-ejemplo-factura2.tex}
-\def\facttres{factura-ejemplo-factura3.tex}
-\def\factcuatro{factura-ejemplo-factura4.tex}
-\def\factcinco{factura-ejemplo-factura5.tex}
-\def\factseis{factura-ejemplo-factura6.tex}
-\def\factsiete{factura-ejemplo-factura7.tex}
-\def\factocho{factura-ejemplo-factura8.tex}
+\def\factuno{factura-ejemplo-factura01.tex}
+\def\factdos{factura-ejemplo-factura02.tex}
+\def\facttres{factura-ejemplo-factura03.tex}
+\def\factcuatro{factura-ejemplo-factura04.tex}
+\def\factcinco{factura-ejemplo-factura05.tex}
+\def\factseis{factura-ejemplo-factura06.tex}
+\def\factsiete{factura-ejemplo-factura07.tex}
+\def\factocho{factura-ejemplo-factura08.tex}
+\def\factnueve{factura-ejemplo-factura09.tex}
+\def\factdiez{factura-ejemplo-factura10.tex}
 \def\repuno{factura-ejemplo-reporte1.tex}
 \def\repdos{factura-ejemplo-reporte2.tex}
 \def\reptres{factura-ejemplo-reporte3.tex}
@@ -100,6 +104,7 @@
 \def\cotiza{factura-ejemplo-cotizacion.tex}
 \def\prefac{factura-ejemplo-prefactura.tex}
 \def\beispiel{factura-beispiel-rechnung.tex}
+\def\auxejemplo{factura-ejemplo-aux.tex}
 \def\firma{factura-ejemplo-firma.tex}
 \def\fondo{factura-ejemplo-fondo.tex}
 \def\membrete{factura-ejemplo-membrete.tex}
@@ -111,6 +116,8 @@
 \generate{\file{\factseis}{\from{\jobname.dtx}{factseis}}}
 \generate{\file{\factsiete}{\from{\jobname.dtx}{factsiete}}}
 \generate{\file{\factocho}{\from{\jobname.dtx}{factocho}}}
+\generate{\file{\factnueve}{\from{\jobname.dtx}{factnueve}}}
+\generate{\file{\factdiez}{\from{\jobname.dtx}{factdiez}}}
 \generate{\file{\repuno}{\from{\jobname.dtx}{repuno}}}
 \generate{\file{\repdos}{\from{\jobname.dtx}{repdos}}}
 \generate{\file{\reptres}{\from{\jobname.dtx}{reptres}}}
@@ -117,6 +124,7 @@
 \generate{\file{\cotiza}{\from{\jobname.dtx}{cotiza}}}
 \generate{\file{\prefac}{\from{\jobname.dtx}{prefac}}}
 \generate{\file{\beispiel}{\from{\jobname.dtx}{beispiel}}}
+\generate{\file{\auxejemplo}{\from{\jobname.dtx}{aux}}}
 \generate{\file{\firma}{\from{\jobname.dtx}{firma}}}
 \generate{\file{\fondo}{\from{\jobname.dtx}{fondo}}}
 \generate{\file{\membrete}{\from{\jobname.dtx}{membrete}}}
@@ -137,6 +145,7 @@
 \Msg{  xelatex factura-ejemplo-firma.tex}
 \Msg{}
 \Msg{Also compile all other examples and recompile \jobname.dtx.}
+\Msg{(factura-ejemplo-aux.tex is not an example!)}
 \Msg{}
 \Msg{To manual update index and changelog, type}
 \Msg{  makeindex -s gind.ist -o \jobname.ind \jobname.idx}
@@ -164,10 +173,10 @@
 %<class>\ProvidesClass{factura}
 %<def>\ProvidesFile{factura.def}
 %<*class|def>
-[2017/07/16 v3.02
+[2017/12/11 v3.40
 %<class>Clase para elaborar facturas legales
 %<class>en la República Bolivariana de Venezuela.
-%<def>Archivo valores iniciales y condiciones de borde para factura.cls
+%<def>Archivo de valores iniciales y condiciones de borde para factura.cls
 ]
 
 %</class|def>
@@ -200,11 +209,14 @@
 
 % Necesario ejecutar \newif de esta forma:
 \csname newif\expandafter\endcsname\csname ifmotorunicode\endcsname
+\csname newif\expandafter\endcsname\csname ifejemplos\endcsname
 
-\ifxetex \motorunicodetrue
+\ejemplostrue
+
+\ifxetex
+ \motorunicodetrue
 \else
- \ifluatex \motorunicodetrue
- \fi
+ \ifluatex \motorunicodetrue \fi
 \fi
 
 \ifmotorunicode
@@ -244,92 +256,73 @@
 
 \widowpenalty10000
 
-\newbool{ejemploizq}
-\newbool{ejemploder}
-\newbool{ejemplocondesc}
+\newbool{Ejemplo}
+\newbool{EjemploIzq}
+\newbool{EjemploDer}
+\newbool{DescripEjemplo}
 
-\newcommand{\ListaDeEjemplos}{
- ejemplo-cotizacion,
- ejemplo-prefactura,
- ejemplo-factura1,
- ejemplo-factura2,
- ejemplo-factura3,
- ejemplo-factura4,
- ejemplo-factura5,
- ejemplo-factura6,
- ejemplo-factura7,
- ejemplo-factura8,
- ejemplo-reporte1,
- ejemplo-reporte2,
- ejemplo-reporte3,
- beispiel-rechnung}
+\def\optcolor{\color{blue}}
+\def\macrocolor{\color{purple}}
+\def\tikz{T\emph{i}kZ\xspace}
 
 \catcode`\%=11
 \catcode`\|=14
-
-\newcommand{\InitEjemplo}{|
- \catcode`\<=12
- \catcode`\>=12
- \foreach \auxvar in \ListaDeEjemplos {|
-  \expandafter\CatchFileBetweenDelims\csname \auxvar\endcsname{factura-\auxvar.tex}{<desc>}{</desc>}[\catcode37=11\catcode13=14]|
- }|
- \catcode`\<=13
- \catcode`\>=13
-}
-
-| Gracias a Werner y egreg por el uso de \begingroup\ttfamily\string ... \endgroup
-| Thanks to Werner and egreg for the use of \begingroup\ttfamily\string ... \endgroup
-| (http://tex.stackexchange.com/questions/342572/error-using-verb-as-the-replace-string-on-xpatchcmd)
-
-| Gracias a cfr y egreg por el esclarecimiento en cuanto a la necesidad de \makeatletter en \CatchFileBetweenDelims y antes de \regexpatchcmd*
-| Thanks to cfr and egreg for the clarification on the use of \makeatletter on \CatchFileBetweenDelims and before \regexpatchcmd*
-| (https://tex.stackexchange.com/questions/380796/how-to-patch-a-macro-with-control-sequences-using-regexpatch)
-\NewDocumentCommand{\Ejemplo}{s s O{0.5} m O{} G{1}}{|
- \IfFileExists{factura-#4.pdf}{|
+\NewDocumentCommand{\Ejemplo}{s s s O{0.5} m O{} G{1} o}{|
+ \IfFileExists{factura-#5.pdf}{|
   \catcode`\<=12
   \catcode`\>=12
-  \IfBooleanTF{#1}{\booltrue{ejemploizq}}{\booltrue{ejemplocondesc}}|
-  \IfBooleanT{#2}{\booltrue{ejemploder}\boolfalse{ejemploizq}}|
-  \def\ancho{#3}|
-  \ifnum #6=1 {\phantomsection\par\mbox{}\hfill{\color{RoyalBlue}\ttfamily \large factura-#4}\hfill\mbox{}\par}{}\fi
-  \ifbool{ejemploder}{\hfill}{}|
-  \begin{minipage}{\ancho\linewidth}
-   \fbox{\includegraphics[page=#6,width=\linewidth-2\fboxrule-2\fboxsep]{factura-#4}}
-   \IfBooleanF{#1}{\addcontentsline{toc}{subsection}{factura-#4}}
-  \end{minipage}|
-  \ifbool{ejemploizq}{\hfill}{}|
-  \ifbool{ejemplocondesc}
+  \IfBooleanTF{#3}{\def\Ancho{0}\booltrue{DescripEjemplo}}{|
+   \def\Ancho{#4}\booltrue{Ejemplo}|
+   \IfBooleanT{#2}{\booltrue{EjemploDer}}|
+   \IfBooleanTF{#1}{\booltrue{EjemploIzq}}{\booltrue{DescripEjemplo}}}|
+  \ifbool{Ejemplo}
+   {\ifnum #7=1 {\phantomsection\par\mbox{}\hfill{\color{RoyalBlue}\ttfamily \large factura-#5}\hfill\mbox{}\par}{}\fi}
+   {}|
+  \ifbool{EjemploDer}{\hfill}{}|
+  \ifbool{Ejemplo}
+   {\begin{minipage}{\Ancho\linewidth}
+     \fbox{\includegraphics[page=#7,width=\linewidth-2\fboxrule-2\fboxsep]{factura-#5}}
+     \IfBooleanF{#1}{\addcontentsline{toc}{subsection}{factura-#5}}
+    \end{minipage}}
+   {}|
+  \ifbool{EjemploIzq}{\hfill}{}|
+  \ifbool{DescripEjemplo}
    {\hfill
-   \CatchFileBetweenDelims{\DescEjemplo}{factura-#4.tex}{<desc>}{</desc>}[\catcode37=11\catcode13=14\makeatletter]|
+   | Gracias a cfr y a egreg por el esclarecimiento en cuanto a la necesidad de \makeatletter en \CatchFileBetweenDelims y antes de \regexpatchcmd*.
+   | Thanks to cfr and egreg for the clarification on the use of \makeatletter on \CatchFileBetweenDelims and before \regexpatchcmd*.
+   | (https://tex.stackexchange.com/questions/380796/how-to-patch-a-macro-with-control-sequences-using-regexpatch)
+   \CatchFileBetweenDelims{\DescEjemplo}{factura-#5.tex}{<desc>}{</desc>}[\catcode37=11\catcode13=14\makeatletter]|
    \catcode`\%=11
    \makeatletter
-   \regexpatchcmd*{\DescEjemplo}{\cC.}{\c{begingroup}\c{ttfamily}\c{string}\0\c{endgroup}\c{xspace}}{}{}|
-   \regexpatchcmd*{\DescEjemplo}{(\()(\cL[a-z]*)(\))}{(\c{begingroup}\c{ttfamily}\2\c{endgroup})}{}{}|
+   | Gracias a Werner y a egreg por el uso de \begingroup\ttfamily\string ... \endgroup.
+   | Thanks to Werner and egreg for the use of \begingroup\ttfamily\string ... \endgroup.
+   | (http://tex.stackexchange.com/questions/342572/error-using-verb-as-the-replace-string-on-xpatchcmd)
+   \regexpatchcmd*{\DescEjemplo}{\cC.\cO[*]*}{\c{begingroup}\c{macrocolor}\c{ttfamily}\c{string}\0\c{endgroup}\c{xspace}}{}{}|
+   \regexpatchcmd*{\DescEjemplo}{(\()(\cL[a-zG]*)(\))}{(\c{begingroup}\c{optcolor}\c{ttfamily}\2\c{endgroup})}{}{}|
    \xpatchcmd*{\DescEjemplo}{%% }{\item}{}{}|
    \xpatchcmd*{\DescEjemplo}{%%}{}{}{}|
    \makeatother
-   \begin{minipage}{\linewidth-\ancho\linewidth}
+   \begin{minipage}{\linewidth-\Ancho\linewidth}
     \begin{itemize}
      \setlength{\itemsep}{0pt}
-     #5\DescEjemplo
+     #6\DescEjemplo
     \end{itemize}
-   \end{minipage}}
+   \end{minipage}
+   \IfValueT{#8}{{#8}}}
    {}|
-  \boolfalse{ejemploizq}\boolfalse{ejemploder}\boolfalse{ejemplocondesc}|
+  \boolfalse{Ejemplo}\boolfalse{EjemploIzq}\boolfalse{EjemploDer}\boolfalse{DescripEjemplo}|
   \catcode`\%=9
   \catcode`\<=13
   \catcode`\>=13
- }{\message{LaTeX warning: No existe factura-#4.pdf; se recomienda compilarlo antes de compilar este documento.}}}
-
+ }{\message{^^JLaTeX Warning: No existe factura-#5.pdf; hay que compilarlo antes de compilar este documento.^^J}}}
 \catcode`\%=14
 \catcode`\|=12
 
-\InitEjemplo
-
 % No quiero que las notas pendientes tengan los números de página:
 \patchcmd{\todoitem}{(p.~\pageref{todopage:\thetodo}):}{-}{}{}
 
 \renewcommand{\todoname}{Pendiente}
+\renewcommand{\todomark}{Pendiente}
 \newcommand{\changesname}{Lista de cambios en las versiones}
 \newcommand{\glosname}{Índice de comandos, entornos y opciones}
 
@@ -359,7 +352,7 @@
   \section*{\glosname}%
   \markboth{\glosname}{\glosname}}%
 
- % Adaptamos un poco la lista de cambios a lo que yo quiero:
+ % Adaptamos un poco la lista de cambios:
  \def\changes@#1#2#3{%
   \protected at edef\@tempa{%
    \noexpand\glossary{%
@@ -382,7 +375,6 @@
   \endgroup\@esphack}%
 
  \patchcmd{\glossary at prologue}{Change History}{\changesname}{}{}
-
 \makeatother
 
 \title{The \textsf{\jobname} class\thanks{Esta documentación corresponde a la clase \textsf{\jobname}~\fileversion, de fecha \filedate.}}
@@ -398,19 +390,25 @@
  \addcontentsline{toc}{section}{\todoname}
  \todos
  \section*{Información específica de esta versión}
- Desde la versión v2.82 de esta clase, para poder compilar con \LuaLaTeX{} es necesaria la versión v2.26 del paquete |zref|, de fecha 2016/05/21, y la versión v1.18 de |atbegshi| de fecha 2016/06/09.%v2.82
+ % v2.82 Desde la versión v2.82 de esta clase, para poder compilar con \LuaLaTeX{} es necesaria la versión v2.26 del paquete |zref|, de fecha 2016/05/21, y la versión v1.18 de |atbegshi| de fecha 2016/06/09.
 
  % v2.82 -> Esta versión de |factura| se sacó principalmente para corregir un error introducido en la versión anterior v2.72 en cuanto a las referencias, para agregar la opción |numitem| que enumera los ítems en la factura y para que la línea diagonal (opción |linea|) funcione correctamente siempre.
  
- Desde la versión v3.00, todos los ejemplos están incorporados a la documentación, con la descripción de cada uno, de manera automatizada.
+ % v3.00 -> Desde la versión v3.00, todos los ejemplos están incorporados a la documentación, con la descripción de cada uno, de manera automatizada.
  
- Esta versión v3.02 se saca porque la versión 3.9 de |fancyhdr| hizo necesaria esta actualización por un error que daba con los reportes por el uso en esta clase de la macro |\fancy at setoffs|. Lo que hacíamos con esa macro de |fancyhdr| lo hicimos ahora de otra forma mejor, dada la incompatibilidad con la nueva versión de ese paquete.%v3.02
+ % v3.02 -> Esta versión v3.02 se saca porque la versión 3.9 de |fancyhdr| hizo necesaria esta actualización por un error que daba con los reportes por el uso en esta clase de la macro |\fancy at setoffs|. Lo que hacíamos con esa macro de |fancyhdr| lo hicimos ahora de otra forma mejor, dada la incompatibilidad con la nueva versión de ese paquete.%v3.02
  
+ Esta versión se saca por los cambios en la política impositiva decretados por el Presidente en Decreto número 3085 relativos a descuentos del 3\% y 5\% en el IVA general cuando los pagos se hacen por medios electrónicos; también se corrigió la tasa de IVA adicional.
+ 
+ Adicionalmente se agregaron nuevas opciones en cuanto al manejo de la fecha de emisión y su formato, posibilidad de facturas a crédito con fecha de vencimiento, campos nuevos adicionales para agregar más textos en la factura, posibilidad de imprimir información en el reverso de la hoja de la factura, posibilidades nuevas en cuanto al posicionamiento de los elementos fijos, diseño \tikz más versátil en los cuadros con bordes, mejor manejo del archivo |.csv|, cambios en los nombres de algunos comandos y opciones.
+ 
+ Finalmente se cambió la estructura de la sección de los comandos en esta documentación y se agregó una página de descripción al final de cada ejemplo.
+ 
  \section*{Agradecimientos}
  
  Por pruebas y sugerencias que dieron lugar a mejoras agradezco a Ritguey%
- \ifmotorunicode\footnote{\setmainfont{Symbola}🐧}\fi{}
- Flores Esteves y a Alberto Mijares. Por contribuciones a través de \texttt{StackExchange} agradezco a cfr, David Carlisle, egreg, Gustavo Mezzetti, Heiko Oberdiek, jfbu, Joseph Wright y Werner.
+ \ifmotorunicode\footnote{\setmainfont{Symbola}🐧}\else\message{^^J^^JLaTeX Warning: Compila con XeLaTeX.^^J}\fi{}
+ Flores Esteves y a Alberto Mijares. Por contribuciones a través de \texttt{StackExchange} agradezco a Alan Munn, cfr, David Carlisle, egreg, Gustavo Mezzetti, Heiko Oberdiek, jfbu, Joseph Wright, Werner y wipet. El motivo por el que se da cada agradecimiento está como comentario en el archivo |.cls| o en el |.dtx|.
  
  \addcontentsline{toc}{section}{\changesname}
  {\makeatletter\def\pfill{\unskip\hfill\@gobble}\makeatother
@@ -475,25 +473,25 @@
 % \changes{v2.1}{2015/08/26}{Mejor manejo de \cs{InicioReporte}.}
 % \changes{v2.6}{2016/03/07}{Cambiado el lugar donde se fija el nombre del documento (FACTURA o COTIZACIÓN) porque antes no era correcto y no se podía cambiar el nombre de la cotización a algo distinto como por ejemplo PRESUPUESTO.}
 % \changes{v2.6}{2016/03/07}{Se renombró la opción \texttt{sincond} en favor de \texttt{sincondiciones}.}
-% \changes{v2.6}{2016/03/07}{Cambiado ``condiciones de pago'' por ``condiciones del documento''.}
+% \changes{v2.6}{2016/03/07}{Cambiado “condiciones de pago” por “condiciones del documento”.}
 % \changes{v2.6}{2016/03/07}{Los descuentos globales aceptan decimales bien; antes no.}
 % \changes{v2.6}{2016/03/07}{Se cambió la forma como se llama al ambiente \texttt{tabularx} en la factura creando una nueva macro que se evalúa completamente resultando en la definición de las columnas.}
-% \changes{v2.6}{2016/03/07}{Agregadas cuatro opciones: \texttt{sinlineasvi}, \texttt{sinlineasve}, \texttt{sinlineash}, \texttt{sinlineashi}, \texttt{sinlineashe} y renombrada la opción \texttt{lineaitem} por \texttt{conlineasha} aludiendo a ``con líneas horizontales para los artículos''.}
+% \changes{v2.6}{2016/03/07}{Agregadas cuatro opciones: \texttt{sinlineasvi}, \texttt{sinlineasve}, \texttt{sinlineash}, \texttt{sinlineashi}, \texttt{sinlineashe} y renombrada la opción \texttt{lineaitem} por \texttt{conlineasha} aludiendo a “con líneas horizontales para los artículos”.}
 % \changes{v2.6}{2016/03/07}{Se arregló la línea oblicua que en algunos casos seguía sin salir.}
-% \changes{v2.6}{2016/03/07}{Textos ``PAGADO'' y ``Por el emisor'' para las facturas y cotizaciones cuando no se define el emisor del documento.}
+% \changes{v2.6}{2016/03/07}{Textos “PAGADO” y “Por el emisor” para las facturas y cotizaciones cuando no se define el emisor del documento.}
 % \changes{v2.6}{2016/03/07}{Nueva opción \texttt{dosfirmas} para poner las dos firmas en casos en los que lo predeterminado sea una o ninguna firma (cotizaciones o prefacturas).}
 % \changes{v2.6}{2016/03/07}{Nuevo comando \cs{Conforme} para el nombre de quien recibe la factura.}
-% \changes{v2.6}{2016/03/07}{Cambiado el lugar en el código donde se llama a la macro que dibuja la línea ``protectora'' y se hace ahora con \cs{AddToShipoutPicture} para que no se genere un espacio en blanco extra.}
+% \changes{v2.6}{2016/03/07}{Cambiado el lugar en el código donde se llama a la macro que dibuja la línea “protectora” y se hace ahora con \cs{AddToShipoutPicture} para que no se genere un espacio en blanco extra.}
 % \changes{v2.6}{2016/03/07}{El ejemplo de la documentación es de una cotización y no de una prefactura; actualizada la documentación y los ejemplos.}
-% \changes{v2.6}{2016/03/07}{En el índice ponemos ``entorno'' en lugar de ``environment''.}
-% \changes{v2.6}{2016/03/07}{El verbo ``poner'' es digno para la documentación. No sólo las gallinas ponen.}
-% \changes{v2.6}{2016/03/07}{Renombrado el comando \cs{EstiloPag} por \cs{InfoPagina}; también \cs{LetraEncReporte} por \cs{LetraInfoPagina}; por otra parte se cambió \cs{LetraDatosReporte} en favor de \cs{LetraEncReporte}, y por último se cambió \cs{LetraTitRenglon} por \cs{LetraTitCuadro}.}
+% \changes{v2.6}{2016/03/07}{En el índice ponemos “entorno” en lugar de “environment”.}
+% \changes{v2.6}{2016/03/07}{El verbo “poner” es digno para la documentación. No sólo las gallinas ponen.}
+% \changes{v2.6}{2016/03/07}{Renombrado el comando \cs{EstiloPag} por \cs{InfoPagina}; también \cs{LetraEncReporte} por \cs{LetraInfoPagina}; por otra parte se cambió \cs{LetraDatosReporte} en favor de \cs{LetraEncReporte}, y por último se cambió \cs{LetraTitRenglon} por \cs{LetraTitColumnas}.}
 % \changes{v2.6}{2016/03/07}{Renombrados los estilos de página: \texttt{soloenc} a \texttt{soloarriba}, y \texttt{solopie} a \texttt{soloabajo}.}
 % \changes{v2.6}{2016/03/07}{Se mejoró el código relativo al estilo de página del reporte y agregada la macro \cs{EstiloPagReporte} para establecer el estilo de página del reporte.}
 % \changes{v2.6}{2016/03/07}{Se agregó una forma para que más de una línea en la descripción de la factura sea mejor manejada.}
 % \changes{v2.6}{2016/03/07}{Mejorado el código de la macro interna \cs{@EscribeTipoDeImpuesto}.}
 % \changes{v2.6}{2016/03/07}{Cuando la descripción en el cuadro de la factura ocupa más que una línea, agrega al final de cada línea el carácter $\hookleftarrow$.}
-% \changes{v2.6}{2016/03/07}{Corregido que salga la ``G'' obligatoria de IVA General cuando hay un elemento exento y uno con IVA General.}
+% \changes{v2.6}{2016/03/07}{Corregido que salga la “G” obligatoria de IVA General cuando hay un elemento exento y uno con IVA General.}
 % \changes{v2.6}{2016/03/07}{Cuatro nuevas definiciones dentro del archivo \texttt{factura.def} para establecer algunos caracteres que antes estaban fijados dentro del archivo \texttt{factura.cls}}
 % \changes{v2.6}{2016/03/07}{{\slshape parbox}es para cada elemento en la tabla, para asegurar que la denominación del gravamen quede alineada correctamente.}
 % \changes{v2.6}{2016/03/07}{Quitados los paquetes \texttt{xifthen} y \texttt{pbox}. Arreglada la presentación de los datos del cliente cuando el resumen es más grande.}
@@ -505,7 +503,7 @@
 % \changes{v2.72}{2016/05/16}{Agregadas las etiquetas y las referencias.}
 % \changes{v2.82}{2016/06/25}{Agregada la opción \texttt{numitem} para enumerar cada ítem en la factura.}
 % \changes{v2.82}{2016/06/25}{Corregido problema de etiquetas repetidas introducido en la versió 2.72.}
-% \changes{v2.82}{2016/06/25}{Corregida la alineación vertical entre las distintas columnas agregando \texttt{[t]} al abrir los ``{\slshape parboxes}'' en los comandos auxiliares que ponen cada celda en un {\slshape parbox} del tamaño de la celda más grande, porque si no se centra verticalmente la celda y se desalinea respecto a la columna de al lado.}
+% \changes{v2.82}{2016/06/25}{Corregida la alineación vertical entre las distintas columnas agregando \texttt{[t]} al abrir los “{\slshape parboxes}” en los comandos auxiliares que ponen cada celda en un {\slshape parbox} del tamaño de la celda más grande, porque si no se centra verticalmente la celda y se desalinea respecto a la columna de al lado.}
 % \changes{v2.82}{2016/06/25}{Ahora dentro de la definición de \cs{@CaracterCeldasVacias} está el código que centra el texto, para poder usar comandos que llenen la caja completa como \cs{dotfill}.}
 % \changes{v2.82}{2016/06/25}{Reimplementada la línea diagonal para que funcione en todos los casos.}
 % \changes{v2.82}{2016/06/25}{Nueva macro interna \cs{@ColumnasMultiColumnTotalesAuxCmd} para hacer más general la colocación de los totales en el modo de columnas dentro de un \cs{multicolumn}.}
@@ -519,11 +517,52 @@
 % \changes{v3.00}{2017/03/11}{Opción \texttt{subtotal} para agregar una columna extra después del precio unitario y antes del descuento, para reflejar el precio antes de aplicar el descuento individual.}
 % \changes{v3.02}{2017/07/16}{Ya no usamos la macro \cs{fancy at setoffs} de \texttt{fancyhdr} en el reporte para establecer valores iniciales por ejemplo de la longitud de la línea en los encabezados; ahora lo hacemos de una forma diferente, incluyendo en el \texttt{.def} una macro llamada \cs{@GrosorLineaInfoPag} que alberga el valor que \texttt{fancyhdr} asigna preterminadamente al grosor de dicha línea. No agregamos un comando para cambiar ese valor por no ser algo de relevancia.}
 % \changes{v3.02}{2017/07/16}{Ajustada ligeramente esta lista de cambios y la inclusión de los ejemplos en la documentación.}
-%
+% \changes{v3.40}{2017/12/11}{Se agregó la opción \texttt{electro} para dar cumplimiento con el Decreto Presidencial 3085 y la Providencia Administrativa 0048 que establece descuentos en el IVA.}
+% \changes{v3.40}{2017/12/11}{Macros nuevas para notas internas al cuadro de la factura y externas a él.}
+% \changes{v3.40}{2017/12/11}{Ahora \cs{PosCond} acepta \texttt{*} para que el texto pueda abrir hacia arriba en la posición establecida y no solamente hacia abajo.}
+% \changes{v3.40}{2017/12/11}{Agregado el comando \cs{Credito} para la posibilidad de facturas a crédito donde es calculada la fecha de vencimiento de la factura que aparecerá debajo de la fecha de emisión.}
+% \changes{v3.40}{2017/12/11}{Ahora \cs{PosFecha} también acepta \texttt{*} para que las fechas (emisión y vencimiento) puedan fijarse también respecto a una posición final y no solamente inicial.}
+% \changes{v3.40}{2017/12/11}{El comando \cs{Fecha} acepta \texttt{*} para poder especificar la fecha en formato \texttt{iso} de forma más estándar para que sea tomada correctamente por el paquete \texttt{datetime2}, usado para calcular la fecha de vencimiento.}
+% \changes{v3.40}{2017/12/11}{Se agregó la macro \cs{FormatoFecha} para poder cambiar el formato en el que el usuario da la fecha de emisión y cómo ésta es presentada.}
+% \changes{v3.40}{2017/12/11}{Si no se especifica la fecha, será tomada la fecha actual y generará una advertencia indicando eso y no un error indicando que no se ha especificado la fecha, como era antes.}
+% \changes{v3.40}{2017/12/11}{Actualizada la documentación para reflejar los cambios.}
+% \changes{v3.40}{2017/12/11}{Se renombró \cs{@EstiloFecha} por \cs{@EstiloFechas}, y \cs{@PosicionaFecha} por \cs{@PosicionaFechas}.}
+% \changes{v3.40}{2017/12/11}{Reestructuración de la documentación.}
+% \changes{v3.40}{2017/12/11}{Nueva opción \texttt{vencimiento} para poner la fecha de vencimiento aún en facturas a contado.}
+% \changes{v3.40}{2017/12/11}{También \cs{PosDenom} y \cs{PosControl} aceptan \texttt{*}. Cambió en 2mm el margen superior predeterminado, así como también hubo un cambio en la coordenada vertical de la fecha, la denominación del documento y el número de control, ya que antes los predeterminados estaban especificados sin \texttt{*} y luego no.}
+% \changes{v3.40}{2017/12/11}{No poner el teléfono ahora produce una advertencia y no un error como antes.}
+% \changes{v3.40}{2017/12/11}{Funciones internas para los mensajes informaticos, advertencias y errores de la clase.}
+% \changes{v3.40}{2017/12/11}{Se le agregó la posibilidad de \texttt{*} a la macro interna \cs{@DatosAux} para que pudiera ser utilizada la misma macro por los casos donde hay resumen y donde no lo hay.}
+% \changes{v3.40}{2017/12/11}{A los cuadros dibujados con \tikz les fue separada la definición del nodo para ponerla dentro del \texttt{.def} en lugar de estar en el \texttt{.cls}.}
+% \changes{v3.40}{2017/12/11}{Cuando se especifica 0 como grosor de línea para la descripción o el encabezado, desaparece la línea completamente y la estructura \tikz.}
+% \changes{v3.40}{2017/12/11}{Renombrada \cs{PosCond} a \cs{PosCondiciones}.}
+% \changes{v3.40}{2017/12/11}{Ahora las condiciones aceptan línea en \tikz, es decir que hay dos macros nuevas: \cs{LineaCondiciones} y \cs{SepCondiciones}. Predeterminadamente las condiciones quedaron como antes, o sea sin diseño de \tikz.}
+% \changes{v3.40}{2017/12/11}{Quitada la macro interna \cs{@TamDescrip} porque no hacía nada.}
+% \changes{v3.40}{2017/12/11}{Renombrada \cs{SepEncabez} a \cs{SepEncabezado}, tambień \cs{SepDescrip} a \cs{SepDescripcion}, \cs{LineaEncabez} en favor de \cs{LineaEncabezado}, y \cs{LineaDescrip} en favor de \cs{LineaDescripcion}, así como algunas macros internas asociadas a ellas.}
+% \changes{v3.40}{2017/12/11}{Macro nueva para una nota previa al cuadro de la factura.}
+% \changes{v3.40}{2017/12/11}{La macro \cs{SepEncabezado} fue dividida entre \cs{SepDatosResumen} y \cs{SepEncabezado}. La macro \cs{SepElementos} fue renombrada a \cs{SepVertical} y \cs{LetraTitCuadro} a \cs{LetraTitColumnas}.}
+% \changes{v3.40}{2017/12/11}{Contador \texttt{@NumItem} renombrado a \texttt{NumItem}. Las macros para los parámetros de las líneas ahora aceptan dar solamente el primer argumento, por ejemplo para definir que no salga la línea, sólo basta con por ejemplo \cs{LineaEncabezado}{0pt}.}
+% \changes{v3.40}{2017/12/11}{Nuevo parámetro opcional después de la descripción en los \cs{Item***} para cambiar el campo que va a salir en el \texttt{.csv}, y ahora se puede especificar un descuento individual en los ítems, que será ignorado si no se carga la opción para descuentos individuales.}
+% \changes{v3.40}{2017/12/11}{Actualizada la tasa de IVA adicional.}
+% \changes{v3.40}{2017/12/11}{Nueva opción \texttt{iva} para agregar una columna adicional que muestra el IVA de cada item.}
+% \changes{v3.40}{2017/12/11}{Modificada la macro interna \cs{@DescripcionAuxCmd} por problemas que daba en algunos casos.}
+% \changes{v3.40}{2017/12/11}{Se renombró la opción \texttt{exparriba} por \texttt{expandecuadro}.}
 % \DoNotIndex{}
+% \changes{v3.40}{2017/12/11}{Modificada la definición de \cs{ItemX} para que maneje la descripción especial para el archivo \texttt{csv}.}
+% \changes{v3.40}{2017/12/11}{Nuevo comando \cs{ivaref} para referenciar el IVA del ítem etiquetado.}
+% \changes{v3.40}{2017/12/11}{Se cambiaron unos \cs{AtEndDocument} por \cs{AtBeginShipoutNext}. Se hizo necesario siempre el paquete \texttt{eso-pic}.}
+% \changes{v3.40}{2017/12/11}{Se quitó la fijación del estilo de página de un \cs{AtBeginDocument} innecesario. Nuevo entorno \texttt{reverso} para el reverso de la factura y nuevo comando para la letra predeterminada del entorno: \cs{LetraReverso}.}
+% \changes{v3.40}{2017/12/11}{Cada ejemplo tiene una página al final con su explicación correspondiente.}
+% \changes{v3.40}{2017/12/11}{Ahora en los ejemplos, primero va la opción o la macro entre paréntesis y después va la explicación y no al revés como era antes.}
+% \changes{v3.40}{2017/12/11}{Quitada la opción \texttt{sincondiciones}. Si no se establecen las condiciones produce una advertencia.}
+% \changes{v3.40}{2017/12/11}{Quitada la macro \cs{mostrar}. Ahora cada texto a mostrar se hace con el mismo comando con el que se definió.}
+% \changes{v3.40}{2017/12/11}{Algunos condicionales cambiados.}
+% \changes{v3.40}{2017/12/11}{Otra vez corregida la macro interna \cs{@DescripcionAuxCmd} y arreglado el espaciado entre los ítems; ojalá que esta vez sí esté bien.}
 %
+%
 % \tableofcontents
 %
+%
 % \section*{Brief description in english}
 %
 % |factura| is the spanish word for `invoice', so this is a \LaTeX{} class for typesetting and calculating invoices, made taking into account requirements of {\slshape SENIAT} legislation (tax collector entity on the Bolivarian Republic of Venezuela), but its use is not restricted to Venezuela because all variables and displayed text can be redefined by invoking commands or editing.
@@ -531,27 +570,36 @@
 % \newpage
 % \setstretch{1.4}
 %
+%
 % \section{Introducción}
 %
-% La clase de \LaTeX{} |factura| está diseñada para su uso en la República Bolivariana de Venezuela, conforme a los requerimientos fijados por las providencias del {\slshape SENIAT} 0591, 0257 y 0071, válidas éstas para julio del año 2017.
+% La clase de \LaTeX{} |factura| está diseñada para su uso en la República Bolivariana de Venezuela, conforme a los requerimientos fijados por las providencias del {\slshape SENIAT} 0591, 0257, 0071 y 0048, válidas éstas para septiembre del año 2017.
 %
-% Con |factura| se pueden elaborar facturas en formas libres fiscales\footnote{En cuanto a las formas libres, cada hoja del talonario de facturas legales tiene un encabezado con los datos del emisor de la factura y un pie de página con la información de identificación de la imprenta, en tamaño de hoja carta entera; esto es lo que se llama ``forma libre''.}, cotizaciones y reportes de servicios, dejando todos los cálculos a \TeX{}.
+% Con |factura| se pueden elaborar facturas en formas libres fiscales\footnote{En cuanto a las formas libres, cada hoja del talonario de facturas legales tiene un encabezado con los datos del emisor de la factura y un pie de página con la información de identificación de la imprenta, en tamaño de hoja carta entera; esto es lo que se llama “forma libre”.}, cotizaciones y reportes de servicios, dejando todos los cálculos a \TeX{}.
 %
-% El diseño de las facturas hechas con esta clase consiste en un encabezado con los datos que identifican al cliente, y al lado un -opcional- resumen; estas partes de la factura están encerradas en cajas con contornos que predeterminadamente tienen esquinas ovaladas. Si no se especifica el resumen saldrá solamente una de estas cajas en el encabezado que es la de los datos del cliente.
+% El diseño de las facturas hechas con esta clase consiste en un encabezado con los datos que identifican al cliente, con al lado un -opcional- resumen; estas partes de la factura están encerradas en recuadros. Si no se especifica el resumen saldrá solamente una de estas cajas en el encabezado que es la de los datos del cliente.
 %
-% Luego de esto viene un cuadro con los campos: cantidad, descripción, precio unitario y precio total\footnote{Pueden haber variaciones en estos campos controlables con las opciones de la clase (véanse secciones \ref{sec:opciones}, \ref{subsec:descuentos} y \ref{subsec:sincantidad}).}, con los elementos a facturar, cada uno en una línea, luego los totales, y al final viene una -opcional- descripción larga que sale en un cuadro. En fin, la factura consta de:
-% \begin{inparaenum}[\bfseries i)]
+% Luego de esto viene un -opcional- recuadro con una nota donde puede ir la forma de pago, luego un cuadro con los campos: cantidad, descripción, precio unitario y precio total\footnote{Pueden haber variaciones en estos campos controlables con las opciones de la clase (véanse subsecciones \ref{subsec:columnas}, \ref{subsec:descuentos} y \ref{subsec:sincantidad}).}, con los elementos a facturar, cada uno en una línea, luego los totales, luego una -opcional- nota dentro del cuadro de la factura, otra nota (opcional también) después del cuadro de la factura y al final viene una opcional descripción larga que sale en un recuadro. La factura puede tener también un reverso con más información.
+%
+% En fin, la factura consta de:
+% \begin{enumerate}[\bfseries i)]
 %  \item el encabezado con los datos del cliente y el -opcional- resumen,
-%  \item el cuadro con los elementos que se están facturando, y
-%  \item una descripción larga (opcional).
-% \end{inparaenum}
+%  \item la opcional nota previa al cuadro de la factura,
+%  \item el cuadro con los elementos que se están facturando y las totalizaciones,
+%  \item la opcional nota interna al cuadro de la factura,
+%  \item la opcional nota externa al cuadro de la factura,
+%  \item una opcional descripción larga, e
+%  \item información opcional en el reverso de la hoja.
+% \end{enumerate}
 %
+% Aparte, el usuario puede escribir un reporte largo asociado a la factura, es decir, esta clase sirve también para escribir reportes.
 %
+%
 % \section{Instalación}
 %
 % El paquete que está en CTAN consta de un archivo |README| en formato |UTF-8|, esta documentación compilada como |factura.pdf| y el archivo |factura.dtx|, del cual se generan todos los demás archivos.
 %
-% Al compilar |factura.dtx| va a producirse |factura.cls| y |factura.def|, además de todos los ejemplos en |.tex| y |factura.ins|.
+% Al compilar |factura.dtx| va a producirse |factura.cls| y |factura.def|, además de todos los ejemplos en archivos |.tex| y |factura.ins|.
 %
 % \noindent Si queremos solamente generar los archivos sin compilar la documentación, debemos ejecutar:
 %
@@ -593,29 +641,31 @@
 %
 % \end{enumerate}
 %
-% \newpage
-% \section{Archivos de ejemplo incluídos}
 %
+% \section{Archivos incluídos en el paquete}
+%
 % Este paquete incluye varios ejemplos, entre ellos la emulación de un diseño de factura entregado por alguna imprenta, que nos sirve para nuestros ejemplos de prefacturas, un diseño de membrete que nos sirve para los reportes, una firma que emula ser una firma real escaneada para su inclusión en algunos casos, así como varios ejemplos de facturas, prefacturas, cotizaciones y reportes. Cada uno de ellos tiene al principio del documento fuente la aclaratoria de qué es lo que hace, para diferenciarlo de los demás ejemplos.
 %
 % \noindent \begin{tabular}{rl}
-% \bfseries Archivo & \bfseries Descripción \\ \hline
-% |factura.dtx| & Archivo principal del que todos los demás se generan, \\
-% |factura.pdf| & Esta documentación, \\
-% |README| & Archivo con la descripción corta, \\
-% |factura-ejemplo-firma.tex| & Ejemplo de firma digitalizada, \\
-% |factura-ejemplo-fondo.tex| &  Elemplo de una forma libre fiscal digitalizada, \\
-% |factura-ejemplo-membrete.tex| & Ejemplo de membrete para los reportes, \\
-% |factura-ejemplo-prefactura.tex| & Ejemplo de ``{\slshape prefactura}'', \\
-% |factura-ejemplo-cotizacion.tex| & Ejemplo de cotización, \\
-% |factura-ejemplo-factura*.tex| & Ejemplos de facturas, \\
-% |factura-ejemplo-reporte*.tex| & Ejemplos de reportes, \\
-% |factura-beispiel-rechnung.tex| & Un ejemplo de una factura adaptada a otra legislación. \\ \hline
-%  \end{tabular}
+%  \bfseries Archivo & \bfseries Descripción \\ \hline
+%  |factura.dtx| & Archivo principal del que todos los demás se generan, \\
+%  |factura.pdf| & Esta documentación, \\
+%  |README| & Archivo con la descripción corta, \\
+%  |factura-ejemplo-firma.tex| & Ejemplo de firma digitalizada, \\
+%  |factura-ejemplo-fondo.tex| &  Elemplo de una forma libre fiscal digitalizada, \\
+%  |factura-ejemplo-membrete.tex| & Ejemplo de membrete para los reportes, \\
+%  |factura-ejemplo-aux.tex| & Archivo auxiliar que se incluye en todos los ejemplos y \\
+%                            & sirve para que cada ejemplo conste de su descripción, \\
+%  |factura-ejemplo-prefactura.tex| & Ejemplo de “{\slshape prefactura}”, \\
+%  |factura-ejemplo-cotizacion.tex| & Ejemplo de cotización, \\
+%  |factura-ejemplo-factura*.tex| & Ejemplos de facturas, \\
+%  |factura-ejemplo-reporte*.tex| & Ejemplos de reportes, \\
+%  |factura-beispiel-rechnung.tex| & Un ejemplo de una factura adaptada a otra legislación. \\ \hline
+% \end{tabular}
 %
 % \IfFileExists{factura-ejemplo-prefactura.pdf}{%
 %  \newpage\section{Ejemplo preliminar\label{sec:ejemplo}}
-%  Lo que sigue es un ejemplo del aspecto final de una {\slshape ``prefactura''}, que está bajo el nombre de ``|factura-ejemplo-prefactura.tex|'' y más adelante explicaremos en qué consiste:
+%  Lo que sigue es un ejemplo del aspecto final de una {\slshape “prefactura”}, que está bajo el nombre de “|factura-ejemplo-prefactura.tex|” y más adelante explicaremos en qué consiste:
 %
 %  \noindent
 %  \mbox{}\hfill
@@ -624,18 +674,18 @@
 %  \hfill\mbox{}
 %  \vfil\mbox{}
 %  \newpage}
-% {\message{LaTeX warning: No existe factura-ejemplo-prefactura; se recomienda compilarlo antes de compilar este documento.}}
+% {\message{^^JLaTeX Warning: No existe factura-ejemplo-prefactura.pdf; hay que compilarlo antes de compilar este documento.^^J}}
 %
 %
 % \section{Geometría de la hoja\label{sec:geohoja}}
 %
-% El espacio que la imprenta deja en el centro de la forma libre está todo disponible para la impresión de la factura con esta clase. Este espacio se delimita con el paquete |geometry|. Los valores predeterminados que tienen que ver con la geometría de la hoja están todos definidos dentro del archivo |factura.def|.
+% El espacio que la imprenta deja en blanco en la forma libre está todo disponible para la impresión de la factura con esta clase. Este espacio se delimita con el paquete |geometry|. Los valores predeterminados que tienen que ver con la geometría de la hoja están todos definidos dentro del archivo |factura.def|.
 %
 % El margen superior que se da con |geometry| está contabilizado desde el inicio del papel\footnote{El papel predeterminado es tamaño carta.} hasta donde empieza el encabezado con los datos del cliente, es decir que el encabezado es el primer elemento desde arriba hacia abajo en una factura.
 %
 % El margen inferior de |geometry| empieza donde termina la descripción del servicio -o el fin del cuadro de la factura, en caso de que no se agregue un texto de descripción larga-, hasta el final del papel.
 %
-% Para aclarar lo anterior es necesario decir que hay textos con posiciones fijas que están fuera de estos márgenes, como la fecha de emisión, la ``denominación'' del documento (que es ``FACTURA'', ``COTIZACIÓN'' u otro especificable), el número de la factura, el número de control (cuando aplica), las condiciones del documento y los espacios para las firmas; todas estas partes del documento están fijas en posiciones arbitrarias fuera de los márgenes dejados por |geometry|. Estos textos son fijos para darles posiciones que no dependan del contenido particular de cada factura sino del diseño del talonario que ya tenemos impreso, que siempre será igual, y para el cual estamos adaptando esta clase |factura|.
+% Para aclarar lo anterior es necesario decir que hay textos con posiciones fijas que están fuera de estos márgenes, como la fecha de emisión, la “denominación” del documento (que es “FACTURA”, “COTIZACIÓN” u otro especificable), el número de la factura, el número de control (cuando aplica), las condiciones del documento y los espacios para las firmas; todas estas partes del documento están fijas en posiciones arbitrarias fuera de los márgenes dejados por |geometry|. Estos textos son fijos para darles posiciones que no dependan del contenido particular de cada factura sino del diseño del talonario que ya tenemos impreso, que siempre será igual, y para el cual estamos adaptando esta clase |factura|.
 %
 % Las ubicaciones de los textos fijos también tienen valores predefinidos dentro de |factura.def|. Cualquiera de esos valores puede cambiarse mediante comandos, tal como se fijan los valores predeterminados en dicho archivo |.def|; esto significa que se puede personalizar a cualquier diseño del talonario entregado por la imprenta, basta con entender qué hace cada comando (explicado en este documento), consultar el |.def| o ver los ejemplos.
 %
@@ -650,19 +700,23 @@
 %
 % El documento debe comenzarse con |\documentclass{factura}| con las opciones necesarias, que se explicarán en la sección \ref{sec:opciones}. Después se definen a través de macros {\bfseries en el preámbulo} todas las variables y dimensiones para personalizar el documento, esto es las posiciones de los textos fijos, tipos de letra (opcional), datos del cliente, un resumen (opcional), fecha y demás. Despues de |\begin{document}| va el cuadro de la factura propiamente, para lo cual la clase define un entorno llamado |factura|
 % \DescribeEnv{factura}
-% (|\begin{factura}...\end{factura}|), en cuyo interior se escriben únicamente los elementos a facturar a través de comandos del tipo |\Item|\footnote{Es posible incluir elementos gravados en IVA con alícuota general (12\%), alícuota reducida (8\%), alícuota adicional (22\%), así como también elementos exentos de impuesto al valor agregado, con \cs{Item}, \cs{ItemR}, \cs{ItemA} e \cs{ItemE} respectivamente.}, especificando su cantidad, descripción y precio unitario como argumentos, en ese orden.
+% (|\begin{factura}...\end{factura}|), en cuyo interior se escriben únicamente los elementos a facturar a través de comandos del tipo |\Item|\footnote{Es posible incluir elementos gravados en IVA con alícuota general (12\%), alícuota reducida (8\%), alícuota adicional (27\%), así como también elementos exentos de impuesto al valor agregado, con \cs{Item}, \cs{ItemR}, \cs{ItemA} e \cs{ItemE} respectivamente.}, especificando su cantidad, descripción y precio unitario como argumentos, en ese orden.
 %
-% Finalizando el ambiente se puede escribir (opcionalmente) una descripción larga o una aclaratoria de lo que se factura; esto se hace con el comando |\Descripcion|.
+% Finalizado el entorno se puede escribir (opcionalmente) una descripción larga o una aclaratoria de lo que se factura; esto se hace con el comando |\Descripcion|.
 %
-% Algunas de las posibilidades de cambio de estilo de esta clase consisten en que puede cambiarse la forma como es presentado cualquiera de los textos, se pueden suprimir las líneas verticales del cuadro de la factura, se pueden agregar líneas horizontales separando cada ítem, también se puede dibujar una línea oblicua que proteja el cuadro de la factura de adiciones posteriores de texto, entre otras prestaciones más.
+% Algunas de las posibilidades de cambio de estilo de esta clase consisten en que puede cambiarse la forma como es presentado cualquiera de los textos, se pueden suprimir las líneas verticales y horizontales del cuadro de la factura, se pueden agregar líneas horizontales separando cada ítem, también se puede dibujar una línea oblicua que proteja el cuadro de la factura de adiciones posteriores de texto, entre otras prestaciones más.
 %
 % Si el emisor lo desea puede digitalizar su firma personal y colocarla en el espacio ya dispuesto para firmar, con un ajuste mínimo para que salga correctamente sobre la línea.
 %
-% También el usuario tiene la posibilidad de producir una {\slshape ``prefactura''}; así le llamamos a un documento sin validez legal pero que puede ser enviado por fax o por correo electrónico. Este documento tiene el mismo aspecto de la factura fiscal si se digitaliza la forma libre vacía\footnote{Quitándole las numeraciones obviamente. También puede diseñarse en un |.tex| una forma libre vacía idéntica a la que se tiene, así como se hace en el ejemplo incluído.}, se incluye la imagen como fondo de la página y se definen las posiciones fijas de las numeraciones impresas en el talonario, es decir el número de factura y el número de control, de los que hablamos previamente.
+% También el usuario tiene la posibilidad de producir una {\slshape “prefactura”}; así le llamamos a un documento sin validez legal pero que puede ser enviado por fax o por correo electrónico. Este documento tiene el mismo aspecto de la factura fiscal si se digitaliza la forma libre vacía\footnote{Quitándole las numeraciones obviamente. También puede diseñarse en un |.tex| una forma libre vacía idéntica a la que se tiene, así como se hace en el ejemplo incluído.}, se incluye la imagen como fondo de la página y se definen las posiciones fijas de las numeraciones impresas en el talonario, es decir el número de factura y el número de control, de los que hablamos previamente.
 %
-% Esta misma clase tiene la posibilidad de imprimir un reporte largo asociado a la factura\footnote{Si lo hubiera, así como también se puede usar estar clase para elaborar un reporte sin asociarlo a una factura en particular.}. Tal reporte se escribe dentro de un ambiente en el mismo documento en el que se escribe la factura asociada a él (|\begin{reporte}...\end{reporte}|),
+% Con esta misma clase tiene se la posibilidad de imprimir un información en el reverso de la hoja de la factura que saldrá escrita utilizando toda la hoja (los márgenes son ajustables). Esa información se encierra en un ambiente destinado para ese fin (|\begin{reverso}...\end{reverso}|),
+% \DescribeEnv{reverso}
+% y al momento de la compilación puede decidirse si se imprime esa parte o no.
+%
+% Otra posibilidad que da esta clase es la de escribir un reporte largo asociado a la factura\footnote{Si lo hubiera, así como también se puede usar estar clase para elaborar un reporte sin asociarlo a una factura en particular.}. Tal reporte se escribe dentro de un ambiente en el mismo documento en el que se escribe la factura asociada a él (|\begin{reporte}...\end{reporte}|),
 % \DescribeEnv{reporte}
-% y con dar una opción al inicio se puede hacer que se impirma el reporte en las páginas siguientes a la factura, o también se puede hacer que se imprima sólo el reporte ignorando todo lo que está dentro del entorno |factura|, de la misma manera como también se puede hacer que se imprima sólo la factura ignorando el entorno |reporte|. Esto permite tener todo en un mismo documento e imprimir lo que se desee en el momento, o todo a la vez.
+% y con dar una opción al inicio se puede hacer que se impirma el reporte en las páginas siguientes a la factura, o también se puede hacer que se imprima sólo el reporte ignorando todo lo que no constituye el reporte, de la misma manera como también se puede hacer que se imprima sólo la factura ignorando el entorno |reporte|. Esto permite tener todo en un mismo documento e imprimir lo que se desee en el momento, o todo a la vez.
 %
 %
 % \section{Compilación de un documento\label{sec:compila}}
@@ -669,7 +723,7 @@
 %
 % Para compilar una |factura| puede usar cualquiera de los motores \LaTeX, pdf\LaTeX, \XeLaTeX{} o \LuaLaTeX, naturalmente con las restricciones que impone cada uno.
 %
-% Hay casos en los que hace falta compilar más de una vez el documento. Dos veces necesita ser compilado un documento cuando alguna descripción en el cuadro de la factura ocupa más que una línea; también dos veces cuando se incluye una firma en el reporte, y más de dos veces cuando se pide que se dibuje una línea oblicua protectora del espacio restante en el cuadro de la factura.
+% Hay casos en los que hace falta compilar más de una vez el documento. Dos veces necesita ser compilado un documento cuando alguna descripción en el cuadro de la factura ocupa más que una línea; también dos veces cuando se incluye una firma en el reporte, y más de dos veces cuando se pide que se dibuje una línea oblicua protectora del espacio restante en el cuadro de la factura o cuando se usan etiquetas (sección \ref{sec:etiquetas}).
 %
 %
 % \section{Opciones al cargar la clase\label{sec:opciones}}
@@ -676,13 +730,20 @@
 %
 % Al cargar la clase con |\documentclass| se le puede dar opciones de la siguiente lista, para cambiar su comportamiento:
 %
+%
+% \subsection{Sobre el tipo de documento a producir}
+%
 % {\setlength{\parindent}{0pt}
+%
 % \DescribeOption{prefactura}
-%  La {\slshape ``prefactura''} es un documento no legal, preliminar, que no se imprime sobre papel de factura sino que está concebido para enviarse por correo o fax. Para eso se define la imagen que contiene el diseño de la factura con el comando |\FondoFactura|, luego la clase escribe la denominación ``FACTURA'' con su número\footnote{Lo predeterminado cuando no es una {\slshape ``prefactura''} sino una factura final es no escribir la denominación ni el número, ya que eso generalmente viene impreso en cada hoja del talonario.}. Esta opción implica la opción |sinfirmas|, ya que si es un documento preliminar sin validez legal, las firmas no son necesarias; sin embargo se puede cambiar este comportamiento con las opciones |dosfirmas| y |unafirma|.
+%  La {\slshape “prefactura”} es un documento no legal, preliminar, que no se imprime sobre papel de factura sino que está concebido para enviarse por correo o fax. Para eso se define la imagen que contiene el diseño de la factura con el comando |\FondoFactura|, luego la clase escribe la denominación “FACTURA” con su número\footnote{Lo predeterminado cuando no es una {\slshape “prefactura”} sino una factura final es no escribir la denominación ni el número, ya que eso generalmente viene impreso en cada hoja del talonario.}. Esta opción implica la opción |sinfirmas|, ya que si es un documento preliminar sin validez legal, las firmas no son necesarias; sin embargo se puede cambiar este comportamiento con las opciones |dosfirmas| y |unafirma|.
 %
 % \DescribeOption{cotizacion}
-%  La cotización es un documento similar a una factura pero no es un documento legal en el sentido de que no se imprime sobre talonario fiscal alguno, así que no lleva número de control y puede o no tener su propia numeración, que es cosa del emisor de la cotización. Esta opción implica la opción |unafirma|, para que firme el emisor de la factura, y si su nombre no se especifica saldrá ``Por el emisor'' debajo de la línea para firmar. También puede cambiarse esto con la opción |dosfirmas| o con |sinfirmas|.
+%  La cotización es un documento similar a una factura pero no es un documento legal en el sentido de que no se imprime sobre talonario fiscal alguno, así que no lleva número de control y puede o no tener su propia numeración, que es cosa del emisor de la cotización. Esta opción implica la opción |unafirma|, para que firme el emisor de la factura, y si su nombre no se especifica saldrá “Por el emisor” debajo de la línea para firmar. También puede cambiarse esto con la opción |dosfirmas| o con |sinfirmas|.
 %
+% \DescribeOption{sinreverso}
+%  No escribe la información -opcional- que se escribió dentro del entorno |reverso| a salir en el reverso de la factura.
+%
 % \DescribeOption{conreporte}
 %  Genera la factura (prefactura o cotización) y luego el reporte.
 %
@@ -689,15 +750,33 @@
 % \DescribeOption{soloreporte}
 %  Genera solamente el reporte, ignorando lo relacionado con la factura. Si no se especifica |conreporte| ni |soloreporte| se va a imprimir únicamente la factura.
 %
-% \DescribeOption{denom}
-%  Con esta opción escribimos también el texto ``FACTURA'' con el número. La razón de esta opción es que hay formas libres que tienen la numeración de la factura y otras que solamente tienen el número de control; para las que tienen sólo el número de control existe esta opción que también escribe el número en cada factura impresa, en la posición que se defina.
 %
-% \DescribeOption{sinnumero}
-%  Escribe el texto de la denominación del documento en su posición (e.g. ``COTIZACIÓN'') pero sin escribir el número; por ejemplo para las cotizaciones que no son documentos que legalmente lleven número, aunque el número puede ser para control interno. Esta opción implica la opción anterior |denom|.
+% \subsection{Relativo a las columnas que puede tener el cuadro de la factura\label{subsec:columnas}}
 %
-% \DescribeOption{sintotales}
-%  Con esta opción evitamos que se totalicen los elementos en la factura; sólo se presenta el cuadro sin los totales. La utilidad de esto no es en las facturas sino en las cotizaciones para casos donde se muestran variantes del mismo producto para que el cliente elija entre ellos. No tendría sentido totalizar allí sino que funcione como un listado de precios. {\itshape Debe usarse en las cotizaciones porque una factura sin totales no es válida.}
+% \DescribeOption{numitem}
+%  Con la opción |numitem| una nueva columna aparece en el cuadro de la factura donde se enumera cada ítem en el órden en el que se escriben dentro del entorno para la factura. Esto es útil por ejemplo cuando se hace referencia al número del ítem con el comando |\itemref|. Véase la sección \ref{sec:etiquetas}.
 %
+% \DescribeOption{sincantidad}
+%  El ambiente |factura| tiene también la posibilidad de no mostrar el campo de la cantidad, ni aceptarlo como argumento de cada ítem; en ese caso los comandos |\Item| -de los que hablaremos en la sección \ref{sec:factura}- aceptan como argumentos solamente la descripción del elemento y su precio, en ese orden.
+%
+% \DescribeOption{descuentos}
+%  Permite agregar un descuento en porcentaje en cada elemento de la factura, siendo dicho porcentaje el último argumento de los comandos |\Item|. Si no aplica descuento para un ítem, puede este dejarse sin ese argumento, dando el mismo resultado que indicar “0” como argumento para ese descuento. (Explicado también en la sección \ref{subsec:descuentos}).
+%
+% \DescribeOption{subtotal}
+%  Agrega una columna extra en la factura; sólo aplica cuando también se usa la opción |descuentos|. La nueva columna escribe el subtotal que cada ítem produce, es decir, el precio unitario multiplicado por la cantidad sin aplicar el descuento. Esta opción sobrecarga la factura (precio unitario, descuento, subtotal y precio total), y su uso es recomendable cuando también se usa |sincantidad|, porque de esta forma se tiene el subtotal, el descuento, y el total.
+%
+% \DescribeOption{iva}
+%  Agrega una nueva columna donde se expresa el porcentaje del IVA para cada elemento en la factura. Sin especificar esta opción queda claro según lo establecido por nuestra legislación cuál será el gravamen que aplica para cada elemento por una letra que lo denota al lado del precio o de la descripción.
+%
+% \DescribeOption{duc}
+%  Cambia el orden de los campos en el documento impreso a: descripción, precio unitario, cantidad y precio total. {\itshape Esto no cambia la forma como deben especificarse los argumentos de |\Item| sino solamente cambiará cómo serán mostrados}.
+%
+% \DescribeOption{dcu}
+%  Cambia el orden de los campos en el documento impreso a: descripción, cantidad, precio unitario y precio total\footnote{Sin \texttt{duc} ni \texttt{dcu}, el modo predeterminado es \texttt{cdu}: cantidad, descripción, precio unitario.}.
+%
+%
+% \subsection{Relativo al IVA}
+%
 % \DescribeOption{siniva}
 %  No se cobra IVA, para los casos en los que eso aplique.
 %
@@ -707,36 +786,39 @@
 % \DescribeOption{todosiva}
 %  Agrega el monto exento y todos los tipos de IVA en los totales así no se hayan incluído elementos gravados con los distintos tipos de impuesto.
 %
+% \DescribeOption{electro}
+%  Se agrega esta opción para dar cumplimiento con las Gacetas Oficiales números 41239, 41242 y 41244\footnote{De fecha 19, 21 y 26 de septiembre del año 2017, respectivamente. En la última de estas gacetas está la Providencia Administrativa PA0048 del SENIAT.} donde se establece que las operaciones de compra (salvo excepciones establecidas en la Gaceta) gravadas con IVA general gozarán de un descuento cuando son pagadas mediante medios electrónicos. El descuento es del 3\% cuando la factura es de un monto menor a Bs. 2.000.000 y del 5\% cuando el monto de la factura es de Bs. 2.000.000 o más. Al dar esta opción el descuento queda establecido según la Gaceta correspondiente al Decreto Presidencial número 3085.
+%
+% {\itshape Esta opción no es compatible con el modo de totalización en filas.}
+%
 % \DescribeOption{G}
-%  Agrega una ``|G|'' al lado de todos los items gravados con IVA general así sea el general el único IVA existente en la factura.
+%  Agrega una “|G|” al lado de todos los items gravados con IVA general así sea el general el único IVA existente en la factura.
 %
 % \DescribeOption{impdesc}
 %  Con esta opción, la letra que indica la denominación del impuesto aplicado a cada elemento, en lugar de escribirse en el precio unitario y en el total, que es la forma predeterminada, sale escrito al final de la descripción. Puede preferirse de esta forma, y ahorra un poco de espacio usable en la descripción porque ya no sale en dos lugares dicha letra sino en uno solo.
 %
-% \DescribeOption{centradesc}
-%  Podemos centrar el texto de la descripción de cada ítem en la factura con este comando en lugar de justificarlo.
 %
-% \DescribeOption{sinmarcas}
-%  Con |sinmarcas| evitamos que el carácter de fin de línea aparezca cuando la descripción ocupa más que una línea; ese carácter indica que la línea continúa abajo, y predeterminadamente es la flecha ``\flechaCR''. También con esta opción no aparece el carácter ``$\cdot$'' en las celdas vacías en este mismo caso.
-% 
-% \DescribeOption{numitem}
-%  Con la opción |numitem| una nueva columna aparece en el cuadro de la factura donde se enumera cada ítem en el órden en el que se escriben dentro del entorno para la factura. Esto es útil por ejemplo cuando se hace referencia al número del ítem con el comando |\itemref|. Véase la sección \ref{sec:etiquetas}.
+% \subsection{Sobre las líneas en el cuadro de la factura}
 %
-% \DescribeOption{sincantidad}
-%  El ambiente |factura| tiene también la posibilidad de no mostrar el campo de la cantidad, ni aceptarlo como argumento de cada ítem; en ese caso los comandos |\Item| -de los que hablaremos en la sección \ref{sec:factura}- aceptan como argumentos solamente la descripción del elemento y su precio, en ese orden.
+% \DescribeOption{sinlineasve}
+% \DescribeOption{sinlineasvi}
+% \DescribeOption{sinlineasv}
+% \DescribeOption{sinlineashe}
+% \DescribeOption{sinlineashi}
+% \DescribeOption{sinlineash}
+%  La clase provee varias opciones para no dibujar las líneas del cuadro de la factura. La clase diferencia entre las líneas internas y las líneas externas. Las líneas externas son las que conforman el contorno externo del cuadro de la factura. Las líneas internas en el caso de las horizontales son la línea que va después del título de cada columna (cantidad, descripción, ...), y la línea que separa los ítems de los totales; en el caso de las verticales, las líneas internas son las que separan las columnas.
 %
-% \DescribeOption{descuentos}
-%  Permite agregar un descuento en porcentaje en cada elemento de la factura, siendo dicho porcentaje el último argumento de los comandos |\Item|. Si no aplica descuento para un ítem, puede este dejarse sin ese argumento, dando el mismo resultado que indicar ``0'' como argumento para ese descuento. (Explicado también en la sección \ref{sec:factura}).
+%  Podemos apagar cada conjunto de línea; ya explicado qué es interno y qué es externo, queda aclarar que “ve” significa vertical externa, “vi” vertical interna, “he” horizontal externa y “hi” horizontal interna. Usando |sinlineasv| o |sinlineash| apagamos todas las líneas verticales u horizontales.
 %
-% \DescribeOption{subtotal}
-%  Agrega una columna extra en la factura; sólo aplica cuando también se usa la opción 'descuentos'. La nueva columna escribe el subtotal que cada ítem produce, es decir, el precio unitario multiplicado por la cantidad sin aplicar el descuento. Esta opción sobrerecarga la factura (precio unitario, descuento, subtotal y precio total), y su uso es recomendable cuando también se usa 'sincantidad', porque de esta forma se tiene el \, descuento y el total.
+% \DescribeOption{conlineasha}
+%  Agrega una línea horizontal separando cada artículo o ítem de los demás dentro del cuadro de la factura, como las facturas hechas a mano que tienen un espacio determinado para cada artículo.
 %
-% \DescribeOption{duc}
-%  Cambia el orden de los campos en el documento impreso a: descripción, precio unitario, cantidad y precio total. {\itshape Esto no cambia la forma como deben especificarse los argumentos de |\Item| sino solamente cambiará cómo serán mostrados}.
 %
-% \DescribeOption{dcu}
-%  Cambia el orden de los campos en el documento impreso a: descripción, cantidad, precio unitario y precio total\footnote{Sin \texttt{duc} ni \texttt{dcu}, el modo predeterminado es \texttt{cdu}: cantidad, descripción, precio unitario.}.
+% \subsection{Elementos a mostrar o no mostrar en la factura}
 %
+% \DescribeOption{sinmarcas}
+%  Con |sinmarcas| evitamos que el carácter de fin de línea aparezca cuando la descripción ocupa más que una línea; ese carácter indica que la línea continúa abajo, y predeterminadamente es la flecha “\flechaCR”. También con esta opción no aparece el carácter “$\cdot$” en las celdas vacías en este mismo caso.
+%
 % \DescribeOption{unafirma}
 %  No pone el espacio para que firme quien recibe el documento sino sólo el emisor; esto es lo predeterminado en las cotizaciones.
 %
@@ -746,152 +828,203 @@
 % \DescribeOption{dosfirmas}
 % Coloca las dos líneas para que firme quien emite y quien recibe. Esta opción es la predeterminada salvo en las prefacturas y en las cotizaciones.
 %
-% \DescribeOption{sincondiciones}
-%  No pone el texto con las condiciones del documento.
+% \DescribeOption{vencimiento}
+%  Cuando establecemos los días del crédito de la factura, se imprime una línea también con la fecha de vencimiento de la factura. Con esta opción podemos pedir que la fecha de vencimiento salga siempre en la facturas, inclusive cuando no sean facturas a crédito.
 %
-% \DescribeOption{sinlineasve}
-%  No aparecen las líneas verticales externas de los extremos del cuadro de la factura, es decir, las líneas verticales a la izquierda y a la derecha cerrando la tabla.
+% \DescribeOption{denom}
+%  Con esta opción escribimos también el texto “FACTURA” con el número. La razón de esta opción es que hay formas libres que tienen la numeración de la factura y otras que solamente tienen el número de control; para las que tienen sólo el número de control existe esta opción que también escribe el número en cada factura impresa, en la posición que se defina.
 %
-% \DescribeOption{sinlineasvi}
-%  No aparecen las líneas verticales internas del cuadro de la factura, es decir, las líneas que separan las columnas.
+% \DescribeOption{sinnumero}
+%  Escribe el texto de la denominación del documento en su posición (e.g. “COTIZACIÓN”) pero sin escribir el número; por ejemplo para las cotizaciones que no son documentos que legalmente lleven número, aunque el número puede ser para control interno. Esta opción implica la opción anterior |denom|.
 %
-% \DescribeOption{sinlineasv}
-%  No aparece ninguna línea vertical en el cuadro de la factura.
+% \DescribeOption{sintotales}
+%  Con esta opción evitamos que se totalicen los elementos en la factura; sólo se presenta el cuadro sin los totales. La utilidad de esto no es en las facturas sino en las cotizaciones para casos donde se muestran variantes del mismo producto para que el cliente elija entre ellos. No tendría sentido totalizar allí sino que funcione como un listado de precios. {\itshape Debe usarse en las cotizaciones porque una factura sin totales no es válida.}
 %
-% \DescribeOption{sinlineashe}
-%  No aparecen las líneas horizontales externas en el cuadro de la factura, estas son la línea de arriba y la línea de abajo que abren y cierran la factura.
+% \DescribeOption{linea}
+%  Agrega una línea diagonal protegiendo los espacios vacíos en el cuadro de la factura. Esta opción requiere de la opción |expandecuadro|, explicada a continuación.
 %
-% \DescribeOption{sinlineashi}
-%  No aparecen las líneas horizontales internas del cuadro de la factura, o sea, las líneas que separan los elementos a facturar del resto, y ese resto es: por arriba el título de cada columna, y por abajo la totalización.
 %
-% \DescribeOption{sinlineash}
-%  No aparece ninguna línea horizontal en el cuadro de la factura.
+% \subsection{Disposición de algunos elementos en la factura}
 %
-% \DescribeOption{conlineasha}
-%  Agrega una línea horizontal separando cada artículo o ítem de los demás dentro del cuadro de la factura, como las facturas hechas a mano que tienen un espacio dedicado para cada artículo.
+% \DescribeOption{expandecuadro}
+%  Expande el cuadro de la factura con espacio en blanco, es decir, rellena el espacio restante del cuadro de la factura con espacio en blanco. Lo predeterminado es expandir la parte de la descripción larga cuando la hay.
 %
+% \DescribeOption{sinexpandir}
+%  No expande ninguna parte en la factura, es decir, deja tanto el cuadro de la factura como la descripción en su tamaño mínimo según el contenido que tenga.
+%
+% \DescribeOption{centradesc}
+%  Podemos centrar el texto de la descripción de cada ítem en la factura con este comando en lugar de justificarlo.
+%
 % \DescribeOption{filas}
-%  Muesta los totales finales en modo de filas; esto los presenta uno al lado del otro en lugar de uno debajo del otro.
+%  Muesta los totales finales en modo de filas; esto los presenta uno al lado del otro en lugar de uno debajo del otro. Esta opción tiene limitaciones, por ejemplo no es compatible con la opción |sintotales|, |sinivaexpresado| ni |electro|, y por razones de espacio tampoco es compatible con los comandos de descuentos en los totales (subsección \ref{subsec:dctototales}).
 %
 % \DescribeOption{centrado}
-%  Centra los totales finales ({\itshape sólo para el modo de totalización en filas}).
+%  Centra los totales finales ({\itshape sólo para el modo de totalización en filas}), que sin esta opción salen alineados al margen derecho.
 %
 % \DescribeOption{agrupado}
-%  Agrupa los totales finales de los items por gravamen ({\itshape sólo para el modo de totalización en columnas}).
+%  No agrupa los totales finales de los items por gravamen sino por tipo ({\itshape sólo para el modo de totalización en columnas}). Con esta opción la agrupación es primero todos los subtotales y los descuentos (cuando aplica), luego las bases imponibles y después los IVA. Sin |agrupado| se ordena por porcentaje del gravamen.
 %
-% \DescribeOption{exparriba}
-%  Expande el espacio de arriba, es decir, rellena el espacio restante del cuadro de la factura con espacio en blanco. Lo predeterminado es expandir la parte de abajo, o sea, la descripción cuando la hay.
 %
-% \DescribeOption{sinexpandir}
-%  No expande partes en la factura, es decir, deja tanto el cuadro de la factura como la descripción en su tamaño mínimo según el contenido que tenga.
+% \subsection{Otras opciones}
 %
-% \DescribeOption{linea}
-%  Agrega una línea diagonal protegiendo los espacios vacíos en el cuadro de la factura. Esta opción requiere de la opción |exparriba|.
-%
 % \DescribeOption{nospanish}
-%  No carga |babel| en castellano\footnote{Por ejemplo para cargar {\ttfamily polyglossia} en su lugar.}, la codificación |T1| de las letras ni el paquete |lmodern|. Si no se especifica esta opción todo esto se carga, pero si se quiere no cargar algo de esto, entonces debe especificarse esta opción y cargar los demás paquetes a mano.
+%  No carga |babel| en castellano\footnote{Por ejemplo para cargar {\ttfamily polyglossia} en su lugar.}, la codificación |T1| de las letras ni el paquete |lmodern|. Si no se especifica esta opción todo esto se carga, pero si se quiere no cargar algo de esto, entonces debe especificarse esta opción y cargar lo que se quiera a mano.
 %
+% \DescribeOption{twoside}
+%  Establece que el reporte se imprime por los dos lados del papel. (Obviamente se ignora esta opción cuando el motor no va a generar un reporte puesto que las facturas ocupan una hoja solamente).
+%
 % \DescribeOption{csv}
 %  Escribe un archivo csv con la información numérica de la factura.
 %
-%  \todo*{Hay problemas con la codificación en el archivo |csv| cuando hay comandos frágiles a escribir.}
-%
-% \DescribeOption{twoside}
-%  Establece que el reporte se imprime por los dos lados del papel. (Naturalmente se ignora esta opción cuando el motor no va a generar un reporte puesto que las facturas ocupan una hoja solamente).
 % }
 %
-% \section{Principales comandos que la clase provee\label{sec:comandos}}
 %
-% A continuación descrirebimos los principales comandos de esta clase; en rojo aparecen aquellos pocos comandos que son de obligatorio uso. Los que no son de obligatorio uso es porque tienen algún valor predeterminado en |factura.def| o porque controlan algún aspecto opcional.
+% \section{Comandos que la clase provee\label{sec:comandos}}
 %
+% A continuación descriremos los principales comandos de esta clase; en rojo aparecen aquellos pocos comandos que son de obligatorio uso. Los que no son de obligatorio uso es porque tienen algún valor predeterminado en |factura.def| o porque controlan algún aspecto opcional.
+%
+%
+% \subsection{Estableciendo los márgenes de la hoja y el fondo}
+%
+%  Como explicamos en la sección (\ref{sec:geohoja}), a la hoja de la factura se le deben establecer los márgenes apropiadamente, y esos márgenes no tienen en cuanta ciertos textos que llamamos “fijos”, para los cuales también debemos establecer sus posiciones en la hoja, y eso lo veremos en esta parte.
+%
+%
 % {\setlength{\parindent}{0pt}
+%
 % \DescribeMacro{\GeometriaFactura}{\color{RoyalBlue}|\GeometriaFactura|\marg{geometría}}
 %
-%  Aquí van los parámetros relativos al paquete |geometry| que van a afectar la manera como la factura es generada. Como dijimos al principio, deberá especificarse el tipo de papel (e.g. |letterpaper|, |legalpaper|, |executive|, |a4paper|, ...) y los márgenes verticales y horizontales.
+%  En el argumento de este comando van los parámetros relativos al paquete |geometry| que van a afectar la manera como la factura es generada. Como dijimos al principio, deberá especificarse el tipo de papel (e.g. |letterpaper|, |legalpaper|, |executive|, |a4paper|, ...) y los márgenes verticales y horizontales.
 %
-%  Para especificar el margen superior debe medirse desde el inicio del papel hasta donde se quiera establecer que empiece el recuadro de los datos del cliente, y el margen inferior debe medirse desde el final del papel hasta donde terminaría la opcional descripción.
+%  Para especificar el margen superior debe medirse desde el inicio del papel hasta donde se quiera establecer que empiece el recuadro de los datos del cliente, y el margen inferior debe medirse desde el final del papel hasta donde terminaría la opcional descripción. Como ya dijimos, hay textos que están fuera de estos márgenes por haberlos considerado fijos en la implementación de la clase |factura|.
 %
-% \DescribeMacro{\GeometriaReporte}{\color{RoyalBlue}|\GeometriaReporte|\marg{geometría}}
+% \DescribeMacro{\GeometriaReverso}{\color{RoyalBlue}|\GeometriaReverso|\marg{geometría}}
 %
-%  Aquí van los parámetros relativos al paquete |geometry| que van a afectar la manera como el reporte es generado.
+%  Define los márgenes del reverso de la hoja de la factura para escribir información extra.
 %
-% Puesto que el reporte no se imprime en hojas de facturas sino en hojas en blanco, el usuario podrá cambiar la geometría del papel completamente a su gusto sin las restricciones impuestas por el diseño que tengan sus facturas. En |factura.def| se definen unos márgenes razonables para un reporte. Si el reporte y la factura usaran un tamaño distinto de papel, entonces al imprimirse ambos juntos (opción |conreporte|), el reporte tomará el tamaño físico del papel especificado para la factura ya que con el paquete |geometry| no podemos cambiar el tamaño del papel en el medio del documento, aunque sí sus márgenes. Entonces, si se quiere imprimir el reporte en un papel de otro tamaño, tendrán que imprimirse ambos documentos por separado, o sea, primero uno y después el otro.
-%
 % \DescribeMacro{\FondoFactura}{\color{RoyalBlue}|\FondoFactura|\marg{nombre del archivo de la imagen}}
 %
-%  Nombre del archivo de la imagen a cargar como diseño, especialmente para las {\slshape prefacturas}, aunque también puede usarse como una ``marca de agua'' para las facturas.
+%  Nombre del archivo de la imagen a cargar como diseño, especialmente para las {\slshape prefacturas}, aunque también puede usarse como una “marca de agua” para las facturas.
 %
-%  Lo que recomendamos es digitalizar la forma libre o pedir a la imprenta un archivo digital con el diseño y así incluir esa imagen con este comando cuando se vayan a producir ``prefacturas'' o cotizaciones, así las prefacturas tienen el mismo diseño que las facturas. Si se puede lograr el diseño en un código como se hace con el ejemplo del fondo, pues mejor aún.
+%  Lo que recomendamos es digitalizar la forma libre o pedir a la imprenta un archivo digital con el diseño y así incluir esa imagen con este comando cuando se vayan a producir “prefacturas” o cotizaciones, así las prefacturas tienen el mismo diseño que las facturas. Si se puede lograr el diseño en un código como se hace con el ejemplo del fondo, pues mejor aún.
 %
-% \DescribeMacro{\FondoReporte}{\color{RoyalBlue}|\FondoReporte|\marg{nombre del archivo de la imagen}}
 %
-%  Imagen a cargar {\bfseries solamente en la primera página del reporte} (e.g. un membrete). Cuando se usa este comando puede necesitarse usar también |\InicioReporte| para fijar el inicio de la primera página del reporte más abajo que las demás páginas cuyos márgenes están establecidos con |\GeometriaReporte|; esto porque la primera página tendría un ``margen superior'' distinto por la existencia del membrete.
+% }
 %
-% \DescribeMacro{\FondoReporte*}{\color{RoyalBlue}|\FondoReporte*|\marg{nombre del archivo de la imagen}}
 %
-%  Esta variante de |\FondoReporte| es para que la imagen esté visible {\bfseries en todas las páginas} y no solamente en la primera como con el comando anterior. Usando esta variante del fondo del reporte no es necesario usar |\InicioReporte| sino solamente establecer los márgenes del reporte de acuerdo a dicho fondo.
+% \subsubsection{Elementos fijos y sus ubicaciones}
 %
-% \DescribeMacro{\EstiloPagReporte}{\color{RoyalBlue}|\EstiloPagReporte|\oarg{estilo primera página}\marg{estilo páginas restantes}}
+% Los elementos cuyas posiciones van fijas en la hoja disponen de macros para establecer sus ubicaciones. Todas estas macros empiezan por |\Pos|, y son las siguientes: |\PosFecha|, |\PosDenom|, |\PosControl|, |\PosCondiciones| y |\PosFirmas|.
 %
-% Con este comando definimos el estilo de página para el reporte (véase el comando |\InfoPagina| y la subsección \ref{subsec:pagestyle}). El estilo de página es lo que cambiamos en \LaTeX{} con |\pagestyle|, o sea, lo relativo a las cabeceras y piés de página.
+% Todos estos comandos aceptan como argumentos dimensiones de \LaTeX{}, y son las posiciones |(x,y)| en la página de los elementos a imprimir, siendo “|x|” la coordenada a lo ancho del papel y “|y|” la coordenada a lo largo del papel, es decir, horizontal y vertical respectivamente. El origen está fijado arriba a la izquierda. Se pueden especificar también valores negativos para denotar que estamos contando desde el extremo derecho o inferior, para el caso de “|x|” o “|y|”, respectivamente\footnote{Varias de estas variables están definidas de esta forma negativa en el archivo de definiciones.}.
 %
-% Con este comando podemos asignar un estilo de página para la primera página del reporte y otro estilo de página para el resto de las páginas. La primera página del reporte pudiera tener un estilo de página distinto por la presencia del membrete si se usa el comando |\FondoReporte| sin ``|*|'', por lo cual puede quererse no poner cabeceras en la primera página pero sí en las demás.
+% Por ejemplo, si queremos que la fecha aparezca desde el margen izquierdo y |5cm| contados desde arriba hacia abajo, haríamos: |\PosFecha{0cm}{5cm},| y si queremos que salga |1cm| desde la derecha y |4cm| contados desde abajo haríamos |\PosFecha{-1cm}{-4cm}|. A continuación todas las macros para fijar las posiciones en el papel:
 %
-% Como vemos de la sintaxis de esta macro, el argumento obligatorio es el del resto de las páginas y el opcional es el que aplica a la primera página. El opcional se pone entre corchetes antes del otro, pero si se omite, todas las páginas toman el estilo especificado entre llaves.
+% {\setlength{\parindent}{0pt}
 %
-% Si no se usa esta macro la clase asume un comportamiento apropiado teniendo en cuenta si se especifica |\FondoReporte| o |\FondoReporte*| para evitar solapamiento de textos, como se explica también en la subsección \ref{subsec:pagestyle}.
+% \DescribeMacro{\PosFecha}{\color{RoyalBlue}|\PosFecha|\marg{pos. x}\marg{pos. y}}
 %
-% La información que aparece como cabecera o como pié de página es la que damos con el comando |\InfoPagina|, explicado más adelante.
+%  Con |\PosFecha| controlamos dónde se ubica la caja que imprime la fecha en la hoja.
 %
-% La clase provee varios estilos de página, que también se explicarán en la subsección \ref{subsec:pagestyle}. En los ejemplos de reportes se puede ver el comportamiento del comando |\EstiloPagReporte|.
+% \DescribeMacro{\PosFecha*}{\color{RoyalBlue}|\PosFecha*|\marg{pos. x}\marg{pos. y}}
 %
-% \DescribeMacro{\InicioReporte}{\color{RoyalBlue}|\InicioReporte|\marg{longitud}}
+%  Con esta variante con “*”, es decir, |\PosFecha*|, logramos que la caja de la fecha abra hacia arriba desde la posición especificada en el eje vertical, de manera que estaríamos especificando una coordenada “|y|” final del texto y no una posición inicial, esto significa que el texto se despliega hacia arriba desde la posición dada y no hacia abajo. Por ejemplo, sin “*”, si especificamos |\PosFecha{-0cm}{5cm}|, las fechas empiezan 5cm desde el tope superior de la hoja, y si especificamos |\PosFecha*{-0cm}{5cm}| ellas terminarán en los 5cm de la hoja. Esto es útil cuando se especifica también |\Credito| que produce una fecha de vencimiento que aparecerá abajo de la fecha de emisión; al ocupar las fechas más de una línea podemos querer que la última fecha (la de vencimiento) quede alineada en cierta posición vertical, la misma posición donde saldría la fecha de emisión en el caso en el que no haya fecha de vencimiento por no especificar la factura a crédito.
 %
-%  Con este comando -cuyo argumento es una longitud de \LaTeX{}- se agrega una distancia extra donde inicia el texto en la primera página del reporte cuando se usa |\FondoReporte| sin ``|*|''. Este comando sólo aplica cuando en el reporte se fija un fondo para que salga solamente en la primera página (comando |\FondoReporte| en su versión sin ``|*|''). La motivación de esto es corregir la alteración que produce un membrete que va a salir solamente en la primera página; si el membrete estuviera en todas las páginas no es necesario hacer esto sino fijar los márgenes adecuadamente con |\GeometriaReporte|. Si en el reporte no se fija un fondo o se fija el fondo para todas las páginas (comando |\FondoReporte*|), lo que se establezca con |\InicioReporte| es ignorado. En estos dos casos los márgenes deben establecerse con |\GeometriaReporte|.
+% \DescribeMacro{\PosDenom}{\color{RoyalBlue}|\PosDenom|\marg{pos. x}\marg{pos. y}}
 %
-% \DescribeMacro{\FirmaFactura}{\color{RoyalBlue}|\FirmaFactura|\marg{inclusión de la imagen}\oarg{corrimiento en x}\oarg{corrimiento en y}}
+%  Con |\PosDenom| controlamos dónde se ubica la caja que imprime la denominación del documento (e.g. “FACTURA”, “COTIZACIÓN”) y su -opcional- número.
 %
-%  Incluye el archivo de la firma digitalizada en el espacio donde firma el emisor del documento. Los argumentos son:
-%  \begin{enumerate}
-%   \item inclusión de la imagen (e.g. |\includegraphics|). {\bfseries Aquí el primer argumento no es el archivo de la imagen sino el comando que la inserta en el documento}, así el usuario tiene más control sobre cómo saldrá la imagen si altera las opciones de |\includegraphics|.
-%   \item corrimiento en |X| de la imagen, para un ajuste más fino de la posición de la firma,
-%   \item corrimiento en |Y|.
-%   \end{enumerate}
-%  {\itshape (Sin especificar los corrimientos, la firma quedará centrada horizontalmente en la línea, dejando hacia la izquiera y hacia la derecha la misma cantidad de la línea. También quedará toda la firma encima de la línea, lo cual muy probablemente haya que corregirlo porque las firmas tienen ``profundidad'' de texto, que significa que hay parte de algunas letras que sobresalen hacia abajo respecto a la línea base del texto. Por todo esto es muy probable el uso de los corrimientos. Pueden verse los ejemplos, que allí se usan los corrimientos.)}
+% \DescribeMacro{\PosDenom*}{\color{RoyalBlue}|\PosDenom*|\marg{pos. x}\marg{pos. y}}
 %
-%  {\bfseries Las facturas no llevan firma porque se supone que el documento es auténtico ya que viene avalado por una imprenta registrada y tiene los números correlativos impresos desde la imprenta, de manera que la factura no necesita la firma de quien la emite; razón por la cual el texto debajo de la línea del emisor en la factura dice ``PAGADO'', porque el emisor firma la factura una vez que haya sido pagada como constancia para el cliente.} Entonces agregar la firma escaneada es una posibilidad que debe contemplarse solamente con las cotizaciones, usando también el comando |\Emisor|, ya que no nos interesaría que apareciera ``PAGADO'' en ese caso sino algún nombre de quien está emitiendo la cotización.
+%  Al igual que con |\PosFecha*| podemos especificar la posición final en “|y|” de la caja para la denominación, así el texto se despliega hacia arriba y no hacia abajo.
 %
-% \DescribeMacro{\FirmaReporte}{\color{RoyalBlue}|\FirmaReporte|\oarg{inclusión la imagen}\oarg{corr. en x}\oarg{corr. en y}\marg{texto}\oarg{pos. x}\oarg{long. línea}}
+% \DescribeMacro{\PosControl}{\color{RoyalBlue}|\PosControl|\marg{pos. x}\marg{pos. y}}
 %
-%  Incluye la firma para el final del reporte. Los argumentos son:
-%  \begin{enumerate}
-%   \item inclusión de la imagen (e.g. |\includegraphics|),
-%   \item corrimiento en |X| de la imagen, para un ajuste más fino de la posición de la firma,
-%   \item corrimiento en |Y|,
-%   \item texto debajo de la línea ({\itshape va entre llaves y no entre corchetes como los demás}. Pred: el dado mediante el comando |\Proveedor|, o en su defecto, |\Emisor|),
-%   \item posición en |X| del final de la línea, medida desde la derecha (predeterminado: 2cm),
-%   \item tamaño de la línea de la firma (pred: tamaño de la imagen o del nombre + 1.5cm extra).
-%  \end{enumerate}
-%  {\itshape {\bfseries Este comando es de los pocos que no es del preámbulo}; debe incluirse en el sitio en el reporte donde se quiera que la firma salga, es decir, al final del reporte y todos sus argumentos son opcionales, incluyendo el texto que va debajo de la línea, que se incluye entre llaves |{}| a pesar de ser opcional. Cuando no se especifica ningún argumento, sólo dibuja la línea para firmar y le escribe abajo el nombre dado con |\Proveedor| o en su defecto el dado con |\Emisor|.}
+%  Con |\PosControl| controlamos dónde se ubica la caja que imprime el número de control con la serie.
 %
-% \DescribeMacro{\TituloReporte}{\color{RoyalBlue}|\TituloReporte|\marg{texto}}
+% \DescribeMacro{\PosControl*}{\color{RoyalBlue}|\PosControl*|\marg{pos. x}\marg{pos. y}}
 %
-%  Especificamos un título para el reporte. Este título saldrá centrado al principio.
+%  También podemos pedir que la caja del número de control abra hacia arriba, es decir que la posición vertical sea tomada como la posición vertical final; para eso |\PosControl*|, igual que con |\PosFecha*| y |\PosDenom*|. 
 %
-% \DescribeMacro{\TituloReporte*}{\color{RoyalBlue}|\TituloReporte*|\marg{texto}}
+% \DescribeMacro{\PosCondiciones}{\color{RoyalBlue}|\PosCondiciones|\marg{pos. x}\marg{pos. y}}
 %
-%  Usando |\TituloReporte| u omitiendo su uso, la información que sale en las cabeceras o piés de página tiene que ver con el número de la factura que está asociada a ese reporte. Con esta variante de |\TituloReporte|, el título del reporte -especificado con este comando- saldrá escrito también en estas partes de la página en lugar del texto que indica que el reporte corresponde a determinada factura.
+%  Con |\PosCondiciones| controlamos dónde se ubica el texto de las condiciones del documento (está hecho con |\parbox|, acepta un párrafo como argumento) en la hoja. {\itshape {\bfseries La coordenada |X| no acepta valores negativos} porque el |\parbox| que coloca el texto con las condiciones llega siempre hasta el final del ancho del texto, o sea, hasta el margen derecho.}
 %
-% Puede usarse esta opción también en aquellos casos en los que se hace un reporte sin asociarlo a una factura, entonces el título del reporte es la información que sale en la cabecera o pie de cada página.
+% \DescribeMacro{\PosCondiciones*}{\color{RoyalBlue}|\PosCondiciones*|\marg{pos. x}\marg{pos. y}}
 %
-% \DescribeMacro{\InfoPagina}{\color{RoyalBlue}|\InfoPagina|\marg{texto}}
+%  De la misma manera como con los comandos precedentes, podemos especificar que la caja del párrafo para las condiciones abra hacia arriba, fijando una posición vertical final y no una posición inicial de las condiciones.
 %
-%  Establece el texto que aparece en la cabecera o pie de página del reporte.
+% \DescribeMacro{\PosFirmas}{\color{RoyalBlue}|\PosFirmas|\marg{pos. x-inicial}\marg{pos. x-final}\marg{pos. y}}
 %
-% {\itshape Si se quiere usar esta opción debe hacerse luego de definir el título del reporte porque si no el comando |\TituloReporte*| establece de nuevo la variable que |\InfoPagina| cambia.}
+%  Con |\PosFirmas| controlamos dónde se ubica la caja que dibuja las lineas para firmar en la factura. {\itshape Aquí delimitamos el intervalo en |X| donde van las firmas, por eso hay una coordenada inicial y una final. La inicial indica dónde empieza la primera linea (para que firme quien recibe), y la coordenada final establece dónde termina la segunda linea para firmar (para que firme el emisor de la factura), que va a estar al lado de la primera. Aquí las coordenadas |X| no aceptan valores negativos; la inicial va medida desde el margen izquierdo y la final va medida desde el margen derecho.}
 %
-% En |factura.def| hay dos definiciones relativas a la información que aparece en las cabeceras o piés de página: aquella que escribe el título y aquella que no, es decir, la que aplica con |\TituloReporte*| y la que aplica con |\TituloReporte|, que también el usuario podrá redefinir si lo necesita, pero lo más práctico sería usar esta macro para fijar el texto que se desee, y |\EstiloPagReporte| para fijarlo donde se quiera.
+% }
 %
+%
+% \subsubsection{Espaciado entre distintas partes. Estilo de los recuadros\label{subsec:espacioslineas}}
+%
+% Podemos cambiar distintos valores del espaciado interno en la factura, así como también la estética de la línea para firmar y los recuadros que encierran los datos del cliente, la descripción, las notas y las condiciones, pudiendo ajustarle estos recuadros o cajas el grosor de la línea, la curvatura y la sombra. Los argumentos de todos estos comandos son dimensiones de \LaTeX{}:
+%
+% {\setlength{\parindent}{0pt}
+%
+% \DescribeMacro{\SepVertical}{\color{RoyalBlue}|\SepVertical|\marg{sep. vertical entre elementos}}
+%
+%  Las distintas partes de la factura (a saber: el encabezado con los datos, la -opcional- nota previa, el cuadro de la factura, la -opcional- nota externa y la -opcional- descripción) también están separadas entre sí una distancia que puede ser cambiada.
+%
+%  La separación que se fija con este comando es la separación vertical mínima que queremos garantizar entre cada elemento a escribir en la factura, y puede ser ajustada automáticamente por la clase aumentándola cuando no hay relleno automático de espacios sobrantes (es decir, sin usar la opción |sinexpandir|). Cuando la descripción larga o el cuadro de la factura (usando la opción |expandecuadro|) toman su tamaño máximo, entonces la separación vertical entre cada elemento de la hoja es la dada con |\SepVertical|, o sea, la que queremos garantizar como la mínima separación entre esas partes.
+%
+% \DescribeMacro{\SepDatosResumen}{\color{RoyalBlue}|\SepDatosResumen|\marg{sep. horizontal}}
+%
+%  Esta macro nos proporciona una forma de cambiar la separación entre los recuadros o cajas donde van los datos del cliente y el resumen que sale a su lado. Naturalmente, si no se escribe un resumen saldría únicamente la caja de los datos del cliente, y esta separación no tendría efecto.
+%
+% \DescribeMacro{\SepEncabezado}
+% \DescribeMacro{\SepNotaPrevia}
+% \DescribeMacro{\SepDescripcion}
+% \DescribeMacro{\SepCondiciones}
+% {\color{RoyalBlue}|\SepEncabezado|\marg{sep. interna texto}}\newline
+% {\color{RoyalBlue}|\SepNotaPrevia|\marg{sep. interna texto}}\newline
+% {\color{RoyalBlue}|\SepDescripcion|\marg{sep. interna texto}}\newline
+% {\color{RoyalBlue}|\SepCondiciones|\marg{sep. interna texto}}
+%
+%  Con estas macros podemos controlar la distancia entre la línea del recuadro y el texto que hay en el recuadro, es decir, un margen interno entre el contorno de la caja y el texto para que no salga pegado a la línea que lo encierra. Esto es parte del diseño de \tikz de estos recuadros. Como puede verse, dicho margen para los datos del cliente y para el resumen se cambia con |\SepEncabezado|, los de la nota previa con |\SepNotaPrevia|, los de la descripción larga con |\SepDescripcion|, y los de las condiciones con |\SepCondiciones|.
+%
+% Predeterminadamente no hay línea ni diseño de \tikz para las condiciones del documento, así que el valor fijado aquí no tiene efecto a menos de que se le especifiquen valores a dicho recuadro con la opción |\LineaCondiciones|, explicada más abajo.
+%
+% \DescribeMacro{\SepItemsExtra}{\color{RoyalBlue}|\SepItemsExtra|\marg{sep. extra entre items}}
+%
+%  Agrega una separación extra entre los elementos o ítems en el cuadro de la factura. La separación entre ítems está dada por el \cs{baselineskip} que se puede establecer con el comando |\LetraItems|, el cual se explicará más adelante en esta misma sección.
+%
+% \DescribeMacro{\SepFilas}{\color{RoyalBlue}|\SepFilas|\marg{sep. en x}\marg{sep. en y}}
+%
+%  Cuando se usa el modo de totalización en filas tenemos también la posibilidad de cambiar la separación entre los totales que salen uno al lado del otro, y la separación entre las distintas líneas.
+%
+%  El primer argumento de |\SepFilas| es la separación horizontal {\itshape mínima} entre los distintos totales que se presentan en el modo de totalización en filas. La clase |factura| expande esa distancia para que queden todos los totales separados igual, y también separados igual de los márgenes del papel.
+%
+%  El segundo argumento de |\SepFilas| es la separación vertical entre las distintas líneas de la totalización en filas.
+%
+% \DescribeMacro{\LineaEncabezado}
+% \DescribeMacro{\LineaNotaPrevia}
+% \DescribeMacro{\LineaDescripcion}
+% \DescribeMacro{\LineaCondiciones}
+% {\color{RoyalBlue}|\LineaEncabezado|\marg{grosor}\marg{curvatura esquinas}\marg{tamaño sombra}}\newline
+% {\color{RoyalBlue}|\LineaNotaPrevia|\marg{grosor}\marg{curvatura esquinas}\marg{tamaño sombra}}\newline
+% {\color{RoyalBlue}|\LineaDescripcion|\marg{grosor}\marg{curvatura esquinas}\marg{tamaño sombra}}\newline
+% {\color{RoyalBlue}|\LineaCondiciones|\marg{grosor}\marg{curvatura esquinas}\marg{tamaño sombra}}
+%
+%  La información del encabezado (datos del cliente y resumen), así como la nota previa, la descripción y las condiciones puede o no tener el diseño \tikz, el cual viene prehecho en el archivo |.def| y consiste en una línea curva, en algunos casos sombreada a la derecha y abajo, y en otros casos no. Esa línea puede ser alterada en su grosor, el tamaño de la sombra, y la distancia entre la línea y la información, es decir un margen interno. Para eso estos comandos, que se comportan igual todos ellos.
+%
+%  Con el primer argumento de estos comandos cambiamos el grosor de la línea\footnote{Si se especifica una dimensión nula, desaparece el diseño \tikz y la línea, quedando solamente un \cs{parbox}, y es así como se estableció en el archivo \texttt{.def} para el caso de las condiciones.} con la que las cajas del encabezado, la nota previa, la descripción y las condiciones se dibujan. Con el segundo argumento cambiamos el radio de curvatura de las esquinas, y con el tercero el tamaño de la sombra\footnote{Todas las sombras salen hacia abajo a la derecha.}.
+%
+%  Se puede modificar el diseño de este nodo de \tikz; está alojado en las macros internas |\@DatosTIKZ|, |\@NotaPreviaTIKZ|, |\@DescripcionTIKZ| y |\@CondicionesTIKZ|.
+%
+%  Lo predeterminado es que las  condiciones se escriban sin diseño de \tikz, es decir, el primer argumento de este comando está fijado en cero para que no salga línea ni diseño de \tikz.
+%
+% \DescribeMacro{\LineaFirmas}{\color{RoyalBlue}|\LineaFirmas|\marg{long. línea}\marg{grosor}}
+%
+%  La longitud de las líneas para firmar y el grosor son también ajustables por medio del primer y segundo argumento, respectivamente, de la macro |\LineaFirmas|.
+%
+%
+% \subsection{Sobre la información del cliente\label{subsec:cliente}}
+%
 % \DescribeMacro{\RazonSocial}{\color{Red}|\RazonSocial|\marg{texto}}
 %
 %  Define la razón social, o sea, el nombre del cliente.
@@ -898,11 +1031,11 @@
 %
 % \DescribeMacro{\Nombre}{\color{Red}|\Nombre|\marg{texto}}
 %
-%  Similar a |\RazonSocial| pero usable más bien para personas naturales, donde no existe una ``persona de contacto'' y por tanto la clase no advierte de su ausencia si no se ha especificado con |\Contacto|. Naturalmente se especifica un solo nombre del cliente, es decir que si se especifica con |\RazonSocial| no hace falta usar este comando. {\itshape Es preferible usar |\RazonSocial|.}
+%  Similar a |\RazonSocial| pero usable más bien para personas naturales, donde no existe una “persona de contacto” y por tanto la clase no advierte de su ausencia si no se ha especificado con |\Contacto|. Naturalmente se especifica un solo nombre del cliente, es decir que si se especifica con |\RazonSocial| no hace falta usar este comando. {\itshape Es preferible usar |\RazonSocial|.}
 %
 % \DescribeMacro{\RIF}{\color{Red}|\RIF|\marg{texto}}
 %
-%  Define el RIF del cliente.
+%  Define el R.I.F. del cliente.
 %
 % \DescribeMacro{\CI}{\color{Red}|\CI|\marg{texto}}
 %
@@ -916,7 +1049,7 @@
 %
 %  Define la dirección fiscal del cliente.
 %
-% \DescribeMacro{\Telefono}{\color{Red}|\Telefono|\marg{texto}}
+% \DescribeMacro{\Telefono}{\color{RoyalBlue}|\Telefono|\marg{texto}}
 %
 %  Especifica el (o los) teléfonos del cliente.
 %
@@ -926,33 +1059,108 @@
 %
 % \DescribeMacro{\Conforme}{\color{RoyalBlue}|\Conforme|\marg{texto}}
 %
-%  Especifica el texto que aparecerá debajo de la línea para que firme el cliente; si no se especifica tomará el texto por omisión, que es ``Recibí conforme'', indicando que el cliente le firma una copia al emisor de la factura donde acepta haber recibido y estar conforme. Este texto puede cambiarse a otro que puede ser el nombre del cliente o la persona de contacto.
+%  Especifica el texto que aparecerá debajo de la línea para que firme el cliente; si no se especifica tomará el texto por omisión, que es “Recibí conforme”, indicando que el cliente le firma una copia al emisor de la factura donde acepta haber recibido y estar conforme. Este texto puede cambiarse a otro que puede ser el nombre del cliente o la persona de contacto, o también “Por el cliente”.
 %
+%
+% \subsection{Sobre la información del emisor del documento}
+%
 % \DescribeMacro{\Emisor}{\color{RoyalBlue}|\Emisor|\marg{texto}}
 %
-%  Define el nombre del emisor de la factura. Si no se especifica saldrá el texto ``PAGADO''\footnote{El texto ``PAGADO'' es lo que la legislación venezolana del SENIAT exige escribir cuando una factura haya sido pagada.} debajo de la línea para firmar, ya que la factura se firma cuando haya sido pagada. Si se especifica un texto con este comando saldrá ese texto debajo de la línea donde va la firma, pero el propósito es que quede constancia para el cliente que ya pagó la factura, razón por la cual el texto predeterminado es el de ``PAGADO''.
+%  Define el nombre del emisor de la factura. Si no se especifica saldrá el texto “PAGADO”\footnote{El texto “PAGADO” es lo que la legislación venezolana del SENIAT exige escribir cuando una factura ha sido pagada.} debajo de la línea para firmar, ya que la factura se firma cuando haya sido pagada. Si se especifica un texto con este comando saldrá ese texto debajo de la línea donde va la firma, pero el propósito es que quede constancia para el cliente que ya pagó la factura, razón por la cual el texto predeterminado es “PAGADO”.
 %
 % \DescribeMacro{\Proveedor}{\color{RoyalBlue}|\Proveedor|\marg{texto}}
 %
 %  Establece el nombre del emisor, para los efectos del reporte. Si no se define mediante esta macro, será tomado del establecido con |\Emisor|.
 %
-% \DescribeMacro{\Fecha}{\color{Red}|\Fecha|\marg{fecha}}
+% \DescribeMacro{\FirmaFactura}{\color{RoyalBlue}|\FirmaFactura|\marg{inclusión de la imagen}\oarg{corrimiento en x}\oarg{corrimiento en y}}
 %
-%  Especifica la fecha de emisión del documento, en el formato venezolano DD/MM/AAAA.
+%  Incluye el archivo de la firma digitalizada en el espacio donde firma el emisor del documento. Los argumentos son:
+%  \begin{enumerate}
+%   \item inclusión de la imagen (e.g. |\includegraphics|). {\bfseries Aquí el primer argumento no es el archivo de la imagen sino el comando que la inserta en el documento}, así el usuario tiene más control sobre cómo saldrá la imagen si altera las opciones de |\includegraphics|.
+%   \item corrimiento en |X| de la imagen, para un ajuste más fino de la posición de la firma,
+%   \item corrimiento en |Y|.
+%   \end{enumerate}
+%  {\itshape (Sin especificar los corrimientos, la firma quedará centrada horizontalmente en la línea, dejando hacia la izquierda y hacia la derecha la misma cantidad de la línea. También quedará toda la firma encima de la línea, lo cual muy probablemente haya que corregirlo porque las firmas tienen “profundidad” de texto, que significa que hay parte de algunas letras que sobresalen hacia abajo respecto a la línea base del texto. Por todo esto es muy probable el uso de los corrimientos. Pueden verse los ejemplos, que allí se usan los corrimientos.)}
 %
+%  {\bfseries Las facturas no llevan firma porque se supone que el documento es auténtico ya que viene avalado por una imprenta registrada y tiene los números correlativos impresos desde la imprenta, de manera que la factura no necesita la firma de quien la emite; razón por la cual el texto debajo de la línea del emisor en la factura dice “PAGADO”, porque el emisor firma la factura una vez que haya sido pagada como constancia para el cliente.} Entonces agregar la firma escaneada es una posibilidad que debe contemplarse solamente con las cotizaciones, usando también el comando |\Emisor|, ya que no nos interesaría que apareciera “PAGADO” en ese caso sino algún nombre de quien está emitiendo la cotización.
+%
+%
+% \subsection{Relativos a la numeración del documento factura}
+%
+% \DescribeMacro{\Num}{\color{RoyalBlue}|\Num|\marg{núm}}
+%
+%  Define el número de la factura. Es opcional porque el talonario de las facturas puede ya tener la numeración. Es de obligatorio uso cuando se define |denom|, o |prefactura| sin usar |sinnumero|.
+%
+% \DescribeMacro{\NumControl}{\color{RoyalBlue}|\NumControl|\marg{núm}}
+%
+%  Define el número de control de la factura. Esta opción sólo aplica con |prefactura| puesto que una factura fiscal siempre tiene el número de control impreso desde la imprenta. Si se usa |prefactura| y no se define el número de control, éste tomará el mismo número de la factura.
+%
+% \DescribeMacro{\NumSerieControl}{\color{RoyalBlue}|\NumSerieControl|\marg{núm}}
+%
+%  Define el número de serie del número de control, también aplica solamente con |prefactura|. Si no se especifica, toma |00|.
+%
+% \DescribeMacro{\Denom}{\color{RoyalBlue}|\Denom|\marg{texto}}
+%
+%  Cambia el nombre del documento a algo distinto de “FACTURA” o “COTIZACIÓN”.
+%
+%
+% \subsection{Estableciendo la fecha del documento}
+%
+% \DescribeMacro{\Fecha}{\color{RoyalBlue}|\Fecha|\marg{fecha}}
+%
+%  Especifica la fecha de emisión del documento, en un formato que puede cambiarse con el comando |\FormatoFecha| pero predeterminadamente es el formato venezolano |dd-mm-aaaa|.
+%
+%  La fecha de emisión se guardará en el identificador “\texttt{FechaEmision}” perteneciente al paquete \texttt{datetime2} y podrá ser usado en cualquier parte del documento según las formas que provee dicho paquete.
+%
+%  {\itshape Si el usuario no provee la fecha, será tomada la fecha actual como la fecha de emisión y se producirá una advertencia indicando que no se especificó la fecha y que la fecha del documento es la fecha del día.}
+% 
+% \DescribeMacro{\Fecha*}{\color{RoyalBlue}|\Fecha*|\marg{aaaa}\marg{mm}\marg{dd}}
+%
+%  Esta variante del comando se incorporó para suministrar la fecha en formato ISO, es decir, primero el año, luego y mes y finalmente el día, cada uno como un parámetro separado del otro (como se hace en \texttt{datetime2}. Esto es independiente de la forma como la fecha será mostrada, o sea que puede la fecha suministrarse de esta forma e igual saldrá en el formato deseado, cambiable con la macro |\FormatoFecha|, explicado a continuación.
+%
+% \DescribeMacro{\FormatoFecha}{\color{RoyalBlue}|\FormatoFecha|\oarg{formato entrada}\marg{formato salida}\marg{separador}}
+%
+%  El comando |\FormatoFecha| le permite al usuario cambiar el formato de entrada de la fecha suministrada y el formato de salida de las fechas (cómo éstas salen escritas en la factura).
+%
+%  Con el primer argumento (opcional, dado entre corchetes) el usuario le puede decir a la clase cúal es el formato según el cual le suministrará la fecha con |\Fecha|; las posibilidades son: \begin{inparaenum}[\bfseries i)]\item |dd-mm-aaaa| (predeterminada), \item |dd.mm.aaaa|, \item |ddmmaaaa|, \item |aaaa-mm-dd|, \item |aaaa.mm.dd|, \item |aaaammdd| y \item |mm-dd-aaaa| \end{inparaenum}. Esto con el fin de establecer la fecha reconocida debidamente por |datetime2| y que sea posible su manejo como fecha y el posible cálculo de la fecha de vencimiento, si aplicara.
+%
+%  El segundo argumento (opcional también, dado entre llaves) le permite al usuario especificar el formato según el cual quiere que las fechas (emisión y vencimiento si aplica) salgan impresas en la factura. Estos son los formatos dados por \texttt{datetime2} y debe consultarse su documentación para más información. Entre ellos tenemos por ejemplo \begin{inparaenum}[\bfseries i)]\item |ddmmyyyy| (predeterminado), \item |default|, \item |iso|, \item |mmddyyyy| \end{inparaenum}.
+%
+%  El tercer argumento (opcional también, dado entre llaves) sirve para cambiar el separador, cuyo carácter predeterminado es el guión (“-”).
+%
+%  Con |\FormatoFecha|, al tener todos sus argumentos opcionales, el usuario podrá especificar solamente el primero (que va entre corchetes), solamente el segundo (entre llaves), pero para especificar el tercero que también está entre llaves debe especificar el segundo, ya que ambos son opcionales pero se dan igualmente entre llaves. Naturalmente podrá especificar dos de estos argumentos o los tres.
+%
+%  Por ejemplo: |\FormatoFecha[mm-dd-aaaa]{mmddyyyy}{.}| serviría para que el usuario pueda dar la fecha así: |\Fecha{12-31-2017}| y que salga igualmente según el formato |mm-dd-aaaa| pero separado por puntos. También puede usarse |\FormatoFecha[aaaa-mm-dd]| para dar luego la fecha de esta forma: |\Fecha{2017-12-31}| pero esta saldrá igual impresa en la factura así: “|31-12-2017|”, ya que no cambiamos el formato de salida. También puede hacer |\FormatoFecha{mmddyyyy}{/}| y dar la fecha por ejemplo así: |\Fecha*{2017}{12}{31}| y saldrá impresa así: “|12/31/2017|”.
+%
+%  Los valores predeterminados cambiables con |\FormatoFecha| están definidos, como siempre, en el archivo |factura.def|.
+%
+% \DescribeMacro{\Credito}{\color{RoyalBlue}|\Credito|\marg{días}}
+%
+%  Este comando, cuyo argumento es la cantidad de días, nos permite emitir una factura a crédito. La fecha de vencimiento será calculada automáticamente y será colocada debajo de la fecha de emisión, especificada por el usuario.
+%
+%  La fecha calculada automáticamente se guarda en el identificador “\texttt{FechaVencimiento}” perteneciente al paquete \texttt{datetime2}, de manera que el usuario podrá hacer uso de esta fecha con los comandos que este paquete provee.
+%
+% }
+%
+% 
+% \subsection{Descuentos en la totalización\label{subsec:dctototales}}
+%
+%  Podemos efectuar un descuento\footnote{Estas opciones de descuento en el subtotal no son compatibles con la opción de totalización en modo de |filas|, explicada en la sección \ref{sec:opciones}, y muy probablemente más adelante seguirán sin serlo.} sobre cualquiera de los subtotales; ese descuento puede ser porcentual (versión sin *) o dado en un monto fijo a sustraer del subtotal (variante con *). Podemos aplicar un descuento que aplique por igual a cualquier tipo de ítem con cualquier gravamen, o discriminado dependiendo del tipo de impuesto se aplica un descuento u otro.
+%
+% {\setlength{\parindent}{0pt}
+%
 % \DescribeMacro{\Descuento}{\color{RoyalBlue}|\Descuento|\marg{porcentaje}}\\
 % \DescribeMacro{\Descuento*}{\color{RoyalBlue}|\Descuento*|\marg{monto}}
-% \todo*{Las macros \cs{Descuento***} no son compatibles con la opción de totalización en modo de filas.}
 %
-%  Efectúa un descuento\footnote{Estas opciones de descuento en el subtotal no son compatibles con la opción de totalización en modo de |filas|, explicada en la sección \ref{sec:opciones}.} en el subtotal dado en porcentaje (versión sin *) o dado en un monto fijo a sustraer del subtotal (variante con *). Con este comando el descuento aplicaría por igual a cualquier subtotal presente, es decir, para elementos con cualquier gravamen y también exentos. Dichos descuentos son aplicados y mostrados al totalizar. Puede usarse inclusive cuando se aplican descuentos individuales que se incluyen con la opción de la clase |descuentos|.
+% Con este comando el descuento aplicaría por igual a cualquier subtotal presente, es decir, para elementos con cualquier gravamen y también exentos. Dichos descuentos son aplicados y mostrados al totalizar. Puede usarse inclusive cuando se aplican descuentos individuales que se incluyen con la opción de la clase |descuentos|.
 %
 % \DescribeMacro{\DescuentoG}{\color{RoyalBlue}|\DescuentoG|\marg{porcentaje}}\\
 % \DescribeMacro{\DescuentoG*}{\color{RoyalBlue}|\DescuentoG*|\marg{monto}}
 %
-% Descuento específico para los elementos gravados con IVA general.
+%  Descuento específico para los elementos gravados con IVA general.
 %
 % \DescribeMacro{\DescuentoR}{\color{RoyalBlue}|\DescuentoR|\marg{porcentaje}}\\
-% \DescribeMacro{\DescuentoR*}{\color{RoyalBlue}|\DescuentoR|*\marg{monto}}
+% \DescribeMacro{\DescuentoR*}{\color{RoyalBlue}|\DescuentoR*|\marg{monto}}
 %
 %  Descuento específico para los elementos gravados con IVA reducido.
 %
@@ -966,30 +1174,104 @@
 %
 %  Descuento específico para los elementos exentos de IVA.
 %
-% \DescribeMacro{\Num}{\color{RoyalBlue}|\Num|\marg{núm}}
 %
-%  Define el número de la factura. Es opcional porque el talonario de las facturas puede ya tener la numeración. Es de obligatorio uso cuando se define |denom|, o |prefactura| sin usar |sinnumero|.
+% \subsection{Textos explicativos en la factura\label{subsec:textos}}
 %
-% \DescribeMacro{\NumControl}{\color{RoyalBlue}|\NumControl|\marg{núm}}
+% \DescribeMacro{\Resumen}{\color{RoyalBlue}|\Resumen|\marg{texto}}
 %
-%  Define el número de control de la factura. Esta opción sólo aplica con |prefactura| puesto que una factura fiscal siempre tiene el número de control impreso desde la imprenta. Si se usa |prefactura| y no se define el número de control, éste tomará el mismo número de la factura.
+%  Pone un resumen que va en una caja a la derecha de los datos del cliente, separado de esta en una distancia ajustable con el comando |\SepEncabezado|, que se describirá más adelante. Este resumen es opcional.
 %
-% \DescribeMacro{\NumSerieControl}{\color{RoyalBlue}|\NumSerieControl|\marg{núm}}
+% \DescribeMacro{\NotaPrevia}{\color{RoyalBlue}|\NotaPrevia|\marg{texto}}
 %
-%  Define el número de serie del número de control, también aplica solamente con |prefactura|. Si no se especifica, toma |00|.
+%  La nota previa es una nota que puede ponerse antes del cuadro de la factura. Sin especificarla no sale nota alguna. Dicha nota va en un recuadro \tikz cuyo aspecto puede cambiarse, como ya se mencionó en la sección \ref{subsec:espacioslineas} donde se explican las líneas o contornos.
 %
-% \DescribeMacro{\Denom}{\color{RoyalBlue}|\Denom|\marg{texto}}
+% \DescribeMacro{\NotaInterna}{\color{RoyalBlue}|\NotaInterna|\marg{texto}}
 %
-%  Cambia el nombre del documento a algo distinto de ``FACTURA'' o ``COTIZACIÓN''.
+%  La nota interna es una coletilla que aparece dentro del cuadro de la factura, por eso la llamamos interna (es interna al cuadro), por ejemplo si aplicamos un descuento podemos decir allí cerca de los totales a qué corresponde tal descuento, o para hacer alguna aclaratoria sobre lo que precede inmediatamente como algún ítem de la factura.
 %
-% \DescribeMacro{\Condiciones}{\color{Red}|\Condiciones|\marg{texto}}
+% \DescribeMacro{\NotaExterna}{\color{RoyalBlue}|\NotaExterna|\marg{texto}}
 %
-%  Con este comando se establece el texto que esclarece las condiciones del documento, por ejemplo para las condiciones de pago si se trata de una factura, o para las condiciones de una cotización. Este comando es de obligatorio uso salvo cuando la clase se cargue con la opción |sincondiciones|. También se puede destinar este espacio para un diseño (que haría el usuario) en el que se agreguen también algunas casillas para especificar la forma de pago.
+%  La nota externa es otro texto opcional que el usuario puede introducir y saldrá al terminar el cuadro de la factura, antes de la opcional descripción larga (comando |\Descripcion|). {\itshape La nota externa no tiene formato \tikz.}
 %
-% \DescribeMacro{\Resumen}{\color{RoyalBlue}|\Resumen|\marg{texto}}
+% \DescribeMacro{\Condiciones}{\color{RoyalBlue}|\Condiciones|\marg{texto}}
 %
-%  Pone un resumen que va en una caja a la derecha de los datos del cliente, separado de esta en una distancia ajustable con el comando |\SepEncabez|, que se describirá más adelante. Este resumen es opcional.
+%  Con este comando se establece el texto que esclarece las condiciones del documento, por ejemplo para las condiciones de pago si se trata de una factura, o para las condiciones de una cotización. Es opcional; si no se define no sale texto alguno. También se puede destinar este espacio para un diseño (que haría el usuario) en el que se agreguen también algunas casillas para especificar la forma de pago.
 %
+%
+% \subsection{Estableciendo los parámetros relativos al reporte}
+%
+% \DescribeMacro{\GeometriaReporte}{\color{RoyalBlue}|\GeometriaReporte|\marg{geometría}}
+%
+%  Aquí van los parámetros relativos al paquete |geometry| que van a afectar la manera como el reporte es generado, de la misma manera como se definieron los márgenes para la factura.
+%
+%  Puesto que el reporte no se imprime en hojas de facturas sino en hojas en blanco, el usuario podrá cambiar la geometría del papel completamente a su gusto sin las restricciones impuestas por el diseño que tengan sus facturas. En |factura.def| se definen unos márgenes razonables para un reporte. Si el reporte y la factura usaran un tamaño distinto de papel, entonces al imprimirse ambos juntos (opción |conreporte|), el reporte tomará el tamaño físico del papel especificado para la factura ya que con el paquete |geometry| no podemos cambiar el tamaño del papel en el medio del documento, aunque sí sus márgenes. Entonces, si se quiere imprimir el reporte en un papel de otro tamaño, tendrán que imprimirse ambos documentos por separado, o sea, primero uno y después el otro.
+%
+% \DescribeMacro{\FondoReporte}{\color{RoyalBlue}|\FondoReporte|\marg{nombre del archivo de la imagen}}
+%
+%  Imagen a cargar {\bfseries solamente en la primera página del reporte} (e.g. un membrete). Cuando se usa este comando puede necesitarse usar también |\InicioReporte| para fijar el inicio de la primera página del reporte más abajo que las demás páginas cuyos márgenes están establecidos con |\GeometriaReporte|; esto porque la primera página tendría un “margen superior” distinto por la existencia del membrete.
+%
+% \DescribeMacro{\FondoReporte*}{\color{RoyalBlue}|\FondoReporte*|\marg{nombre del archivo de la imagen}}
+%
+%  Esta variante de |\FondoReporte| es para que la imagen esté visible {\bfseries en todas las páginas} y no solamente en la primera como con el comando anterior. Usando esta variante del fondo del reporte no es necesario usar |\InicioReporte| sino solamente establecer los márgenes del reporte de acuerdo a dicho fondo.
+%
+% \DescribeMacro{\EstiloPagReporte}{\color{RoyalBlue}|\EstiloPagReporte|\oarg{estilo primera página}\marg{estilo páginas restantes}}
+%
+%  Con este comando definimos el estilo de página para el reporte (véase el comando |\InfoPagina| y la subsección \ref{subsec:pagestyle}). El estilo de página es lo que cambiamos en \LaTeX{} con |\pagestyle|, o sea, lo relativo a las cabeceras y pies de página.
+%
+%  Con este comando podemos asignar un estilo de página para la primera página del reporte y otro estilo de página para el resto de las páginas. La primera página del reporte pudiera tener un estilo de página distinto por la presencia del membrete si se usa el comando |\FondoReporte| sin “|*|”, por lo cual se puede querer no poner cabeceras en la primera página pero sí en las demás.
+%
+%  Como vemos de la sintaxis de esta macro, el argumento obligatorio es el del resto de las páginas y el opcional es el que aplica a la primera página. El opcional se pone entre corchetes antes del otro, pero si se omite, todas las páginas toman el estilo especificado entre llaves.
+%
+%  Si no se usa esta macro la clase asume un comportamiento apropiado teniendo en cuenta si se especifica |\FondoReporte| o |\FondoReporte*| para evitar solapamiento de textos, como se explica también en la subsección \ref{subsec:pagestyle}.
+%
+%  La información que aparece como cabecera o como pie de página es la que damos con el comando |\InfoPagina|, explicado más adelante.
+%
+%  La clase provee varios estilos de página, que también se explicarán en la subsección \ref{subsec:pagestyle}. En los ejemplos de reportes se puede ver el comportamiento del comando |\EstiloPagReporte|.
+%
+% \DescribeMacro{\InicioReporte}{\color{RoyalBlue}|\InicioReporte|\marg{longitud}}
+%
+%  Con este comando -cuyo argumento es una longitud de \LaTeX{}- se agrega una distancia extra donde inicia el texto en la primera página del reporte cuando se usa |\FondoReporte| sin “|*|”. Este comando sólo aplica cuando en el reporte se fija un fondo para que salga solamente en la primera página (comando |\FondoReporte| en su versión sin “|*|”). La motivación de esto es corregir la alteración que produce un membrete que va a salir solamente en la primera página; si el membrete estuviera en todas las páginas no es necesario hacer esto sino fijar los márgenes adecuadamente con |\GeometriaReporte|. Si en el reporte no se fija un fondo o se fija el fondo para todas las páginas (comando |\FondoReporte*|), lo que se establezca con |\InicioReporte| es ignorado. En estos dos casos los márgenes deben establecerse con |\GeometriaReporte|.
+%
+% \DescribeMacro{\FirmaReporte}{\color{RoyalBlue}|\FirmaReporte|\oarg{inclusión la imagen}\oarg{corr. en x}\oarg{corr. en y}\marg{texto}\oarg{pos. x}\oarg{long. línea}}
+%
+%  Incluye la firma para el final del reporte. Los argumentos son:
+%  \begin{enumerate}
+%   \item inclusión de la imagen (e.g. |\includegraphics|),
+%   \item corrimiento en |X| de la imagen, para un ajuste más fino de la posición de la firma,
+%   \item corrimiento en |Y|,
+%   \item texto debajo de la línea ({\itshape va entre llaves y no entre corchetes como los demás}). El predeterminado es el dado mediante el comando |\Proveedor|, o en su defecto, |\Emisor|),
+%   \item posición en |X| del final de la línea, medida desde la derecha (predeterminado: 2cm),
+%   \item tamaño extra de la línea de la firma. La clase mide el tamaño del texto y de la imagen (si se especificó), y al que sea mayor le agrega este extra de línea para que sobresalga a los dos lados. (Predeterminado: tamaño de la imagen o del nombre + 1.5cm extra).
+%  \end{enumerate}
+%  {\itshape {\bfseries Este comando es de los pocos que no es del preámbulo}; debe incluirse en el sitio en el reporte donde se quiera que la firma salga, generalmente al final del reporte y todos sus argumentos son opcionales, incluyendo el texto que va debajo de la línea, que se incluye entre llaves |{}| a pesar de ser opcional. Cuando no se especifica ningún argumento, sólo dibuja la línea para firmar y le escribe abajo el nombre dado con |\Proveedor| o en su defecto el dado con |\Emisor|.}
+%
+% \DescribeMacro{\TituloReporte}{\color{RoyalBlue}|\TituloReporte|\marg{texto}}
+%
+%  Especificamos un título para el reporte. Este título saldrá centrado al principio del reporte.
+%
+% \DescribeMacro{\TituloReporte*}{\color{RoyalBlue}|\TituloReporte*|\marg{texto}}
+%
+%  Usando |\TituloReporte| u omitiendo su uso, la información que sale en las cabeceras o pies de página tiene que ver con el número de la factura que está asociada a ese reporte. Con esta variante con “|*|” de |\TituloReporte|, el título del reporte -especificado con este comando- saldrá escrito también en estas partes de la página en lugar del texto que indica que el reporte corresponde a determinada factura.
+%
+% Puede usarse esta opción también en aquellos casos en los que se hace un reporte sin asociarlo a una factura, entonces el título del reporte es la información que sale en la cabecera o pie de cada página.
+%
+% \DescribeMacro{\InfoPagina}{\color{RoyalBlue}|\InfoPagina|\marg{texto}}
+%
+%  Establece el texto que aparece en la cabecera o pie de página del reporte.
+%
+% {\itshape Si se quiere usar esta opción debe hacerse luego de definir el título del reporte porque si no el comando |\TituloReporte*| establece de nuevo la variable que |\InfoPagina| cambia.}
+%
+%  En |factura.def| hay dos definiciones relativas a la información que aparece en las cabeceras o pies de página: aquella que escribe el título y aquella que no, es decir, la que aplica con |\TituloReporte*| y la que aplica con |\TituloReporte|, que también el usuario podrá redefinir si lo necesita, pero lo más práctico sería usar esta macro para fijar el texto que se desee, y |\EstiloPagReporte| para fijarlo donde se quiera.
+%
+%
+% \subsection{Definiciones en archivos separados \label{subsec:aux}}
+%
+% \DescribeMacro{\Cliente}{\color{RoyalBlue}|\Cliente|\marg{archivo \LaTeX}}
+%
+%  {\bfseries Todos los comandos definibles en el preámbulo que alteren la forma como el reporte o la factura es presentada, así como cualquier variable definida en |factura.def| se puede redefinir y agregar a otro archivo |.tex| o |.def| que el usuario cargue en el preámbulo con |\input|, |\include| o con el comando |\Cliente|; el comando para el cliente existe para que el usuario pueda definir archivos |.tex| o |.def| con los valores específicos que aplican para cada cliente.}
+%
+%  La macro |\Cliente| incluye un archivo cuya extensión debe ser |.def| o |.tex|, de la misma forma como se hace con |\input|; es simplemente un atajo que además lee archivos |.def|.
+%
 % }
 %
 %
@@ -996,7 +1278,7 @@
 % \section{La factura\label{sec:factura}}
 %
 % \DescribeEnv{factura}
-% La parte del documento donde se agregan los elementos a facturar no se escribe en el preámbulo sino luego de |\begin{document}|, dentro de un ambiente especial para su tratamiento, llamado |factura|, que produce el cuadro de la factura, y naturalmente se usa así:
+% La parte del documento donde se agregan los elementos a facturar se escribe dentro de un entorno especial para su tratamiento, llamado |factura|, que produce el cuadro de la factura:
 % \iffalse
 %<*literal>
 % \fi
@@ -1009,8 +1291,9 @@
 %</literal>
 % \fi
 %
-% Dentro de dicho ambiente tenemos únicamente los comandos que incluyen los elementos a facturar; esos comandos son, para distintos gravámenes, los siguientes:
+% Dentro de dicho ambiente podemos usar únicamente los comandos que incluyen los elementos a facturar y las posibles etiquetas; esos comandos son, para distintos gravámenes, los siguientes:
 %
+%
 % \subsection{Agregando elementos a la factura}
 %
 % \noindent
@@ -1018,15 +1301,18 @@
 % \DescribeMacro{\ItemR}
 % \DescribeMacro{\ItemA}
 % \DescribeMacro{\ItemE}
-% {\color{Red}|\Item|\marg{cantidad}\marg{descripción}\marg{precio unitario}}
+% {\color{Red}|\Item|\marg{cantidad}\marg{descripción}\oarg{descripción para csv}\marg{precio unitario}}
 %
-% Con estos comandos agregamos elementos a la factura propiamente dicha. Con |\Item| agregamos un elemento gravado con IVA general (actualmente 12\%); con |\ItemR| agregamos uno con IVA reducido (8\%), con |\ItemA| uno con IVA adicional (22\%), y con |\ItemE| agregamos un elemento exento de impuesto al valor agregado.
+% Con estos comandos agregamos elementos a la factura propiamente dicha. Con |\Item| agregamos un elemento gravado con IVA general (actualmente 12\%); con |\ItemR| agregamos uno con IVA reducido (8\%), con |\ItemA| uno con IVA adicional (27\%), y con |\ItemE| agregamos un elemento exento de impuesto al valor agregado.
 %
+% Como podemos ver, se especifica la cantidad, luego la descripción y al final el precio unitario, todos entre llaves, pudiendo intercalar entre estos dos últimos un parámetro adicional entre corchetes que sirve para escribir otro texto al archivo |.csv| en sustitución de la descripción, ya que a veces la descripción puede tener macros o caracteres no imprimibles; si se declara una descripción y una descripción para el |.csv|, la factura impresa manejará la descripción dada entre llaves y al archivo |.csv| se escribirá la descripción dada entre corchetes.
+%
 % También tenemos la posibilidad de agregar un ítem al que no le ponemos precio, por ejemplo por ser parte de un total, y sus argumentos son la cantidad y la descripción nada más.
 %
 % \noindent
-% \DescribeMacro{\ItemX}{\color{RoyalBlue}|\ItemX|\marg{cantidad}\marg{descripción}}
+% \DescribeMacro{\ItemX}{\color{RoyalBlue}|\ItemX|\marg{cantidad}\marg{descripción}\oarg{descripción para csv}}
 %
+%
 % \subsubsection{Opción `{\ttfamily descuentos}'\label{subsec:descuentos}}
 %
 % \noindent
@@ -1034,10 +1320,11 @@
 % \DescribeMacro{\ItemR}
 % \DescribeMacro{\ItemA}
 % \DescribeMacro{\ItemE}
-% {\color{Red}|\Item|\marg{cantidad}\marg{descripción}\marg{precio unitario}\marg{\% descuento}}
+% {\color{Red}|\Item|\marg{cantidad}\marg{descripción}\oarg{descripción para csv}\marg{precio unitario}\marg{\% descuento}}
 %
-% Cuando pedimos descuentos individuales (opción |descuentos| al cargar la clase), todas las macros |\Item| tienen un posible\footnote{Es un argumento opcional, aunque va entre llaves como todos los demás.} argumento más al final. que es el descuento porcentual. No especificarlo da el mismo resultado que un descuento de 0\% sobre ese ítem:
+% Cuando pedimos descuentos individuales (opción |descuentos| al cargar la clase), todas las macros |\Item| tienen un posible\footnote{Es un argumento opcional, aunque va entre llaves como todos los demás.} argumento más al final que es el descuento porcentual. No especificarlo da el mismo resultado que un descuento de 0\% sobre ese ítem:
 %
+%
 % \subsubsection{Opción `{\ttfamily sincantidad}'\label{subsec:sincantidad}}
 %
 % \noindent
@@ -1045,33 +1332,57 @@
 % \DescribeMacro{\ItemR}
 % \DescribeMacro{\ItemA}
 % \DescribeMacro{\ItemE}
-% {\color{Red}|\Item|\marg{descripción}\marg{precio unitario}}
+% {\color{Red}|\Item|\marg{descripción}\oarg{descripción para csv}\marg{precio unitario}}
 %
-% \noindent {\color{Red}|\Item|\marg{descripción}\marg{precio unitario}\marg{\% descuento}}
+% \noindent {\color{Red}|\Item|\marg{descripción}\oarg{descripción para csv}\marg{precio unitario}\marg{\% descuento}}
 %
 % Por otra parte, si se usa la opción |sincantidad| al cargar la clase, todos los comandos |\Item| aceptan un argumento menos, que es el de la cantidad; eso significa que sin usar la opción |descuentos|, la sintaxis de |\Item| queda como lo indica la primera línea, y usando |descuentos|, queda como lo indica la segunda línea.
 %
 % \noindent
-% \DescribeMacro{\ItemX}{\color{RoyalBlue}|\ItemX|\marg{descripción}}
+% \DescribeMacro{\ItemX}{\color{RoyalBlue}|\ItemX|\marg{descripción}\oarg{descripción para csv}}
 % 
-% Puesto que |\ItemX| se usa para argumentos sin precio, al usar |sincantidad| quedará aceptando solo un argumento, que es la descripción. Cuando se activa la opción |descuentos|, |\ItemX| queda igual puesto que esta macro no lleva precio, entonces tampoco acepta descuentos.
+% Puesto que |\ItemX| se usa para argumentos sin precio, al usar |sincantidad| quedará aceptando solo un argumento obligatorio que es la descripción, y el opcional para la descripción para el archivo |.csv|. Cuando se activa la opción |descuentos|, |\ItemX| queda igual puesto que esta macro no lleva precio, entonces tampoco acepta descuentos.
 %
 % {\itshape Todas las variaciones de estos comandos |\Item| pueden apreciarse en los ejemplos.}
 %
+%
 % \subsection{Descripción larga al final de la factura}
 %
+% Una vez terminado el entorno de la factura se puede escribir una descripción larga que saldrá en una caja -cuyo estilo puede cambiarse-\footnote{El diseño de esta descripción consiste en su linea de contorno, cambiable como ya explicamos en la subsección \ref{subsec:espacioslineas}, específicamente con la macro \cs{LineaDescripcion}.} debajo del cuadro de la factura, esto va dentro de un \cs{parbox} en la implementación de la caja. Si esta descripción no se escribe, simplemente no va a aparecer nada debajo del cuadro de la factura.
 %
-% Una vez terminado el ambiente de la factura se puede escribir una descripción larga que saldrá en una caja -cuyo estilo puede cambiarse- debajo del cuadro de la factura. Si esta descripción no se escribe, simplemente no va a aparecer nada debajo del cuadro de la factura.
-%
 % \noindent \DescribeMacro{\Descripcion}
 % {\color{RoyalBlue}|\Descripcion|\marg{texto en formato de párrafos}}
 %
-% {\itshape Como podemos ver, |\Descripcion| es otro de los pocos comandos que no se usan en el preámbulo sino que se escribe jústamente al terminar el ambiente} |factura|.
+% {\itshape Como podemos ver, |\Descripcion| es otro de los pocos comandos que no se usan en el preámbulo sino dentro del documento, jústamente al terminar el ambiente} |factura|.
 %
+%
+% \section{Reverso de la factura}
+%
+% \DescribeEnv{reverso}
+%  La factura puede tener información escrita en su reverso, por ejemplo para condiciones cuando estas necesitan mucho espacio. Ese texto se escribe dentro de un entorno llamado |reverso|, que puede o no incluirse según el requerimiento del usuario. si está escrito en el documento fuente también podrá decidirse si se incluye o no en el documento compilado.
+%
+% \iffalse
+%<*literal>
+% \fi
+\begin{verbatim}
+\begin{reverso}
+ (Aquí va toda la información que irá escrita
+  en el reverso de la hoja de la factura.)
+\end{reverso}
+\end{verbatim}
+% \iffalse
+%</literal>
+% \fi
+%
+% El reverso de la factura va escrito con la tipografía que el usuario elije con el comando |\LetraReverso|, como se explicará en la sección \ref{sec:tipografia}, y las dimensiones de la página se establecen con el comando |\GeometriaReverso| (sección \ref{sec:comandos}). Dicha geometría viene con un valor predeterminado en el |.def|.
+%
+% Si se compila con la opción |sinreverso|, lo escrito dentro del ambiente |reverso| no saldrá como reverso en la hoja de la factura.
+%
+%
 % \section{El reporte}
 %
 % \DescribeEnv{reporte}
-% Para elaborar un reporte, lo único que se debe hacer es escribir el texto del reporte dentro del ambiente para ese fin, que se llama |reporte|, de manera que en el documento tenemos un ambiente para la factura y otro para el reporte, eligiendo al momento de compilar qué es lo que queremos obtener.
+%  Para elaborar un reporte, lo único que se debe hacer es escribir el texto del reporte dentro del ambiente para ese fin, que se llama |reporte|, de manera que en el documento tenemos un ambiente para la factura y otro para el reporte, y elegimos al momento de compilar qué es lo que queremos obtener.
 %
 % \iffalse
 %<*literal>
@@ -1089,214 +1400,149 @@
 %
 % Cuando se compila con |soloreporte|, el motor de compilación no procesa la factura en favor del reporte, y sin especificar ninguna de estas dos opciones, el reporte es ignorado y sale únicamente la factura (o la prefactura o cotización).
 %
+% El reporte empieza con un encabezado y luego un título especificable; el encabezado consiste en el nombre del proveedor, el nombre del cliente y la persona de contacto. Luego de ese encabezado viene el título del reporte y después empieza lo que el usuario escriba dentro del entorno del reporte.
+%
 % Hay que tener en cuenta que, como se explicó en la sección \ref{sec:comandos}, el reporte puede tener una imagen de fondo, que puede ser un membrete. Ese membrete, si se quiere en todas las páginas deberá incluirse con |\FondoReporte*|, y si se quiere sólo en la primera página del reporte deberá usarse |\FondoReporte|. Ahora, si se usa la versión sin |*|, será necesario también usar |\InicioReporte| con una distancia para empezar a escribir un poco más abajo en la primera página, ya que es la única que tiene el membrete. Pero si se usa la versión con |*|, entonces basta fijar los márgenes para todas las páginas con |\GeometriaReporte|, tal como se adelantó en la sección \ref{sec:comandos}.
 %
+% El reporte estará escrito con la tipografía especificable con |\LetraReporte|, como se explicará más adelante en la sección \ref{sec:tipografia}.
+%
 % Por otra parte, al reporte se le asigna un título, que puede aparecer o no en la cabecera de página o en el pie de página. Si se quiere que aparezca el título en esos lugares, debe usarse |\TituloReporte*|, de lo contrario, |\TituloReporte|. Si no se especifica el título, entonces la información mostrada allí es la referencia a la factura asociada a este reporte, como se comentó antes cuando se introdujeron estos comandos.
 %
+%
 % \subsection{Estilos de página para el reporte\label{subsec:pagestyle}}
 %
 % La clase define varios estilos de página\footnote{Usables en el reporte únicamente.} de \LaTeX{}, cambiables con los comandos usuales: |\pagestyle| y |\thispagestyle| dentro del entorno del reporte, pero es mejor definir el estilo de página en el preámbulo del documento, con |\EstiloPagReporte|.
 %
-% Estos estilos de página son: \begin{inparaenum}[\bfseries i)]\item |plain|, \item |empty|, \item |soloarriba|, \item |soloabajo|, y \item |solonumpag|\end{inparaenum}.
+% Estos estilos de página están definidos con el paquete |fancyhdr|, y son: \begin{inparaenum}[\bfseries i)]\item |plain|, \item |empty|, \item |soloarriba|, \item |soloabajo|, y \item |solonumpag|\end{inparaenum}.
 %
 % Con |plain|\footnote{Por razones de compatibilidad usamos dos estilos de página conocidos en \LaTeX, que son |plain| y |empty|, siendo |plain| uno de nuestros predeterminados.}, en la cabecera saldrá la información sobre el reporte y en el pie de página saldrá el número de página; con |empty| no sale nada en ninguna parte; con |soloarriba| y |soloabajo|, toda esa información anterior sale en la cabecera o en el pie de página, respectivamente, y con |solonumpag|, lo único que aparece es el número de página centrado en el pie de página.
 %
 % El formato con la información a poner en estas partes de las páginas del reporte es cambiable con |\InfoPagina|, descrito anteriormente.
 %
-% Por último, cuando se usa |\FondoReporte*|, como se supone que se usa para un membrete en todas las páginas, el estilo de página predeterminado del reporte será |soloabajo|, para todas las páginas, porque no tendría sentido tener un membrete en todas las páginas y una cabecera como la descrita anteriormente. Si el comando |\FondoReporte*| se está usando para algo distinto de un membrete, por ejemplo una marca de agua, entonces es probable querer cambiar los estilos de página con |\EstiloPagReporte|.
+% Cuando se usa |\FondoReporte*|, como se supone que se usa para un membrete en todas las páginas, el estilo de página predeterminado del reporte será |soloabajo|, para todas las páginas, porque no tendría sentido tener un membrete en todas las páginas y una cabecera como la descrita anteriormente. Si el comando |\FondoReporte*| se está usando para algo distinto de un membrete, por ejemplo una marca de agua, entonces es probable querer cambiar los estilos de página con |\EstiloPagReporte|.
 %
 % Si se usa |\FondoReporte|, el estilo predeterminado para la primera página será |solonumpag|, y |plain| para el resto de las páginas, y si se no se especifica fondo alguno, entonces el estilo de página predeterminado para todas las páginas será |plain|.
 %
-% El usuario podrá definir más estilos de página adicionales para colocar el texto que se quiera en el lugar que se quiera, y usar esos estilos de página con |\EstiloPagReporte|. Para eso puede leer la documentación del paquete |fancyhdr|, que es lo que esta clase usa para los estilos de página. También puede consultar |factura.def|.
+% El usuario podrá definir más estilos de página adicionales para colocar el texto que se quiera en el lugar que se quiera, y usar esos estilos de página con |\EstiloPagReporte|. Para eso puede leer la documentación del paquete |fancyhdr|, que es lo que esta clase usa para los estilos de página. También puede consultar |factura.def|, que es donde están predefinidos los estilos que trae la clase.
 %
 % El grosor de la línea decorativa que coloca el paquete |fancyhdr| está definido en el archivo |.def|, y es cambiable en la macro |\@GrosorLineaInfoPag| como podrá verse en dicho archivo; no definimos un comando para ello por no ser algo relevante pero igual podrá cambiarse con |\renewcommand| por ejemplo, como se hace en dicho |.def|.
 %
-% \section{Elementos fijos y sus ubicaciones}
 %
-% Los elementos cuyas posiciones van fijas en la hoja disponen de macros para establecer sus ubicaciones. Todas estas macros empiezan por |\Pos|, y son las siguientes: |\PosFecha|, |\PosDenom|, |\PosControl|, |\PosCond| y |\PosFirmas|.
+% \section{Tipografías para cada elemento a escribir\label{sec:tipografia}}
 %
-% Todos estos comandos aceptan como argumentos dimensiones de \LaTeX{}, y son las posiciones |(x,y)| en la página de los elementos a imprimir, siendo ``|x|'' la coordenada a lo ancho del papel y ``|y|'' la coordenada a lo largo del papel, es decir, horizontal y vertical respectivamente. El origen está fijado arriba a la izquierda. Se pueden especificar también valores negativos para denotar que estamos contando desde el extremo derecho o inferior, para el caso de ``|x|'' y ``|y|'', respectivamente\footnote{Varias de estas variables están definidas de esta forma negativa en el archivo de definiciones.}.
+% Cada elemento escrito en la factura o reporte es sujeto a ser mostrado con una tipografía distinta, para lo cual existen comandos con los que se asigna el tipo de letra o estilo para cada cosa que sale escrita en el documento, por ejemplo, se puede cambiar el tipo de letra con el que se escribe la fecha, el tipo de letra con el que salen los elementos dentro del cuadro de la factura, el tipo de letra de los totales, de los títulos, de las cabeceras o pies de página en el reporte, etc.
 %
-% Por ejemplo, si queremos que la fecha aparezca |5cm| contados desde arriba hacia abajo, haríamos: |\PosFecha{0cm}{5cm},| y si queremos que salga |1cm| desde la derecha y |4cm| contados desde abajo haríamos |\PosFecha{-1cm}{-4cm}|. A continuación todas las macros para fijar las posiciones en el papel:
-%
-% {\setlength{\parindent}{0pt}
-% \DescribeMacro{\PosFecha}{\color{RoyalBlue}|\PosFecha|\marg{pos. x}\marg{pos. y}}
-%
-% Con |\PosFecha| controlamos dónde se ubica la caja que imprime la fecha en la hoja.
-%
-% \DescribeMacro{\PosDenom}{\color{RoyalBlue}|\PosDenom|\marg{pos. x}\marg{pos. y}}
-%
-% Con |\PosDenom| controlamos dónde se ubica la caja que imprime la denominación del documento (e.g. ``FACTURA'', ``COTIZACIÓN'') y su -opcional- número.
-%
-% \DescribeMacro{\PosControl}{\color{RoyalBlue}|\PosControl|\marg{pos. x}\marg{pos. y}}
-%
-% Con |\PosControl| controlamos dónde se ubica la caja que imprime el número de control con la serie.
-%
-% \DescribeMacro{\PosCond}{\color{RoyalBlue}|\PosCond|\marg{pos. x}\marg{pos. y}}
-%
-% Con |\PosCond| controlamos dónde se ubica el texto de las condiciones del documento (está hecho con |\parbox|, acepta un párrafo como argumento) en la hoja. {\itshape {\bfseries La coordenada |X| no acepta valores negativos} porque el |\parbox| que coloca el texto con las condiciones llega siempre hasta el final del ancho del texto, o sea, hasta el margen derecho.}
-%
-% \DescribeMacro{\PosFirmas}{\color{RoyalBlue}|\PosFirmas|\marg{pos. x-inicial}\marg{pos. x-final}\marg{pos. y}}
-%
-% Con |\PosFirmas| controlamos dónde se ubica la caja que dibuja las lineas para firmar en la factura. {\itshape Aquí delimitamos el intervalo en |X| donde van las firmas, por eso hay una coordenada inicial y una final. La inicial indica dónde empieza la primera linea (para que firme quien recibe), y la coordenada final establece dónde termina la segunda linea para firmar (para que firme el emisor de la factura), que va a estar al lado de la primera. Aquí las coordenadas |X| no aceptan valores negativos; la inicial va medida desde el margen izquierdo y la final va medida desde el margen derecho.}
-%
-% }
-%
-% \section{Otros ajustes en el diseño}
-%
-% {\setlength{\parindent}{0pt}
-% Todos los siguientes comandos también aceptan como argumentos dimensiones de \LaTeX{}:
-%
-% \DescribeMacro{\SepElementos}{\color{RoyalBlue}|\SepElementos|\marg{sep. vertical}}
-%
-% Las distintas partes de la factura (a saber: el encabezado con los datos, el cuadro de la factura y la -opcional- descripción) también están separadas una distancia que puede ser cambiada.
-%
-% La separación que se fija aquí es la mínima que queremos garantizar, y puede ser ajustada automáticamente por la clase aumentándola cuando no hay relleno automático de espacios sobrantes (es decir, sin usar la opción |sinexpandir|). Cuando la descripción (sin opciones de expansión) o el cuadro de la factura (usando la opción |exparriba|) toman su tamaño máximo, entonces la separación vertical entre cada elemento de la hoja es la dada con |\SepElementos|, o sea, la que queremos garantizar como la mínima separación entre esas partes.
-%
-% \DescribeMacro{\SepEncabez}{\color{RoyalBlue}|\SepEncabez|\marg{sep. en encabezado}\marg{sep. interna texto}}
-%
-% Las cajas donde van los datos del cliente y el resumen están separadas entre sí una distancia controlable con el primer argumento de |\SepEncabez|. Obviamente, si no se escribe un resumen saldría unícamente la caja de los datos del cliente, y esta separación no tendría efecto. El segundo argumento de |\SepEncabez| nos permite controlar la distancia entre la línea del recuadro y el texto, es decir, un margen interno entre el contorno de la caja y el texto que hay dentro para que no salga pegado a la línea que lo encierra.
-%
-% \DescribeMacro{\SepItemsExtra}{\color{RoyalBlue}|\SepItemsExtra|\marg{sep. extra entre items}}
-%
-% Agrega una separación extra entre los elementos o ítems en el cuadro de la factura. La separación entre ítems está dada por el ``\textsl{baselineskip}'' que se da con el comando |\LetraItems| que se explicará más adelante en esta misma sección.
-%
-% \DescribeMacro{\SepDescrip}{\color{RoyalBlue}|\SepDescrip|\marg{sep. interna texto}}
-%
-% Con este comando controlamos la distancia entre la línea del recuadro de la descripción y el texto, o sea, el margen interno del cuadro de la descripción, tal como lo definimos para el caso anterior.
-%
-% \DescribeMacro{\SepFilas}{\color{RoyalBlue}|\SepFilas|\marg{sep. en x}\marg{sep. en y}}
-%
-% Cuando se usa el modo de totalización en filas tenemos también la posibilidad de cambiar la separación entre los totales que salen uno al lado del otro, y la separación entre las distintas líneas.
-%
-% El primer argumento de |\SepFilas| es la separación horizontal {\itshape mínima} entre los distintos totales que se presentan en el modo de totalización en filas. La clase |factura| expande esa distancia para que queden todos los totales separados igual, y también separados igual de los márgenes del papel.
-%
-% El segundo argumento de |\SepFilas| es la separación vertical entre las distintas líneas de la totalización en filas.
-%
-% \DescribeMacro{\LineaEncabez}{\color{RoyalBlue}|\LineaEncabez|\marg{grosor}\marg{curva. esquinas}\marg{tam. sombra}}
-%
-% Con el primer argumento de este comando cambiamos el grosor de la línea con la que las cajas del encabezado se dibujan, con el segundo argumento cambiamos la curvatura de las esquinas, y con el tercero el tamaño de la sombra\footnote{Todas las sombras salen hacia abajo a la derecha.}.
-%
-% \DescribeMacro{\LineaDescrip}{\color{RoyalBlue}|\LineaDescrip|\marg{grosor}\marg{curva. esquinas}\marg{tam. sombra}}
-%
-% Con el primer argumento de |\LineaDescrip| ajustamos el grosor de la línea con la que la descripción larga se dibuja, con el segundo argumento cambiamos la curvatura de las esquinas, y con el tercero el tamaño de la sombra.
-%
-% \DescribeMacro{\LineaFirmas}{\color{RoyalBlue}|\LineaFirmas|\marg{long. línea}\marg{grosor}}
-%
-% La longitud de la líneas para firmar y el grosor son también ajustables por medio del primer y segundo argumento, respectivamente, de la macro |\LineaFirmas|.
-%
-% }
-%
-% \section{Tipografías para cada elemento a escribir}
-%
-% Cada elemento escrito en la factura o reporte es sujeto a ser mostrado con una tipografía distinta, para lo cual existen comandos con los que se asigna el tipo de letra o estilo para cada cosa que sale escrita en el documento, por ejemplo, se puede cambiar el tipo de letra con el que se escribe la fecha, el tipo de letra con el que salen los elementos dentro del cuadro de la factura, el tipo de letra de los totales, de los títulos, de las cabeceras o piés de página en el reporte, etc.
-%
 % Cuando en lo sucesivo nos referiremos a tipografía, tipo de letra, o letra, nos estaremos refiriendo a cualquier cambio en la tipografía que pueda significar el nombre de la letra, su tamaño o atributos como negritas, es decir, mediante cualquiera de estos comandos podemos cambiar cualquier aspecto de la tipografía. Mirando el archivo |.def| pueden verse todos los valores predeterminados, que la mayoría de ellos son simplemente cambios en el tamaño (macro |\fontsize| de \LaTeX{}), y en algunos casos negritas.
 %
 % {\setlength{\parindent}{0pt}
 % \DescribeMacro{\LetraItems}{\color{RoyalBlue}|\LetraItems|\marg{tipo de letra}}
 %
-% Con este comando cambiamos la tipografía utilizada en los ítems o elementos que están en el cuadro de la factura, de manera que {\itshape cambiar la longitud \cs{baselineskip} con el segundo argumento de \cs{fontsize} hará que la tabla tenga una altura distinta de las celdas.}
+%  Con este comando cambiamos la tipografía utilizada en los ítems o elementos que están en el cuadro de la factura, de manera que {\itshape cambiar la longitud \cs{baselineskip} con el segundo argumento de \cs{fontsize} hará que la tabla tenga una altura distinta de las celdas.}
 %
-% Lo anterior significa que {\bfseries para cambiar la altura de las celdas, la forma correcta es a través de cambiar el tamaño de la letra de sus elementos con este comando. (Véase el archivo |.def|)}.
+%  Lo anterior significa que {\bfseries para cambiar la altura de las celdas, la forma correcta es a través de cambiar el tamaño de la letra de sus elementos con este comando. (Véase el archivo |.def|)}.
 %
 % \DescribeMacro{\LetraNumeros}{\color{RoyalBlue}|\LetraNumeros|\marg{tipo de letra}}
 %
-% Este comando sirve para cambiar el tipo de letra de los números de los ítems individuales en la factura, es decir, la cantidad, los precios y el descuento.
+%  Este comando sirve para cambiar el tipo de letra de tota la información numérica que aparece en las distintas columnas del cuadro de la factura, sin contar los totales, para los cuales hay otros comandos.
 %
 % \DescribeMacro{\LetraTipoIVA}{\color{RoyalBlue}|\LetraTipoIVA|\marg{tipo de letra}}
 %
-% El tipo del IVA es la letra que indica qué IVA está siendo gravado, por ejemplo, la ``|G|'', ``|R|'' y ``|A|'' que puede salir al lado de los elementos con IVA general, reducido y adicional respectivamente, y ``|(E)|'' al lado de los elementos exentos. Con esta macro cambiamos la letra con la que eso sale.
+%  El tipo del IVA es la letra que indica qué IVA está siendo gravado, por ejemplo, la “|G|”, “|R|” y “|A|” que puede salir al lado de los elementos con IVA general, reducido y adicional respectivamente, y “|(E)|” al lado de los elementos exentos. Con esta macro cambiamos la letra con la que eso sale.
 %
-% \DescribeMacro{\LetraTitCuadro}{\color{RoyalBlue}|\LetraTitCuadro|\marg{tipo de letra}}
+% \DescribeMacro{\LetraTitColumnas}{\color{RoyalBlue}|\LetraTitColumnas|\marg{tipo de letra}}
 %
-% Con |\LetraTitCuadro| podemos cambiar la tipografía de los títulos de los campos que hay en el cuadro de la factura, es decir, los textos ``Cantidad'', ``Descripción'', ``Precio U.'', etc.
+%  Con |\LetraTitColumnas| podemos cambiar la tipografía de los títulos de los campos que hay en el cuadro de la factura, es decir, los textos “Cantidad”, “Descripción”, “Precio U.”, etc.
 %
 % \DescribeMacro{\LetraTitTotales}{\color{RoyalBlue}|\LetraTitTotales|\marg{tipo de letra}}
 %
-% Con este comando cambiamos la tipografía de los nombres de los totales, es decir, ``IVA G.'', ``BI G.'', salvo el total general que se cambia con |\LetraTitTotal|.
+%  Con este comando cambiamos la tipografía de los nombres de los totales, es decir, “IVA G.”, “BI G.”, salvo el total general que se cambia con |\LetraTitTotal|.
 %
 % \DescribeMacro{\LetraNumTotales}{\color{RoyalBlue}|\LetraNumTotales|\marg{tipo de letra}}
 %
-% Con esta macro se cambia la tipografía utilizada en los totales numéricos de la factura, exceptuando el total general que se cambia con |\LetraNumTotal|.
+%  Con esta macro se cambia la tipografía utilizada en los totales numéricos de la factura, exceptuando el total general que se cambia con |\LetraNumTotal|.
 %
 % \DescribeMacro{\LetraTitTotal}{\color{RoyalBlue}|\LetraTitTotal|\marg{tipo de letra}}
 %
-% Para cambiar la tipografía de la palabra que indica el total general, e.g. ``TOTAL'', lo hacemos con |\LetraTitTotal|.
+%  Para cambiar la tipografía de la palabra que indica el total general, e.g. “TOTAL”, lo hacemos con |\LetraTitTotal|.
 %
 % \DescribeMacro{\LetraNumTotal}{\color{RoyalBlue}|\LetraNumTotal|\marg{tipo de letra}}
 %
-% Para la tipografía del total general (la celda del número), utilizamos este comando.
+%  Para la tipografía del total general (la celda con el número del total final), utilizamos este comando.
 %
 % \DescribeMacro{\LetraTitEnc}{\color{RoyalBlue}|\LetraTitEnc|\marg{tipo de letra}}
 %
-% Con este comando cambiamos el tipo de letra de la información en el título de las cajas del encabezado de la factura, por ejemplo los textos: ``Resumen'' y ``Datos del cliente''.
+%  Con este comando cambiamos el tipo de letra de la información en el título de las cajas del encabezado de la factura, por ejemplo los textos: “Resumen” y “Datos del cliente”.
 %
 % \DescribeMacro{\LetraEncFactura}{\color{RoyalBlue}|\LetraEncFactura|\marg{tipo de letra}}
 %
-% Podemos también cambiar el tipo de letra de la información del encabezado de la factura, es decir, el tipo de letra del texto que escribe el usuario en el resumen o de toda la identificación del cliente en la factura. El resumen naturalmente acepta más cambios de tipografía escribiéndolos dentro del párrafo que se escribe con el comando |\Resumen|.
+%  Podemos también cambiar el tipo de letra de la información del encabezado de la factura, es decir, el tipo de letra del texto que escribe el usuario en el resumen o de toda la identificación del cliente en la factura. El resumen naturalmente acepta más cambios de tipografía escribiéndolos dentro del párrafo que se escribe con el comando |\Resumen|.
 %
 % \DescribeMacro{\LetraEncReporte}{\color{RoyalBlue}|\LetraEncReporte|\marg{tipo de letra}}
 %
-% Para cambiar la tipografía de la información del encabezado del reporte usamos |\LetraEncReporte|.
+%  Para cambiar la tipografía de la información del encabezado del reporte usamos |\LetraEncReporte|.
 %
+% \DescribeMacro{\LetraNotaPrevia}{\color{RoyalBlue}|\LetraNotaPrevia|\marg{tipo de letra}}
+%
+%  Con |\LetraNotaPrevia| podemos cambiar la tipografía con la que se escribe la -opcional- nota previa al cuadro de la factura.
+%
+% \DescribeMacro{\LetraNotaInterna}{\color{RoyalBlue}|\LetraNotaInterna|\marg{tipo de letra}}
+%
+%  Con |\LetraNotaInterna| cambiamos el formato de la nota opcional que aparece como coletilla de la factura (nota interna).
+%
+% \DescribeMacro{\LetraNotaExterna}{\color{RoyalBlue}|\LetraNotaExterna|\marg{tipo de letra}}
+%
+%  También podemos cambiar la tipografía de la nota externa a la factura, es decir, la -opcional- nota que va al terminar el cuadro de la factura antes de la -opcional también- descripción larga.
+%
 % \DescribeMacro{\LetraDescripcion}{\color{RoyalBlue}|\LetraDescripcion|\marg{tipo de letra}}
 %
-% Con este comando cambiamos la tipografía de la descripción larga; naturalmente cualquier cambio puede hacerse luego dentro del texto de la descripción, igual que con el resumen.
+%  Con este comando cambiamos la tipografía de la descripción larga; naturalmente cualquier cambio puede hacerse luego dentro del texto de la descripción, igual que con el resumen.
 %
 % \DescribeMacro{\LetraFirmas}{\color{RoyalBlue}|\LetraFirmas|\marg{tipo de letra}}
 %
-% Con |\LetraFirmas| podemos cambiar la letra usada para escribir el nombre debajo de la línea para firmar en la factura.
+%  Con |\LetraFirmas| podemos cambiar la letra usada para escribir el nombre debajo de la línea para firmar en la factura.
 %
 % \DescribeMacro{\LetraCondiciones}{\color{RoyalBlue}|\LetraCondiciones|\marg{tipo de letra}}
 %
-% Para cambiar la tipografía de las condiciones del documento se hace con este comando. (Aplica el mismo comentario que para la descripción y el resumen).
+%  Para cambiar la tipografía de las condiciones del documento se hace con este comando. (Aplica el mismo comentario que para la descripción y el resumen).
 %
 % \DescribeMacro{\LetraDenom}{\color{RoyalBlue}|\LetraDenom|\marg{tipo de letra}}
 %
-% La tipografía asociada a la denominación del documento, es decir, al lado del número (e.g. ``FACTURA'' o ``COTIZACIÓN''), y la asociada al texto ``No. CONTROL'' se cambia con |\LetraDenom|.
+%  La tipografía asociada a la denominación del documento, es decir, al lado del número (e.g. “FACTURA” o “COTIZACIÓN”), y la asociada al texto “No. CONTROL” se cambia con |\LetraDenom|.
 %
 % \DescribeMacro{\LetraNumeracion}{\color{RoyalBlue}|\LetraNumeracion|\marg{tipo de letra}}
 %
-% Con |\LetraNumeracion| cambiamos la tipografía de las numeraciones como la del número de la factura y el número de control.
+%  Con |\LetraNumeracion| cambiamos la tipografía de las numeraciones como la del número de la factura y el número de control.
 %
 % \DescribeMacro{\LetraFecha}{\color{RoyalBlue}|\LetraFecha|\marg{tipo de letra}}
 %
-% La tipografía de la fecha de emisión la podemos cambiar con este comando.
+%  La tipografía para la fecha de emisión y la fecha de vencimiento la podemos cambiar con este comando.
 %
 % \DescribeMacro{\LetraTitReporte}{\color{RoyalBlue}|\LetraTitReporte|\marg{tipo de letra}}
 %
-% La letra del título del reporte se puede cambiar con |\LetraTitReporte|.
+%  La letra del título que aparece al principio del reporte se puede cambiar con |\LetraTitReporte|.
 %
 % \DescribeMacro{\LetraInfoPagina}{\color{RoyalBlue}|\LetraInfoPagina|\marg{tipo de letra}}
 %
-% Las cabeceras o piés de página del reporte también tienen un comando para su tipo de letra, y es |\LetraInfoPagina|.
+%  Las cabeceras o pies de página del reporte también tienen un comando para su tipo de letra, y es |\LetraInfoPagina|.
 %
-% \DescribeMacro{\LetraReporte}{\color{RoyalBlue}|\LetraReporte|\marg{tipo de letra}}%
+% \DescribeMacro{\LetraReverso}{\color{RoyalBlue}|\LetraReverso|\marg{tipo de letra}}
 %
-% Finalmente, para cambiar la tipografía con la que se inicia el reporte tenemos este comando. Obviamente también luego se puede hacer cualquier cambio dentro del ambiente |reporte|.
+%  Con |\LetraReverso| cambiamos la tipografía de la información que escribamos en el reverso de la hoja de la factura.
 %
-% {\bfseries Todos los comandos definidos en todas las secciones anteriores, así como cualquier comando definido en |factura.def| se puede redefinir y agregar a otro archivo |.tex| o |.def| que el usuario cargue en el preámbulo con |\input|, |\include| o con el comando |\Cliente|:}
+% \DescribeMacro{\LetraReporte}{\color{RoyalBlue}|\LetraReporte|\marg{tipo de letra}}
 %
-% \DescribeMacro{\Cliente}{\color{RoyalBlue}|\Cliente|\marg{archivo \LaTeX}}
+%  Finalmente, para cambiar la tipografía con la que se inicia el reporte tenemos este comando. Obviamente también luego se puede hacer cualquier cambio dentro del ambiente |reporte|.
 %
-%  Incluye un archivo cuya extensión debe ser |.def| o |.tex|, con cualquiera de los comandos anteriores que modifican el estilo del documento, identifican al cliente o al proveedor del servicio.
+% }
 %
-% \noindent \DescribeMacro{\mostrar}{\color{RoyalBlue}|\mostrar|\marg{@-macro}}
 %
-% Por último, disponemos del comando |\mostrar| cuya función es escribir lo que está alojado en una macro interna que contenga un símbolo ``|@|'' en su nombre. Es necesario un comando para mostrar una macro con este símbolo para que el usuario no tenga que usar |\makeatletter| y |\makeatother|.
+% \section{Etiquetas y referencias a ítems de la factura\label{sec:etiquetas}}
 %
-% Por ejemplo, el número de la factura está alojado en la variable |\@Num|, y si queremos hacer referencia a ese número en alguna parte del reporte o de la descripción de la factura podremos usar |\mostrar{@Num}|.
+% Esta clase |factura| soporta agregar etiquetas a cada elemento de la factura que luego en el reporte o en casi cualquier otra parte queramos referenciar; {\slshape no se pueden referenciar etiquetas solamente en la nota previa ni en el resumen.}
 %
-% }
-%
-% \section{Etiquetas y referencias\label{sec:etiquetas}}
-%
-% Esta clase |factura| soporta agregar etiquetas a cada elemento de la factura que luego en la descripción larga o en el reporte queramos referenciar.
-%
 % \noindent \DescribeMacro{\label}{\color{RoyalBlue}|\label|\marg{etiqueta}}
 %
-% Para ello usamos la conocida macro |\label| de \LaTeX{} justamente después del ítem que nos interese luego referenciar, por ejemplo (usando descuentos individuales):
+%  Para ello usamos la conocida macro |\label| de \LaTeX{} justamente después del ítem que nos interese luego referenciar, por ejemplo (usando descuentos individuales):
 %
 % \iffalse
 %<*literal>
@@ -1311,7 +1557,7 @@
 %</literal>
 % \fi
 %
-% De esta forma creamos una etiqueta llamada ``el-otro'' para el segundo elemento, que luego podremos citar en la descripción larga o en el reporte con comandos similares a los que \LaTeX{} provee para referenciar etiquetas.
+% De esta forma creamos una etiqueta llamada “el-otro” para el segundo elemento, que luego podremos citar por ejemplo en la descripción larga o en el reporte con comandos similares a los que \LaTeX{} provee para referenciar etiquetas.
 %
 % \noindent \DescribeMacro{\itemref}{\color{RoyalBlue}|\itemref|\marg{etiqueta}}\\
 % \noindent \DescribeMacro{\cantref}{\color{RoyalBlue}|\cantref|\marg{etiqueta}}\\
@@ -1319,61 +1565,85 @@
 % \noindent \DescribeMacro{\puref}{\color{RoyalBlue}|\puref|\marg{etiqueta}}\\
 % \noindent \DescribeMacro{\subtref}{\color{RoyalBlue}|\subtref|\marg{etiqueta}}\\
 % \noindent \DescribeMacro{\dctoref}{\color{RoyalBlue}|\dctoref|\marg{etiqueta}}\\
+% \noindent \DescribeMacro{\ivaref}{\color{RoyalBlue}|\ivaref|\marg{etiqueta}}\\
 % \noindent \DescribeMacro{\ptref}{\color{RoyalBlue}|\ptref|\marg{etiqueta}}\par
 %
-% Los comandos anteriores son para usarse donde queramos hacer la cita, es decir, en la descripción larga o en el reporte.
+% Si se quiere mostrar el número de la línea que ocupa el ítem en la lista lo hacemos con |\itemref|, que en el ejemplo aparecería el número “|2|” indicando que es el segundo ítem de la factura\footnote{Cuando se usa \cs{itemref} conviene enumerar los ítems en la factura con la opción \texttt{numitem}.}. Con |\cantref| escribimos la cantidad del elemento citado mediante la etiqueta, en nuestro ejemplo sería “|3|”. Para la descripción del ítem usamos |\descref|, que en el caso del ejemplo sería el texto “|Otro artículo gravado con IVA general|”. Para el precio unitario usamos |\puref|, en el ejemplo “|1.500,00|”. El subtotal lo mostraríamos con |\subtref|; en nuestro caso “|4.500,00|”. Si se quiere mostrar el porcentaje del descuento del ítem citado usamos |\dctoref|, que para el ejemplo sería “|10|”. Para el porcentaje del IVA, usamos |\ivaref|, en nuestro caso escribiría “|12|”. Por último, para mostrar el precio total usamos |\ptref|, y en nuestro ejemplo eso escribiría “|4.050,00|” puesto que aplicamos un descuento del 10\%.
 %
-% Si se quiere mostrar el número de fila que ocupa el ítem en la lista lo hacemos con |\itemref|, que en el ejemplo aparecería el número ``|2|'' indicando que es el segundo ítem de la factura\footnote{Cuando se usa \cs{itemref} conviene enumerar los ítems en la factura con la opción \texttt{numitem}.}. Con |\cantref| escribimos la cantidad del elemento citado mediante la etiqueta, en nuestro ejemplo sería ``|3|''. Para la descripción del ítem usamos |\descref|, que en el caso del ejemplo sería el texto ``|Otro artículo gravado con IVA general|''. Para el precio unitario usamos |\puref|, en el ejemplo ``|1.500,00|''. El subtotal lo mostraríamos con |\subtref|; en nuestro caso ``|4.500,00|''. Si se quiere mostrar el descuento del ítem citado usamos |\dctoref|, que para el ejemplo sería ``|10|''. Por último, para mostrar el precio total usamos |\ptref|, y en nuestro ejemplo eso escribiría ``|4.050,00|'' puesto que aplicamos un descuento del 10\%.
-%
 % Podemos ver que el uso de los comandos |\puref|, |\subtref| y |\ptref| nos muestra el precio en el mismo formato con el que lo vemos en la presentación de la factura, en cuanto al redondeo y al separador de miles y decimal.
 %
-% Con la asignación de estas etiquetas y su uso mediante las referencias podemos de manera conveniente citar cualquier ítem que se haya facturado, de manera dinámica sin tener que reescribir en la descripción larga o en el reporte aquello que ya se escribió en el cuadro de la factura.
+% Con la asignación de estas etiquetas y su uso mediante las referencias podemos de manera conveniente citar cualquier ítem que se haya facturado, de manera dinámica sin tener que reescribir en la descripción larga o en el reporte aquello que ya se escribió en el cuadro de la factura. Para estas referencias se escogieron nombres de las macros que terminan en “\texttt{ref}” por compatibilidad con comandos de \LaTeX{} como \cs{pageref}.
 %
-% Por otra parte, también podemos en la descripción larga y en el reporte referirnos al signo monetario con el comando |\Moneda|, y a cualquiera de los totales de la siguiente forma\footnote{Las macros de la tabla, para representarlas en el mismo formato que en la factura, debemos usar la macro \cs{numprint}}:
 %
-% \begin{tabular}{rl}
+%
+% \section{Referencias a los valores establecidos y a los totales\label{sec:ref}}
+%
+%  En el preámbulo el usuario definió distintas macros, es decir, estableció la razón social del cliente, su R.I.F., la dirección, entre otras cosas. Cualquiera de esas definiciones hechas en el preámbulo puede consultarse luego en otra parte del documento usando el comando que se usó para su definición, es decir, tenemos las siguientes macros: \cs{RazonSocial}, \cs{RIF}, \cs{Direccion}, \cs{Telefono}, \cs{Email}, \cs{Contacto}, \cs{Emisor}, \cs{Conforme}, \cs{Proveedor}, \cs{Credito}, \cs{Num}, \cs{NumSerieControl}, \cs{NumControl}, \cs{Condiciones}, \cs{Resumen}, \cs{NotaPrevia}, \cs{NotaInterna}, \cs{NotaExterna}; ellas en el preámbulo funcionarán para definir valores y textos, por ejemplo, como ya sabemos, establecemos la razón social así: \cs{RazonSocial{...}}, pero si ya no estamos en el preámbulos sino dentro del cuerpo del documento y llamamos a la macro \cs{RazonSocial}\footnote{Dentro del cuerpo del documento estas macros no aceptan parámetros.}, ella nos va a escribir el texto que definimos en el preámbulo como la razón social. Eso es usable con todas las macros que acabamos de mencionar, incluyendo las que definen textos largos como las notas o las condiciones.
+%
+% Por otra parte, también el usuario puede referirse al signo monetario con el comando |\Moneda|, y a cualquiera de los totales de la siguiente tabla\footnote{Las macros de la tabla, para representarlas en el mismo formato que en la factura, debemos usar la macro \cs{numprint}.}:
+%
+% \noindent \begin{tabular}{rl}
 % \hline
 % Total & Comando \\ \hline
 % Bases imponibles & |\BIG|, |\BIR|, |\BIA|, |\BIE|\footnote{Lo llamamos \cs{BIE} para mantener la nomenclatura pero no es una base imponible ya que es un monto exento de impuesto.} \\
 % IVA & |\AlicuotaG|, |\AlicuotaR|, |\AlicuotaA| \\
+% Descuento en IVA & |\AlicuotaGDesc| \\
 % Subtotales\footnote{El subtotal es el monto sin aplicar descuentos generales (los que se hacen con los comandos \cs{Descuento***}, es decir, los descuentos que no son individuales a cada item sino al totalizar), que coincide con la base imponible cuando no hay esos descuentos.} & |\SubtG|, |\SubtE|, |\SubtR|, |\SubtA| \\
 % Descuentos & |\DescG|, |\DescE|, |\DescR|, |\DescA| \\
-% Total final & |\Total|
+% Total final & |\Total| \\
+% \hline
 % \end{tabular}
 %
+% También ya mencionamos que la fecha de emisión y vencimiento se pueden acceder con la interfaz dada por el paquete |datetime2|, por ejemplo, para mostrar la fecha de emisión, usaríamos \cs{DTMusedate\{FechaEmision\}} y para la fecha de vencimiento, \cs{DTMusedate\{FechaVencimiento\}}. También aclaramos ya que la cantidad de ítems en la factura lo podemos acceder via el contador |NumItem|, por ejemplo así \cs{arabic\{NumItem\}}.
+%
+% En los ejemplos hay casos con todas estas funciones de esta sección.
+%
+%
 % \section{Más personalizaciones}
 %
-% \DescribeMacro{\@PosicionaFecha}
+% \DescribeMacro{\@PosicionaFechas}
 % \DescribeMacro{\@PosicionaDenom}
 % \DescribeMacro{\@PosicionaNumControl}
 % \DescribeMacro{\@PosicionaCondiciones}
 % \DescribeMacro{\@PosicionaFirmas}
-% Es posible darle aspecto distinto a muchas de las partes que conforman la factura. Internamente en la clase, cada parte es ubicada en la hoja con un comando y su contenido es escrito en el papel con otro comando. Los comandos que más probablemente son sujetos a ser cambiados por el usuario son los comandos que escriben el texto más que aquellos que lo ubican en la hoja, por tal razón, los comandos que posicionan aquello que va a escribirse lo definimos dentro del archivo |.cls|, y los que propiamente escriben cada parte de la hoja están definidos en el |.def|. Ambas fuentes las podrán consultar los usuarios para mayor comprensión, y para la total personalización. Recomendamos empezar por el archivo de definiciones |factura.def|.
-%
-% Estas macros son internas y sirven para, como dijimos antes, que \TeX{} se prepare para escribir el texto en la hoja; todas empiezan con |\@Posiciona| y no debe ser común necesitar cambiarlas.
-%
-% \DescribeMacro{\@EstiloFecha}
+% \DescribeMacro{\@EstiloFechas}
 % \DescribeMacro{\@EstiloDenom}
 % \DescribeMacro{\@EstiloNumControl}
+% \DescribeMacro{\@EstiloNotaPrevia}
 % \DescribeMacro{\@EstiloCondiciones}
 % \DescribeMacro{\@EstiloFirmas}
-% Todas estas macros llaman a su correspondiente macro que escribe el texto, que comienza con |\@Estilo|, y con cambiar su contenido podemos cambiar la forma como es escrita esa parte de la factura en la hoja.
-%
-% Estas últimas son las que están definidas dentro de |factura.def|, y que eventualmente puede desearse cambiarlas.
-%
 % \DescribeMacro{\@EscribeDatos}
 % \DescribeMacro{\@EscribeDatosResumen}
 % \DescribeMacro{\@EscribeDatosReporte}
+% \DescribeMacro{\@EscribeCondiciones}
+% \DescribeMacro{\@EscribeNotaPrevia}
 % \DescribeMacro{\@DibujaLinea}
+% \DescribeMacro{\@EscribeItemsEnCSV}
 % \DescribeMacro{\@EscribeTotalesEnCSV}
 % \DescribeMacro{\@EncabezadoFactura}
 % \DescribeMacro{\@EncabezadoReporte}
-% Adicionalmente tenemos las macros que escriben el contenido de la caja de los datos del cliente, o de las cajas de los datos y del resumen una al lado de la otra. Estos elementos, como no tienen posición fija (tal como se explicó en la sección \ref{sec:geohoja}) entonces no necesitan de una macro que los ubique y otra que escriba el texto, sino simplemente la que escribe el contenido de ese elemento. También la clase consta de una macro interna para escribir los datos del reporte al principio de éste, así como también para dibujar la línea ``de protección'' dentro del cuadro de la factura, otra para escribir los totales en el archivo |.csv| y otras dos para escribir las cajas del encabezado de la factura y el encabezado del reporte; todas estas son macros internas que no deben ser llamadas por el usuario, y no consideramos que pueda ser común cambiarlas.
+% \DescribeMacro{\@DatosTIKZ}
+% \DescribeMacro{\@NotaPreviaTIKZ}
+% \DescribeMacro{\@DescripcionTIKZ}
+% \DescribeMacro{\@CondicionesTIKZ}
+% Es posible darle aspecto distinto a muchas de las partes que conforman la factura. Internamente en la clase, cada parte es ubicada en la hoja con un comando y su contenido es escrito en el papel con otro comando. Los comandos que más probablemente son sujetos a ser cambiados por el usuario son los comandos que escriben el texto más que aquellos que lo ubican en la hoja, por tal razón, los comandos que posicionan aquello que va a escribirse lo definimos dentro del archivo |.cls|, y los que propiamente escriben cada parte de la hoja están definidos en el |.def|. Ambas fuentes las podrán consultar los usuarios para mayor comprensión, y para la total personalización. Recomendamos empezar por el archivo de definiciones |factura.def|.
 %
-% Cualquiera de estas macros que se quiera redefinir habría que hacerlo en el preámbulo del |.tex| y encerrándolas entre |\makeatletter| y |\makeatother| para poder redefinir una macro que contiene un símbolo ``|@|''.
+% Estas macros son internas y sirven para, como dijimos antes, que \LaTeX{} se prepare para escribir el texto en la hoja; todas empiezan con |\@Posiciona| y no debe ser común necesitar cambiarlas.
 %
-% {\bfseries \itshape Finalmente, como hemos dicho antes, una vez adecuada la clase al diseño que se quiere, se podrán escribir todos los comandos que hacen estos ajustes en un} |.tex| {\itshape o} |.def| {\itshape y cargarlo con} |\input|, |\include| {\itshape o con} |\Cliente|.
+% Todas estas macros llaman a su correspondiente macro con el estilo del elemento a escribir, que comienza con |\@Estilo|, y con cambiar su contenido podemos cambiar la forma como es escrita esa parte de la factura en la hoja.
 %
+% Estas últimas son las que están definidas dentro de |factura.def|, y que eventualmente puede desearse cambiarlas.
+%
+% Adicionalmente tenemos las macros que escriben el contenido de distintas partes de la factura y el reporte como los datos del cliente, el resumen, la nota previa, las condiciones, los encabezados, la información en el archivo |.csv|, y la macro que dibuja la línea “de protección” dentro del cuadro de la factura. Todas estas son macros internas que no deben ser llamadas por el usuario, y no consideramos que pueda sea necesario cambiarlas.
+%
+% Por último, las macros que alojan el diseño \tikz de los datos del cliente, la nota previa, la descripción larga y las condiciones del documento son |\@DatosTIKZ|, |\@NotaPreviaTIKZ|, |\@DescripcionTIKZ| y |\@CondicionesTIKZ|; están definidas en el archivo |factura.def|.
+%
+% Cualquiera de estas macros que se quiera redefinir habría que hacerlo en el preámbulo del |.tex| y encerrándolas entre |\makeatletter| y |\makeatother| para poder redefinir una macro que contiene un símbolo “|@|”.
+%
+% {\bfseries \itshape Finalmente, como dijimos en la sección (\ref{subsec:aux}), una vez adecuada la clase al diseño que se quiere, se podrán escribir todos los comandos que hacen estos ajustes en un} |.tex| {\itshape o} |.def| {\itshape y cargarlo con} |\input|, |\include| {\itshape o con} |\Cliente|, pudiendo discriminar por clientes dicha personalización.
+%
+%
+%
 % \newpage
 % \setstretch{1}
 % \section{Tabla con todas las opciones}
@@ -1380,214 +1650,312 @@
 %
 % \noindent La tabla que sigue muestra una lista de las opciones posibles al momento de cargar la clase:
 %
-% \noindent \begin{tabular}{>{\ttfamily}rl}
+% \noindent \begin{tabular}{>{\ttfamily}ll}
 %  \rmfamily \bfseries Opción & \bfseries Significado \\ \hline
-%  prefactura & Imprime una prefactura. \\
+%  agrupado & Agrupa los totales por tipo en el modo de columnas. \\
+%  centradesc & Centra la descripción de los ítems. \\
+%  centrado & Centra los totales en el modo de filas. \\
+%  conlineasha & Dibuja una línea separando los artículos entre sí. \\
+%  conreporte & Produce la factura y el reporte. \\
 %  cotización & Imprime una cotización. \\
-%  soloreporte & Produce únicamente el reporte. \\
-%  conreporte & Produce la factura y el reporte. \\
-%  twoside & Imprime el reporte a dos caras. \\
-%  dcu & Descripción, cantidad, precio u.. \\
-%  duc & Descripción, precio u., cantidad. \\
-%  sinlineasvi & No dibuja las líneas verticales internas. \\
-%  sinlineasve & No dibuja las líneas verticales externas. \\
-%  sinlineasv & Mo dibuja ninguna línea vertical. \\
-%  sinlineashi & No dibuja las líneas horizontal internas. \\
-%  sinlineashe & No dibuja las líneas horizontal externas. \\
-%  sinlineash & No dibuja ninguna línea horizontal. \\
-%  conlineasha & Dibuja una línea separando los artículos entre sí. \\
+%  csv & Genera un archivo |.csv| con la información numérica de la factura. \\
+%  dcu & Descripción, cantidad, precio unitario. \\
+%  denom & Explicita la denominación del documento. \\
+%  descuentos & A cada artículo se le puede asignar un descuento individual. \\
+%  dosfirmas & Incluye los dos espacios para firmar. \\
+%  duc & Descripción, precio unitario, cantidad. \\
+%  electro & Calcula los descuentos para el IVA al pagar electrónicamente. \\
+%  expandecuadro & Llena con espacio extra el cuadro de la factura. \\
 %  filas & Escribe los totales en filas. \\
-%  centrado & Centra los totales en el modo de filas. \\
-%  agrupado & Agrupa los totales según su impuesto en el modo de columnas. \\
-%  exparriba & Llena con espacio extra el cuadro de la factura. \\
-%  sinexpandir & No expande elementos en la factura. \\
+%  G & Agrega una “|G|” en los ítems con IVA general. \\
+%  impdesc & Escribe la denominación del IVA en la descripción. \\
+%  iva & Expresa en otra columna el porcentaje de IVA para cada elemento a facturar. \\
 %  linea & Dibuja una línea protectora en el cuadro de la factura. \\
 %  nospanish & No carga |babel|, |fontenc| ni |lmodern|. \\
-%  dosfirmas & Incluye los dos espacios para firmar. \\
-%  unafirma & Sólo incluye la firma del emisor. \\
+%  numitem & Enumera los ítems en la factura en otra columna extra al principio. \\
+%  prefactura & Imprime una prefactura. \\
+%  sincantidad & Los artículos van sin expresar su cantidad. \\
+%  sinexpandir & No expande elementos en la factura. \\
 %  sinfirmas & No incluye espacios para firmar. \\
-%  sincondiciones & No incluye las condiciones del documento. \\
 %  siniva & No incluye IVA, pero lo deja expresado. \\
 %  sinivaexpresado & No incluye IVA ni lo expresa. \\
-%  todosiva & Expresa todos los tipos de IVA. \\
-%  G & Agrega una ``|G|'' en los ítems con IVA general. \\
-%  impdesc & Escribe la denominación del IVA en la descripción. \\
-%  centradesc & Centra la descripción de los ítems. \\
+%  sinlineasvi & No dibuja las líneas verticales internas. \\
+%  sinlineasve & No dibuja las líneas verticales externas. \\
+%  sinlineasv & No dibuja ninguna línea vertical. \\
+%  sinlineashi & No dibuja las líneas horizontales internas. \\
+%  sinlineashe & No dibuja las líneas horizontales externas. \\
+%  sinlineash & No dibuja ninguna línea horizontal. \\
 %  sinmarcas & No escribe el carácter de fin de línea ni el carácter en las celdas vacías \\
 %            & cuando la descripción ocupa más que una línea. \\
-%  numitem & Enumera los ítems en la factura en otra columna extra a la izquierda. \\
-%  denom & Explicita la denominación del documento. \\
 %  sinnumero & No pone el número cuando se usa |denom|. \\
 %  sintotales & No escribe los totales al final del cuadro; para cotizaciones. \\
-%  sincantidad & Los artículos van sin expresar su cantidad. \\
-%  descuentos & Los artículos van con descuento individual. \\
-%  subtotal & Muestra el subtotal de cada ítem antes aplicar descuento. \\
-%  csv & Genera un archivo |.csv| con la información numérica de la factura. \\ \hline
+%  sinreverso & No compila el reverso de la factura así se haya escrito. \\
+%  soloreporte & Produce únicamente el reporte. \\
+%  subtotal & En otra columna muestra el subtotal de cada ítem antes aplicar descuento. \\
+%  todosiva & Expresa todos los tipos de IVA. \\
+%  twoside & Imprime el reporte a dos caras. \\
+%  unafirma & Sólo incluye la firma del emisor. \\
+%  vencimiento & Escribe la fecha de vencimiento así no haya crédito en la factura. \\
 % \end{tabular}
 %
+%
 % \newpage
 % \section{Tabla con todos los comandos}
 %
 % A continuación presentamos una tabla con todos los comandos, que salvo |\FirmaReporte|, los |\Item| y |\Descripcion|, se poner todos en el preámbulo.
 %
-% \noindent \begin{tabular}{>{\ttfamily}rl}
+% \noindent \begin{tabular}{>{\ttfamily}ll}
 % \rmfamily \bfseries Comando & \bfseries Significado \\ \hline
-%  |\GeometriaFactura| & Establece los parámetros de la geometría de la factura. \\
-%  |\GeometriaReporte| & Establece los parámetros de la geometría del reporte. \\
-%  |\FondoFactura| & Carga la imagen del fondo de la factura. \\
-%  |\FondoReporte| & Carga la imagen del fondo del reporte para la primera página. \\
-%  |\FondoReporte*| & Carga la imagen del fondo del reporte para todas las páginas. \\
-%  |\EstiloPagReporte| & Establece el estilo de página del reporte. \\
-%  |\InicioReporte| & Distancia hasta el inicio del texto en la primera hoja del reporte. \\
-%  |\FirmaFactura| & Carga la imagen de la firma en la factura. \\
-%  |\FirmaReporte| & Carga la imagen de la firma en el reporte\footnote{El comando \cs{FirmaReporte} se escribe dentro del ambiente \texttt{reporte} y no en el preámbulo.}. \\
-%  |\TituloReporte| & Establece el título del reporte. \\
-%  |\TituloReporte*| & Establece el título del reporte a salir en las cabeceras o piés de página. \\
-%  |\InfoPagina| & Cambia la información de las cabeceras o piés de página del reporte. \\
-%  |\RazonSocial| & Establece la razón social. \\
-%  |\Nombre| & Establece el nombre del cliente. \\
-%  |\RIF| & RIF del cliente. \\
+%  |\cantref| & Muestra la cantidad del ítem referenciado. \\
 %  |\CI| & Cédula de identidad del cliente. \\
-%  |\Telefono| & Teléfono del cliente. \\
-%  |\Direccion| & Dirección del cliente. \\
-%  |\Email| & E-mail del cliente. \\
+%  |\Cliente| & Carga un archivo |.def| o |.tex| con personalizaciones. \\
+%  |\Condiciones| & Establece las condiciones del documento. \\
+%  |\Conforme| & Nombre de quien recibe la factura, para el espacio de la firma. \\
 %  |\Contacto| & Persona de contacto. \\
-%  |\Conforme| & Nombre de quien recibe la factura, para el espacio de la firma. \\
-%  |\Emisor| & Nombre de quien emite la factura, para el espacio de la firma. \\
-%  |\Proveedor| & Nombre de quien firma el reporte. \\
-%  |\Fecha| & Establece la fecha de emisión de la factura. \\
+%  |\Credito| & Establece la cantidad de días para el crédito de la factura. \\
+%  |\dctoref| & Muestra al descuento del ítem referenciado. \\
+%  |\Denom| & Nombre de la denominación de documento. \\
+%  |\descref| & Muestra a la descripción del ítem referenciado. \\
+%  |\Descripcion| & Descripción larga de la factura\footnote{El comando \cs{Descripcion} se escribe dentro del documento, luego del ambiente \texttt{factura}, y no en el preámbulo.}. \\
 %  |\Descuento| & Porcentaje de descuento para todos los elementos. \\
 %  |\Descuento*| & Descuento neto en el subtotal, para todos los elementos. \\
 %  |\Descuento[GRAE]| & Descuento en porcentaje, discriminado según el tipo de ítem. \\
 %  |\Descuento[GRAE]*| & Descuento en el subtotal, discriminado según el tipo de ítem. \\
-%  |\Num| & Número de la factura. \\
-%  |\NumControl| & Número de control de la factura. \\
-%  |\NumSerieControl| & Número de serie de control de la factura. \\
-%  |\Denom| & Nombre de la denominación de documento. \\
-%  |\Condiciones| & Establece las condiciones del documento. \\
-%  |\Resumen| & Resumen. \\
-%  |\Cliente| & Carga un archivo |.def| o |.tex| con personalizaciones. \\
-%  |\PosFecha| & Posición $(x,y)$ de la fecha. \\
-%  |\PosDenom| & Posición $(x,y)$ del texto de la denominación. \\
-%  |\PosControl| & Posición $(x,y)$ del número de control. \\
-%  |\PosCond| & Posición $(x,y)$ del párrafo con las condiciones del documento. \\
-%  |\PosFirmas| & Posición $(x_o,x_f,y)$ de las firmas. \\
-%  |\SepFilas| & Separación horizontal y vertical en los totales en el modo de filas. \\
-%  |\SepElementos| & Separación vertical entre los distintos elementos de la factura. \\
-%  |\SepEncabez| & Separación entre las cajas del encabezado de la factura y \\
-%                & separación interna entre el borde y el texto. \\
-%  |\SepItemsExtra| & Separación vertical extra entre los elementos en la factura. \\
-%  |\SepDescrip| & Separación interna entre el borde y el texto en la descripción. \\
+%  |\Direccion| & Dirección del cliente. \\
+%  |\Email| & E-mail del cliente. \\
+%  |\Emisor| & Nombre de quien emite la factura, para el espacio de la firma. \\
+%  |\EstiloPagReporte| & Establece el estilo de página del reporte. \\
+%  |\Fecha| & Establece la fecha de emisión de la factura en formato predeterminado. \\
+%  |\Fecha*| & Establece la fecha de emisión de la factura en formato ISO. \\
+%  |\FirmaFactura| & Carga la imagen de la firma en la factura. \\
+%  |\FirmaReporte| & Carga la imagen de la firma en el reporte\footnote{El comando \cs{FirmaReporte} se escribe dentro del ambiente \texttt{reporte} y no en el preámbulo.}. \\
+%  |\FondoFactura| & Carga la imagen del fondo de la factura. \\
+%  |\FondoReporte| & Carga la imagen del fondo del reporte para la primera página. \\
+%  |\FondoReporte*| & Carga la imagen del fondo del reporte para todas las páginas. \\
+%  |\FormatoFecha| & Establece lo relacionado con el formato de las fechas. \\
+%  |\GeometriaFactura| & Establece los parámetros de la geometría de la factura. \\
+%  |\GeometriaReporte| & Establece los parámetros de la geometría del reporte. \\
+%  |\InfoPagina| & Cambia la información de las cabeceras o pies de página del reporte. \\
+%  |\InicioReporte| & Distancia hasta el inicio del texto en la primera hoja del reporte. \\
+%  |\Item[RAEX]| & Agrega un elemento a la factura\footnote{Estos comandos \cs{Item} se escriben dentro del ambiente \texttt{factura} y no en el preámbulo.}. \\
+%  |\itemref| & Muestra el número de línea en la factura del ítem referenciado. \\
+%  |\ivaref| & Muestra al IVA del ítem referenciado. \\
+%  |\label| & Agrega una etiqueta a un ítem de la factura\footnote{Se mantiene el nombre “\cs{label}” por compatibilidad con los comandos conocidos de \LaTeX. Este comando también se escribe dentro del ambiente \texttt{factura}.}. \\
 % \end{tabular}
 % \newpage
-% \noindent \begin{tabular}{>{\ttfamily}rl}
+% \noindent \begin{tabular}{>{\ttfamily}ll}
 % \rmfamily \bfseries Comando & \bfseries Significado \\ \hline
-%  |\LineaEncabez| & Grosor de la línea de las cajas del encabezado de la factura. \\
-%                  & curvatura de la esquina y sombra. \\
-%  |\LineaDescrip| & Grosor de la línea de la caja de la descripción. \\
-%                  & curvatura de la esquina y sombra. \\
-%  |\LineaFirmas| & Longitud y grosor de las líneas para firmar. \\
+%  |\LetraCondiciones| & Tipografía para las condiciones del documento. \\
+%  |\LetraDenom| & Tipografía para la denominación del documento. \\
+%  |\LetraDescripcion| & Tipografía para la descripción en la factura. \\
+%  |\LetraEncFactura| & Tipografía para la información en las cajas del encabezado. \\
+%  |\LetraEncReporte| & Tipografía para la información del encabezado del reporte. \\
+%  |\LetraFecha| & Tipografía para la fecha de emisión. \\
+%  |\LetraFirmas| & Tipografía para los nombres de quienes firman la factura. \\
+%  |\LetraInfoPagina| & Tipografía para las cabeceras o pies de página del reporte. \\
 %  |\LetraItems| & Tipografía para los ítems en la factura. \\
+%  |\LetraNotaExterna| & Tipografía para la nota externa al cuadro de la factura. \\
+%  |\LetraNotaInterna| & Tipografía para la nota interna al cuadro de la factura. \\
+%  |\LetraNotaPrevia| & Tipografía para la nota previa al cuadro de la factura. \\
+%  |\LetraNumeracion| & Tipografía para las numeraciones. \\
 %  |\LetraNumeros| & Tipografía para los números en la factura. \\
+%  |\LetraNumTotal| & Tipografía para el total final numérico. \\
+%  |\LetraNumTotales| & Tipografía para los totales numéricos. \\
+%  |\LetraReporte| & Tipografía para el texto del reporte. \\
+%  |\LetraReverso| & Tipografía para el reverso de la factura. \\
 %  |\LetraTipoIVA| & Tipografía para el tipo de IVA. \\
-%  |\LetraTitCuadro| & Tipografía para los nombres de las columnas del cuadro de la factura. \\
-%  |\LetraTitTotales| & Tipografía para los nombres de los totales. \\
-%  |\LetraNumTotales| & Tipografía para los totales numéricos. \\
-%  |\LetraTitTotal| & Tipografía para el nombre del total final. \\
-%  |\LetraNumTotal| & Tipografía para el total final numérico. \\
+%  |\LetraTitColumnas| & Tipografía para los nombres de las columnas del cuadro de la factura. \\
 %  |\LetraTitEnc| & Tipografía para los títulos en las cajas del encabezado de la factura. \\
-%  |\LetraEncFactura| & Tipografía para la información en las cajas del encabezado. \\
-%  |\LetraEncReporte| & Tipografía para la información del encabezado del reporte. \\
-%  |\LetraDescripcion| & Tipografía para la descripción en la factura. \\
-%  |\LetraFirmas| & Tipografía para los nombres de quienes firman la factura. \\
-%  |\LetraCondiciones| & Tipografía para las condiciones del documento. \\
-%  |\LetraDenom| & Tipografía para la denominación del documento. \\
-%  |\LetraNumeracion| & Tipografía para las numeraciones. \\
-%  |\LetraFecha| & Tipografía para la fecha de emisión. \\
 %  |\LetraTitReporte| & Tipografía para el título del reporte. \\
-%  |\LetraInfoPagina| & Tipografía para las cabeceras o piés de página del reporte. \\
-%  |\LetraReporte| & Tipografía para el texto del reporte. \\
-%  |\Item[RAEX]| & Agrega un elemento a la factura\footnote{Estos comandos \cs{Item} se escriben dentro del ambiente \texttt{factura} y no en el preámbulo.}. \\
-%  |\Descripcion| & Descripción larga de la factura\footnote{El comando \cs{Descripcion} se escribe dentro del documento, luego del ambiente \texttt{factura}, y no en el preámbulo.}. \\
-%  |\label| & Agrega una etiqueta a un ítem de la factura\footnote{Se mantiene el nombre ``\cs{label}'' por compatibilidad con los comandos conocidos de \LaTeX. Este comando también se escribe dentro del ambiente \texttt{factura}.}. \\
-%  |\itemref| & Hace referencia al número de línea que ocupa el ítem etiquetado\footnote{También se mantienen los nombres de las macros que terminan en ``\texttt{ref}'' por compatibilidad con comandos de \LaTeX{} como \cs{pageref}.}. \\
-%  |\cantref| & Hace referencia a la cantidad del ítem. \\
-%  |\descref| & Hace referencia a la descripción del ítem. \\
-%  |\puref| & Hace referencia al precio unitario del ítem. \\
-%  |\subtref| & Hace referencia al subtotal del ítem. \\
-%  |\dctoref| & Hace referencia al descuento del ítem. \\
-%  |\ptref| & Hace referencia al precio total del ítem. \\
-%  |\mostrar| & Mostramos una variable que contenga ``|@|'' sin usar ``|\makeatletter|''\footnote{Este comando tampoco se usa en el preámbulo sino en cualquier otra parte del documento.}.
+%  |\LetraTitTotal| & Tipografía para el nombre del total final. \\
+%  |\LetraTitTotales| & Tipografía para los nombres de los totales. \\
+%  |\LineaCondiciones| & Grosor de la línea de la caja de las condiciones, \\
+%                      & curvatura de la esquina y sombra. \\
+%  |\LineaDescripcion| & Grosor de la línea de la caja de la descripción, \\
+%                      & curvatura de la esquina y sombra. \\
+%  |\LineaEncabezado| & Grosor de la línea de las cajas del encabezado de la factura, \\
+%                     & curvatura de la esquina y sombra. \\
+%  |\LineaNotaPrevia| & Grosor de la línea de la caja de la nota previa al cuadro, \\
+%                     & curvatura de la esquina y sombra. \\
+%  |\LineaFirmas| & Longitud y grosor de las líneas para firmar. \\
 % \end{tabular}
+% \newpage
+% \noindent \begin{tabular}{>{\ttfamily}ll}
+% \rmfamily \bfseries Comando & \bfseries Significado \\ \hline
+%  |\Nombre| & Establece el nombre del cliente. \\
+%  |\NotaInterna| & Escribe una nota interna al cuadro de la factura. \\
+%  |\NotaExterna| & Escribe una nota extra externa al cuadro de la factura. \\
+%  |\NotaPrevia| & Escribe una nota antes del cuadro de la factura. \\
+%  |\Num| & Número de la factura. \\
+%  |\NumControl| & Número de control de la factura. \\
+%  |\NumSerieControl| & Número de serie de control de la factura. \\
+%  |\PosCondiciones| & Posición $(x,y)$ del párrafo con las condiciones del documento. \\
+%  |\PosCondiciones*| & Posición $(x,y)$ del párrafo con las condiciones del documento \\
+%                     & (el texto se despliega hacia arriba). \\
+%  |\PosControl| & Posición $(x,y)$ del número de control. \\
+%  |\PosControl*| & Posición $(x,y)$ del número de control \\
+%                 & (el texto se despliega hacia arriba). \\
+%  |\PosDenom| & Posición $(x,y)$ del texto de la denominación. \\
+%  |\PosDenom*| & Posición $(x,y)$ del texto de la denominación \\
+%               & (el texto se despliega hacia arriba). \\
+%  |\PosFecha| & Posición $(x,y)$ de las fechas. \\
+%  |\PosFecha*| & Posición $(x,y)$ de las fechas \\
+%               & (el texto se despliega hacia arriba). \\
+%  |\PosFirmas| & Posición $(x_o,x_f,y)$ de las firmas. \\
+%  |\Proveedor| & Nombre de quien firma el reporte. \\
+%  |\ptref| & Muestra al precio total del ítem referenciado. \\
+%  |\puref| & Muestra al precio unitario del ítem referenciado. \\
+%  |\RazonSocial| & Establece la razón social. \\
+%  |\Resumen| & Resumen. \\
+%  |\RIF| & R.I.F. del cliente. \\
+%  |\SepCondiciones| & Separación interna entre el borde y el texto en las condiciones. \\
+%  |\SepDatosResumen| & Separación horizontal entre los datos del cliente y el resumen. \\
+%  |\SepDescripcion| & Separación interna entre el borde y el texto en la descripción. \\
+%  |\SepEncabezado| & Separación interna entre el borde y el texto en el encabezado. \\
+%  |\SepNotaPrevia| & Separación interna entre el borde y el texto en la nota previa. \\
+%  |\SepFilas| & Separación horizontal y vertical en los totales en el modo de filas. \\
+%  |\SepItemsExtra| & Separación vertical extra entre los elementos en la factura. \\
+%  |\SepVertical| & Separación vertical entre los distintos elementos de la factura. \\
+%  |\subtref| & Muestra al subtotal del ítem referenciado. \\
+%  |\Telefono| & Teléfono del cliente. \\
+%  |\TituloReporte| & Establece el título del reporte. \\
+%  |\TituloReporte*| & Establece el título del reporte a salir en las cabeceras o pies de página. \\
+% \end{tabular}
 %
-% \section{Ejemplos incluídos\label{sec:ejemplos}}
-% \todo*{Hay que hacer que en la documentación, toda opción y macro referencie al ejemplo donde se usa.}
 %
-% Desde la página siguiente se muestran todos los ejemplos incluídos en la clase:
+% \ifejemplos
+%  \section{Ejemplos incluídos\label{sec:ejemplos}}
+%  \todo*{Hay que hacer que en la documentación, toda opción y macro referencie al ejemplo donde se usa.}
 %
-% \newpage
-% \newgeometry{marginparsep=0pt,vmargin={1cm,1cm},hmargin={1cm,1cm}}
-% \setlength{\parindent}{0pt}
-% \hbadness=10000
+%  Desde la página siguiente se muestran todos los ejemplos incluídos en la clase:
 %
-% \Ejemplo{ejemplo-cotizacion}
-% \Ejemplo{ejemplo-prefactura}
-% \newpage
-% \Ejemplo{ejemplo-factura1}
-% \Ejemplo{ejemplo-factura2}[\small]
-% \newpage
-% \Ejemplo{ejemplo-factura3}
-% \Ejemplo{ejemplo-factura4}
-% \newpage
-% \Ejemplo{ejemplo-factura5}
-% \Ejemplo{ejemplo-factura6}
-% \newpage
-% \Ejemplo[0.4]{ejemplo-factura7}[\small]
-% \Ejemplo{ejemplo-factura8}
-% \newpage
-% \Ejemplo*[0.49]{ejemplo-reporte1}
-% \Ejemplo**[0.49]{ejemplo-reporte1}{2}
-% \Ejemplo[0.49]{ejemplo-reporte1}{3}
-% \newpage
-% \Ejemplo*[0.49]{ejemplo-reporte2}
-% \Ejemplo**[0.49]{ejemplo-reporte2}{2}
-% \Ejemplo[0.49]{ejemplo-reporte2}{3}
-% \newpage
-% \Ejemplo*[0.49]{ejemplo-reporte3}
-% \Ejemplo**[0.49]{ejemplo-reporte3}{2}
-% \Ejemplo[0.49]{ejemplo-reporte3}{3}
-% \newpage
-% \Ejemplo{beispiel-rechnung}
+%  \newpage
+%  \newgeometry{marginparsep=0pt,vmargin={1cm,1cm},hmargin={1cm,1cm}}
+%  {
+%   \pagestyle{empty}
+%   \setlength{\parindent}{0pt}
+%   \hbadness=10000
 %
-% \newpage
-% \hbadness=1000
-% \restoregeometry
+%   \Ejemplo{ejemplo-cotizacion}
+%   \Ejemplo{ejemplo-prefactura}
+%   \newpage
+%   \Ejemplo{ejemplo-factura01}
+%   \Ejemplo{ejemplo-factura02}[\small\parskip=3pt]
+%   \newpage
+%   \Ejemplo{ejemplo-factura03}[\parskip=2pt]
+%   \Ejemplo{ejemplo-factura04}
+%   \newpage
+%   \Ejemplo{ejemplo-factura05}
+%   \Ejemplo{ejemplo-factura06}
+%   \newpage
+%   \Ejemplo[0.4]{ejemplo-factura07}[\small\parskip=3pt]
+%   \Ejemplo{ejemplo-factura08}
+%   \newpage
+%   \Ejemplo*[0.49]{ejemplo-factura09}
+%   \Ejemplo**[0.49]{ejemplo-factura09}{2}
+%   \Ejemplo***{ejemplo-factura09}
+%   \newpage
+%   \Ejemplo*[0.49]{ejemplo-factura10}
+%   \Ejemplo**[0.49]{ejemplo-factura10}{2}
+%   \Ejemplo***{ejemplo-factura10}
+%   \newpage
+%   \Ejemplo*[0.49]{ejemplo-reporte1}
+%   \Ejemplo**[0.49]{ejemplo-reporte1}{2}
+%   \Ejemplo[0.49]{ejemplo-reporte1}{4}[\slshape Por espacio se omitió la página 2 en esta representación.]
+%   \newpage
+%   \Ejemplo*[0.49]{ejemplo-reporte2}
+%   \Ejemplo**[0.49]{ejemplo-reporte2}{2}
+%   \Ejemplo[0.49]{ejemplo-reporte2}{3}
+%   \newpage
+%   \Ejemplo*[0.49]{ejemplo-reporte3}
+%   \Ejemplo**[0.49]{ejemplo-reporte3}{2}
+%   \Ejemplo[0.49]{ejemplo-reporte3}{3}
+%   \newpage
+%   \Ejemplo{beispiel-rechnung}
+%   \newpage
+%  }
+%  \hbadness=1000
+%  \restoregeometry
+% \else
+%  \message{^^JLaTeX Warning: Compilación rápida. No se incluyeron los ejemplos.^^J}
+% \fi
 %
 % \StopEventually{\endorgo}
 %
 %    \begin{macrocode}
 %<*class>
+\RequirePackage{etoolbox}%  'etoolbox' para los condicionales binarios y para \AtEndPreamble.
+
+%% Condicionales auxiliares que sólo pueden ser usados dentro de un grupo.
+\newbool{Electro}
+\newbool{Descuentos}
+\newbool{IVA}
+\newbool{Subtotal}
+\newbool{SinCantidad}
+\newbool{SinLineasVertInt}
+\newbool{SinLineasVertExt}
+\newbool{SinLineasHoriInt}
+\newbool{SinLineasHoriExt}
+\newbool{DCU}
+\newbool{DUC}
+\newbool{NumItem}
+\newbool{PrimeroDescripcion}
+\newbool{ExpAbajo}\booltrue{ExpAbajo}
+
+%% Condicionales auxiliares para la posición de los objetos fijos cuando son medidos desde la derecha, o desde abajo.
+\newbool{FechaXnegativo}
+\newbool{FechaYnegativo}
+\newbool{FechaYarriba}
+\newbool{CondYnegativo}% no hay CondXnegativo.
+\newbool{CondYarriba}
+\newbool{DenomXnegativo}
+\newbool{DenomYnegativo}
+\newbool{DenomYarriba}
+\newbool{ControlXnegativo}
+\newbool{ControlYnegativo}
+\newbool{ControlYarriba}
+\newbool{FirmasYnegativo}% no hay FirmasXnegativo; hay X_inicial y X_final para las firmas.
+
+%% Condicionales relativos a opciones de la clase.
 \newif\if at prefactura
 \newif\if at cotizacion
-\newif\if at spanish \@spanishtrue
-\newif\if at ivaexpresado \@ivaexpresadotrue
+\newif\if at nospanish
+\newif\if at sinivaexpresado
 \newif\if at todosiva
-\newif\if at confirmas \@confirmastrue
-\newif\if at unafirma \@unafirmafalse
-\newif\if at concondiciones \@concondicionestrue
+\newif\if at sinfirmas
+\newif\if at unafirma
 \newif\if at filas
 \newif\if at agrupado
 \newif\if at centrado
 \newif\if at descuentos
 \newif\if at denom
+\newif\if at vencimiento
 \newif\if at sinnumero
 \newif\if at sintotales
 \newif\if at conlineasha
 \newif\if at linea
-\newif\if at lineacompleta
-\newif\if at lineahastatotal
-\newif\if at lineadesdeinicio
 \newif\if at G
+\newif\if at csv
+\newif\if at cdu \@cdutrue
+\newif\if at dcu
+\newif\if at duc
+\newif\if at expandecuadro
+\newif\if at factura \@facturatrue
+\newif\if at reverso \@reversotrue
+\newif\if at reporte
+\newif\if at impdesc
+\newif\if at centradesc
+\newif\if at sinmarcas
+
+%% Condicionales auxiliares.
+\newif\if at FondoFactura
+\newif\if at FondoReporte
+\newif\if at FondoReporteStar
+\newif\if at Nombre
+\newif\if at PruebaRef
+\newif\if at LineaCompleta
+\newif\if at LineaHastaTotal
+\newif\if at LineaDesdeInicio
 \newif\if at BIR
 \newif\if at BIA
 \newif\if at Exento
@@ -1599,85 +1967,138 @@
 \newif\if at DescRnum
 \newif\if at DescAnum
 \newif\if at DescEnum
-\newif\if at Descuentos
-\newif\if at csv
-\newif\if at cdu \@cdutrue
-\newif\if at dcu
-\newif\if at duc
-\newif\if at exparriba
-\newif\if at fondofactura
-\newif\if at fondoreporte
-\newif\if at fondoreportestar
-\newif\if at factura \@facturatrue
-\newif\if at reporte
-\newif\if at nombre
-\newif\if at pagado
-\newif\if at impdesc
-\newif\if at centradesc
-\newif\if at sinmarcas
-\newif\if at pruebaref
+\newif\if at DescuentoTotal
 
-\RequirePackage{etoolbox}%  'etoolbox' para los condicionales binarios.
 
-\newbool{Descuentos}
-\newbool{Subtotal}
-\newbool{SinCantidad}
-\newbool{SinLineasVertInt}
-\newbool{SinLineasVertExt}
-\newbool{SinLineasHoriInt}
-\newbool{SinLineasHoriExt}
-\newbool{DCU}
-\newbool{DUC}
-\newbool{NumItem}
-\newbool{PrimeroDescrip}
-\newbool{ExpAbajo}\booltrue{ExpAbajo}
+%% Longitudes para uso interno.
+\newlength{\@TamDatos}
+\newlength{\@TamResumen}
+\newlength{\@TamFinalEncabezado}
+\newlength{\@TamLineaFirmas}
+\newlength{\@TamNumItem}
+\newlength{\@TamCantidad}
+\newlength{\@TamPrecioU}
+\newlength{\@TamPrecioS}
+\newlength{\@TamDescuento}
+\newlength{\@TamIVA}
+\newlength{\@TamPrecioT}
+\newlength{\@GrosorLineaFirmas}
+\newlength{\@GrosorLineaEncabezado}
+\newlength{\@GrosorLineaNotaPrevia}
+\newlength{\@GrosorLineaDescripcion}
+\newlength{\@GrosorLineaCondiciones}
+\newlength{\@GrosorLineaInfoPag}
+\newlength{\@EsquinaLineaEncabezado}
+\newlength{\@EsquinaLineaNotaPrevia}
+\newlength{\@EsquinaLineaDescripcion}
+\newlength{\@EsquinaLineaCondiciones}
+\newlength{\@SombraEncabezado}
+\newlength{\@SombraNotaPrevia}
+\newlength{\@SombraDescripcion}
+\newlength{\@SombraCondiciones}
+\newlength{\@LineaNodoXo}
+\newlength{\@LineaNodoYo}
+\newlength{\@LineaNodoXf}
+\newlength{\@LineaNodoYf}
+\newlength{\@SepTotales}
+\newlength{\@PosFechaX}
+\newlength{\@PosFechaY}
+\newlength{\@PosDenomX}
+\newlength{\@PosDenomY}
+\newlength{\@PosFirmasXuno}
+\newlength{\@PosFirmasXdos}
+\newlength{\@PosFirmasY}
+\newlength{\@PosCondicionesX}
+\newlength{\@PosCondicionesY}
+\newlength{\@PosControlX}
+\newlength{\@PosControlY}
+\newlength{\@EspacioVacioInicial}
+\newlength{\@EspacioVacioFinal}
+\newlength{\@SeparaItemsExtra}
+\newlength{\@SeparaItemsExtraFinal}
+\newlength{\@SeparaInternaEncabezado}
+\newlength{\@SeparaInternaNotaPrevia}
+\newlength{\@SeparaInternaDescripcion}
+\newlength{\@SeparaInternaCondiciones}
+\newlength{\@SeparaDatosResumen}
+\newlength{\@SeparaVertical}
+\newlength{\@SeparaMinTotales}
+\newlength{\@SeparaFilas}
+\newlength{\@SeparaFinLineaDesc}
+\newlength{\@SeparaTelefonoEmail}
+\newlength{\@InicioReporte}
+\newlength{\@FirmaFacturaXcorr}
+\newlength{\@FirmaFacturaYcorr}
+\newlength{\@FirmaReporteXcorr}
+\newlength{\@FirmaReporteYcorr}
+\newlength{\@FirmaReporteTextPos}
+\newlength{\@FirmaReporteFirmaPos}
+\newlength{\@FirmaReporteTamLinea}
+\newlength{\@FirmaReportePosX}
+\newlength{\@FirmaReporteExcesoLinea}
+\newlength{\@TempDimen}
 
-%% Condicionales auxiliares para la posición de los objetos fijos cuando son medidos desde la derecha, o desde abajo.
-\newbool{FechaXnegativo}
-\newbool{FechaYnegativo}
-\newbool{CondYnegativo}% no hay CondXnegativo.
-\newbool{DenomXnegativo}
-\newbool{DenomYnegativo}
-\newbool{ControlXnegativo}
-\newbool{ControlYnegativo}
-\newbool{FirmasYnegativo}% no hay FirmasXnegativo; hay X_inicial y X_final para las firmas.
+%% Cajas para uso interno.
+\newbox{\@CajaDatos}
+\newbox{\@CajaResumen}
+\newbox{\@CajaFirmaEmisor}
+\newbox{\@CajaFirmas}
+\newbox{\@CajaFecha}
+\newbox{\@CajaDenom}
+\newbox{\@CajaControl}
+\newbox{\@CajaCond}
+\newbox{\@CajaEspacioVacio}
+\newbox{\@CajaPrueba}
+\newbox{\@CajaCaracterCR}
 
-\DeclareOption{prefactura}{\@prefacturatrue\@denomtrue\@confirmasfalse}%  La prefactura; con el diseño de la forma libre... para enviar por correo electrónico, fax o imprimir preliminarmente.
+%% Contadores.
+\newcounter{@IVANoGeneral}%  '0' con sólo IVA G, '1' cuando hay IVA R o IVA A, y '2' cuando hay ambos.
+\newcounter{NumItem}%  Número del ítem actual, para uso de algunas macros en el cuadro de la factura y para cuando se usa la opción 'numitem'.
+\newcount\AuxFecha
+
+% Errores, advertencias e informaciones de LaTeX.
+\newcommand{\CLASSERROR}[1]{\ClassError{factura}{** #1. **}{}}
+\newcommand{\CLASSWARNING}[1]{\ClassWarning{factura}{** #1. **}{}}
+\newcommand{\CLASSINFO}[1]{\ClassInfo{factura}{** #1. **}{}}
+
+% Opciones de la clase.
+\DeclareOption{prefactura}{\@prefacturatrue\@denomtrue\@sinfirmastrue}%  La prefactura; con el diseño de la forma libre... para enviar por correo electrónico, fax o imprimir preliminarmente.
 \DeclareOption{cotizacion}{\@cotizaciontrue\@denomtrue\@unafirmatrue}%  Cambia la denominación a 'COTIZACIÓN' y no 'FACTURA'.
-\DeclareOption{nospanish}{\@spanishfalse}%  No carga babel en castellano ni la codificación T1 de las letras.
-\DeclareOption{sinfirmas}{\@confirmasfalse}%  No agrega los espacios para firmar.
-\DeclareOption{unafirma}{\@unafirmatrue\@confirmastrue}%  No agrega el espacio para que firme quien recibe.
-\DeclareOption{dosfirmas}{\@unafirmafalse\@confirmastrue}%  Pone las dos firmas para firmar.
+\DeclareOption{nospanish}{\@nospanishtrue}%  No carga babel en castellano ni la codificación T1 de las letras.
+\DeclareOption{sinfirmas}{\@sinfirmastrue}%  No agrega los espacios para firmar.
+\DeclareOption{unafirma}{\@unafirmatrue\@sinfirmasfalse}%  No agrega el espacio para que firme quien recibe.
+\DeclareOption{dosfirmas}{\@unafirmafalse\@sinfirmasfalse}%  Pone las dos firmas para firmar.
 \DeclareOption{descuentos}{\booltrue{Descuentos}\@descuentostrue}%  Para los descuentos individuales.
+\DeclareOption{iva}{\@impdesctrue\booltrue{IVA}}%  Para la columna del IVA.
 \DeclareOption{subtotal}{%  Para la columna extra del subtotal antes del descuento.
  \if at descuentos
   \booltrue{Subtotal}
  \else
-  \ClassWarning{factura}{La opción 'subtotal' no aplica sin descuentos individuales. Sin efecto opción 'subtotal'}{}
+  \CLASSWARNING{La opción 'subtotal' no aplica sin descuentos individuales. Sin efecto opción 'subtotal'}
  \fi}
-\DeclareOption{sincondiciones}{\@concondicionesfalse}%  No agrega el texto con las condiciones del documento.
 \DeclareOption{denom}{\@denomtrue}%  Agrega el texto con la denominación del documento, para las formas libres que no tienen el número de factura.
+\DeclareOption{vencimiento}{\@vencimientotrue}%  Escribe fecha de vencimiento, aún con facturas sin crédito.
 \DeclareOption{sinnumero}{\@sinnumerotrue\@denomtrue}%  Escribir el texto de la denominación del documento pero sin escribir el número.
 \DeclareOption{G}{\@Gtrue}%  Con esta opción sale la letra 'G' en los items con IVA general, y sale el porcentaje en la base imponible general.
 \DeclareOption{filas}{\@filastrue}%  Estilo de totalización en filas.
 \DeclareOption{sintotales}{\@sintotalestrue%  No escribe los totales al final, por ejemplo para cotizaciones de productos similares.
  \if at filas
-  \ClassWarning{factura}{La opción 'sintotales' no aplica para el modo de totalización en filas. Sin efecto opción 'filas'.}{}
+  \CLASSWARNING{La opción 'sintotales' no aplica para el modo de totalización en filas. Sin efecto opción 'filas'}
   \@filasfalse
  \fi
  \if at cotizacion
  \else
-  \ClassWarning{factura}{La opción 'sintotales' no debe usarse en facturas sino en cotizaciones. No es válida una factura sin totales.}{}
+  \CLASSWARNING{La opción 'sintotales' no debe usarse en facturas sino en cotizaciones. No es válida una factura sin totales}
  \fi}
 \DeclareOption{centrado}{%  Total y exento 'centrado'; sólo para estilo 'filas'
  \if at filas
   \@centradotrue
  \else
-  \ClassWarning{factura}{La opción 'centrado' no es compatible con el modo de totalización en columnas. Sin efecto opción 'centrado'.}{}
+  \CLASSWARNING{La opción 'centrado' no es compatible con el modo de totalización en columnas. Sin efecto opción 'centrado'}
  \fi}
 \DeclareOption{agrupado}{%  Agrupados los elementos totalizadores en el modo en columnas.
  \if at filas
-  \ClassWarning{factura}{La opción 'agrupado' no es compatible con el modo de totalización en filas. Sin efecto opción 'agrupado'.}{}
+  \CLASSWARNING{La opción 'agrupado' no es compatible con el modo de totalización en filas. Sin efecto opción 'agrupado'}
  \else
   \@agrupadotrue
  \fi}
@@ -1688,22 +2109,30 @@
 \DeclareOption{dcu}{%  Descripción, luego cantidad y luego precio unitario.
  \@dcutrue\@cdufalse\@ducfalse
  \booltrue{DCU}\boolfalse{DUC}
- \booltrue{PrimeroDescrip}}
+ \booltrue{PrimeroDescripcion}}
 \DeclareOption{duc}{%  Descripción, luego precio unitario y luego cantidad.
  \if at dcu
-  \ClassWarning{factura}{Las opciones 'duc' y 'dcu' no son compatibles. Sin efecto ambas opciones}{}
-  \boolfalse{PrimeroDescrip}\boolfalse{DCU}\@dcufalse\@cdutrue
+  \CLASSWARNING{Las opciones 'duc' y 'dcu' no son compatibles. Sin efecto ambas opciones}
+  \boolfalse{PrimeroDescripcion}\boolfalse{DCU}\@dcufalse\@cdutrue
  \else
   \@ductrue\@cdufalse\@dcufalse
   \booltrue{DUC}\boolfalse{DCU}
-  \booltrue{PrimeroDescrip}
+  \booltrue{PrimeroDescripcion}
  \fi}
 \DeclareOption{siniva}{\AtBeginDocument{\gdef\@ImpuestoG{0}\gdef\@ImpuestoR{0}\gdef\@ImpuestoA{0}}}%  No cobra IVA.
 \DeclareOption{todosiva}{\@todosivatrue}%  Con esta opción salen todos los IVA así valgan cero.
+\DeclareOption{electro}{%  Parche por el Decreto 3085 de Nikolài.
+ \booltrue{Electro}
+ \gdef\@NotaInterna{\@TextoDescuentoPresidencial}
+ \CLASSINFO{Se estableció el texto aclaratorio del descuento presidencial como 'nota interna'}
+ \if at filas
+  \CLASSWARNING{La opción 'electro' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}
+  \@filasfalse
+ \fi}
 \DeclareOption{sinivaexpresado}{%  Cuando no se cobra IVA y tampoco se quiere que aparezca la totalización del IVA.
- \@ivaexpresadofalse
+ \@sinivaexpresadotrue
  \if at filas
-  \ClassWarning{factura}{La opción 'sinivaexpresado' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}{}
+  \CLASSWARNING{La opción 'sinivaexpresado' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}
   \@filasfalse
  \else
   \AtBeginDocument{\gdef\@ImpuestoG{0}\gdef\@ImpuestoR{0}\gdef\@ImpuestoA{0}}
@@ -1711,14 +2140,13 @@
 \DeclareOption{sincantidad}{%  Para no poner el campo de la cantidad.
  \booltrue{SinCantidad}
  \if at dcu
-  \ClassWarning{factura}{La opción 'sincantidad' no es compatible con 'dcu' . Sin efecto opción 'dcu'}{}
-  \@dcufalse\@cdutrue\boolfalse{DCU}\boolfalse{PrimeroDescrip}
+  \CLASSWARNING{La opción 'sincantidad' no es compatible con 'dcu' . Sin efecto opción 'dcu'}
+  \@dcufalse\@cdutrue\boolfalse{DCU}\boolfalse{PrimeroDescripcion}
  \fi
  \if at duc
-  \ClassWarning{factura}{La opción 'sincantidad' no es compatible con 'duc' . Sin efecto opción 'duc'}{}
-  \@ducfalse\@cdutrue\boolfalse{DUC}\boolfalse{PrimeroDescrip}
+  \CLASSWARNING{La opción 'sincantidad' no es compatible con 'duc' . Sin efecto opción 'duc'}
+  \@ducfalse\@cdutrue\boolfalse{DUC}\boolfalse{PrimeroDescripcion}
  \fi}
-
 \DeclareOption{conlineasha}{\@conlineashatrue}%  Una línea horizontal para cada ítem, como las facturas a mano.
 \DeclareOption{sinlineasv}{%  Estilo 'sinlineasv'.
  \booltrue{SinLineasVertExt}\booltrue{SinLineasVertInt}}
@@ -1728,16 +2156,17 @@
  \booltrue{SinLineasHoriExt}\booltrue{SinLineasHoriInt}}
 \DeclareOption{sinlineashi}{\booltrue{SinLineasHoriInt}}%  Estilo 'sinlineashi'.
 \DeclareOption{sinlineashe}{\booltrue{SinLineasHoriExt}}%  Estilo 'sinlineashe'.
-\DeclareOption{exparriba}{\@exparribatrue\boolfalse{ExpAbajo}}%  Para rellenar con líneas en blanco de manera automática.
-\DeclareOption{sinexpandir}{\boolfalse{ExpAbajo}\@exparribafalse}%  No expande ninguna de las dos partes de la factura.
+\DeclareOption{expandecuadro}{\@expandecuadrotrue\boolfalse{ExpAbajo}}%  Para rellenar con líneas en blanco de manera automática.
+\DeclareOption{sinexpandir}{\boolfalse{ExpAbajo}\@expandecuadrofalse}%  No expande ninguna de las dos partes de la factura.
 \DeclareOption{linea}{%  Para la línea que protege el espacio en blanco.
- \if at exparriba
+ \if at expandecuadro
   \@lineatrue
  \else
-  \ClassWarning{factura}{La opción 'linea' requiere la opción 'exparriba'. Sin efecto opción 'linea'.}{}
+  \CLASSWARNING{La opción 'linea' requiere la opción 'expandecuadro'. Sin efecto opción 'linea'}
  \fi}
 \DeclareOption{conreporte}{\@reportetrue}%  Para imprimir factura y reporte.
-\DeclareOption{soloreporte}{\@reportetrue\@facturafalse}%  Para imprimir sólo el reporte.
+\DeclareOption{soloreporte}{\@reportetrue\@facturafalse\@reversofalse}%  Para imprimir sólo el reporte.
+\DeclareOption{sinreverso}{\@reversofalse}%  Para no imprimir el reverso de la factura.
 \DeclareOption{twoside}{\PassOptionsToClass{twoside}{article}}%  Opción 'twoside' de article para los reportes.
 \DeclareOption{csv}{%  Para la salida en modo csv también.
  \if at factura
@@ -1744,7 +2173,7 @@
   \@csvtrue
   \if at sintotales\else\AtEndDocument{\@EscribeTotalesEnCSV}\fi
  \else
-  \ClassWarning{factura}{La opción 'csv' require generar la factura. Sin efecto opción 'csv'.}{}
+  \CLASSWARNING{La opción 'csv' require generar la factura. Sin efecto opción 'csv'}
  \fi}
 
 \ProcessOptions\relax
@@ -1754,6 +2183,7 @@
 \RequirePackage{xparse}%  Algunos comandos los definimos con \NewDocumentCommand.
 \RequirePackage[absolute]{textpos}%  Es necesario 'textpos' para colocar texto en ubicaciones arbitrarias.
 \RequirePackage{geometry}%  'geometry' para ajustar todos los márgenes.
+\RequirePackage{eso-pic}%  Para el comando \AddToShipoutPicture.
 \RequirePackage{xstring}%  Lo usamos sólo para tomar el menos al principio de una longitud.
 \RequirePackage{calc}%  'calc' para hacer aritmética con las dimensiones.
 \RequirePackage{fp-upn}%  Fundamental el paquete 'fp-upn' para todos los cálculos.
@@ -1763,75 +2193,119 @@
 \RequirePackage{tabularx}%  Con 'tabularx' hacemos la tabla.
 \RequirePackage{environ}%  Con 'environ' podemos usar tabularx dentro del ambiente de la factura y escribir texto en el enddef.
 \RequirePackage{fancyhdr}%  Las cabeceras fancy; así se use solamente en reporte, hay que cargarlo siempre.
+\RequirePackage[calc]{datetime2}%  Para calcular la fecha del vencimiento del crédito.
 
-\AtBeginDocument{%  Da error si algún campo necesario no está definido.
+%% Gracias a Alan Munn y a wipet (Thanks to Alan Munn and wipet).
+%% (https://tex.stackexchange.com/questions/396363/input-a-date-to-datetime2-in-a-format-different-than-iso)
+\def\DTMsavedatex#1#2{%
+ \expandafter \ifx \csname f=\DTMinformat\endcsname \relax
+  \CLASSERROR{\string\DTMsavedatex: formato "\DTMinformat" desconocido}%
+ \else
+  \csname f=\DTMinformat\expandafter\endcsname#2&{#1}%
+ \fi
+}
+\def\DTMfdef#1{\expandafter\def\csname f=#1\endcsname}
+\def\DTMs#1#2{\DTMsavedate{#2}{#1}}
+\DTMfdef{yyyy-mm-dd}#1-#2-#3&{\DTMs{#1-#2-#3}}
+\DTMfdef{yyyy.mm.dd}#1.#2.#3&{\DTMs{#1-#2-#3}}
+\DTMfdef{yyyymmdd}#1#2#3#4#5#6#7#8&{\DTMs{#1#2#3#4-#5#6-#7#8}}
+\DTMfdef{dd-mm-yyyy}#1-#2-#3&{\DTMs{#3-#2-#1}}
+\DTMfdef{dd.mm.yyyy}#1.#2.#3&{\DTMs{#3-#2-#1}}
+\DTMfdef{ddmmyyyy}#1#2#3#4#5#6#7#8&{\DTMs{#5#6#7#8-#3#4-#1#2}}
+\DTMfdef{mm-dd-yyyy}#1-#2-#3&{\DTMs{#3-#1-#2}}
+
+\AtEndPreamble{\DTMsetstyle{\@FormatoFecha}\DTMsetup{datesep=\@FechaSeparadores}\gdef\DTMinformat{\@FormatoFechaEntrada}}
+\def\@Fecha{\DTMusedate{FechaEmision}}
+
+%% Una vez definido todo en el preámbulo los comandos usados para definir campos servirán para mostrar el campo que se definió con ese comando.
+\AtEndPreamble{%
+ \def\RazonSocial{\@RazonSocial}
+ \let\Nombre\RazonSocial
+ \def\RIF{\@RIF}
+ \let\CI\RIF
+ \def\Direccion{\@Direccion}
+ \def\Telefono{\@Telefono}
+ \def\Email{\@Email}
+ \def\Contacto{\@Contacto}
+ \def\Emisor{\@Emisor}
+ \def\Conforme{\@Conforme}
+ \def\Proveedor{\@Proveedor}
+ \def\Credito{\@Credito}
+ \def\Num{\@Num}
+ \def\NumSerieControl{\@NumSerieControl}
+ \def\NumControl{\@NumControl}
+ \def\Condiciones{\@Condiciones}
+ \def\Resumen{\@Resumen}
+ \def\NotaPrevia{\@NotaPrevia}
+ \def\NotaInterna{\@NotaInterna}
+ \def\NotaExterna{\@NotaExterna}}
+
+\AtBeginDocument{%  Efectúa distintos chequeos.
  \if at reporte
-  \ifdefvoid{\@Fecha}{\ClassWarning{factura}{** No se especificó una fecha. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras **}{}}{}%
-  \ifdefvoid{\@Num}{\ClassWarning{factura}{** No se especificó el número de la factura. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras **}{}}{}%
+  \ifdefvoid{\@Num}{\CLASSWARNING{No se especificó el número de la factura. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras}}{}%
   \ifdefvoid{\@Proveedor}{%
    \ifdefvoid{\@Emisor}
-    {\ClassError{factura}{** Hay que definir el nombre del proveedor cuando se emite un reporte **}{}}%
-    {\ClassWarning{factura}{** Se toma el emisor como el proveedor por no haberse especificado este último **}{}%
+    {\CLASSERROR{Hay que definir el nombre del proveedor cuando se emite un reporte}}%
+    {\CLASSWARNING{Se toma el emisor como el proveedor por no haberse especificado este último}%
     \let\@Proveedor=\@Emisor}}
    {}%
  \fi
- \ifdefvoid{\@RazonSocial}{\ClassError{factura}{** Hay que definir la razón social **}{}}{}%
+ \ifdefvoid{\@RazonSocial}{\CLASSERROR{Hay que definir la razón social}}{}%
  \if at factura
-  \ifdefvoid{\@RIF}{\ClassError{factura}{** Hay que definir el R.I.F. **}{}}{}%
-  \ifdefvoid{\@Direccion}{\ClassError{factura}{** Hay que definir la dirección fiscal **}{}}{}%
-  \ifdefvoid{\@Telefono}{\ClassError{factura}{** Hay que definir un número telefónico **}{}}{}%
-  \ifdefvoid{\@Email}{\ClassWarning{factura}{** Pudiera definirse una dirección de correo electrónico **}{}}{}%
-  \ifdefvoid{\@Fecha}{\ClassError{factura}{** Hay que definir la fecha de emisión **}{}}{}%
-  \if at concondiciones
-   \ifdefvoid{\@Condiciones}{\ClassError{factura}{** Hay que definir las condiciones del documento o usar la opción 'sincondiciones' **}{}}{}%
-  \fi
+  \ifdefvoid{\@RIF}{\CLASSERROR{Hay que definir el R.I.F}}{}%
+  \ifdefvoid{\@Direccion}{\CLASSERROR{Hay que definir la dirección fiscal}}{}%
+  \ifdefvoid{\@Telefono}{\CLASSWARNING{Pudiera definirse un número telefónico}}{}%
+  \ifdefvoid{\@Email}{\CLASSWARNING{Pudiera definirse una dirección de correo electrónico}}{}%
+  \ifdefvoid{\@Condiciones}{\CLASSWARNING{Pudieran definirse las condiciones del documento}}{}%
+  \DTMifsaveddate{FechaEmision}{}{%
+   \CLASSWARNING{No se especificó fecha. Asumiendo la fecha de hoy}%
+   \DTMsavedate{FechaEmision}{\the\year-\the\month-\the\day}}%
   \if at cotizacion
-   \ifdefvoid{\@FondoFactura}{\ClassWarning{factura}{** En la opción para cotizacion se recomienda agregar el fondo **}{}}{}%
+   \ifdefvoid{\@FondoFactura}{\CLASSWARNING{En la opción para cotizacion se recomienda agregar el fondo}}{}%
   \fi
   \if at prefactura
-   \ifdefvoid{\@FondoFactura}{\ClassWarning{factura}{** En la opción para prefactura se recomienda agregar el fondo **}{}}{}%
+   \ifdefvoid{\@FondoFactura}{\CLASSWARNING{En la opción para prefactura se recomienda agregar el fondo}}{}%
   \fi
   \if at sinnumero
    \if at cotizacion
    \else
-    \ClassError{factura}{** La opción para no poner el número sólo es compatible con las cotizaciones **}{}%
+    \CLASSERROR{La opción para no poner el número sólo es compatible con las cotizaciones}%
    \fi
   \fi
   \if at denom
    \if at sinnumero
    \else
-    \ifdefvoid{\@Num}{\ClassError{factura}{** Hay que definir el número de la factura **}{}}{}%
+    \ifdefvoid{\@Num}{\CLASSERROR{Hay que definir el número de la factura}}{}%
    \fi
   \fi
  \fi
- \ifdefvoid{\@Contacto}{\if at nombre\else\ClassWarning{factura}{** Pudiera definirse una persona de contacto **}{}\fi}{}%
+ \ifdefvoid{\@Contacto}{\if at Nombre\else\CLASSWARNING{Pudiera definirse una persona de contacto}\fi}{}%
 }
 
 %% Escribimos el total como comentario en el .log, y avisamos cuando la fecha no sea la de hoy.
 \AtEndDocument{%
- \edef\@Hoy{\ifnum\number\day<10 0\fi\the\day-\ifnum\number\month<10 0\fi\the\month-\the\year}%
- \ifx\undefined\@Fecha
+ \DTMsavenow{Ahora}%
+ \DTMsaveddatediff{FechaEmision}{Ahora}{\AuxFecha}%
+ \ifnum\AuxFecha=0%
  \else
-  \edef\@Fecha{\@Fecha}%
-  \ifx\@Fecha\@Hoy
-  \else
-   \ClassWarning{factura}{** Fecha del documento\space \@Fecha\space distinta de la fecha de hoy. **}{}%
-  \fi
+  \CLASSWARNING{Fecha del documento \@Fecha\space distinta de la fecha de hoy}%
  \fi
  \if at sintotales
  \else
-  \if at factura\ClassInfo{factura}{\@@Total: \space\space\space \Moneda \Total}{}\fi
+  \if at factura\CLASSINFO{\@@Total: \space\space\space \Moneda \Total}\fi
  \fi}
 
 %</class>
 %<*class|def>
-%% La geometría en formato de factura y de reporte.
-%% El margen superior está definido desde el encabezado con los datos del cliente.
-%% El margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
-%% Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
+%% La geometría para la factura, su reverso, y el reporte.
+%% Para la factura, el margen superior está definido desde el encabezado con los datos del cliente;
+%%  el margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
+%%  Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
 %<class>\def\GeometriaFactura#1{\gdef\@GeometriaFactura{#1}}
+%<class>\def\GeometriaReverso#1{\gdef\@GeometriaReverso{#1}}
 %<class>\def\GeometriaReporte#1{\gdef\@GeometriaReporte{#1}}
-%<def>\GeometriaFactura{letterpaper,vmargin={5cm,5.5cm},  hmargin={1cm,1cm},footskip=0pt,  headsep=0pt,    headheight=0pt}
+%<def>\GeometriaFactura{letterpaper,vmargin={5.2cm,5.5cm},hmargin={1cm,1cm},footskip=0pt,  headsep=0pt,    headheight=0pt}
+%<def>\GeometriaReverso{letterpaper,vmargin={1cm,1cm},    hmargin={1cm,1cm},footskip=0cm,  headsep=0pt,    headheight=0pt}
 %<def>\GeometriaReporte{letterpaper,vmargin={2.8cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
 
 %<class>%% Se utiliza '\@Impuesto' como el factor del impuesto, el cual viene predefinido en '\@Alicuota'.
@@ -1838,19 +2312,25 @@
 %<class>\def\@ImpuestoG{\@AlicuotaG}
 %<class>\def\@ImpuestoR{\@AlicuotaR}
 %<class>\def\@ImpuestoA{\@AlicuotaA}
-%<def>%% Porcentajes de los distintos IVA (general, reducido y adicional):
+%<def>%% Factores para los distintos IVA y el límite para el descuento:
 %<def>\def\@AlicuotaG{0.12}
+%<def>\def\@AlicuotaGDescBajo{0.03}
+%<def>\def\@AlicuotaGDescAlto{0.05}
+%<def>\def\@AlicuotaGDescLimite{2000000}
 %<def>\def\@AlicuotaR{0.08}
-%<def>\def\@AlicuotaA{0.22}
+%<def>\def\@AlicuotaA{0.27}
 %<def>
 %</class|def>
 %<*def>
-%% i) separador de miles, ii) separador decimal, iii) número de decimales para la moneda iv) y para los porcentajes, v) número de dígitos de la numeración de la factura:
+%% i) separador de miles, ii) separador decimal, iii) número de decimales para la moneda iv) y para los porcentajes, v) número de dígitos de la numeración de la factura, vi) formato de la fecha, vii) separadores para la fecha.
 \npthousandsep{.}
 \npdecimalsign{,}
 \def\@DigitosMoneda{2}
 \def\@DigitosPorc{2}
 \def\@DigitosNumeracion{5}
+\def\@FormatoFecha{ddmmyyyy}
+\def\@FormatoFechaEntrada{dd-mm-yyyy}
+\def\@FechaSeparadores{-}
 
 %% La moneda:
 \def\Moneda{Bs.}
@@ -1861,17 +2341,41 @@
 \def\@DenomAlicuotaA{A}
 \def\@DenomAlicuotaE{(E)}
 
+%% El texto predeterminado para la nota interna por el descuento presidencial.
+\def\@TextoDescuentoPresidencial{Se aplica un descuento del \@AlicuotaGDescPorc\% al IVA General seg\'un Decreto Presidencial 3085 en Gaceta Oficial 41239.}
+
 %% Macros que guardan textos que corresponden a nombres de campos:
 \def\@@Fecha{Fecha de emisi\'on:}
+\def\@@FechaVencimiento{Fecha de vencimiento:}
+\def\@@Control{N\textordmasculine\space CONTROL}
+\def\@@Datos{Datos del cliente}
+\def\@@Resumen{Resumen del servicio}
+\def\@@DenomFactura{FACTURA}
+\def\@@DenomCotiza{COTIZACI\'ON}
 \def\@@RazonSocial{Raz\'on social:}
+\def\@@Nombre{Nombre:}
+\def\@@RIF{R.I.F.:}
+\def\@@CI{C.I.:}
+\def\@@Direccion{Direcci\'on fiscal:}
+\def\@@Telefono{Tel\'efono:}
+\def\@@Email{E-mail:}
+\def\@@Contacto{Persona de contacto:}
+\def\@@Proveedor{Proveedor:}
+\def\@@Cliente{Cliente:}
+\def\@@Emisor{Por el emisor}
+\def\@@Conforme{Recib\'i conforme}
+\def\@@Pagado{PAGADO}
 \def\@@NumItem{\#}
 \def\@@Cantidad{Cantidad}
 \def\@@Descripcion{Descripci\'on}
+\def\@@Precio{Precio}
 \def\@@PrecioU{Precio U.}
 \def\@@PrecioS{Subtotal}
+\def\@@Descuento{Dcto.}
+\def\@@IVA{IVA}
 \def\@@PrecioT{Precio T.}
-\def\@@Precio{Precio}
 \def\@@AlicuotaG{IVA G}
+\def\@@AlicuotaGDesc{Descuento IVA G}
 \def\@@AlicuotaR{IVA R}
 \def\@@AlicuotaA{IVA A}
 \def\@@BIG{BI G}
@@ -1879,7 +2383,6 @@
 \def\@@BIA{BI A}
 \def\@@BIE{Exento}% La base imponible exenta. ;)
 \def\@@Total{TOTAL}
-\def\@@Descuento{Dcto.}
 \def\@@DescuentoG{Descuento G}
 \def\@@DescuentoR{Descuento R}
 \def\@@DescuentoA{Descuento A}
@@ -1888,22 +2391,6 @@
 \def\@@SubtotalR{Subtotal R}
 \def\@@SubtotalA{Subtotal A}
 \def\@@SubtotalE{Subtotal E}
-\def\@@RIF{R.I.F.:}
-\def\@@CI{C.I.:}
-\def\@@Contacto{Persona de contacto:}
-\def\@@Direccion{Direcci\'on fiscal:}
-\def\@@Telefono{Tel\'efono:}
-\def\@@Email{E-mail:}
-\def\@@Datos{Datos del cliente}
-\def\@@Resumen{Resumen del servicio}
-\def\@@Conforme{Recib\'i conforme}
-\def\@@Emisor{Por el emisor}
-\def\@@Pagado{PAGADO}
-\def\@@DenomFactura{FACTURA}
-\def\@@DenomCotiza{COTIZACI\'ON}
-\def\@@Control{N\textordmasculine\space CONTROL}
-\def\@@Proveedor{Proveedor:}
-\def\@@Cliente{Cliente:}
 
 %% i) carácter para separar el teléfono del e-mail del cliente,
 %% ii) carácter para los campos vacíos cuando se usa \ItemX,
@@ -1922,14 +2409,22 @@
   \draw[line width=0.075ex] (0,0) arc (20:70:0.75ex) + (0,0) arc (-70:-20:0.75ex) ++ (0.8ex,0.55ex) arc (0:-100:1ex);
  \end{tikzpicture}}}
 
-%% Separación entre la última letra y el carácter que indica que se continúa en la línea siguiente en la descripción cuando ocupa más de una línea. No vale la pena hacer una macro para cambiar esto.
-\setlength{\@SeparaFinLineaDesc}{0.05cm}
-
 %% Separación entre el inicio de una columna en la tabla y el inicio del texto.
 \tabcolsep=0.15cm
 
+%% Separación entre la última letra y el carácter que indica que se continúa en la línea siguiente en la descripción cuando ocupa más de una línea.
+\setlength{\@SeparaFinLineaDesc}{0.15cm}
+
+%% Separación entre el teléfono y el carácter \@CaracterSeparaTelefonoEmail, y luego desde ese carácter hasta el email,
+%% para cuando no hay resumen.
+\setlength{\@SeparaTelefonoEmail}{0.666em}
+
 %% Grosor de la línea de 'fancyhdr' para las cabeceras, en aquellas donde haya línea.
-\def\@GrosorLineaInfoPag{0.4pt}
+\setlength{\@GrosorLineaInfoPag}{0.4pt}
+
+%% Posición en X desde la derecha y excedente en la línea de la firma.
+\setlength{\@FirmaReportePosX}{2cm}
+\setlength{\@FirmaReporteExcesoLinea}{1.5cm}
 %</def>
 %<class|def>
 %<*class>
@@ -1943,10 +2438,16 @@
 \def\@DescuentoAnum{0}
 \def\@DescuentoEnum{0}
 
-%% \Fecha, \RazonSocial, \Nombre, \RIF, \CI, \Contacto, \Dirección, \Telefono, \Email, \Emisor, \Proveedor.
-\def\Fecha#1{\gdef\@Fecha{#1}}
+%% \Fecha, \FormatoFecha, \Credito, \RazonSocial, \Nombre, \RIF, \CI, \Contacto, \Dirección, \Telefono, \Email, \Conforme, \Emisor, \Proveedor.
+\NewDocumentCommand{\Fecha}{s m g g}{%
+ \IfBooleanTF{#1}
+  {\AtEndPreamble{\DTMsavedate{FechaEmision}{#2-#3-#4}}}
+  {\AtEndPreamble{\DTMsavedatex{FechaEmision}{#2}}}}
+\NewDocumentCommand{\FormatoFecha}{o g g}{%
+ \IfValueT{#1}{\gdef\@FormatoFechaEntrada{#1}}\IfValueT{#2}{\gdef\@FormatoFecha{#2}}\IfValueT{#3}{\gdef\@FechaSeparadores{#3}}}
+\def\Credito#1{\gdef\@Credito{#1}\@vencimientotrue}
 \def\RazonSocial#1{\gdef\@RazonSocial{#1}}
-\def\Nombre#1{\gdef\@RazonSocial{#1}\@nombretrue}
+\def\Nombre#1{\gdef\@RazonSocial{#1}\@Nombretrue}
 \def\RIF#1{\gdef\@RIF{#1}}
 \def\CI#1{\gdef\@RIF{#1}\let\@@RIF\@@CI\let\@CI\@RIF}
 \def\Contacto#1{\gdef\@Contacto{#1}}
@@ -1964,23 +2465,23 @@
   \gdef\@DescuentoGnum{#2}\gdef\@DescuentoRnum{#2}\gdef\@DescuentoAnum{#2}\gdef\@DescuentoEnum{#2}}
   {\@DescGnumfalse\@DescRnumfalse\@DescAnumfalse\@DescEnumfalse
   \gdef\@DescuentoGporc{#2}\gdef\@DescuentoRporc{#2}\gdef\@DescuentoAporc{#2}\gdef\@DescuentoEporc{#2}}%
- \@DescGtrue\@DescRtrue\@DescAtrue\@DescEtrue\@Descuentostrue}
+ \@DescGtrue\@DescRtrue\@DescAtrue\@DescEtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoG}{s m}{%
  \IfBooleanTF{#1}{\@DescGnumtrue\gdef\@DescuentoGnum{#2}}{\@DescGnumfalse\gdef\@DescuentoGporc{#2}}%
- \@DescGtrue\@Descuentostrue}
+ \@DescGtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoR}{s m}{%
  \IfBooleanTF{#1}{\@DescRnumtrue\gdef\@DescuentoRnum{#2}}{\@DescRnumfalse\gdef\@DescuentoRporc{#2}}%
- \@DescRtrue\@Descuentostrue}
+ \@DescRtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoA}{s m}{%
  \IfBooleanTF{#1}{\@DescAnumtrue\gdef\@DescuentoAnum{#2}}{\@DescAnumfalse\gdef\@DescuentoAporc{#2}}%
- \@DescAtrue\@Descuentostrue}
+ \@DescAtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoE}{s m}{%
  \IfBooleanTF{#1}{\@DescEnumtrue\gdef\@DescuentoEnum{#2}}{\@DescEnumfalse\gdef\@DescuentoEporc{#2}}%
- \@DescEtrue\@Descuentostrue}
+ \@DescEtrue\@DescuentoTotaltrue}
 
 \def\Denom#1{\gdef\@Denominacion{#1}}%  La denominación puede ser 'FACTURA', 'COTIZACIÓN' u otra. Se predetermina una de estas dos según las opciones de la clase.
 
@@ -1989,7 +2490,7 @@
 \def\NumControl#1{\gdef\@NumControl{\nplpadding{\@DigitosNumeracion}\npthousandsep{}\numprint{#1}}}%  Si el número de control no se especifica, toma el mismo que el de la factura
 \def\NumSerieControl#1{\gdef\@NumSerieControl{#1}}%  Si el número de serie de control no se especifica, toma '00'.
 
-%% Información de página: cabeceras de páginas o piés de página.
+%% Información de página: cabeceras de páginas o pies de página.
 \def\InfoPagina#1{\gdef\@InfoPagina{#1}}
 
 %% Texto que esclarece las condiciones del documento.
@@ -1998,7 +2499,21 @@
 %% Resumen opcional que va a la derecha de los datos del cliente.
 \NewDocumentCommand{\Resumen}{+m}{\gdef\@Resumen{#1}}
 
+\NewDocumentCommand{\NotaPrevia}{+m}{\gdef\@NotaPrevia{#1}}
+
+%% Nota interna al cuadro de la factura y nota externa a él (que sale antes de \Descripcion).
+\NewDocumentCommand{\NotaInterna}{+m}{%
+ \ifdefvoid{\@NotaInterna}{}{\CLASSWARNING{Se sobreescribió la nota interna automática aclaratoria del descuento presidencial}}%
+ \gdef\@NotaInterna{#1}}
+\NewDocumentCommand{\NotaExterna}{+m}{\gdef\@NotaExterna{#1}}
+
 \AtBeginDocument{%
+ % El cálculo de la fecha de vencimiento para cuando haya crédito o fecha de vencimiento explícita.
+ \ifdefvoid{\@Credito}
+  {\gdef\@FechaVencimiento{\DTMusedate{FechaEmision}}}
+  {\DTMsaveddateoffsettojulianday{FechaEmision}{\@Credito}{\AuxFecha}%
+   \DTMsavejulianday{FechaVencimiento}{\number\AuxFecha}%
+   \gdef\@FechaVencimiento{\DTMusedate{FechaVencimiento}}}%
  \ifx\@undefined\@NumControl\let\@NumControl\@Num\fi
  \ifx\@undefined\@NumSerieControl\gdef\@NumSerieControl{00}\fi
  % Establecemos los porcentajes de las alícuotas, y redondeamos los descuentos.
@@ -2005,6 +2520,7 @@
  \FPupn\@AlicuotaGporc{\@AlicuotaG{} 100 * \@DigitosPorc{} round clip}%
  \FPupn\@AlicuotaRporc{\@AlicuotaR{} 100 * \@DigitosPorc{} round clip}%
  \FPupn\@AlicuotaAporc{\@AlicuotaA{} 100 * \@DigitosPorc{} round clip}%
+ \FPset\@AlicuotaEporc{0}%
  \FPupn\@DescuentoGporc{\@DescuentoGporc{} \@DigitosPorc{} round clip}%
  \FPupn\@DescuentoRporc{\@DescuentoRporc{} \@DigitosPorc{} round clip}%
  \FPupn\@DescuentoAporc{\@DescuentoAporc{} \@DigitosPorc{} round clip}%
@@ -2018,52 +2534,56 @@
 %<*class|def>
 %% Posiciones (X,Y) de los objetos: i) fecha, ii) denominación, iii) condiciones, iv) número de control, v) firmas.
 %<*class>
-\def\PosFecha#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosFechaX}{-\templeng}\booltrue{FechaXnegativo}}
-  {\boolfalse{FechaXnegativo}\setlength{\@PosFechaX}{#1}}
+\NewDocumentCommand{\PosFecha}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{FechaYarriba}}{\boolfalse{FechaYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosFechaY}{-\templeng}\booltrue{FechaYnegativo}}
-  {\boolfalse{FechaYnegativo}\setlength{\@PosFechaY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosFechaX}{-\templeng}\booltrue{FechaXnegativo}}
+  {\boolfalse{FechaXnegativo}\setlength{\@PosFechaX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosFechaY}{-\templeng}\booltrue{FechaYnegativo}}
+  {\boolfalse{FechaYnegativo}\setlength{\@PosFechaY}{#3}}}
 
 %</class>
-%<def>\PosFecha{-0cm}{4.3cm}
+%<def>\PosFecha*{-0cm}{5cm}
 %<*class>
-\def\PosDenom#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosDenomX}{-\templeng}\booltrue{DenomXnegativo}}
-  {\boolfalse{DenomXnegativo}\setlength{\@PosDenomX}{#1}}
+\NewDocumentCommand{\PosDenom}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{DenomYarriba}}{\boolfalse{DenomYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosDenomY}{-\templeng}\booltrue{DenomYnegativo}}
-  {\boolfalse{DenomYnegativo}\setlength{\@PosDenomY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosDenomX}{-\templeng}\booltrue{DenomXnegativo}}
+  {\boolfalse{DenomXnegativo}\setlength{\@PosDenomX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosDenomY}{-\templeng}\booltrue{DenomYnegativo}}
+  {\boolfalse{DenomYnegativo}\setlength{\@PosDenomY}{#3}}}
 
 %</class>
-%<def>\PosDenom{0cm}{4.3cm}
+%<def>\PosDenom*{0cm}{5cm}
 %<*class>
-\def\PosControl#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosControlX}{-\templeng}\booltrue{ControlXnegativo}}
-  {\boolfalse{ControlXnegativo}\setlength{\@PosControlX}{#1}}
+\NewDocumentCommand{\PosControl}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{ControlYarriba}}{\boolfalse{ControlYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosControlY}{-\templeng}\booltrue{ControlYnegativo}}
-  {\boolfalse{ControlYnegativo}\setlength{\@PosControlY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosControlX}{-\templeng}\booltrue{ControlXnegativo}}
+  {\boolfalse{ControlXnegativo}\setlength{\@PosControlX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosControlY}{-\templeng}\booltrue{ControlYnegativo}}
+  {\boolfalse{ControlYnegativo}\setlength{\@PosControlY}{#3}}}
 
 %</class>
-%<def>\PosControl{0cm}{-2.5cm}
+%<def>\PosControl*{0cm}{-2.4cm}
 %<*class>
-\def\PosCond#1#2{%
- \setlength{\@PosCondX}{#1}%
- \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosCondY}{-\templeng}\booltrue{CondYnegativo}}
-  {\boolfalse{CondYnegativo}\setlength{\@PosCondY}{#2}}}
+\NewDocumentCommand{\PosCondiciones}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{CondYarriba}}{\boolfalse{CondYarriba}}
+ \setlength{\@PosCondicionesX}{#2}%
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosCondicionesY}{-\templeng}\booltrue{CondYnegativo}}
+  {\boolfalse{CondYnegativo}\setlength{\@PosCondicionesY}{#3}}}
 %</class>
-%<def>\PosCond{0cm}{-5.3cm}
-%% 'X' no acepta valores negativos en \PosCond.
+%<def>\PosCondiciones{0cm}{-5.3cm}
+%% 'X' no acepta valores negativos en \PosCondiciones.
 %<*class>
 
-\def\PosFirmas#1#2#3{%
- \setlength{\@PosFirmasXuno}{#1}%
- \setlength{\@PosFirmasXdos}{#2}%
+\NewDocumentCommand{\PosFirmas}{m m m}{
+ \setlength{\@PosFirmasXuno}{#1}
+ \setlength{\@PosFirmasXdos}{#2}
  \IfBeginWith{#3}{-}
   {\StrBehind{#3}{-}[\templeng]\setlength{\@PosFirmasY}{-\templeng}\booltrue{FirmasYnegativo}}
   {\boolfalse{FirmasYnegativo}\setlength{\@PosFirmasY}{#3}}}
@@ -2073,8 +2593,8 @@
 
 %% Tamaño y grosor de la línea de las firmas.
 %<*class>
-\def\LineaFirmas#1#2{%
- \setlength{\@TamLineaFirmas}{#1}%
+\def\LineaFirmas#1#2{
+ \setlength{\@TamLineaFirmas}{#1}
  \setlength{\@GrosorLineaFirmas}{#2}}
 %</class>
 %<def>\LineaFirmas{5.5cm}{0.7pt}
@@ -2084,29 +2604,64 @@
 %<def>\SepFilas{0.8cm}{2.5pt}
 
 %% Separación vertical entre los elementos de la factura (entre el encabezado y el cuadro de la 'factura', luego desde dicho cuadro hasta la descripción, o hasta los totales en modo de filas).
-%<class>\def\SepElementos#1{\setlength{\@SeparaElementos}{#1}}
-%<def>\SepElementos{0.2cm}
+%<class>\def\SepVertical#1{\setlength{\@SeparaVertical}{#1}}
+%<def>\SepVertical{0.2cm}
 
-%% Separación horizontal entre las cajas del encabezado y separación interna entre la línea y el texto.
-%<class>\def\SepEncabez#1#2{\setlength{\@SeparaEncabez}{#1}\setlength{\@SeparaInternaEncabez}{#2}}
-%<def>\SepEncabez{0.2cm}{6pt}
+%% Separación horizontal entre la caja de los datos del cliente y la caja del resumen.
+%<class>\def\SepDatosResumen#1{\setlength{\@SeparaDatosResumen}{#1}}
+%<def>\SepDatosResumen{0.2cm}
 
+%% Separación horizontal interna entre la línea y el texto en los datos del cliente y en el resumen.
+%<class>\def\SepEncabezado#1{\setlength{\@SeparaInternaEncabezado}{#1}}
+%<def>\SepEncabezado{6pt}
+
+%% Separación interna entre la línea y el texto de la nota previa.
+%<class>\def\SepNotaPrevia#1{\setlength{\@SeparaInternaNotaPrevia}{#1}}
+%<def>\SepNotaPrevia{6pt}
+
 %% Separación extra entre los elementos en la factura.
 %<class>\def\SepItemsExtra#1{\setlength{\@SeparaItemsExtra}{#1}}
 %<def>\SepItemsExtra{0pt}
 
 %% Separación interna entre la línea y el texto de la descripción.
-%<class>\def\SepDescrip#1{\setlength{\@SeparaInternaDescrip}{#1}}
-%<def>\SepDescrip{6pt}
+%<class>\def\SepDescripcion#1{\setlength{\@SeparaInternaDescripcion}{#1}}
+%<def>\SepDescripcion{6pt}
 
+%<class>\def\SepCondiciones#1{\setlength{\@SeparaInternaCondiciones}{#1}}
+%<def>\SepCondiciones{5pt}
+
 %% Grosor de la línea de las cajas del encabezado, curvatura de la esquina y sombra.
-%<class>\def\LineaEncabez#1#2#3{\setlength{\@GrosorLineaEncabez}{#1}\setlength{\@EsquinaLineaEncabez}{#2}\setlength{\@SombraEncabez}{#3}}
-%<def>\LineaEncabez{0.4pt}{10pt}{0pt}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+%<class>\NewDocumentCommand{\LineaEncabezado}{m g g}{
+%<class> \setlength{\@GrosorLineaEncabezado}{#1}
+%<class> \IfValueT{#2}{\setlength{\@EsquinaLineaEncabezado}{#2}}
+%<class> \IfValueT{#3}{\setlength{\@SombraEncabezado}{#3}}}
+%<def>\LineaEncabezado{0.4pt}{10pt}{0pt}
 
+%% Grosor de la línea de la nota previa, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+%<class>\NewDocumentCommand{\LineaNotaPrevia}{m g g}{
+%<class> \setlength{\@GrosorLineaNotaPrevia}{#1}
+%<class> \IfValueT{#2}{\setlength{\@EsquinaLineaNotaPrevia}{#2}}
+%<class> \IfValueT{#3}{\setlength{\@SombraNotaPrevia}{#3}}}
+%<def>\LineaNotaPrevia{0.4pt}{7pt}{0pt}
+
 %% Grosor de la línea de la descripción, curvatura de la esquina y sombra.
-%<class>\def\LineaDescrip#1#2#3{\setlength{\@GrosorLineaDescrip}{#1}\setlength{\@EsquinaLineaDescrip}{#2}\setlength{\@SombraDescrip}{#3}}
-%<def>\LineaDescrip{0.4pt}{0pt}{4pt}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+%<class>\NewDocumentCommand{\LineaDescripcion}{m g g}{
+%<class> \setlength{\@GrosorLineaDescripcion}{#1}
+%<class> \IfValueT{#2}{\setlength{\@EsquinaLineaDescripcion}{#2}}
+%<class> \IfValueT{#3}{\setlength{\@SombraDescripcion}{#3}}}
+%<def>\LineaDescripcion{0.4pt}{0pt}{4pt}
 
+%% Grosor de la línea de las condiciones, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+%<class>\NewDocumentCommand{\LineaCondiciones}{m g g}{
+%<class> \setlength{\@GrosorLineaCondiciones}{#1}
+%<class> \IfValueT{#2}{\setlength{\@EsquinaLineaCondiciones}{#2}}
+%<class> \IfValueT{#3}{\setlength{\@SombraCondiciones}{#3}}}
+%<def>\LineaCondiciones{0pt}{0pt}{0pt}
+
 %% El espacio vertical que hay que avanzar sólo en la primera página del reporte antes de empezar a escribir sobre él. Usable cuando la primera página tiene un membrete y las demás no, es decir, cuando se usa \FondoReporte y no \FondoReporte*.
 %<class>\def\InicioReporte#1{\setlength{\@InicioReporte}{#1}}
 %<def>\InicioReporte{1.6cm}
@@ -2116,9 +2671,17 @@
 %<class>\def\LetraItems#1{\gdef\@LetraItems{#1\selectfont}}
 %<def>\LetraItems{\fontsize{14}{18}}
 
+%% Tipo de letra para la nota interna:
+%<class>\def\LetraNotaInterna#1{\gdef\@LetraNotaInterna{#1\selectfont}}
+%<def>\LetraNotaInterna{\fontsize{11}{13}\itshape}
+
+%% Tipo de letra para la nota externa:
+%<class>\def\LetraNotaExterna#1{\gdef\@LetraNotaExterna{#1\selectfont}}
+%<def>\LetraNotaExterna{\fontsize{14}{16.8}}
+
 %% Con este comando se cambia la etra del título de la tabla, es decir, los textos 'Cantidad, 'Descripción', etc...
-%<class>\def\LetraTitCuadro#1{\gdef\@LetraTitCuadro{#1\selectfont}}
-%<def>\LetraTitCuadro{\fontsize{10}{10}\bfseries}
+%<class>\def\LetraTitColumnas#1{\gdef\@LetraTitColumnas{#1\selectfont}}
+%<def>\LetraTitColumnas{\fontsize{10}{10}\bfseries}
 
 %% Tipo de letra de los títulos de los totales, por ejemplo los textos: 'B.I. G', 'IVA G'.
 %<class>\def\LetraTitTotales#1{\gdef\@LetraTitTotales{#1\selectfont}}
@@ -2164,6 +2727,10 @@
 %<class>\def\LetraFirmas#1{\gdef\@LetraFirmas{#1\selectfont}}
 %<def>\LetraFirmas{\fontsize{12}{12}}
 
+%% Tipo de letra para la nota previa.
+%<class>\def\LetraNotaPrevia#1{\gdef\@LetraNotaPrevia{#1\selectfont}}
+%<def>\LetraNotaPrevia{\fontsize{11}{12.5}}
+
 %% Tipo de letra para las condiciones del documento.
 %<class>\def\LetraCondiciones#1{\gdef\@LetraCondiciones{#1\selectfont}}
 %<def>\LetraCondiciones{\fontsize{12}{12}}
@@ -2176,9 +2743,9 @@
 %<class>\def\LetraNumeracion#1{\gdef\@LetraNumeracion{#1\selectfont}}
 %<def>\LetraNumeracion{\fontsize{14}{14}\bfseries\color{red}}
 
-%% Letra para la fecha de emisión.
+%% Letra para las fechas (emisión y vencimiento).
 %<class>\def\LetraFecha#1{\gdef\@LetraFecha{#1\selectfont}}
-%<def>\LetraFecha{\fontsize{14}{14}}
+%<def>\LetraFecha{\fontsize{14}{15}}
 
 %% Letra para el título del reporte.
 %<class>\def\LetraTitReporte#1{\gdef\@LetraTitReporte{#1\selectfont}}
@@ -2188,6 +2755,10 @@
 %<class>\def\LetraInfoPagina#1{\gdef\@LetraInfoPagina{#1\selectfont}}
 %<def>\LetraInfoPagina{\fontsize{12}{12}\slshape}
 
+%% Letra para el reverso de la factura.
+%<class>\def\LetraReverso#1{\gdef\@LetraReverso{#1\selectfont}}
+%<def>\LetraReverso{\fontsize{10}{12}}
+
 %% Letra para el reporte.
 %<class>\def\LetraReporte#1{\gdef\@LetraReporte{#1\selectfont}}
 %<def>\LetraReporte{\fontsize{12}{20}}
@@ -2201,12 +2772,7 @@
   \ifx&#2&\else\setlength{\@FirmaFacturaXcorr}{#2}\fi
   \ifx&#3&\else\setlength{\@FirmaFacturaYcorr}{#3}\fi
   \savebox{\@CajaFirmaEmisor}{#1}
-  \if at reporte
-   \expandafter\AtBeginShipoutNext
-  \else
-   \expandafter\AtEndDocument
-  \fi
-  {%
+  \AtBeginShipoutNext{%
    \begin{textblock*}{\@TamLineaFirmas}%
     (\textwidth+\oddsidemargin+1in-\@TamLineaFirmas/2-\wd\@CajaFirmaEmisor/2-\@PosFirmasXdos+\@FirmaFacturaXcorr,\@PosFirmasY-\ht\@CajaFirmaEmisor-\dp\@CajaFirmaEmisor+\@FirmaFacturaYcorr)%
     \usebox{\@CajaFirmaEmisor}%
@@ -2213,19 +2779,19 @@
    \end{textblock*}}%
  \fi}
 
-\NewDocumentCommand{\FirmaReporte}{O{} O{0pt} O{0pt} G{\@Proveedor} O{2cm} O{1.5cm}}{% \Firma[imagen][x-corr][y-corr]{texto}[posición en X desde la derecha][tamaño linea]
+\NewDocumentCommand{\FirmaReporte}{O{} O{0pt} O{0pt} G{\@Proveedor} O{\@FirmaReportePosX} O{\@FirmaReporteExcesoLinea}}{% \Firma[imagen][x-corr][y-corr]{texto}[posición en X desde la derecha][tamaño linea]
  \renewcommand{\baselinestretch}{1}\selectfont
- \newif\if at firma@dibujo
+ \newif\if at Firma@Dibujo
  \newbox{\TextoFirma}%
  \newbox{\DibujoFirma}%
- \ifx&#1&\else\savebox{\DibujoFirma}{#1}\@firma at dibujotrue\fi
- \ifx&#2&\else\setlength{\@FirmaReporteXcorr}{#2}\fi
- \ifx&#3&\else\setlength{\@FirmaReporteYcorr}{#3}\fi
+ \ifx&#1&\else\savebox{\DibujoFirma}{#1}\@Firma at Dibujotrue\fi
+ \setlength{\@FirmaReporteXcorr}{#2}%
+ \setlength{\@FirmaReporteYcorr}{#3}%
  \savebox{\TextoFirma}{#4}%
- \ifx&#5&\setlength{\@FirmaReporteTextPos}{2cm}\else\setlength{\@FirmaReporteTextPos}{#5}\fi
- \ifx&#6&\setlength{\@FirmaReporteTamLinea}{1.5cm}\else\setlength{\@FirmaReporteTamLinea}{#6}\fi
+ \setlength{\@FirmaReporteTextPos}{#5}%
+ \setlength{\@FirmaReporteTamLinea}{#6}%
  \@LetraFirmas
- \if at firma@dibujo
+ \if at Firma@Dibujo
   \newlength{\@FirmaReporteoddeven}%
   \setlength{\@FirmaReporteFirmaPos}{\zposy{Firma at zref@PosY}sp}%
  \fi
@@ -2239,11 +2805,11 @@
  \vspace*{\dp\DibujoFirma}%
  \hfill
  \parbox{\@FirmaReporteTamLinea}{%
-  \if at firma@dibujo\zsaveposy{Firma at zref@PosY}\fi
+  \if at Firma@Dibujo\zsaveposy{Firma at zref@PosY}\fi
   \rule{\@FirmaReporteTamLinea}{\@GrosorLineaFirmas}\\
   \centering{\usebox{\TextoFirma}}}%
  \hspace*{\@FirmaReporteTextPos}\par
- \if at firma@dibujo
+ \if at Firma@Dibujo
   \mbox{}%
   \par
   \ifodd\c at page
@@ -2262,7 +2828,7 @@
 \newcommand{\FondoFactura}[1]{
  \if at factura
   \RequirePackage{graphicx}
-  \@fondofacturatrue
+  \@FondoFacturatrue
   \gdef\@FondoFactura{#1}
  \fi}
 
@@ -2269,10 +2835,10 @@
 %% Con \FondoReporte le damos el nombre del archivo que contiene el formato del reporte. Existen dos posibilidades: que dicho fondo salga en todas las páginas o sólo en la primera.
 \NewDocumentCommand{\FondoReporte}{s m}{
  \if at reporte
-  \@fondoreportetrue
+  \@FondoReportetrue
   \RequirePackage{graphicx}
   \gdef\@FondoReporte{#2}
-  \IfBooleanT{#1}{\@fondoreportestartrue}% Con * sale en todas las páginas; sin * sale sólo en la primera página.
+  \IfBooleanT{#1}{\@FondoReporteStartrue}% Con * sale en todas las páginas; sin * sale sólo en la primera página.
  \fi}
 
 %% Comando para establecer desde el preámbulo el estilo de página (\pagestyle) del reporte, tanto para la primera página como para las siguientes.
@@ -2283,7 +2849,7 @@
 %% El título para el reporte.
 \NewDocumentCommand{\TituloReporte}{s m}{
  \gdef\@TituloReporte{#2}%
- \IfBooleanTF{#1}{% Con '*' sale el título en las cabeceras o piés. Sin '*' no.
+ \IfBooleanTF{#1}{% Con '*' sale el título en las cabeceras o pies. Sin '*' no.
   \gdef\@InfoPagina{\let\\\relax\@InfoPaginaTitulo}}%
  {\let\@InfoPagina\@InfoPaginaNoTitulo}}
 
@@ -2291,84 +2857,8 @@
 \newcommand{\Cliente}[1]{%
  \IfFileExists{#1.def}{\input{#1.def}}{
   \IfFileExists{#1.tex}{\input{#1.tex}}{
-   \ClassError{factura}{** No existe #1.def ni #1.tex **}{}}}}
+   \CLASSERROR{No existe #1.def ni #1.tex}}}}
 
-%% Comando para mostrar macros con '@'.
-\newcommand{\mostrar}[1]{\csname #1\endcsname}
-
-%% Longitudes para uso interno.
-\newlength{\@TamDatos}
-\newlength{\@TamResumen}
-\newlength{\@TamFinalEncabez}
-\newlength{\@TamLineaFirmas}
-\newlength{\@TamNumItem}
-\newlength{\@TamCantidad}
-\newlength{\@TamDescrip}
-\newlength{\@TamPrecioU}
-\newlength{\@TamPrecioS}
-\newlength{\@TamDescuento}
-\newlength{\@TamPrecioT}
-\newlength{\@GrosorLineaFirmas}
-\newlength{\@GrosorLineaEncabez}
-\newlength{\@GrosorLineaDescrip}
-\newlength{\@EsquinaLineaEncabez}
-\newlength{\@EsquinaLineaDescrip}
-\newlength{\@SombraEncabez}
-\newlength{\@SombraDescrip}
-\newlength{\@LineaNodoXo}
-\newlength{\@LineaNodoYo}
-\newlength{\@LineaNodoXf}
-\newlength{\@LineaNodoYf}
-\newlength{\@SepTotales}
-\newlength{\@PosFechaX}
-\newlength{\@PosFechaY}
-\newlength{\@PosDenomX}
-\newlength{\@PosDenomY}
-\newlength{\@PosFirmasXuno}
-\newlength{\@PosFirmasXdos}
-\newlength{\@PosFirmasY}
-\newlength{\@PosCondX}
-\newlength{\@PosCondY}
-\newlength{\@PosControlX}
-\newlength{\@PosControlY}
-\newlength{\@EspacioVacioInicial}
-\newlength{\@EspacioVacioFinal}
-\newlength{\@SeparaEncabez}
-\newlength{\@SeparaItemsExtra}
-\newlength{\@SeparaItemsExtraFinal}
-\newlength{\@SeparaInternaEncabez}
-\newlength{\@SeparaInternaDescrip}
-\newlength{\@SeparaElementos}
-\newlength{\@SeparaMinTotales}
-\newlength{\@SeparaFilas}
-\newlength{\@SeparaFinLineaDesc}
-\newlength{\@InicioReporte}
-\newlength{\@FirmaFacturaXcorr}
-\newlength{\@FirmaFacturaYcorr}
-\newlength{\@FirmaReporteXcorr}
-\newlength{\@FirmaReporteYcorr}
-\newlength{\@FirmaReporteTextPos}
-\newlength{\@FirmaReporteFirmaPos}
-\newlength{\@FirmaReporteTamLinea}
-\newlength{\@TempDimen}
-
-%% Cajas para uso interno.
-\newbox{\@CajaDatos}
-\newbox{\@CajaResumen}
-\newbox{\@CajaFirmaEmisor}
-\newbox{\@CajaFirmas}
-\newbox{\@CajaFecha}
-\newbox{\@CajaDenom}
-\newbox{\@CajaControl}
-\newbox{\@CajaCond}
-\newbox{\@CajaEspacioVacio}
-\newbox{\@CajaPrueba}
-\newbox{\@CajaCaracterCR}
-
-%% Contadores para uso interno para uso interno:
-\newcounter{@IVANoGeneral}%  '0' con sólo IVA G, '1' cuando hay IVA R o IVA A, y '2' cuando hay ambos.
-\newcounter{@NumItem}%  Número del ítem actual, para uso de algunas macros en el cuadro de la factura y para cuando se usa la opción 'numitem'.
-
 \input{factura.def}%  Cargamos los valores predeterminados.
 
 \if at todosiva
@@ -2383,23 +2873,22 @@
  \immediate\openout\csv=\jobname.csv
 \fi
 
-\if at spanish
+\if at nospanish
+\else
  \RequirePackage[spanish]{babel}%  Babel en castellano.
  \RequirePackage[T1]{fontenc}%  Codificación T1 para las tipografías.
  \IfFileExists{lmodern.sty}{\RequirePackage{lmodern}}{}
 \fi
 
-\if at exparriba
+\if at expandecuadro
  \RequirePackage{zref-savepos}[2016/05/21]%  Para guardar la posición en 'Y'.
 \fi
 
 \if at reporte
- \RequirePackage{eso-pic}%  Para el comando \AddToShipoutPicture.
  \RequirePackage{zref-savepos}%  Para la firma, que debe ser cargado aquí porque \FirmaReporte no se ejecuta desde el preámbulo.
 \fi
 
 \if at sinmarcas
- \setlength{\@SeparaFinLineaDesc}{0pt}
  \def\@CaracterCR{\mbox{}}
  \def\@CaracterCeldasVacias{\mbox{}}
 \fi
@@ -2407,14 +2896,14 @@
 %% Comando para escribir el encabezado en la factura.
 \newcommand\@EncabezadoFactura{%
  \ifdefvoid{\@Resumen}{\@EscribeDatos}{\@EscribeDatosResumen}%
- \vspace*{\@SeparaElementos}%
- \if at exparriba\else\vfill\fi}
+ \vspace*{\@SeparaVertical}%
+ \if at expandecuadro\else\vfill\fi}
 
 %% Comando para escribir el encabezado en el reporte.
 \newcommand\@EncabezadoReporte{%
  \vspace*{-\topskip}%
- \if at fondoreporte
-  \if at fondoreportestar
+ \if at FondoReporte
+  \if at FondoReporteStar
   \else
    \vspace*{\@InicioReporte}%
   \fi
@@ -2423,49 +2912,84 @@
  \@LetraReporte}
 
 %% El ambiente 'factura', usando el paquete 'environ' para su definición, y el comando auxiliar \@FacturaAuxCmd.
-%% Gracias a Heiko Oberdiek y David Carlisle (Thanks to Heiko Oberdiek and David Carlisle).
+%% Gracias a Heiko Oberdiek y a David Carlisle (Thanks to Heiko Oberdiek and David Carlisle).
 %% http://tex.stackexchange.com/questions/108565/know-the-cell-width-with-tabular-or-include-a-paragraph-box-without-specifying
 \NewEnviron{factura}{%
  \expandafter\@FacturaAuxCmd\expandafter{\BODY}%
- \ifnum\value{page}=1\else\ClassError{factura}{** La factura ocupa mas que una pagina **}{}\fi
-}
+ \ifnum\value{page}=1\else\CLASSERROR{La factura ocupa mas que una pagina}\fi}
 
+\NewEnviron{reverso}{%
+ \if at factura
+   \expandafter\newgeometry\expandafter{\@GeometriaReverso}%
+   \topskip1sp% ¡¡No puedo poner 0 porque se genera una página en blanco extra!!
+  \begin{minipage}[t][\textheight-\pagetotal]{\linewidth}%
+   \thispagestyle{empty}%
+   \@LetraReverso\BODY
+  \end{minipage}
+  \clearpage
+ \fi}
+
 %% Comando auxiliar para agregar un carácter al final de cada línea en la descripción dentro del cuadro de la factura si ocupa ésta más de una línea.
-%% Gracias a Gustavo Mezzetti y David Carlisle (Thanks to Gustavo Mezzetti and David Carlisle)
+%% Gracias a Gustavo Mezzetti y a David Carlisle (Thanks to Gustavo Mezzetti and David Carlisle).
 %% http://tex.stackexchange.com/questions/296035/insert-a-special-character-at-each-end-of-line-in-a-paragraph
 %% http://tex.stackexchange.com/questions/248944/how-to-put-before-lines
 \newcommand{\@DescripcionAuxCmd}[2]{%
- \immediate\write\@auxout{\gdef\noexpand\@TamDescrip{\the\linewidth}}% Para poder establecer la línea diagonal hay que saber el tamaño del campo de la descripción.
- \setbox0\hbox{\parbox[t]{\linewidth}{\if at centradesc\centering\arraybackslash\fi#1%
-  \if at impdesc\hfill\ \@EscribeTipoDeImpuesto{#2}\fi%
-  \par\global\count1=\prevgraf}}%
- \ifnum\count1 = 1
-  \if at centradesc\centering\arraybackslash\fi#1%
-  \if at impdesc\vskip-\baselineskip\hfill\ \@EscribeTipoDeImpuesto{#2}\fi
- \else
-  \parbox[t]{\linewidth-\wd\@CajaCaracterCR-\@SeparaFinLineaDesc}{%
+ \if at impdesc\settowidth{\@TempDimen}{\@EscribeTipoDeImpuesto{#2}}\fi
+ \savebox{\@CajaPrueba}{%
+  \parbox[t]{\linewidth}{%
    \David at XStart
    \if at centradesc\centering\arraybackslash\fi
    #1%
    \David at XEnd
-   \par
-   \count0=\prevgraf
-   \count2=\prevgraf
-   \loop
-    \ifnum\count0=\count2
-     \if at impdesc
-      \vskip-\baselineskip
-      \mbox{}\hfill\rlap{\hspace*{\wd\@CajaCaracterCR}\hspace*{\@SeparaFinLineaDesc}\llap{\@EscribeTipoDeImpuesto{#2}}}%
+   \ifdim\@TempDimen=0pt%
+   \else
+    \hfill\kern\@SeparaFinLineaDesc\@EscribeTipoDeImpuesto{#2}%
+   \fi
+   \par\global\count1=\prevgraf}}%
+ \if at sinmarcas
+  \usebox{\@CajaPrueba}%
+ \else
+  \ifnum\count1=1%
+   \usebox{\@CajaPrueba}%
+  \else
+   \ifdim\@TempDimen>\wd\@CajaCaracterCR
+   \else
+    \setlength{\@TempDimen}{\wd\@CajaCaracterCR}%
+   \fi
+   \parbox[t]{\linewidth-\@TempDimen-\@SeparaFinLineaDesc}{%
+    \David at XStart
+    \if at centradesc\centering\arraybackslash\fi
+    #1%
+    \David at XEnd
+    \par
+    \global\count1=\prevgraf% Esto lo necesitamos en otro lado para calcular el espacio extra en los ítems.
+    \count0=\prevgraf
+    \count2=\prevgraf
+    \loop
+     \ifnum\count0=\count2
+      \if at impdesc
+       \vskip-\baselineskip
+       \mbox{}\hfill
+       \rlap{%
+        \hspace*{\@TempDimen}%
+        \hspace*{\@SeparaFinLineaDesc}%
+        \llap{\@EscribeTipoDeImpuesto{#2}}}%
+      \fi
+     \else
+      \mbox{}\hfill
+      \rlap{%
+       \hspace*{\@TempDimen}%
+       \hspace*{\@SeparaFinLineaDesc}%
+       \hspace*{-\wd\@CajaCaracterCR}%
+       \usebox{\@CajaCaracterCR}}%
      \fi
-    \else
-     \mbox{}\hfill\rlap{\hspace*{\@SeparaFinLineaDesc}\usebox{\@CajaCaracterCR}}%
-    \fi
-    \vskip-2\baselineskip
-    \advance\count0 -1
-    \ifnum\count0 > 0
-   \repeat
-   \kern\count2\baselineskip\mbox{}%
-   \strut}%
+     \vskip-2\baselineskip
+     \advance\count0 -1
+     \ifnum\count0 > 0
+    \repeat
+    \kern\count2\baselineskip\mbox{}%
+    \strut}%
+  \fi
  \fi}
 
 %% Comandos auxiliares para colocar en \parbox cada celda.
@@ -2494,6 +3018,11 @@
  \ifdim\wd\@CajaPrueba > \@TamDescuento \global\@TamDescuento=\wd\@CajaPrueba\fi
  \parbox[t]{\@TamDescuento}{#1}}
 
+\newcommand{\@IVAAuxCmd}[1]{%
+ \savebox{\@CajaPrueba}{#1}%
+ \ifdim\wd\@CajaPrueba > \@TamIVA \global\@TamIVA=\wd\@CajaPrueba\fi
+ \parbox[t]{\@TamIVA}{#1}}
+
 \newcommand{\@PrecioTAuxCmd}[1]{%
  \savebox{\@CajaPrueba}{#1}%
  \ifdim\wd\@CajaPrueba > \@TamPrecioT \global\@TamPrecioT=\wd\@CajaPrueba\fi
@@ -2502,11 +3031,11 @@
 %% Presentación de totales en modo de columnas.
 \newcommand{\@EscribeTotalCol}[1]{%
  \expandafter\FPifeq\csname Desc#1\endcsname{0}%
-  \if at ivaexpresado\@EscribeTotalColBI{#1}\fi
+  \if at sinivaexpresado\else\@EscribeTotalColBI{#1}\fi
  \else
   \@EscribeTotalColSubt{#1}%
   \@EscribeTotalColDesc{#1}%
-  \if at ivaexpresado\@EscribeTotalColBI{#1}\fi
+  \if at sinivaexpresado\else\@EscribeTotalColBI{#1}\fi
  \fi}
 
 %% Forma agupada para la presentación de totales en modo de columnas.
@@ -2519,7 +3048,8 @@
  \if at BIR\if at DescR\@EscribeTotalColDesc{R}\fi\fi
  \if at DescG\@EscribeTotalColDesc{G}\fi
  \if at BIA\if at DescA\@EscribeTotalColDesc{A}\fi\fi
- \if at ivaexpresado
+ \if at sinivaexpresado
+ \else
   \if at Exento\@EscribeTotalColBI{E}\fi
   \if at BIR\@EscribeTotalColBI{R}\fi
   \@EscribeTotalColBI{G}%
@@ -2527,6 +3057,7 @@
   \if at BIR\@EscribeTotalColAlicuota{R}\fi
   \@EscribeTotalColAlicuota{G}%
   \if at BIA\@EscribeTotalColAlicuota{A}\fi
+  \ifbool{Electro}{\@EscribeTotalColAlicuotaGDesc}{}%
  \fi}
 
 \newcommand{\@EscribeTotalColBI}[1]{%
@@ -2541,6 +3072,10 @@
  {\@LetraTitTotales \csname @@Alicuota#1\endcsname\ \hfill (\csname @Alicuota#1porc\endcsname\%)}
  & \@LetraNumTotales\numprint{\csname Alicuota#1\endcsname} \\}
 
+\newcommand{\@EscribeTotalColAlicuotaGDesc}{%
+ {\@LetraTitTotales \@@AlicuotaGDesc\ \hfill (\@AlicuotaGDescPorc\%)}
+ & \@LetraNumTotales\numprint{\AlicuotaGDesc} \\}
+
 \newcommand{\@EscribeTotalColSubt}[1]{%
  {\@LetraTitTotales \csname @@Subtotal#1\endcsname}
  & \@LetraNumTotales\numprint{\csname Subt#1\endcsname} \\}
@@ -2666,10 +3201,10 @@
  % Hay que abrir un grupo de ejecución porque el cambio en la tipografía altera la celda.
  {\if at G
    \@LetraTipoIVA
-   \ifx#1G\@DenomAlicuotaG\fi% Si tiene IVA general escribimos 'G'.
-   \ifx#1E\@DenomAlicuotaE\fi% Si está exento escribimos '(E)'.
-   \ifx#1R\@DenomAlicuotaR\fi% Si tiene IVA reducido escribimos 'R'.
-   \ifx#1A\@DenomAlicuotaA\fi% Si tiene IVA adicional escribimos 'A'.
+   \ifx#1G\@DenomAlicuotaG\fi
+   \ifx#1R\@DenomAlicuotaR\fi
+   \ifx#1A\@DenomAlicuotaA\fi
+   \ifx#1E\@DenomAlicuotaE\fi
   \fi}}
  
 %% Comando para poner en cero los contadores de los totales porque el ambiente de la factura se evalúa tres veces y los totales se sumarían todos tres veces.
@@ -2689,6 +3224,7 @@
  \FPset\DescA{0}\global\let\DescA\DescA
  \FPset\DescX{0}\global\let\DescX\DescX
  \FPset\AlicuotaG{0}\global\let\AlicuotaG\AlicuotaG
+ \FPset\AlicuotaGDesc{0}\global\let\AlicuotaGDesc\AlicuotaGDesc
  \FPset\AlicuotaR{0}\global\let\AlicuotaR\AlicuotaR
  \FPset\AlicuotaA{0}\global\let\AlicuotaA\AlicuotaA}
 
@@ -2698,7 +3234,18 @@
  \FPifeq\SubtR{0}\else\@CalculaTotalesII{R}\fi
  \FPifeq\SubtA{0}\else\@CalculaTotalesII{A}\fi
  \FPifeq\SubtE{0}\else\@CalculaTotalesII{E}\fi
- \FPupn\Total{\BIE{} \BIR{} + \BIG{} + \BIA{} + \AlicuotaR{} + \AlicuotaG{} + \AlicuotaA{} + \@DigitosMoneda{} round}%
+ \ifbool{Electro}{%
+  \FPiflt\BIG\@AlicuotaGDescLimite
+   \let\@AlicuotaGDesc\@AlicuotaGDescBajo
+  \else
+   \let\@AlicuotaGDesc\@AlicuotaGDescAlto
+  \fi
+  \FPupn\@AlicuotaGDescPorc{\@AlicuotaGDesc{} 100 * \@DigitosPorc{} round clip}%
+  \FPupn\AlicuotaGDesc{\BIG{} \@AlicuotaGDesc{} * \@DigitosMoneda{} round}%
+  \global\let\AlicuotaGDesc\AlicuotaGDesc
+  \global\let\@AlicuotaGDescPorc\@AlicuotaGDescPorc
+  \global\let\@AlicuotaGDesc\@AlicuotaGDesc}{}%
+ \FPupn\Total{\BIE{} \BIR{} + \BIG{} + \BIA{} + \AlicuotaR{} + \AlicuotaG{} + \AlicuotaA{} + \AlicuotaGDesc{} sub \@DigitosMoneda{} round}%
  \global\let\Total\Total}
 
 \newcommand{\@CalculaTotalesII}[1]{%
@@ -2724,7 +3271,7 @@
  % Segunda línea, que sale solamente cuando se usa la opción 'numitem'
  \ifbool{NumItem}{\ifbool{SinLineasVertInt}{}{|}}{}
  % Columna 'X' con DCU, columna fantasma con 'sincantidad' y columna 'c' con CDU.
- \ifbool{PrimeroDescrip}{X}{
+ \ifbool{PrimeroDescripcion}{X}{
   \ifbool{SinCantidad}{l@{\extracolsep{0pt}}}{c}}
  % Tercera línea.
  \ifbool{SinCantidad}{}{\ifbool{SinLineasVertInt}{}{|}}
@@ -2746,9 +3293,13 @@
  \ifbool{Descuentos}{c}{r@{\extracolsep{0pt}}}
  % Séptima línea, que sale solamente cuando hay descuentos.
  \ifbool{Descuentos}{\ifbool{SinLineasVertInt}{}{|}}{}
+ % Columna 'c' para 'iva' y columna 'r' sin espacio si no hay columna de IVA.
+ \ifbool{IVA}{c}{r@{\extracolsep{0pt}}}
+ % Octava línea, que sale solamente cuando hay columna de IVA.
+ \ifbool{IVA}{\ifbool{SinLineasVertInt}{}{|}}{}
  % Columna 'r' siempre.
  r
- % Octava y última línea.
+ % Novena y última línea.
  \ifbool{SinLineasVertExt}{}{|}}
 
 %% Comando auxiliar para abrir la tabla del cuadro de la factura y expandir completamente las columnas.
@@ -2756,18 +3307,28 @@
 
 %% Comando auxiliar para abrir el '\multicolumn' para los totales en el modo de columnas y expandir completamente las columnas cuando hay o no barras verticales.
 \edef\@ColumnasMultiColumnTotalesAuxCmd{%
- \noexpand\multicolumn{7}{\ifbool{SinLineasVertExt}{}{|} r}\begingroup
+ \noexpand\multicolumn{8}{\ifbool{SinLineasVertExt}{}{|} r}\begingroup
    \noexpand\ifdim \noexpand\ht\noexpand\@CajaEspacioVacio=0pt
    \noexpand\else
     \noexpand\if at linea\noexpand\zsaveposx{LineaNodoBCoordX}\noexpand\zsaveposy{LineaNodoBCoordY}\noexpand\fi\noexpand\fi% Fijamos la posición (x,y) final para la línea ya que estaremos justo en el punto donde escribimos el total, y hasta allí llega la línea en el modo de columnas.
     \noexpand\begin{tabular}[b]{@{\noexpand\extracolsep{2\noexpand\tabcolsep}}lr \ifbool{SinLineasVertExt}{}{|}}}
 
+%% Comando auxiliar para abrir el '\multicolumn' de la nota interna y evalúe la presencia o no de las barras verticales.
+\edef\@ColumnasMultiColumnNotaIntAuxCmd{%
+ \noexpand\multicolumn{8}{\ifbool{SinLineasVertExt}{}{|}l\ifbool{SinLineasVertExt}{}{|}}{%
+  \noexpand\parbox[t]{\linewidth-2\tabcolsep-2\arrayrulewidth}{\noexpand\@LetraNotaInterna\noexpand\@NotaInterna\noexpand\strut}}%
+  \noexpand\\}
+
 %% Comando para hacer los cálculos sobre cada ítem y establecer las macros con el contenido de cada ítem introducido.
-\newcommand{\@CalculaItem}[5]{%
- \addtocounter{@NumItem}{1}%
+\NewDocumentCommand{\@CalculaItem}{m m m o m m}{%
+ \addtocounter{NumItem}{1}%
  % Calculamos.
- \FPupn\PrecioU{#4 \@DigitosMoneda{} round}%
- \ifx\\#5\\\FPset\Dcto{0}\else\FPupn\Dcto{#5 \@DigitosPorc{} round clip}\fi% Fijamos en 0 el descuento si no se especifica.
+ \FPupn\PrecioU{#5 \@DigitosMoneda{} round}%
+ \ifbool{Descuentos}
+  {\ifx\\#6\\\FPset\Dcto{0}\else\FPupn\Dcto{#6 \@DigitosPorc{} round clip}\fi}% Fijamos en 0 el descuento si no se especifica en \Item***.
+  {\FPset\Dcto{#6}%
+   \FPifeq\Dcto{0}\else\CLASSWARNING{Se pidió un descuento individual sin dar la opción de la clase 'descuentos'. No se tomará en cuenta.}\fi
+   \FPset\Dcto{0}}% También fijamos en 0 el descuento por si se especifica en \Item*** pero no se pide la opción 'descuentos'.
  \FPupn\PrecioS{#2 \PrecioU{} * \@DigitosMoneda{} round}%
  \FPupn\PrecioT{100 \Dcto{} 100 - / \PrecioS{} * \@DigitosMoneda{} round}%
  \global\let\PrecioU\PrecioU
@@ -2778,60 +3339,63 @@
  \expandafter\FPupn\csname Subt#1\endcsname{\PrecioT{} \csname Subt#1\endcsname{} + \@DigitosMoneda{} round}%
  \global\expandafter\let\csname Subt#1\expandafter\endcsname\csname Subt#1\endcsname
  % Guardamos en macros cada elemento agregado a la factura; por ejemplo: \@Item at i@Cantidad contiene la cantidad que se introdujo para el primer ítem; así mismo con ii@, @iii@, y así mismo también con @Descripcion, @PrecioU, @Descuento y @PrecioT.
- \expandafter\gdef\csname @Item@\romannumeral\value{@NumItem}@Cantidad\endcsname{\numprint{#2}}%
- \expandafter\gdef\csname @Item@\romannumeral\value{@NumItem}@Descripcion\endcsname{#3}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioU\endcsname{\noexpand\numprint{\PrecioU}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioS\endcsname{\noexpand\numprint{\PrecioS}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@Descuento\endcsname{\noexpand\numprint{\Dcto}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioT\endcsname{\noexpand\numprint{\PrecioT}}}
+ \expandafter\gdef\csname @Item@\romannumeral\value{NumItem}@Cantidad\endcsname{\numprint{#2}}%
+ \expandafter\gdef\csname @Item@\romannumeral\value{NumItem}@Descripcion\endcsname{#3}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioU\endcsname{\noexpand\numprint{\PrecioU}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioS\endcsname{\noexpand\numprint{\PrecioS}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@Descuento\endcsname{\noexpand\numprint{\Dcto}}%
+ \expandafter\global\expandafter\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@IVA\endcsname{%
+  \noexpand\numprint\expandafter{\csname @Alicuota#1porc\endcsname}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioT\endcsname{\noexpand\numprint{\PrecioT}}}
 
-% Macro interna para saber si una etiqueta existe o no.
+%% Macro interna para saber si una etiqueta existe o no.
 \gdef\@pruebaref#1{%
  \expandafter\ifx\csname @Etiqueta@#1\endcsname\relax
-  \ClassWarning{factura}{La etiqueta `#1' no está definida}{}\ignorespaces
-  \@pruebareffalse
+  \CLASSWARNING{La etiqueta `#1' no está definida}\ignorespaces
+  \@PruebaReffalse
  \else
-  \@pruebareftrue
+  \@PruebaReftrue
  \fi}
 
-% Comandos para las referencias: i) referencia al número de ítem, ii) a la cantidad, iii) a la descripción, iv) al precio unitario, v) al descuento, vi) al precio total.
+%% Comandos para las referencias: i) referencia al número de ítem, ii) a la cantidad, iii) a la descripción, iv) al precio unitario, v) al descuento, vi) al precio total.
 \gdef\itemref#1{%
- \ifbool{NumItem}{}{\ClassWarning{factura}{Es recomendable usar la opción 'numitem' para enumerar los ítems}{}}%
- \@pruebaref{#1}\if at pruebaref \csname @Etiqueta@#1\endcsname \fi}
-\gdef\cantref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Cantidad\endcsname \fi}
-\gdef\descref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descripcion\endcsname \fi}
-\gdef\puref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioU\endcsname \fi}
-\gdef\subtref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioS\endcsname \fi}
-\gdef\dctoref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descuento\endcsname \fi}
-\gdef\ptref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioT\endcsname \fi}
+ \ifbool{NumItem}{}{\CLASSWARNING{Es recomendable usar la opción 'numitem' para enumerar los ítems}}%
+ \@pruebaref{#1}\if at PruebaRef \csname @Etiqueta@#1\endcsname \fi}
+\gdef\cantref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Cantidad\endcsname \fi}
+\gdef\descref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descripcion\endcsname \fi}
+\gdef\puref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioU\endcsname \fi}
+\gdef\subtref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioS\endcsname \fi}
+\gdef\dctoref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descuento\endcsname \fi}
+\gdef\ivaref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @IVA\endcsname \fi}
+\gdef\ptref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioT\endcsname \fi}
 
-% Definimos un comando para la etiqueta, que se define dentro del entorno de la factura para que tenga alcance local; cuando se acaba dicho entorno, el comando \label vuelve a ser lo que está definido en latex.ltx.
+%% Definimos un comando para la etiqueta, que se define dentro del entorno de la factura para que tenga alcance local; cuando se acaba dicho entorno, el comando \label vuelve a ser lo que está definido en latex.ltx.
 \newcommand{\label at factura}[1]{%
  \expandafter\ifx\csname @Etiqueta@#1\endcsname\relax
-  \expandafter\global\expandafter\edef\csname @Etiqueta@#1\endcsname{\arabic{@NumItem}}\ignorespaces
-  \ClassInfo{factura}{Etiqueta `#1' definida para el ítem \arabic{@NumItem}}{}%
+  \expandafter\global\expandafter\edef\csname @Etiqueta@#1\endcsname{\arabic{NumItem}}\ignorespaces
+  \CLASSINFO{Etiqueta `#1' definida para el ítem \arabic{NumItem}}%
  \else
   \edef\@label at test@uno{\csname @Etiqueta@#1\endcsname}%
-  \edef\@label at test@dos{\the at NumItem}%
+  \edef\@label at test@dos{\theNumItem}%
   \ifx\@label at test@uno\@label at test@dos
   \else
-   \ClassWarning{factura}{La etiqueta `#1' se definió más de una vez}{}\ignorespaces
+   \CLASSWARNING{La etiqueta `#1' se definió más de una vez}\ignorespaces
   \fi
  \fi}
 
 %% Comando auxiliar para la definición del ambiente de la factura; al final de este comando está el texto que va en el enddef del ambiente de la factura.
 \newcommand{\@FacturaAuxCmd}[1]{%
- \if at exparriba
+ \if at expandecuadro
   \setlength{\@EspacioVacioInicial}{\zposy{EspacioVacioInicial}sp}%
   \setlength{\@EspacioVacioFinal}{\zposy{EspacioVacioFinal}sp}%
-  \global\@EspacioVacioInicial=\@EspacioVacioInicial% ¿por qué tendré que globalizarlas?
+  \global\@EspacioVacioInicial=\@EspacioVacioInicial% Hay que globalizarlas
   \global\@EspacioVacioFinal=\@EspacioVacioFinal
-  \savebox{\@CajaEspacioVacio}{\parbox[b][\@EspacioVacioInicial-\@EspacioVacioFinal]{\@TamDescrip}{%
+  \savebox{\@CajaEspacioVacio}{\parbox[b][\@EspacioVacioInicial-\@EspacioVacioFinal]{0pt}{%
    \if at linea
-    \if at lineacompleta
+    \if at LineaCompleta
      \zsaveposy{LineaNodoBCoordY}%
     \else
-     \if at lineahastatotal
+     \if at LineaHastaTotal
      \else
       \zsaveposx{LineaNodoACoordX}\mbox{}\hfill \zsaveposx{LineaNodoBCoordX}\zsaveposy{LineaNodoBCoordY}%
      \fi
@@ -2840,14 +3404,14 @@
   \ifdim \ht\@CajaEspacioVacio=0pt \global\@lineafalse \fi
  \fi
  
- \ifx\undefined\Total\relax\else\ClassError{factura}{** Parece ya haberse usado un entorno de factura **}{}\fi
+ \ifx\undefined\Total\relax\else\CLASSERROR{Parece ya haberse usado un entorno de factura}\fi
  %
  % Comandos \David at SavePos, \David at XStart, \David at XEnd, \David at XPad, \David at XLeft y \David at XRight para poder manejar el salto de línea en las columnas adyacentes a la columna 'X' del tabularx (la descripción), cuando esta ocupa más que una línea.
  % Gracias a David Carlisle (Thanks to David Carlisle).
  % http://tex.stackexchange.com/questions/111203/tabularx-bottom-alignment-on-r-or-l-columns-when-x-column-wraps
  \def\David at SavePos##1{\leavevmode\pdfsavepos\write\@auxout{\gdef\noexpand##1{\the\pdflastypos sp}}}%
- \def\David at XStart{\expandafter\David at SavePos\csname save at start@\romannumeral\value{@NumItem}\endcsname}%
- \def\David at XEnd{\expandafter\David at SavePos\csname save at end@\romannumeral\value{@NumItem}\endcsname}%
+ \def\David at XStart{\expandafter\David at SavePos\csname save at start@\romannumeral\value{NumItem}\endcsname}%
+ \def\David at XEnd{\expandafter\David at SavePos\csname save at end@\romannumeral\value{NumItem}\endcsname}%
  \def\David at XPad##1##2##3{%
   \vtop{%
    \baselineskip\normalbaselineskip
@@ -2866,33 +3430,40 @@
     \repeat
    \fi
    ##3}}%
- \def\David at XLeft##1{\David at XPad{\romannumeral\value{@NumItem}}{\hbox{##1}}{}}%
- \def\David at XRight##1{\David at XPad{\romannumeral\value{@NumItem}}{}{\hbox{##1}}}%
+ \def\David at XLeft##1{\David at XPad{\romannumeral\value{NumItem}}{\hbox{##1}}{}}%
+ \def\David at XRight##1{\David at XPad{\romannumeral\value{NumItem}}{}{\hbox{##1}}}%
  %
  % Caja auxiliar para el caracter de retorno de carro y poder saber si tamaño en el campo de la descripción.
  \savebox{\@CajaCaracterCR}{\@LetraItems\@CaracterCR}
  %
+ % Comando para fijar la separación extra final de cada item, lo cual viene dado por la cantidad de líneas de la descripción,
+ % que está alojado en \count1, definido en \@DescripcionAuxCmd.
+ \def\@CalculaSeparaItemsExtraFinal{%
+  \setlength{\@SeparaItemsExtraFinal}{\numexpr\the\count1\normalbaselineskip-\normalbaselineskip+\@SeparaItemsExtra}%
+  \global\@SeparaItemsExtraFinal=\@SeparaItemsExtraFinal}
+ %
  % Comando interno general para agregar cualquier ítem.
- \newcommand{\@ITEM}[5]{% 1. [R|G|A|E|X]; 2. cantidad; 3. descripción; 4. p/u; 5. dcto.
-  \@CalculaItem{##1}{##2}{##3}{##4}{##5}%
+ \NewDocumentCommand{\@ITEM}{m m m o m m}{%
+  % 1. [R|G|A|E|X]; 2. cantidad; 3. descripción; 4. descripción para el csv (entre corchetes); 5. p/u; 6. dcto.
+  \@CalculaItem{##1}{##2}{##3}{##5}{##6}%
   % Si no es el primer ítem, entonces hace falta \\ para terminar el ítem anterior.
-  \ifnum\value{@NumItem}=1%
+  \ifnum\value{NumItem}=1% Aquí, \@CalculaItem aumenta en 1 el contador NumItem, que si vale 1 significa que aún no hemos procesado la línea 1, es decir, no hay que hacer el salto de línea. La última línea se termina en otro lado.
   \else
-   \setlength{\@SeparaItemsExtraFinal}{\numexpr\the\count1\normalbaselineskip-\normalbaselineskip+\@SeparaItemsExtra}%
+   \@CalculaSeparaItemsExtraFinal
    \\[\@SeparaItemsExtraFinal]
    \if at conlineasha\hline\fi% Líneas para separar cada ítem, si hiciera falta.
   \fi
   % Primer -opcional- campo: El número del ítem.
-  \ifbool{NumItem}{\David at XLeft{\@NumItemAuxCmd{\mbox{}\hfill \@LetraNumeros \arabic{@NumItem}\hfill\mbox{}}}}{}%
+  \ifbool{NumItem}{\David at XLeft{\@NumItemAuxCmd{\mbox{}\hfill \@LetraNumeros \arabic{NumItem}\hfill\mbox{}}}}{}%
   &
   % Segundo campo: Acá puede ir la cantidad (cdu) o la descripción (dcu y duc).
   \ifbool{SinCantidad}{}{%
-   \ifbool{PrimeroDescrip}
+   \ifbool{PrimeroDescripcion}
    {\@DescripcionAuxCmd{##3}{##1}}% dcu y duc.
    {\David at XLeft{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}}}% cdu.
   &
   % Tercer campo: Acá puede ir la descripción (cdu), la cantidad (dcu), o el precio unitario (duc).
-  \ifbool{PrimeroDescrip}{%
+  \ifbool{PrimeroDescripcion}{%
    \if at dcu
     \David at XRight{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}% dcu.
    \else
@@ -2905,7 +3476,7 @@
   {\@DescripcionAuxCmd{##3}{##1}}% cdu.
   &
   % Cuarto campo: Acá puede ir el precio unitario (cdu y dcu) o la cantidad (duc).
-  \FPifeq\PrecioU{##4}\else\ClassWarning{factura}{** Se está introduciendo un precio con más de dos decimales: (##3 - ##4. Redondeado a \PrecioU) **}{}\fi% Advertimos cuando el precio unitario tiene más de dos decimales.
+  \FPifeq\PrecioU{##5}\else\CLASSWARNING{Se está introduciendo un precio con más de dos decimales: (##3 - ##5. Redondeado a \PrecioU)}{}\fi% Advertimos cuando el precio unitario tiene más de dos decimales.
   \ifbool{SinCantidad}{}{%
    \if at duc
     \David at XRight{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}% duc.
@@ -2932,7 +3503,15 @@
      \mbox{}\hfill \@LetraNumeros \numprint{\Dcto}\%\hfill\mbox{}%
     \fi}}}{}% Tenemos que usar un condicional booleano porque si no da problemas con el condicional \FPifeq.
   &
-  % Séptimo campo: El total.
+  % Séptimo -opcional- campo: IVA.
+  \ifbool{IVA}{%
+   \David at XRight{\@IVAAuxCmd{%
+    \ifx##1X \hfill \@CaracterItemXVacio \hfill\mbox{}%
+    \else
+     \mbox{}\hfill \@LetraNumeros \numprint{\csname @Alicuota##1porc\endcsname}\%\hfill\mbox{}%
+    \fi}}}{}% Tenemos que usar un condicional booleano porque si no da problemas con el condicional \FPifeq.
+  &
+  % Octavo campo: El total.
   \David at XRight{\@PrecioTAuxCmd{%
    \ifx##1X \hfill \@CaracterItemXVacio \hfill\mbox{}%
    \else
@@ -2940,35 +3519,39 @@
    \fi}}%
   % Escribimos al csv.
   \if at csv
-   \ifbool{SinCantidad}
-    {\if at descuentos
-      \immediate\write\csv{"\unexpanded{##3}","\Dcto","\PrecioT","##1"}%
-     \else
-      \immediate\write\csv{"\unexpanded{##3}","\PrecioT","##1"}%
-     \fi}
-    {\if at cdu
-      \if at descuentos
-       \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\PrecioT","##1"}%
-      \fi
-     \fi
-     \if at dcu
-      \if at descuentos
-       \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\PrecioT","##1"}%
-      \fi
-     \fi
-     \if at duc
-      \if at descuentos
-       \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\PrecioT","##1"}%
-      \fi
-     \fi}%
-   \fi}%
+   \IfValueTF{##4}{\@EscribeItemsEnCSV{##1}{##2}{##4}}{\@EscribeItemsEnCSV{##1}{##2}{##3}}%
+  \fi}%
  %
+ % Comando para escribir en el .csv.
+ \newcommand{\@EscribeItemsEnCSV}[3]{%
+  \ifbool{SinCantidad}
+  {\if at descuentos
+    \immediate\write\csv{"\unexpanded{##3}","\Dcto","\PrecioT","##1"}%
+   \else
+    \immediate\write\csv{"\unexpanded{##3}","\PrecioT","##1"}%
+   \fi}
+  {\if at cdu
+    \if at descuentos
+     \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\PrecioT","##1"}%
+    \fi
+   \fi
+   \if at dcu
+    \if at descuentos
+     \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\PrecioT","##1"}%
+    \fi
+   \fi
+   \if at duc
+    \if at descuentos
+     \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\PrecioT","##1"}%
+    \fi
+   \fi}}%
+ %
  % Usamos la definición de \label at factura dentro del entorno de la factura para que sea local aquí nada más.
  \let\label\label at factura
  \@LetraItems% Este es el tipo de letra que tendrán los ítems, y en este tipo de letra se define el \baselineskip de toda la factura.
@@ -2976,44 +3559,51 @@
  \ifbool{SinLineasHoriExt}{}{\hline}%
  \@ZERO
  % Estamos en el número del ítem, si aplicara.
- \if at lineadesdeinicio \hspace*{-\tabcolsep}\zsaveposx{LineaNodoACoordX}\hspace*{\tabcolsep}\fi
- \ifbool{NumItem}{\@NumItemAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@NumItem \hfill\mbox{}}}{}%
+ \if at LineaDesdeInicio \hspace*{-\tabcolsep}\zsaveposx{LineaNodoACoordX}\hspace*{\tabcolsep}\fi
+ \ifbool{NumItem}{\@NumItemAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@NumItem \hfill\mbox{}}}{}%
  &
  % Avanzamos a la cantidad, o la descripción.
- \ifbool{SinCantidad}{}{\ifbool{PrimeroDescrip}{\@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}}{\@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}}}%
+ \ifbool{SinCantidad}{}{\ifbool{PrimeroDescripcion}{\@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}}{\@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}}}%
  &% Avanzamos hasta la descripción, la cantidad o el precio unitario.
- \ifbool{SinCantidad}{\@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}}
-  {\if at cdu \@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}\fi
-   \if at dcu \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}\fi
-   \if at duc \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioU \space (\Moneda)\hfill\mbox{}}\fi}%
+ \ifbool{SinCantidad}{\@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}}
+  {\if at cdu \@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}\fi
+   \if at dcu \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}\fi
+   \if at duc \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioU \space (\Moneda)\hfill\mbox{}}\fi}%
  &% Avanzamos hasta el precio unitario, o la cantidad, o columna fantasma cuando es 'sincantidad'.
  \ifbool{SinCantidad}{}
   {%
    \mbox{}\hfill
    \if at duc
-    \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}%
+    \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}%
    \else
-    \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioU \space (\Moneda)\hfill\mbox{}}%
+    \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioU \space (\Moneda)\hfill\mbox{}}%
    \fi}%
  &% Avanzamos hasta el subtotal, que puede o no existir,
- \ifbool{Subtotal}{\@PrecioSAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioS \space (\Moneda)\hfill\mbox{}}}{}%
+ \ifbool{Subtotal}{\@PrecioSAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioS \space (\Moneda)\hfill\mbox{}}}{}%
  &% Avanzamos hasta el descuento, que puede o no existir.
- \if at descuentos \@DescuentoAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Descuento \hfill\mbox{}}\fi
+ \if at descuentos \@DescuentoAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Descuento \hfill\mbox{}}\fi
+ &% Avanzamos hasta el IVA, que puede o no existir.
+ \ifbool{IVA}{\@IVAAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@IVA \hfill\mbox{}}}{}
  &% Avanzamos hasta el precio total.
- \@PrecioTAuxCmd{\mbox{}\hfill \@LetraTitCuadro \ifbool{SinCantidad}{\@@Precio}{\@@PrecioT}\space (\Moneda)\hfill\mbox{}}%
- \if at lineacompleta \hspace*{\tabcolsep}\zsaveposx{LineaNodoBCoordX}\hspace*{-\tabcolsep}\fi
+ \@PrecioTAuxCmd{\mbox{}\hfill \@LetraTitColumnas \ifbool{SinCantidad}{\@@Precio}{\@@PrecioT}\space (\Moneda)\hfill\mbox{}}%
+ \if at LineaCompleta \hspace*{\tabcolsep}\zsaveposx{LineaNodoBCoordX}\hspace*{-\tabcolsep}\fi
  \\
  \ifbool{SinLineasHoriInt}{}{\hline}%
  %
  #1% Aquí entran todos los items que el usuario declara dentro del ambiente.
- \\% El último fin de línea se hace aquí.
+ \@CalculaSeparaItemsExtraFinal
+ \\[\@SeparaItemsExtraFinal]% El último fin de línea se hace aquí.
  \if at conlineasha\hline\fi% Se verifica si hace falta una línea horizontal o no.
  \if at filas
-  % Esto en lugar de \if at exparriba para que no se haga una linea vacía en la tabla cuando la caja está vacía.
+  % Esto en lugar de \if at expandecuadro para que no se haga una linea vacía en la tabla cuando la caja está vacía.
   \ifdim \ht\@CajaEspacioVacio=0pt
-   \ifbool{SinLineasHoriExt}{}{\if at conlineasha\else\hline\fi}% Verificamos si hay que poner la línea horizontal. Si está 'conlineasha' ya salió debido a esta opción.
+   \ifdefvoid{\@NotaInterna}{%
+    \ifbool{SinLineasHoriExt}{}{%
+     \if at conlineasha\else\hline\fi}% Verificamos si hay que poner la línea horizontal. Si está 'conlineasha' ya salió debido a esta opción.
+    }{\@ColumnasMultiColumnNotaIntAuxCmd\ifbool{SinLineasHoriExt}{}{\hline}}%
   \else
-   \ifbool{PrimeroDescrip}{&\usebox{\@CajaEspacioVacio}&&&&&\\}{&&\usebox{\@CajaEspacioVacio}&&&&\\}%
+   \ifbool{PrimeroDescripcion}{&\usebox{\@CajaEspacioVacio}&&&&&&\\}{&&\usebox{\@CajaEspacioVacio}&&&&&\\}%
+   \ifdefvoid{\@NotaInterna}{}{\@ColumnasMultiColumnNotaIntAuxCmd}%
    \ifbool{SinLineasHoriExt}{}{\hline}% Siempre que hay relleno se pone la línea acá.
   \fi
  \else
@@ -3022,7 +3612,7 @@
   \ifdim \ht\@CajaEspacioVacio=0pt
   \else
    % Rellenamos la tabla con espacio espúreo, y le agregamos las lineas externas, si aplica.
-   \ifbool{SinLineasVertExt}{\multicolumn{7}{c}{\usebox{\@CajaEspacioVacio}}}{\multicolumn{7}{|c|}{\usebox{\@CajaEspacioVacio}}}\\
+   \ifbool{SinLineasVertExt}{\multicolumn{8}{c}{\usebox{\@CajaEspacioVacio}}}{\multicolumn{8}{|c|}{\usebox{\@CajaEspacioVacio}}}\\
   \fi
   % Si pedimos sin totalizaciones, entonces cerramos la tabla ya, si no, calculamos los totales y los escribimos
   \if at sintotales
@@ -3034,14 +3624,16 @@
     \@EscribeTotalColAgrupado
    \else
     \if at Exento \@EscribeTotalCol{E}\fi
-    \if at BIR\@EscribeTotalCol{R}\if at ivaexpresado\@EscribeTotalColAlicuota{R}\fi\fi
-    \@EscribeTotalCol{G}\if at ivaexpresado\@EscribeTotalColAlicuota{G}\fi
-    \if at BIA\@EscribeTotalCol{A}\if at ivaexpresado\@EscribeTotalColAlicuota{A}\fi\fi
+    \if at BIR\@EscribeTotalCol{R}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{R}\fi\fi
+    \@EscribeTotalCol{G}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{G}\fi
+    \ifbool{Electro}{\@EscribeTotalColAlicuotaGDesc}{}%
+    \if at BIA\@EscribeTotalCol{A}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{A}\fi\fi
    \fi
-   \if at ivaexpresado\cline{2-2}\fi
+   \if at sinivaexpresado\else\cline{2-2}\fi
    \hfill \@LetraTitTotal\@@Total & \@LetraNumTotal\numprint{\Total}\\
    \end{tabular}\endgroup
    \\
+   \ifdefvoid{\@NotaInterna}{}{\@ColumnasMultiColumnNotaIntAuxCmd}%
    \ifbool{SinLineasHoriExt}{}{\hline}%
   \fi
  \fi
@@ -3053,8 +3645,8 @@
  \if at filas
   \@CalculaTotalesI
   \@LetraNumTotales
-  \vspace*{\@SeparaElementos}\par
-  \if at exparriba\else\vfill\fi
+  \vspace*{\@SeparaVertical}\par
+  \if at expandecuadro\else\vfill\fi
   \@GeneraCajasTotalesFilas
   \newbox{\@CajaTotal}%
   \savebox{\@CajaTotal}{{\@LetraTitTotal\@@Total}: \@LetraNumTotal\numprint{\Total}}%
@@ -3102,7 +3694,7 @@
      \if at Exento\usebox{\@CajaBIE}\hspace*{\@SeparaMinTotales}\fi\usebox{\@CajaTotal}%
      \if at centrado\hspace*{\@SepTotales}\fi
     \else% Aquí casi cualquier cosa tiene aspecto feo.
-     \ClassWarning{factura}{Es mejor no usar la opción de totalización en filas en este caso, o disminuir los tamaños de los tipos de letra para la totalización}{}%
+     \CLASSWARNING{Es mejor no usar la opción de totalización en filas en este caso, o disminuir los tamaños de los tipos de letra para la totalización}%
      \centering{%
       \begin{tabular}{r@{\hspace*{\@SeparaMinTotales}}l}
        \usebox{\@CajaBIAliR} & \usebox{\@CajaBIAliA} \\[\@SeparaFilas]
@@ -3113,98 +3705,82 @@
   \fi
  \fi
  \par
- \if at exparriba
+ \if at expandecuadro
   \vspace*{-\@EspacioVacioInicial}%
   \vspace*{\@EspacioVacioFinal}%
   \zsaveposy{EspacioVacioInicial}%
  \fi
  \vfill
- \if at exparriba\zsaveposy{EspacioVacioFinal}\fi
- \vspace*{\@SeparaElementos}\par}
+ \if at expandecuadro\zsaveposy{EspacioVacioFinal}\fi
+ \vspace*{\@SeparaVertical}\par
+ \ifdefvoid{\@NotaExterna}{}{\parbox[t]{\linewidth}{\@LetraNotaExterna\@NotaExterna}\vspace*{\@SeparaVertical}\par}}
 
  \ifbool{SinCantidad}
  % Definamos todos los comandos \Item***. El descuento es opcional; por eso usamos G{0} en \NewDocumentCommand.
  {%
-  \if at descuentos
-   \NewDocumentCommand{\Item}{m m G{0}}{\@ITEM{G}{1}{#1}{#2}{#3}}% Ítem normal.
-   \NewDocumentCommand{\ItemR}{m m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemA}{m m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemE}{m m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-  \else
-   \newcommand{\Item}[2]{\@ITEM{G}{1}{#1}{#2}{0}}% Ítem normal.
-   \newcommand{\ItemR}[2]{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemA}[2]{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemE}[2]{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-  \fi
-  \newcommand{\ItemX}[1]{\@ITEM{X}{1}{#1}{0}{0}}% Ítem sin precio.
+  \NewDocumentCommand{\Item}{m o m G{0}}{\@ITEM{G}{1}{#1}[#2]{#3}{#4}}% Ítem normal.
+  \NewDocumentCommand{\ItemR}{m o m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}[#2]{#3}{#4}}% Ítem con IVA reducido.
+  \NewDocumentCommand{\ItemA}{m o m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}[#2]{#3}{#4}}% Ítem con IVA adicional.
+  \NewDocumentCommand{\ItemE}{m o m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}[#2]{#3}{#4}}% Ítem exento de IVA.
+  \NewDocumentCommand{\ItemX}{m o}{\@ITEM{X}{1}{#1}[#2]{0}{0}}% Ítem sin precio.
   \let\ItemG\Item
   \if at csv
    \if at descuentos
-    \immediate\write\csv{"\@@Descripcion","\@@Descuento","\@@Precio \space (\Moneda)"}
+    \immediate\write\csv{"\@@Descripcion","\@@Descuento","\@@Precio \space (\Moneda)","\@@IVA"}%
    \else
-    \immediate\write\csv{"\@@Descripcion","\@@Precio \space (\Moneda)"}
+    \immediate\write\csv{"\@@Descripcion","\@@Precio \space (\Moneda)","\@@IVA"}%
    \fi
   \fi}
  {%
-  \if at descuentos
-   \NewDocumentCommand{\Item}{m m m G{0}}{\@ITEM{G}{#1}{#2}{#3}{#4}}% Ítem normal.
-   \NewDocumentCommand{\ItemR}{m m m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}{#3}{#4}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemA}{m m m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}{#3}{#4}}% Ítem con IVA adicional.
-   \NewDocumentCommand{\ItemE}{m m m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}{#3}{#4}}% Ítem exento de IVA.
-  \else
-   \newcommand{\Item}[3]{\@ITEM{G}{#1}{#2}{#3}{0}}% Ítem normal.
-   \newcommand{\ItemR}[3]{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}{#3}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemA}[3]{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}{#3}{0}}% Ítem con IVA adicional.
-   \newcommand{\ItemE}[3]{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}{#3}{0}}% Ítem exento de IVA.
-  \fi
-  \newcommand{\ItemX}[2]{\@ITEM{X}{#1}{#2}{0}{0}}% Ítem sin precio.
+  \NewDocumentCommand{\Item}{m m o m G{0}}{\@ITEM{G}{#1}{#2}[#3]{#4}{#5}}% Ítem normal.
+  \NewDocumentCommand{\ItemR}{m m o m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}[#3]{#4}{#5}}% Ítem con IVA reducido.
+  \NewDocumentCommand{\ItemA}{m m o m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}[#3]{#4}{#5}}% Ítem con IVA adicional.
+  \NewDocumentCommand{\ItemE}{m m o m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}[#3]{#4}{#5}}% Ítem exento de IVA.
+  \NewDocumentCommand{\ItemX}{m m o}{\@ITEM{X}{#1}{#2}[#3]{0}{0}}% Ítem sin precio.
   \let\ItemG\Item
   \if at csv
    \if at cdu
     \if at descuentos
-     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
    \if at dcu
     \if at descuentos
-     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
    \if at duc
     \if at descuentos
-     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
   \fi}
 
- 
 \if at factura
- % Los descuentos totales no son compatibles -y no sé si lo serán- con el modo de totalización en filas.
+ % Los descuentos totales no son compatibles -y no creo que lo vayan a ser- con el modo de totalización en filas.
  \if at filas
-  \if at Descuentos
-   \ClassWarning{factura}{La opción 'filas' no es compatible con los descuentos totales; sin efecto opción 'filas'.}{}
+  \if at DescuentoTotal
+   \CLASSWARNING{La opción 'filas' no es compatible con los descuentos totales; sin efecto opción 'filas'}
    \@filasfalse
   \fi
  \fi
+ \if at reverso
+ \else
+   \RenewEnviron{reverso}{}
+ \fi
  \if at cotizacion\def\@Denominacion{\@@DenomCotiza}\else\def\@Denominacion{\@@DenomFactura}\fi%  Fijamos la denominación del documento paras las cotizaciones o facturas, que son casos particulares del modo 'factura'.
- \AtEndPreamble{%  La geometría debe aplicarse aquí.
-  \expandafter\geometry\expandafter{\@GeometriaFactura}}
- \AtBeginDocument{%  Aquí en la factura hay que cargar el estilo de página del reporte, pero con la factura se aplicará \thispagestyle{empty} luego, aunque quedará \pagestyle aplicado desde ahora.
-  \if at fondoreportestar
-   \pagestyle{soloabajo}%  Cuando el fondo es con '*' la información de página va sólo abajo.
-  \else
-   \pagestyle{plain}%  Esto aplica para cuando se define un fondo sin '*' y cuando no se define fondo en el reporte.
-  \fi
+ \AtEndPreamble{\expandafter\geometry\expandafter{\@GeometriaFactura}}%  La geometría debe aplicarse aquí.
+ \AtBeginDocument{%
   \addtolength{\@PosFechaX}{\oddsidemargin+1in}%  Le sumamos el margen izquierdo a las posiciones de las cosas; importante que se haga en un \AtBeginDocument antes de que empiecen a escribirse otras cosas que también se agregan a \AtBeginDocument.
   \addtolength{\@PosDenomX}{\oddsidemargin+1in}%
   \addtolength{\@PosControlX}{\oddsidemargin+1in}%
-  \addtolength{\@PosCondX}{\oddsidemargin+1in}%
+  \addtolength{\@PosCondicionesX}{\oddsidemargin+1in}%
   \addtolength{\@PosFirmasXuno}{\oddsidemargin+1in}%
   \setlength{\parindent}{0pt}%
   \setlength{\lineskip}{0pt}%
@@ -3212,48 +3788,49 @@
   \expandafter\setlength{\@SepTotales}{\the\@SeparaMinTotales plus 1fill}% \@SeparaMinTotales es el mínimo espacio entre los totales en el modo 'filas', y SepTotales es una dimensión interna, estirable, con ese como su mínimo.
   \thispagestyle{empty}%
   \pagenumbering{roman}%
-  \@EncabezadoFactura}
-  \if at reporte
-   \expandafter\AtBeginShipoutNext
-  \else
-   \expandafter\AtEndDocument%  Para la factura no puede estar lo que viene en un \AtBeginDocument porque se inserta un espacio extra que genera una página extra; tiene que estar en \AtEndDocument.
-  \fi
-   {%
+  \@EncabezadoFactura
+  \@EscribeNotaPrevia}
+  \AtBeginShipoutNext{% Antes abría aquí un \AtBeginShipoutNext cuando había reporte y un \AtEndDocument cuando no. No es necesario eso. También lo modifiqué en \FirmaFactura.
    \@CargaFondoFactura
-   \@PosicionaFecha
+   \@PosicionaFechas
    \if at denom\@PosicionaDenom\fi
-   \if at confirmas\@PosicionaFirmas\fi
-   \if at concondiciones\@PosicionaCondiciones\fi
-   \if at prefactura\@PosicionaNumControl\fi}
-
+   \if at prefactura\@PosicionaNumControl\fi
+   \if at sinfirmas\else\@PosicionaFirmas\fi
+   \ifdefvoid{\@Condiciones}{}{\@PosicionaCondiciones}}
  \if at linea
-  \RequirePackage{zref-savepos}%  Para determinar las coordenadas de la línea.
-  \RequirePackage{eso-pic}%  Para poder usar \AtBeginShipoutNext porque si no se hace en el 'shipout' de la página se genera un espacio en blanco extra.
+  \RequirePackage{zref-savepos}
+  % Para determinar las coordenadas de la línea hay que usar \AtBeginShipoutNext porque si no se hace en el 'shipout' de la página se genera un espacio en blanco extra.
   \AtBeginShipoutNext{\if at linea\@DibujaLinea\fi}
    \if at filas
-    \ifbool{SinLineasVertInt}{\@lineacompletatrue}
+    \ifbool{SinLineasVertInt}{\@LineaCompletatrue}
    \else
-    \@lineahastatotaltrue\@lineadesdeiniciotrue
+    \@LineaHastaTotaltrue\@LineaDesdeIniciotrue
    \fi
  \fi
-
  %% El comando para la descripción del servicio prestado.
  \NewDocumentCommand{\Descripcion}{+m}{%
-  \@LetraDescripcion
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaDescrip, line width=\@GrosorLineaDescrip, rounded corners=\@EsquinaLineaDescrip,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraDescrip, shadow yshift=-\@SombraDescrip}]{%
-    \ifbool{ExpAbajo}
-     {\parbox[t][\textheight-\pagetotal-2\@SeparaInternaDescrip-\@GrosorLineaDescrip-\@SombraDescrip]
-      {\textwidth-2\@SeparaInternaDescrip-\@GrosorLineaDescrip-\@SombraDescrip}}%
-     {\parbox[t]{\textwidth-\@SombraDescrip-2\@SeparaInternaDescrip-2\@GrosorLineaDescrip}}%
-    {\setlength{\parindent}{0.5cm}%
-     \setlength{\parskip}{2pt plus 8pt}%
-     \ifbool{ExpAbajo}{\vfill}{}%
-      #1%
-     \ifbool{ExpAbajo}{\vfill}{}}};%
-  \end{tikzpicture}
-  \par\vspace*{\@SombraDescrip}}%
+  {% Abrimos un grupo adicional para que la redefinición del entorno 'tikzpicture' sea local.
+   \@LetraDescripcion
+   % Cuando la línea tiene grosor cero, hacemos que el entorno 'tikzpicture' sea "fake", y redefinimos \node para que obvie los parámetros que le dimos como argumento opcional.
+   \ifdim\@GrosorLineaDescripcion=0pt%
+    \setlength{\@SeparaInternaDescripcion}{0pt}\setlength{\@EsquinaLineaDescripcion}{0pt}\setlength{\@SombraDescripcion}{0pt}%
+    \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+   \fi
+   \begin{tikzpicture}
+    % Expandimos después para poderle pasar el contenido de la macro como argumento opcional a \node.
+    \expandafter\node\expandafter[\@DescripcionTIKZ]{%
+     \ifbool{ExpAbajo}
+      {\parbox[t][\textheight-\pagetotal-2\@SeparaInternaDescripcion-\@GrosorLineaDescripcion-\@SombraDescripcion]
+       {\textwidth-2\@SeparaInternaDescripcion-\@GrosorLineaDescripcion-\@SombraDescripcion}}%
+      {\parbox[t]{\textwidth-\@SombraDescripcion-2\@SeparaInternaDescripcion-2\@GrosorLineaDescripcion}}%
+     {\setlength{\parindent}{0.5cm}%
+      \setlength{\parskip}{2pt plus 8pt}%
+      \ifbool{ExpAbajo}{\vfill}{}%
+       #1%
+      \ifbool{ExpAbajo}{\vfill}{}}}%
+    \ifdim\@GrosorLineaDescripcion=0pt\else ;\fi% El fin del nodo va cuando hay el entorno tikzpicture original.
+   \end{tikzpicture}
+   \par\vspace*{\@SombraDescripcion}}}%
 \else
  \RenewEnviron{factura}{%
   \@ZERO
@@ -3261,6 +3838,7 @@
   \let\@ITEM\@CalculaItem
   \BODY
   \@CalculaTotalesI}
+ \RenewEnviron{reverso}{}
  \NewDocumentCommand{\Descripcion}{+m}{}
 \fi
 
@@ -3279,7 +3857,7 @@
   \@CargaFondoReporte
   \@EncabezadoReporte
   \ifdefvoid{\@EstiloPagReporteResto}{%
-   \if at fondoreportestar%  Si no usamos \EstiloPagReporte entonces se fijará 'soloabajo' cuando se use \FondoReporte* para que sólo use marcas de pie de página, y si no se usó \FondoReporte* entonces se fijará 'plain' que usa cabeceras y piés de página.
+   \if at FondoReporteStar%  Si no usamos \EstiloPagReporte entonces se fijará 'soloabajo' cuando se use \FondoReporte* para que sólo use marcas de pie de página, y si no se usó \FondoReporte* entonces se fijará 'plain' que usa cabeceras y pies de página.
     \pagestyle{soloabajo}%
    \else
     \pagestyle{plain}%
@@ -3286,8 +3864,8 @@
    \fi}
    {\pagestyle{\@EstiloPagReporteResto}}%  Si usamos \EstiloPagReporte en su argumento obligatorio entonces fijamos ese estilo de página.
   \ifdefvoid{\@EstiloPagReporteUno}{%
-   \if at fondoreporte%  Si no le damos a \EstiloPagReporte su argumento opcional, entonces se fijará 'solonumpag' como el estilo de página para la primera página, pero solamente si usamos \FondoReporte, ya que el estilo de página predeterminado al usar \FondoReporte* ya se acaba de fijar y no necesita el caso especial de la primera hoja (\thispagestyle).
-    \if at fondoreportestar
+   \if at FondoReporte%  Si no le damos a \EstiloPagReporte su argumento opcional, entonces se fijará 'solonumpag' como el estilo de página para la primera página, pero solamente si usamos \FondoReporte, ya que el estilo de página predeterminado al usar \FondoReporte* ya se acaba de fijar y no necesita el caso especial de la primera hoja (\thispagestyle).
+    \if at FondoReporteStar
     \else
      \thispagestyle{solonumpag}%
     \fi
@@ -3304,7 +3882,7 @@
 
 %% Comando para el diseño de la forma libre.
 \newcommand{\@CargaFondoFactura}{%
- \if at fondofactura
+ \if at FondoFactura
   \begin{textblock*}{\paperwidth}(0pt,0pt)%
    \includegraphics{\@FondoFactura}%
   \end{textblock*}%
@@ -3313,8 +3891,8 @@
 %% Comando para el fondo del reporte.
 \newcommand{\@CargaFondoReporte}{%
  \begin{textblock*}{\paperwidth}(0pt,0pt)% Tuve que abrir el textblock* aquí para que aplique siempre; de esta manera se corrige un defecto que se produce cuando se usa \vspace* al inicio de la página (dentro de \@EncabezadoReporte).
-  \if at fondoreporte
-   \if at fondoreportestar
+  \if at FondoReporte
+   \if at FondoReporteStar
     \AddToShipoutPictureBG{\includegraphics{\@FondoReporte}}%
    \else
      \noindent\includegraphics{\@FondoReporte}%
@@ -3326,9 +3904,7 @@
 \newcommand{\@PosicionaFirmas}{%
  \savebox{\@CajaFirmas}{%
   \parbox{\textwidth+\oddsidemargin+1in-\@PosFirmasXuno-\@PosFirmasXdos}{\@EstiloFirmas}}%
- \ifbool{FirmasYnegativo}
-  {\addtolength{\@PosFirmasY}{\paperheight-\ht\@CajaFirmas-\dp\@CajaFirmas}}
-  {}%
+ \ifbool{FirmasYnegativo}{\addtolength{\@PosFirmasY}{\paperheight-\ht\@CajaFirmas-\dp\@CajaFirmas}}{}%
  \begin{textblock*}{\wd\@CajaFirmas}(\@PosFirmasXuno,\@PosFirmasY)%
   \usebox{\@CajaFirmas}%
  \end{textblock*}}
@@ -3336,11 +3912,10 @@
 %% Comando que coloca las condiciones del documento.
 \newcommand{\@PosicionaCondiciones}{%
  \savebox{\@CajaCond}{%
-  \parbox{\textwidth+\oddsidemargin+1in-\@PosCondX}{\@EstiloCondiciones}}%
- \ifbool{CondYnegativo}
-  {\addtolength{\@PosCondY}{\paperheight}}% Aquí la caja abre hacia abajo, por eso no restamos el tamaño de la caja (\ht y \dp).
-  {}%
- \begin{textblock*}{\wd\@CajaCond}(\@PosCondX,\@PosCondY)%
+  \parbox{\textwidth+\oddsidemargin+1in-\@PosCondicionesX}{\@EscribeCondiciones}}%
+ \ifbool{CondYnegativo}{\addtolength{\@PosCondicionesY}{\paperheight}}{}%
+ \ifbool{CondYarriba}{\addtolength{\@PosCondicionesY}{-\ht\@CajaCond-\dp\@CajaCond}}{}% Aquí la caja abre hacia abajo, a menos de que usemos \PosCondiciones*
+ \begin{textblock*}{\wd\@CajaCond}(\@PosCondicionesX,\@PosCondicionesY)%
   \usebox{\@CajaCond}%
  \end{textblock*}}
 
@@ -3347,12 +3922,9 @@
 %% Comando que coloca el número de control.
 \newcommand{\@PosicionaNumControl}{%
  \savebox{\@CajaControl}{\@EstiloNumControl}%
- \ifbool{ControlXnegativo}
-  {\addtolength{\@PosControlX}{\textwidth-\wd\@CajaControl}}
-  {}%
- \ifbool{ControlYnegativo}
-  {\addtolength{\@PosControlY}{\paperheight-\ht\@CajaControl-\dp\@CajaControl}}
-  {}%
+ \ifbool{ControlXnegativo}{\addtolength{\@PosControlX}{\textwidth-\wd\@CajaControl}}{}%
+ \ifbool{ControlYnegativo}{\addtolength{\@PosControlY}{\paperheight}}{}%
+ \ifbool{ControlYarriba}{\addtolength{\@PosControlY}{-\ht\@CajaControl-\dp\@CajaControl}}{}%
  \begin{textblock*}{\wd\@CajaControl}(\@PosControlX,\@PosControlY)%
   \usebox{\@CajaControl}%
  \end{textblock*}}
@@ -3360,25 +3932,19 @@
 %% Comando que coloca la denominación del documento.
 \newcommand{\@PosicionaDenom}{%
  \savebox{\@CajaDenom}{\@EstiloDenom}%
- \ifbool{DenomXnegativo}
-  {\addtolength{\@PosDenomX}{\textwidth-\wd\@CajaDenom}}
-  {}%
- \ifbool{DenomYnegativo}
-  {\addtolength{\@PosDenomY}{\paperheight-\ht\@CajaDenom-\dp\@CajaDenom}}
-  {}%
+ \ifbool{DenomXnegativo}{\addtolength{\@PosDenomX}{\textwidth-\wd\@CajaDenom}}{}%
+ \ifbool{DenomYnegativo}{\addtolength{\@PosDenomY}{\paperheight}}{}%
+ \ifbool{DenomYarriba}{\addtolength{\@PosDenomY}{-\ht\@CajaDenom-\dp\@CajaDenom}}{}%
  \begin{textblock*}{\wd\@CajaDenom}(\@PosDenomX,\@PosDenomY)%
   \usebox{\@CajaDenom}%
  \end{textblock*}}
 
-%% Comando que coloca la fecha.
-\newcommand{\@PosicionaFecha}{%
- \savebox{\@CajaFecha}{\@EstiloFecha}%
- \ifbool{FechaXnegativo}
-  {\addtolength{\@PosFechaX}{\textwidth-\wd\@CajaFecha}}
-  {}%
- \ifbool{FechaYnegativo}
-  {\addtolength{\@PosFechaY}{\paperheight-\ht\@CajaFecha-\dp\@CajaFecha}}
-  {}%
+%% Comando que coloca la(s) fecha(s).
+\newcommand{\@PosicionaFechas}{%
+ \savebox{\@CajaFecha}{\@EstiloFechas}%
+ \ifbool{FechaXnegativo}{\addtolength{\@PosFechaX}{\textwidth-\wd\@CajaFecha}}{}%
+ \ifbool{FechaYnegativo}{\addtolength{\@PosFechaY}{\paperheight}}{}%
+ \ifbool{FechaYarriba}{\addtolength{\@PosFechaY}{-\ht\@CajaFecha-\dp\@CajaFecha}}{}%
  \begin{textblock*}{\wd\@CajaFecha}(\@PosFechaX,\@PosFechaY)%
   \usebox{\@CajaFecha}%
  \end{textblock*}}
@@ -3392,73 +3958,104 @@
   \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
   \ifdefvoid{\@TituloReporte}{}{\vspace*{\baselineskip}{\@LetraTitReporte \centering \@TituloReporte \par}}}}
 
-%% Comando que coloca la caja con los datos del cliente.
+%% Comando que coloca las dos cajas del encabezado: la de los datos del cliente y la del resumen.
 \newcommand{\@EscribeDatos}{%
- {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía sea sólo local.
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-   \parbox{\textwidth-\@SombraEncabez-2\@SeparaInternaEncabez-\@GrosorLineaEncabez}{%
-    \hfill {\@LetraTitEnc \@@Datos} \hfill \mbox{}\par
-    {\bfseries \@@RazonSocial} \@RazonSocial
-    \dotfill
-    {\bfseries \@@RIF} {\ttfamily \@RIF}%
-    \par
-    \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
-    {\bfseries \@@Direccion} \@Direccion
-    \par
-    {\bfseries \@@Telefono} {\ttfamily \@Telefono}%
-    \ifdefvoid{\@Email}{}{\hspace*{0.666em}\@CaracterSeparaTelefonoEmail\hspace*{0.666em}{\bfseries \@@Email} {\ttfamily \@Email}}}};%
+ {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía y la redefinición del entorno 'tikzpicture' sean locales.
+  \ifdim\@GrosorLineaEncabezado=0pt%
+   \setlength{\@SeparaInternaEncabezado}{0pt}\setlength{\@EsquinaLineaEncabezado}{0pt}\setlength{\@SombraEncabezado}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@DatosTIKZ]{%
+   \parbox{\textwidth-\@SombraEncabezado-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado}{\@DatosAux}}%
+    \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \par\vspace*{\@SombraEncabez}}}%  Para que textblock* esté en modo vertical.
+  \par\vspace*{\@SombraEncabezado}}}%  Para que textblock* esté en modo vertical.
 
-%% Comandos auxiliares para los datos y el resumen.
-\newcommand{\@DatosAux}{%
- \vfill
- \hfill {\@LetraTitEnc \@@Datos}\hfill \mbox{}\par
- {\bfseries \@@RazonSocial} \@RazonSocial \par
- {\bfseries \@@RIF} {\ttfamily \@RIF} \par
- \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
- {\bfseries \@@Direccion} \@Direccion \par
- {\bfseries \@@Telefono} {\ttfamily \@Telefono} \hfill \par
- \ifdefvoid{\@Email}{}{{\bfseries \@@Email} {\ttfamily \@Email}}%
- \vfill}
-
-\newcommand{\@ResumenAux}{%
- \hfill {\@LetraTitEnc \@@Resumen}\hfill \mbox{}%
- \vfill\@Resumen\vfill}
-
-%% Comando que coloca las dos cajas del encabezado: la de los datos del cliente y la del resumen.
 \newcommand{\@EscribeDatosResumen}{%
- {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía sea sólo local.
+ {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía y la redefinición del entorno 'tikzpicture' sean locales.
+  \ifdim\@GrosorLineaEncabezado=0pt%
+   \setlength{\@SeparaInternaEncabezado}{0pt}\setlength{\@EsquinaLineaEncabezado}{0pt}\setlength{\@SombraEncabezado}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
   \savebox{\@CajaDatos}{%
-   \parbox[t]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-    \@DatosAux}}%
+   \parbox[t]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{\@DatosAux*}}%
   \savebox{\@CajaResumen}{%
-   \parbox[t]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-    \@ResumenAux}}%
+   \parbox[t]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{\@ResumenAux}}%
   \setlength{\@TamDatos}{\ht\@CajaDatos+\dp\@CajaDatos}%
   \setlength{\@TamResumen}{\ht\@CajaResumen+\dp\@CajaResumen}%
   \ifdim\@TamDatos>\@TamResumen
-   \setlength{\@TamFinalEncabez}{\@TamDatos}%
+   \setlength{\@TamFinalEncabezado}{\@TamDatos}%
   \else
-   \setlength{\@TamFinalEncabez}{\@TamResumen}%
+   \setlength{\@TamFinalEncabezadoado}{\@TamResumen}%
   \fi
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-    \parbox[t][\@TamFinalEncabez]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%    
-    \@DatosAux}};%
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@DatosTIKZ]{%
+    \parbox[t][\@TamFinalEncabezado]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{%    
+    \@DatosAux*}}%
+   \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \hspace*{\@SeparaEncabez}\hspace*{\@SombraEncabez}%
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-    \parbox[t][\@TamFinalEncabez]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-     \@ResumenAux}};%
+  \hspace*{\@SeparaDatosResumen}\hspace*{\@SombraEncabezado}%
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@ResumenTIKZ]{%
+    \parbox[t][\@TamFinalEncabezado]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{%
+     \@ResumenAux}}%
+   \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \par\vspace*{\@SombraEncabez}}}%  El \par es para que textblock* esté en modo vertical.
+  \par\vspace*{\@SombraEncabezado}}}%  El \par es para que textblock* esté en modo vertical.
 
+%% Comando que coloca la caja para la nota previa, con la posibilidad de TikZ.
+\newcommand{\@EscribeNotaPrevia}{%
+ {% Abrimos un nuevo grupo para que la redefinición del entorno 'tikzpicture' sea local.
+  \baselineskip0pt
+  \ifdefvoid{\@NotaPrevia}{}{%
+   \ifdim\@GrosorLineaNotaPrevia=0pt%
+    \setlength{\@SeparaInternaNotaPrevia}{0pt}\setlength{\@EsquinaLineaNotaPrevia}{0pt}\setlength{\@SombraNotaPrevia}{0pt}%
+    \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+   \fi
+   \begin{tikzpicture}%
+    \expandafter\node\expandafter[\@NotaPreviaTIKZ]{%
+    \parbox{\textwidth-\@SombraNotaPrevia-2\@SeparaInternaNotaPrevia-\@GrosorLineaNotaPrevia}{\@EstiloNotaPrevia}}%
+     \ifdim\@GrosorLineaNotaPrevia=0pt\else ;\fi
+   \end{tikzpicture}%
+   \par\vspace*{\@SombraNotaPrevia}\vspace*{\@SeparaVertical}%
+   \if at expandecuadro\else\vfill\fi}}}
+
+%% Comando que coloca la caja para las condiciones, con la posibilidad de TikZ.
+\newcommand{\@EscribeCondiciones}{%
+ {% Abrimos un nuevo grupo para que la redefinición del entorno 'tikzpicture' sea local.
+  \ifdim\@GrosorLineaCondiciones=0pt%
+   \setlength{\@SeparaInternaCondiciones}{0pt}\setlength{\@EsquinaLineaCondiciones}{0pt}\setlength{\@SombraCondiciones}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@CondicionesTIKZ]{%
+   \parbox{\textwidth-\@SombraCondiciones-2\@SeparaInternaCondiciones-\@GrosorLineaCondiciones}{\@EstiloCondiciones}}%
+    \ifdim\@GrosorLineaCondiciones=0pt\else ;\fi
+  \end{tikzpicture}%
+  \par\vspace*{\@SombraCondiciones}}}
+
+%% Comandos auxiliares para los datos y el resumen.
+%% En el caso de los datos, la versión \@DatosAux se ejecuta cuando no hay resumen, y la versión \@DatosAux* se ejecuta cuando hay resumen.
+\NewDocumentCommand{\@DatosAux}{s}{%
+ \hfill {\@LetraTitEnc \@@Datos}\hfill \mbox{}\par
+ \IfBooleanT{#1}{\vfill}%
+ {\bfseries \if at Nombre \@@Nombre \else \@@RazonSocial \fi} \@RazonSocial
+ \IfBooleanTF{#1}{\par}{\dotfill}%
+ {\bfseries \@@RIF} {\ttfamily \@RIF}\par
+ \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
+ {\bfseries \@@Direccion} \@Direccion \par
+ \ifdefvoid{\@Telefono}{}{{\bfseries \@@Telefono} {\ttfamily \@Telefono}}%
+ \ifdefvoid{\@Email}
+  {\par}
+  {\IfBooleanTF{#1}
+   {\par}
+   {\ifdefvoid{\@Telefono}{}{\hspace*{\@SeparaTelefonoEmail}\@CaracterSeparaTelefonoEmail\hspace*{\@SeparaTelefonoEmail}}}%
+  {\bfseries \@@Email} {\ttfamily \@Email}}%
+ \IfBooleanT{#1}{\vfill}}
+
+\newcommand{\@ResumenAux}{\hfill {\@LetraTitEnc \@@Resumen}\hfill \mbox{}\vfill\@Resumen\vfill}
+
 %% Comando que coloca la línea diagonal.
 \newcommand{\@DibujaLinea}{%
  \@LetraItems% Volvemos a fijar el \baselineskip de la tabla.
@@ -3474,7 +4071,8 @@
   \if at DescA \if at BIA \addtolength{\@LineaNodoYo}{2\baselineskip}\fi\fi
   \if at DescE \if at Exento \addtolength{\@LineaNodoYo}{2\baselineskip}\fi\fi
   \addtolength{\@LineaNodoYo}{\baselineskip/2}%
-  \if at ivaexpresado
+  \if at sinivaexpresado
+  \else
    \addtolength{\@LineaNodoYo}{2\baselineskip}%
    \if at BIR\addtolength{\@LineaNodoYo}{2\baselineskip}\fi
    \if at BIA\addtolength{\@LineaNodoYo}{2\baselineskip}\fi
@@ -3494,32 +4092,26 @@
  \if at csv
   \if at Exento
    \if at DescE
-    \immediate\write\csv{Totales: \@@SubtotalE: \Moneda \SubtE}%
-    \immediate\write\csv{Totales: \@@DescuentoE: \Moneda \DescE}%
+    \immediate\write\csv{Totales: \@@SubtotalE: \Moneda \SubtE^^JTotales: \@@DescuentoE: \Moneda \DescE}%
    \fi
    \immediate\write\csv{Totales: \@@BIE: \Moneda \BIE}%
   \fi
   \if at BIR
    \if at DescE
-    \immediate\write\csv{Totales: \@@SubtotalR: \Moneda \SubtR}%
-    \immediate\write\csv{Totales: \@@DescuentoR: \Moneda \DescR}%
+    \immediate\write\csv{Totales: \@@SubtotalR: \Moneda \SubtR^^JTotales: \@@DescuentoR: \Moneda \DescR}%
    \fi
-   \immediate\write\csv{Totales: \@@BIR: \Moneda \BIR}%
-  \immediate\write\csv{Totales: \@@AlicuotaR: \Moneda \AlicuotaR}%
+   \immediate\write\csv{Totales: \@@BIR: \Moneda \BIR^^JTotales: \@@AlicuotaR: \Moneda \AlicuotaR}%
   \fi
   \if at DescG
-   \immediate\write\csv{Totales: \@@SubtotalG: \Moneda \SubtG}%
-   \immediate\write\csv{Totales: \@@DescuentoG: \Moneda \DescG}%
+   \immediate\write\csv{Totales: \@@SubtotalG: \Moneda \SubtG^^JTotales: \@@DescuentoG: \Moneda \DescG}%
   \fi
-  \immediate\write\csv{Totales: \@@BIG: \Moneda \BIG}%
-  \immediate\write\csv{Totales: \@@AlicuotaG: \Moneda \AlicuotaG}%
+  \immediate\write\csv{Totales: \@@BIG: \Moneda \BIG^^JTotales: \@@AlicuotaG: \Moneda \AlicuotaG}%
+  \FPifeq\AlicuotaGDesc{0}\else\immediate\write\csv{Totales: \@@AlicuotaGDesc: \Moneda \AlicuotaGDesc}\fi
   \if at BIA
    \if at DescA
-    \immediate\write\csv{Totales: \@@SubtotalA: \Moneda \SubtA}%
-    \immediate\write\csv{Totales: \@@DescuentoA: \Moneda \DescA}%
+    \immediate\write\csv{Totales: \@@SubtotalA: \Moneda \SubtA^^JTotales: \@@DescuentoA: \Moneda \DescA}%
    \fi
-   \immediate\write\csv{Totales: \@@BIA: \Moneda \BIA}%
-   \immediate\write\csv{Totales: \@@AlicuotaA: \Moneda \AlicuotaA}%
+   \immediate\write\csv{Totales: \@@BIA: \Moneda \BIA^^JTotales: \@@AlicuotaA: \Moneda \AlicuotaA}%
   \fi
   \immediate\write\csv{Totales: \@@Total: \Moneda \Total}%
   \immediate\closeout\csv
@@ -3540,26 +4132,44 @@
 
 %</class>
 %<*def>
+%% Diseño hecho en TikZ para los datos del cliente, el resumen, la nota previa, la descripción y las condiciones.
+\def\@DatosTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaEncabezado, line width=\@GrosorLineaEncabezado, rounded corners=\@EsquinaLineaEncabezado, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabezado, shadow yshift=-\@SombraEncabezado}}
+
+\let\@ResumenTIKZ\@DatosTIKZ
+
+\def\@NotaPreviaTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaNotaPrevia, line width=\@GrosorLineaNotaPrevia, rounded corners=\@EsquinaLineaNotaPrevia, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraNotaPrevia, shadow yshift=-\@SombraNotaPrevia}}
+
+\def\@DescripcionTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaDescripcion, line width=\@GrosorLineaDescripcion, rounded corners=\@EsquinaLineaDescripcion, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraDescripcion, shadow yshift=-\@SombraDescripcion}}
+
+\def\@CondicionesTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaCondiciones, line width=\@GrosorLineaCondiciones, rounded corners=\@EsquinaLineaCondiciones, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraCondiciones, shadow yshift=-\@SombraCondiciones}}
+
 %% El diseño de las distintas partes de la hoja.
-\newcommand{\@EstiloFirmas}{%
+\newcommand{\@EstiloFirmas}{
  \@LetraFirmas
  \if at unafirma
  \else
-  \parbox{\@TamLineaFirmas}{%
+  \parbox{\@TamLineaFirmas}{
    \rule{\@TamLineaFirmas}{\@GrosorLineaFirmas}
-   \centering \ifdefvoid{\@Conforme}{\@@Conforme}{\@Conforme}}%
+   \centering \ifdefvoid{\@Conforme}{\@@Conforme}{\@Conforme}}
  \fi
  \hfill
- \parbox{\@TamLineaFirmas}{%
+ \parbox{\@TamLineaFirmas}{
   \rule{\@TamLineaFirmas}{\@GrosorLineaFirmas}
   \centering \ifdefvoid{\@Emisor}{\if at cotizacion \@@Emisor \else \@@Pagado \fi}{\@Emisor}}}
 
+\newcommand{\@EstiloNotaPrevia}{\@LetraNotaPrevia \@NotaPrevia}
+
 \newcommand{\@EstiloCondiciones}{\@LetraCondiciones \@Condiciones}
 
 \newcommand{\@EstiloNumControl}{%
+ \renewcommand{\baselinestretch}{0}\selectfont
  \begin{tabular}{@{\extracolsep{0pt}}l}
-  \@LetraDenom \@@Control \\
-  {\@LetraDenom\@NumSerieControl-}\space\@LetraNumeracion\@NumControl
+  \@LetraDenom \@@Control \\[.4em]
+  {\@LetraDenom\@NumSerieControl-}\space\@LetraNumeracion\@NumControl \\
  \end{tabular}}
 
 \newcommand{\@EstiloDenom}{%
@@ -3569,13 +4179,19 @@
   \space\space{\@LetraNumeracion N\textordmasculine\space\@Num}%
  \fi}
 
-\newcommand{\@EstiloFecha}{\@LetraFecha\@@Fecha{\ttfamily\ \@Fecha}}
+\newcommand*{\@EstiloFechas}{%
+ \renewcommand{\baselinestretch}{0}%
+ \setlength{\tabcolsep}{0pt}%
+ \@LetraFecha\begin{tabular}{r@{\extracolsep{1ex}}l@{\extracolsep{0pt}}}
+ \@@Fecha & \ttfamily\@Fecha \\[.3em]
+ \if at vencimiento \@@FechaVencimiento & \ttfamily\@FechaVencimiento \\ \else \vspace*{-.3em}\fi
+ \end{tabular}}
 
 \newcommand{\@InfoPaginaNoTitulo}{\@LetraInfoPagina Reporte correspondiente a la factura n\'umero \@Num \space de fecha \@Fecha}
 
 \newcommand{\@InfoPaginaTitulo}{\@LetraInfoPagina \@TituloReporte \space - \@Proveedor \space - \@Fecha}
 
-%% Estilos de página: normal, sólo cabeceras, sólo piés de página y sólo número de página al pié.
+%% Estilos de página: normal, sólo cabeceras, sólo pies de página y sólo número de página al pie.
 \fancypagestyle{plain}{%
  \expandafter\ps at fancy
  \fancyhf{}%
@@ -3612,109 +4228,144 @@
  \fancyfoot[C]{\thepage}}
 
 %</def>
-%<*!class&!def&!firma&!fondo&!membrete&!batchfile>
+%<*!class&!def&!firma&!fondo&!membrete&!aux&!batchfile>
 %% Descripción de este ejemplo:
 %
 %%<desc>
-%<factuno|factdos|facttres|factcuatro|factcinco|factseis|factsiete|factocho|repuno|repdos>%%  Escribimos una factura,
-%<prefac>%%  Escribimos una prefactura (prefactura),
-%<cotiza>%%  Escribimos una cotización (cotizacion),
-%<repuno|repdos|reptres>%%  Escribimos un reporte,
-%<repuno>%%  Generamos factura y reporte (conreporte),
-%<repdos>%%  Escribimos factura y reporte, pero sólo producimos el reporte (soloreporte),
-%<reptres>%%  Generamos solamente un reporte (soloreporte),
-%<factcinco|factocho>%%  Escribimos factura y reporte, pero sólo producimos la factura,
+%<beispiel>%%  Adaptado a otra legislación
+%<factuno|factdos|facttres|factcuatro|factcinco|factseis|factsiete|factocho|factnueve|factdiez|repuno|repdos>%%  Escribimos una factura
+%<reptres>%%  No escribimos factura ni usamos las macros que definen valores para su uso
+%<factnueve|factdiez|repuno>%%  Escribimos en el reverso de la factura
+%<prefac|beispiel>%%  (prefactura) Escribimos una prefactura
+%<cotiza>%%  (cotizacion) Escribimos una cotización
+%<repuno|repdos|reptres>%%  Escribimos un reporte
+%<repuno>%%  (sinreverso) Escribimos el reverso de la factura pero sólo producimos su anverso
+%<repuno>%%  (conreporte) Generamos factura y reporte
+%<repdos>%%  (soloreporte) Escribimos factura y reporte, pero sólo producimos el reporte
+%<reptres>%%  (soloreporte) Generamos solamente un reporte
+%<factcinco|factocho>%%  Escribimos factura y reporte, pero sólo producimos la factura
 %
-%<factuno>%%  Todo con los valores por omisión,
+%<factuno>%%  Todo con los valores por omisión
 %
-%<reptres>%%  El reporte se imprime en las dos caras del papel (twoside),
+%<reptres>%%  (twoside) El reporte se imprime en las dos caras del papel
 %
-%<factcinco>%%  Cuadro de la factura sin la columna de cantidades (sincantidad),
-%<factdos|factseis>%%  Con la columna para enumerar los ítems (numitem),
-%<factdos|factsiete>%%  Con descuentos individuales (descuentos),
-%<factsiete>%%  Con columna extra para subtotal (subtotal),
+%<factcinco>%%  (sincantidad) Cuadro de la factura sin la columna de cantidades
+%<factdos|factseis>%%  (numitem) Con la columna para enumerar los ítems
+%<factdos|factsiete>%%  (descuentos) Con la columna para descuentos individuales
+%<factsiete>%%  (subtotal) Con la columna extra para subtotal
+%<factcinco>%%  (iva) Con la columna para el IVA
 %
-%<facttres>%%  Agrupados los totales por gravámenes (agrupado),
-%<factcuatro|factcinco|factsiete>%%  Totalización en modo de filas (filas),
-%<factcuatro>%%  Centrados los totales en el modo de filas (centrado),
+%<facttres>%%  (agrupado) Agrupados los totales por tipo y no por gravamen
+%<factcuatro|factcinco|factsiete>%%  (filas) Totalización en modo de filas
+%<factsiete>%%  (centrado) Centrados los totales en el modo de filas
 %
-%<factdos>%%  Primero la descripción, luego la cantidad, luego el precio unitario (dcu),
-%<factcuatro>%%  Primero la descripción, luego el precio unitario, luego la cantidad (duc),
-%<factcinco|factseis>%%  Escribe la denominación (“FACTURA”) y el número (denom),
-%<cotiza>%%  Escribe la denominación (“COTIZACIÓN”) pero sin número (sinnumero),
-%<cotiza>%%  No totaliza, para que el cliente tenga un presupuesto por distintos ítems que luego elegirá entre ellos, es decir, una lista de precios. (sintotales),
+%<factdos>%%  (dcu) Primero la descripción, luego la cantidad, luego el precio unitario
+%<factcuatro>%%  (duc) Primero la descripción, luego el precio unitario, luego la cantidad
+%<factcinco|factseis|factsiete>%%  (denom) Escribe la denominación (“FACTURA”) y el número
+%<cotiza>%%  (sinnumero) Escribe la denominación (“COTIZACIÓN”) pero sin número
+%<cotiza>%%  (sintotales) No totaliza, para que el cliente tenga un presupuesto por distintos ítems que luego elegirá entre ellos, es decir, una lista de precios
 %
-%<factdos|factseis>%%  Sin líneas verticales externas (sinlineasve),
-%<facttres|factcuatro>%%  Sin líneas verticales internas (sinlineasvi),
-%<factcuatro>%%  Sin líneas horizontales internas (sinlineashi),
-%<factseis>%%  Sin líneas horizontales externas (sinlineashe),
-%<facttres|factcinco>%%  Separado cada ítem con una línea horizontal (conlineasha),
+%<factdos|factseis>%%  (sinlineasve) Sin líneas verticales externas
+%<facttres|factcuatro>%%  (sinlineasvi) Sin líneas verticales internas
+%<factdiez>%%  (sinlineasv) Sin lineas verticales
+%<factcuatro>%%  (sinlineashi) Sin líneas horizontales internas
+%<factseis>%%  (sinlineashe) Sin líneas horizontales externas
+%<factdiez>%%  (sinlineash) Sin lineas horizontales
+%<facttres|factcinco>%%  (conlineasha) Separado cada ítem con una línea horizontal
 %
-%<factcinco|factocho>%%  Sin expandir el cuadro de la factura ni la descripción (sinexpandir),
-%<facttres|factcuatro|prefac>%%  Expande el cuadro de la factura con espacio en blanco (exparriba),
-%<prefac|facttres>%%  Con línea protectora del espacio en blanco (linea),
+%<factcinco|factocho>%%  (sinexpandir) Sin expandir el cuadro de la factura ni la descripción
+%<facttres|factcuatro|prefac>%%  (expandecuadro) Expande el cuadro de la factura con espacio en blanco
+%<prefac|facttres>%%  (linea) Con línea protectora del espacio en blanco
 %
-%<facttres>%%  Con el tipo de impuesto como parte de la descripción y no de los precios (impdesc),
-%<factdos>%%  Centra la descripción en los elementos en la factura (centradesc),
-%<factseis|factsiete>%%  Escribimos un ítem cuya descripción ocupa más que una línea,
-%<factsiete>%%  Cuando la descripción de un ítem ocupa más que una línea, no pone el carácter que indica continuación en la siguiente línea ni los caracteres en las columnas vacías (sinmarcas),
-%<factcinco|factseis|factsiete>%%  Obligando a especificar todos los IVA así no existan productos gravados con ellos (todosiva),
-%<factseis>%%  Especificando 'G' en los ítems gravados con IVA general (G),
-%<factocho>%%  Sin IVA (siniva),
-%<factdos>%%  Sólo la firma del emisor (unafirma),
-%<facttres>%%  Sin firmas (sinfirmas),
-%<factcuatro>%%  Sin condiciones del documento (sincondiciones),
-%<factseis>%%  Escribe un archivo CSV con la información numérica de la factura (csv),
+%<facttres>%%  (impdesc) Con el tipo de impuesto como parte de la descripción y no de los precios
+%<factdos>%%  (centradesc) Centra la descripción en los elementos en la factura
+%<factsiete>%%  (sinmarcas) Cuando la descripción de un ítem ocupa más que una línea, no pone el carácter que indica continuación en la siguiente línea ni los caracteres en las columnas vacías
+%<factcinco|factseis|factsiete>%%  (todosiva) Forzando a totalizar todos los IVA así no existan productos gravados con ellos
+%<factnueve>%%  (G) Escribiendo una letra ‘G’ en los ítems gravados con IVA general así sea el único gravamen a facturar
+%<factocho>%%  (siniva) Sin IVA
+%<factnueve|factdiez>%%  (electro) Con descuento en IVA al pagar por medios electrónicos
+%<factdos>%%  (unafirma) Sólo la firma del emisor
+%<facttres>%%  (sinfirmas) Sin firmas
+%<factdiez>%%  (vencimiento) Con fecha de vencimiento explícita así no haya crédito
 %
-%<factsiete>%%  Cambiando la geometría del papel de la factura (\GeometriaFactura),
-%<repdos>%%  Cambiando la geometría del papel del reporte (\GeometriaReporte),
-%<prefac|cotiza>%%  Con el fondo de la imprenta agregado (\FondoFactura),
-%<repuno>%%  Especificamos el fondo (membrete) del reporte, sólo para la primera página (\FondoReporte),
-%<repdos>%%  Especificamos el fondo (membrete) del reporte para todas las páginas (\FondoReporte*),
-%<reptres>%%  Sin especificar fondo de reporte,
-%<repuno>%%  Estableciendo un margen superior distinto para la primera página del reporte por presencia de membrete (\InicioReporte),
-%<repuno|reptres>%%  Establecemos el título del reporte sin que salga en las cabeceras (\TituloReporte),
-%<repdos>%%  Establecemos el título del reporte para que salga en las cabeceras (\TituloReporte*),
-%<reptres>%%  Personalizamos la información de la cabecera del reporte y mostramos el nombre del proveedor allí (\InfoPagina),
-%<reptres>%%  Cambiamos el estilo de página para que la información del reporte aparezca como pie de página (\EstiloPagReporte),
-%<cotiza>%%  Agregando la firma escaneada en la factura, es decir, en la cotización (\FirmaFactura),
-%<repdos>%%  Agregando la firma escaneada en el reporte (\FirmaReporte),
-%<reptres>%%  Agregando en el reporte la línea para firmar a mano (\FirmaReporte),
+%<factocho>%%  (csv) Escribe un archivo CSV con la información numérica de la factura
+%<beispiel>%%  (nospanish) Sin cargar babel en castellano, ‘lmodern’ ni la codificación T1 para la tipografías
 %
-%<factdos|facttres|factsiete>%%  Alterando la separación mínima vertical entre los elementos (\SepElementos),
-%<factdos|facttres|factsiete>%%  Alterando la separación horizontal en el encabezado y la distancia desde el contorno hasta el texto (\SepEncabez),
-%<factdos|factcuatro>%%  Agregando una separación extra entre los ítems en la factura (\SepItemsExtra),
-%<factdos|factsiete>%%  Alterando la la distancia desde el contorno hasta el texto en la descripción (\SepDescrip),
-%<factsiete>%%  Alterando la separación horizontal y vertical entre los totales en el modo de filas (\SepFilas),
-%<facttres|factsiete>%%  Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra (\LineaEncabez),
-%<factdos|factsiete>%%  Alterando la línea de la descripción, la curvatura en la esquina y la sombra (\LineaDescrip),
-%<factsiete>%%  Alterando la longitud de las líneas para firmar y su grosor (\LineaFirmas),
-%<factsiete>%%  Alterando la posición de la fecha, las firmas y de la denominación del documento (\PosFecha, \PosFirmas y \PosDenom),
-%<factcuatro|factocho>%%  Cambiando varias de las tipografías (\Letra***),
-%<factseis>%%  Redefiniendo el formato de la fecha (redefiniendo macros \@@Fecha y \@EstiloFecha),
-%<factsiete>%%  Redefiniendo el texto para la cantidad (redefiniendo macro \@@Cantidad),
+%<factdos|factcuatro>%%  Usando \Nombre y \CI en lugar de \RazonSocial y \RIF
+%<factdos|factcuatro|reptres>%%  Sin especificar la persona de contacto
+%<factcinco|factseis>%%  Sin especificar el teléfono del cliente
+%<factcuatro|factseis>%%  Sin especificar el e-mail del cliente
+%<factcinco|repuno>%%  (\Emisor) Especificando el nombre del emisor de la factura
+%<factcinco|factseis>%%  (\Conforme) Especificando el nombre de quien firma la copia de la factura como recibida
+%<repuno>%%  Sin especificar el proveedor, así toma el emisor de la factura como el nombre del proveedor
+%<repdos|reptres>%%  (\Proveedor) Especificando el nombre del proveedor para el encabezado del reporte
 %
-%<factdos|factcuatro>%%  Usando “\Nombre” y “\CI” en lugar de “\RazonSocial” y “\RIF”,
-%<factcuatro>%%  Sin especificar la persona de contacto,
-%<factcuatro>%%  Sin especificar el e-mail del cliente,
-%<factcinco|repuno>%%  Especificando el nombre del emisor de la factura (\Emisor),
-%<factcinco|factseis>%%  Especificando el nombre de quien firma la copia de la factura como recibida (\Conforme),
-%<repuno>%%  Sin especificar el proveedor, así toma el emisor de la factura como el nombre del proveedor,
+%<factocho|factnueve>%%  Sin especificar fecha para que tome la del día
 %
-%<facttres>%%  Con descuentos totales en porcentajes para exentos y gravables con IVA general (\DescuentoE y \DescuentoG),
-%<factocho>%%  Con descuentos totales en moneda aplicables por igual a todos los tipos de elementos existentes (\Descuento***),
-%<prefac>%%  Con descuentos totales en porcentaje aplicables por igual a todos los tipos de elementos existentes (\Descuento),
-%<factuno|factdos|factcinco|factocho>%%  Con resumen (\Resumen),
-%<facttres|factcuatro|prefac|cotiza|repuno|repdos>%%  Sin resumen,
+%<factcuatro>%%  (\Fecha*) Suministrando la fecha según formato de datetime2 sin alterar cómo sale escrita
+%<facttres>%%  (\FormatoFecha) Cambiando el separador de la fecha para que salga escrita dd/mm/yyyy
+%<factcinco>%%  (\FormatoFecha) Suministrando la fecha según el formato yyyymmdd pero que salga escrita dd.mm.yyyy
+%<factseis>%%  (\FormatoFecha) Cambiando el formato para que la fecha salga escrita en el formato default de datetime2 pero cambiando el separador yyyy/mm/dd
+%<factocho>%%  Redefiniendo el formato de la fecha (redefiniendo macros \@@Fecha y \@EstiloFecha)
 %
-%<factdos|factcuatro|factcinco>%%  Agregando un ítem sin precio (\ItemX),
-%<factdos|facttres>%%  Con artículos gravados con todos los IVA,
+%<factnueve>%%  (\Credito) Especificando la cantidad días para el crédito
+%<facttres>%%  (\DescuentoE y \DescuentoG) Con descuentos totales en porcentajes para exentos y gravables con IVA general
+%<factocho>%%  (\Descuento*) Con descuentos totales en moneda aplicables por igual a todos los tipos de elementos existentes
+%<prefac>%%  (\Descuento) Con descuentos totales en porcentaje aplicables por igual a todos los tipos de elementos existentes
 %
-%<factseis|repdos>%%  Con etiquetas y referencias,
+%<factsiete>%%  Redefiniendo el texto para la cantidad (redefiniendo macro \@@Cantidad)
 %
-%<!facttres&!reptres&!beispiel>%%  Con descripción larga (\Descripcion).
-%<facttres|reptres>%%  Sin descripción larga.
-%<beispiel>%%  Adaptado a otra legislación.
+%<factsiete>%%  (\GeometriaFactura) Cambiando la geometría del papel de la factura
+%<factdiez>%%  (\GeometriaReverso) Cambiando la geometría del reverso de la factura
+%<repdos>%%  (\GeometriaReporte) Cambiando la geometría del papel del reporte
+%<prefac|cotiza>%%  (\FondoFactura) Con el fondo de la imprenta agregado
+%<repuno>%%  (\FondoReporte) Especificamos el fondo o membrete del reporte, sólo para la primera página
+%<repdos>%%  (\FondoReporte*) Especificamos el fondo o membrete del reporte para todas las páginas
+%<reptres>%%  Sin especificar fondo de reporte
+%<repuno>%%  (\InicioReporte) Estableciendo un margen superior distinto para la primera página del reporte por presencia de membrete
+%<repuno|reptres>%%  (\TituloReporte) Establecemos el título del reporte sin que salga en las cabeceras
+%<repdos>%%  (\TituloReporte*) Establecemos el título del reporte para que salga en las cabeceras
+%<reptres>%%  (\InfoPagina) Personalizamos la información de la cabecera del reporte y mostramos el nombre del proveedor allí
+%<reptres>%%  (\EstiloPagReporte) Cambiamos el estilo de página para que la información del reporte aparezca como pie de página
+%<cotiza>%%  (\FirmaFactura) Agregando la firma escaneada en la factura, es decir, en la cotización
+%
+%<factdos|facttres|factsiete>%%  (\SepVertical) Alterando la separación mínima vertical entre los elementos
+%<factdos|factcinco>%%  (\SepDatosResumen) Alterando la separación horizontal entre los datos del cliente y el resumen
+%<factdos|facttres|factseis>%%  (\SepEncabezado) Alterando el margen interno desde el contorno hasta el texto en el encabezado
+%<factnueve>%%  (\SepNotaPrevia) Alterando el margen interno desde el contorno hasta el texto en la nota previa
+%<factdos|factcuatro>%%  (\SepItemsExtra) Agregando una separación extra entre los ítems en la factura
+%<factdos|factseis>%%  (\SepDescripcion) Alterando la distancia desde el contorno hasta el texto en la descripción
+%<factnueve>%%  (\SepCondiciones) Especificando la distancia desde el contorno hasta el texto de las condiciones, predeterminadamente sin contorno
+%<factsiete>%%  (\SepFilas) Alterando la separación horizontal y vertical entre los totales en el modo de filas
+%<facttres|factsiete>%%  (\LineaEncabezado) Alterando la línea de las cajas del encabezado, la curvatura en la esquina y la sombra
+%<factdiez>%%  (\LineaNotaPrevia) Alterando la línea de la nota previa, para desaparecerla
+%<factdos|factsiete>%%  (\LineaDescripcion) Alterando la línea de la descripción, la curvatura en la esquina y la sombra
+%<factnueve>%%  (\LineaCondiciones) Agregando el contorno para las condiciones que predeterminadamente está deshabilitado
+%<factsiete>%%  (\LineaFirmas) Alterando la longitud de las líneas para firmar y su grosor
+%<factsiete>%%  (\PosFecha, \PosFirmas y \PosDenom) Alterando la posición de la fecha, las firmas y de la denominación del documento
+%<factcuatro|factocho>%%  (\Letra***) Cambiando varias de las tipografías
+%
+%<!factcuatro&!reptres>%%  (\Condiciones) Con condiciones del documento
+%<factnueve>%%  Haciendo mención a las fechas y al crédito en las condiciones
+%<factcuatro>%%  Sin condiciones del documento
+%<factuno|factdos|factcinco|factocho>%%  (\Resumen) Con resumen
+%<facttres|factcuatro|factseis|factsiete|prefac|cotiza|repuno|repdos>%%  Sin resumen
+%<factcuatro|factnueve|factdiez>%%  (\NotaPrevia) Con nota previa
+%<factocho>%%  (\NotaInterna) Con nota interna
+%<factnueve|factdiez>%%  Con nota interna predeterminada por usar opción ‘electro’
+%<factnueve>%%  (\NotaExterna) Con nota externa
+%
+%<factdos|facttres>%%  Con artículos gravados con todos los IVA
+%<factseis|factsiete>%%  Escribimos un ítem cuya descripción ocupa más que una línea
+%<factdos|factcuatro|factcinco>%%  (\ItemX) Agregando un ítem sin precio
+%
+%<!facttres&!reptres&!beispiel>%%  (\Descripcion) Con descripción larga
+%<facttres|reptres>%%  Sin descripción larga
+%
+%<factseis|repdos>%%  Con etiquetas y referencias
+%
+%<repuno>%%  (\FirmaReporte) Agregando en el reporte la línea para firmar a mano
+%<factocho|repdos|reptres>%%  (\FirmaReporte) Agregando la firma escaneada en el reporte
 %%</desc>
 %%
 %<factuno>\documentclass{factura}
@@ -3721,6 +4372,7 @@
 %<!factuno>\documentclass[
 %<prefac|beispiel>prefactura,
 %<cotiza>cotizacion,
+%<repuno>sinreverso,
 %<repuno>conreporte,
 %<repdos|reptres>soloreporte,
 %<beispiel>nospanish,
@@ -3729,10 +4381,11 @@
 %<factdos|factseis>numitem,
 %<factdos|factsiete>descuentos,
 %<factsiete>subtotal,
+%<factcinco>iva,
 %<factcuatro|factcinco|factsiete>filas,
-%<factcuatro>centrado,
+%<factsiete>centrado,
 %<facttres>agrupado,
-%<factcinco|factseis>denom,
+%<factcinco|factseis|factsiete>denom,
 %<cotiza>sinnumero, % sin esta opción aparecerá el número de la cotización.
 %<cotiza>sintotales,
 %<factdos>dcu,
@@ -3739,29 +4392,31 @@
 %<factcuatro>duc,
 %<factdos|factseis>sinlineasve,
 %<facttres|factcuatro>sinlineasvi,
-%<factdos|facttres|factcuatro|factseis>% sinlineasv, % sin ninguna línea vertical
+%<factdiez>sinlineasv,
 %<factcuatro>sinlineashi,
 %<factseis>sinlineashe,
-%<factcuatro|factseis>% sinlineash, % sin ninguna línea horizontal
+%<factdiez>sinlineash,
 %<facttres|factcinco>conlineasha,
 %<factcinco|factocho>sinexpandir,
-%<facttres|factcuatro|prefac>exparriba,
+%<facttres|factcuatro|prefac>expandecuadro,
 %<facttres|prefac>linea,
 %<facttres>impdesc,
 %<factdos>centradesc,
 %<factsiete>sinmarcas,
 %<factcinco|factseis|factsiete>todosiva,
-%<factseis>G,
+%<factnueve>G,
 %<factocho>siniva,
+%<factnueve|factdiez>electro,
 %<factdos>unafirma,
-%<prefac|cotiza>% dosfirmas, % para poner las dos firmas
-%<prefac>% unafirma, % para poner la firma del emisor
-%<cotiza>% sinfirmas, % para no poner firmas
+%<prefac|cotiza>% dosfirmas, % para poner las dos firmas.
+%<prefac>% unafirma, % para poner la firma del emisor.
+%<cotiza>% sinfirmas, % para no poner firmas.
 %<facttres>sinfirmas,
-%<factcuatro>sincondiciones,
-%<factseis>csv,
+%<factdiez>vencimiento,
+%<factocho>csv,
 %<!factuno>]{factura}
 
+\input{factura-ejemplo-aux.tex}% Se incluye para efectos del ejemplo, así tendremos disponible la macro \Ejemplo.
 \usepackage[utf8]{inputenc}
 %<beispiel>\usepackage[official]{eurosym}
 %<beispiel>\usepackage[ngerman]{babel}
@@ -3804,8 +4459,44 @@
 %<beispiel>\renewcommand{\@EstiloNumControl}{}
 %<beispiel>\makeatother
 
+%<factcinco|factseis|factsiete|cotiza|prefac|repuno|repdos|beispiel>\Num{1}
+%<prefac>% \NumControl{1001}
+%<prefac>% \NumSerieControl{9}
+%<!factdos&!factcuatro&!beispiel>\RazonSocial{Ayala San Vicente Usureros}
+%<factdos|factcuatro|beispiel>\Nombre{Jacinto de Ayala y San Vicente}
+%<!factdos&!factcuatro&!beispiel&!reptres>\RIF{Y-12.345.678-9}
+%<factdos|factcuatro|beispiel>\CI{V-987.654.321}
+%<!factdos&!factcuatro&!reptres&!beispiel>\Contacto{Jacinto de Ayala}
+%<!reptres>\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
+%<!factcinco&!factseis&!reptres>\Telefono{+58 (987) 654.32.10}
+%<!factcuatro&!factseis&!reptres>\Email{jacinto at ayala.sv}
+%<factcinco|repuno>\Emisor{Lázaro de la Vega}
+%<factcinco>\Conforme{\Contacto}
+%<factseis>\Conforme{Ramela San Vicente}
+%<repdos|reptres>\Proveedor{Lázaro de la Vega y San Román}
+
+%<factcinco>\FormatoFecha[yyyymmdd]{ddmmyyyy}{.}
+%<facttres>\FormatoFecha{ddmmyyyy}{/}
+%<factseis>\FormatoFecha{default}{/}
+%<!factcuatro&!factcinco&!factocho&!factnueve>\Fecha{06-11-2017}
+%<factocho|factnueve>% \Fecha{06-11-2017}
+%<factcuatro>\Fecha*{2017}{11}{06}
+%<factcinco>\Fecha{20171106}
+%<factsiete|factocho>
+%<factsiete|factocho>\makeatletter
+%<factocho> \renewcommand{\@@Fecha}{\slshape FECHA:}
+%<factocho> \renewcommand{\@EstiloFechas}{\@LetraFecha\bfseries\@@Fecha\space{\color{blue}\@Fecha}}
+%<factsiete> \renewcommand{\@@Cantidad}{Cant.}
+%<factsiete|factocho>\makeatother
+%<factnueve>\Credito{21}
+
+%<prefac>\Descuento{18}
+%<facttres>\DescuentoE{15}
+%<facttres>\DescuentoG{20}
+%<factocho>\Descuento*{300}
 %<factsiete>\GeometriaFactura{legalpaper,vmargin={5cm,5.5cm},hmargin={1cm,1cm},footskip=0pt,headsep=0pt,headheight=0pt}
-%<repdos>\GeometriaReporte{letterpaper,vmargin={4.4cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
+%<factdiez>\GeometriaReverso{vmargin={4cm,4cm},hmargin={4cm,4cm},footskip=0pt,headsep=0pt,headheight=0pt}
+%<repdos>\GeometriaReporte{vmargin={4.4cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
 %<prefac|cotiza|beispiel>\FondoFactura{factura-ejemplo-fondo}
 %<repuno>\FondoReporte{factura-ejemplo-membrete}
 %<repdos>\FondoReporte*{factura-ejemplo-membrete}
@@ -3812,7 +4503,7 @@
 %<repuno>\InicioReporte{2.2cm}
 %<repuno|reptres>\TituloReporte{El título del reporte}
 %<repdos>\TituloReporte*{El título del reporte}
-%<reptres>\InfoPagina{La cabecera o pie del reporte - \mostrar{@Proveedor}}
+%<reptres>\InfoPagina{La cabecera o pie del reporte - \Proveedor}
 %<repuno|reptres>% \EstiloPagReporte{soloabajo}
 %<repuno|reptres>% \EstiloPagReporte[soloabajo]{plain}
 %<repuno|reptres>% \EstiloPagReporte[empty]{plain}
@@ -3827,14 +4518,20 @@
 %<repuno|reptres>% \EstiloPagReporte[empty]{soloarriba}
 %<repuno|reptres>% \EstiloPagReporte{soloarriba}
 %<cotiza>\FirmaFactura{\includegraphics[width=5cm]{factura-ejemplo-firma.pdf}}[0pt][21pt]
-%<factdos|facttres|factsiete>\SepElementos{0.75cm}
-%<factdos|facttres|factsiete>\SepEncabez{1cm}{16pt}
-%<factdos|factcuatro>\SepItemsExtra{8pt}
-%<factdos|factsiete>\SepDescrip{16pt}
+%<factdos|facttres|factsiete>\SepVertical{0.75cm}
+%<factdos|factcinco>\SepDatosResumen{1cm}
+%<factdos|facttres|factseis>\SepEncabezado{16pt}
+%<factdos|factcuatro>\SepItemsExtra{5pt}
+%<factdos|factseis>\SepDescripcion{16pt}
+%<factnueve>\SepNotaPrevia{16pt}
 %<factsiete>\SepFilas{1cm}{10pt}
-%<facttres|factsiete>\LineaEncabez{1pt}{20pt}{3pt}
-%<factdos|factsiete>\LineaDescrip{1pt}{20pt}{3pt}
+%<factnueve>\SepCondiciones{16pt}
+%<facttres|factsiete>\LineaEncabezado{1pt}{20pt}{3pt}
+%<factdiez>\LineaNotaPrevia{0pt}
+%<factdos|factsiete>\LineaDescripcion{1pt}{20pt}{3pt}
+%<factnueve>\LineaCondiciones{0.4pt}{4pt}{3pt}
 %<factsiete>\LineaFirmas{6.5cm}{2pt}
+%<factsiete>% Puede usarse \PosFecha* o \PosDenom*, \PosControl* o \PosCondiciones* para que el texto se despliegue en la posición 'Y' dada pero hacia arriba y no hacia abajo. \PosFirmas no acepta eso.
 %<factsiete>\PosFecha{-0cm}{-1.5cm}
 %<factsiete>\PosFirmas{1cm}{1cm}{-3cm}
 %<factsiete>\PosDenom{-0cm}{4.3cm}
@@ -3847,46 +4544,27 @@
 %<factocho>\LetraTipoIVA{\fontsize{20}{30}\bfseries}
 %<factocho>\LetraTitTotales{\fontsize{20}{30}\slshape}
 %<factocho>\LetraNumTotales{\fontsize{20}{30}}
-%<factocho>\LetraTitCuadro{\fontsize{15}{20}}
+%<factocho>\LetraTitColumnas{\fontsize{15}{20}}
 %<factocho>\LetraTitTotal{\fontsize{20}{30}\bfseries\slshape}
 %<factocho>\LetraNumTotal{\fontsize{20}{30}\bfseries}
 %<factocho>\tabcolsep7pt
-%<factsiete>
-%<factseis|factsiete>\makeatletter
-%<factseis> \renewcommand{\@@Fecha}{\slshape FECHA:}
-%<factseis> \renewcommand{\@EstiloFecha}{\@LetraFecha\bfseries\@@Fecha\space{\color{blue}\@Fecha}}
-%<factsiete> \renewcommand{\@@Cantidad}{Cant.}
-%<factseis|factsiete>\makeatother
-%<!factuno&!factcinco>
-%<cotiza>% \Denom{PRESUPUESTO} % También podemos cambiar el nombre del documento
-\Fecha{06-11-2017}
-%<factcinco|factseis|cotiza|prefac|repuno|repdos|beispiel>\Num{1}
-%<!factdos&!factcuatro&!beispiel>\RazonSocial{Ayala San Vicente Usureros}
-%<factdos|factcuatro|beispiel>\Nombre{Jacinto de Ayala y San Vicente}
-%<!factdos&!factcuatro&!beispiel&!reptres>\RIF{Y-12.345.678-9}
-%<factdos|factcuatro|beispiel>\CI{V-987.654.321}
-%<!factdos&!factcuatro&!reptres&!beispiel>\Contacto{Jacinto de Ayala}
-%<!reptres>\Direccion{Av. Ayala, Galpón San Vicente, Sector Arauca, Apure, Venezuela}
-%<!reptres>\Telefono{+58 (987) 654.32.10}
-%<!factcuatro&!reptres>\Email{jacinto at ayala.sv}
-%<factcinco|repuno>\Emisor{Lázaro de la Vega}
-%<factcinco>\Conforme{\mostrar{@Contacto}}
-%<factseis>\Conforme{Ramela San Vicente}
-%<repdos|reptres>\Proveedor{Lázaro de la Vega y San Román}
-%<!factcuatro&!beispiel&!reptres>\Condiciones{Las condiciones del documento...}
+%<!factuno&!factcinco&!prefac&!reptres>
+%<cotiza>% \Denom{PRESUPUESTO} % También podemos cambiar el nombre del documento.
+%<!factcuatro&!factnueve&!beispiel&!reptres>\Condiciones{Las condiciones del documento...}
+%<factnueve>\Condiciones{La factura se emitió el \DTMusedate{FechaEmision} con crédito de \Credito{} dias, siendo su fecha de vencimiento el \DTMusedate{FechaVencimiento}.}
 %<beispiel>\Condiciones{Die Zahlungsbedingungen}
-%<prefac>\Descuento{18}
-%<facttres>\DescuentoE{15}
-%<facttres>\DescuentoG{20}
-%<factocho>\Descuento*{300}
 %<factuno|factdos|factcinco|factocho>\Resumen{El resumen opcional}
 %<beispiel>\Resumen{Zusammenfassung}
+%<factocho>\NotaInterna{LA NOTA INTERNA}
+%<factcuatro|factnueve|factdiez>\NotaPrevia{\hfill LA NOTA PREVIA}
+%<factnueve>\NotaExterna{LA NOTA EXTERNA}
 
 \begin{document}
 %<!reptres>
 %<!reptres>\begin{factura}
-%<!factdos&!factcinco&!factseis&!factsiete&!repdos&!reptres&!beispiel> \Item{1}{ítem con IVA general}{1000}
+%<!factdos&!factcinco&!factseis&!factsiete&!factdiez&!repdos&!reptres&!beispiel> \Item{1}{ítem con IVA general}{1000}
 %<factseis|repdos> \Item{2}{ítem con IVA general}{1000}\label{primeritem}
+%<factdiez>  \Item{1}{ítem con IVA general}{2000000}
 %<factuno|factcuatro|repdos> \Item{4}{otro ítem con IVA general}{100}
 %<factseis> \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}{1000}
 %<cotiza> \Item{1}{otro ítem con IVA general}{1100}
@@ -3895,7 +4573,7 @@
 %<facttres> \ItemA{1}{ítem con IVA adicional}{1000}
 %<facttres> \ItemE{1}{ítem exento de impuesto}{1000}
 %<factdos,factsiete> \Item{1}{ítem con IVA general, con descuento}{1000}{8}
-%<factsiete> \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}{1000}{20}
+%<factsiete|factocho> \Item{10}{otro ítem con IVA general (descripción larga para mostrar el cambio de línea)}[otro ítem con IVA general (esta descripción es sólo para el .csv)]{1000}{20}
 %<factdos> \ItemR{1}{ítem con IVA reducido, con descuento}{1000}{5}
 %<factdos> \ItemA{1}{ítem con IVA adicional, con descuento}{1000}{10}
 %<factdos> \ItemE{1}{ítem exento de impuesto, con descuento}{1000}
@@ -3908,23 +4586,36 @@
 %<beispiel> \ItemE{1}{Artikel mit kein MwSt}{100}
 %<!reptres>\end{factura}
 %<!facttres&!reptres>
-%<!facttres&!factseis&!reptres&!beispiel>\Descripcion{Descripción larga del servicio}
-%<factseis>\Descripcion{Descripción larga del servicio.
+%<!facttres&!factseis&!reptres&!beispiel>\Descripcion{La descripción larga}
+%<factseis>\Descripcion{
 %<factseis>
 %<beispiel>\Descripcion{Lange Beschreibung.}
-%<repuno|repdos|reptres|factcinco|factocho>
-%<repuno|repdos|reptres|factcinco|factocho>\begin{reporte}
-%<repuno|repdos|reptres|factcinco|factocho> El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
+%<factcinco|factocho|factnueve|factdiez|repuno|repdos|reptres>
+%<factnueve|factdiez|repuno>\begin{reverso}
+%<factnueve|factdiez|repuno>esquina superior izquierda del reverso\hfill esquina superior derecha del reverso\par
+%<factnueve|factdiez|repuno>\vfill
+%<factnueve|factdiez|repuno>esquina inferior izquierda del reverso\hfill esquina inferior derecha del reverso
+%<factnueve|factdiez|repuno>\end{reverso}
+%<repuno>
+%<factcinco|factocho|repuno|repdos|reptres>\begin{reporte}
+%<factcinco|factocho|repuno|repdos|reptres> El reporte - página 1\newpage El reporte - página 2 \newpage El reporte - página 3.
 %<repdos>
-%<factseis|repdos> En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, el descuento porcentual de ese artículo es \dctoref{primeritem}, dando un total de \Moneda\ptref{primeritem}. El IVA de este ítem es de \Moneda\numprint\AlicuotaG; luego se facturó otro artículo más, dando un total final de \Moneda\numprint\Total.
-%<factseis|repdos> % También podemos usar \dctoref{primeritem} para la referencia al descuento, y en cuanto a las totalizaciones: \BIE, \BIR, \BIA, \AlicuotaR, \AlicuotaA, \SubtG, \SubtE, \SubtR, \SubtA, \DescG, \DescE, \DescR, \DescA para los demás totales.
+%<factseis|repdos> En el artículo número \itemref{primeritem} se facturaron \cantref{primeritem} \descref{primeritem} por un valor de \Moneda\puref{primeritem} cada uno, dando un subtotal por este elemento de \Moneda\subtref{primeritem}; el descuento en ese artículo es del \dctoref{primeritem}\%, dando un total de \Moneda\ptref{primeritem}, y esta gravado con IVA de \ivaref{primeritem}\%.
+%<factseis|repdos>
+%<factseis|repdos> La base imponible total de esta factura es de \Moneda\numprint\BIG; el IVA es de \Moneda\numprint\AlicuotaG, el descuento presidencial en el IVA es de \Moneda\numprint\AlicuotaGDesc, y el total final es de \Moneda\numprint\Total.
+%<factseis|repdos>
+%<factseis|repdos> % Estas son todas las macros para las totalizaciones: \BIG, \BIR, \BIA, \BIE, \AlicuotaG, \AlicuotaGDesc, \AlicuotaR, \AlicuotaA, \SubtG, \SubtR, \SubtA, \SubtE, \DescG, \DescR, \DescA, \DescE.
 %<factseis>}
-%<repdos%<repdos|factcinco|factocho> \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
-%<reptres> \vspace{1.5cm}\FirmaReporte
-%<repuno|repdos|reptres|factcinco|factocho>\end{reporte}
+%<repuno> \vspace{1.5cm}\FirmaReporte
+%<factocho|repdos> \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]
+%<reptres> \FirmaReporte[\includegraphics[width=5cm]{factura-ejemplo-firma}][0pt][21pt]{el que firma}[5cm][0.5cm]
+%<factcinco|factocho|repuno|repdos|reptres>\end{reporte}
 
+%% Este es un comando auxiliar suministrado por factura-ejemplo-aux.tex para escribir el detalle del ejemplo en la última hoja.
+\Ejemplo
+
 \end{document}
-%</!class&!def&!firma&!fondo&!membrete&!batchfile>
+%</!class&!def&!firma&!fondo&!membrete&!aux&!batchfile>
 %<*firma>
 %% (PSTricks code generated with LaTeXDraw 2.0.8)
 %% (Compilar con XeLaTeX)
@@ -4071,6 +4762,42 @@
  \end{minipage}
 \end{document}
 %</fondo|membrete>
+%<*aux>
+%% Helper file; not to be compiled standalone, only to be included on examples.
+%% Archivo auxiliar; no para ser compilado sino para ser incluido en los ejemplos.
+%%
+\usepackage{xspace,catchfilebetweentags,regexpatch}
+\def\optcolor{\color{blue}}
+\def\macrocolor{\color{purple}}
+\makeatletter
+\catcode`\%=11
+\catcode`\|=14
+\newcommand{\Ejemplo}{|
+ \newpage
+ \ClearShipoutPictureBG
+ \newgeometry{vmargin={2cm,2cm},hmargin={2cm,2cm},footskip=0pt,headheight=0pt,headsep=0pt,footnotesep=0pt}|
+ \thispagestyle{empty}|
+ \catcode`\<=12
+ \catcode`\>=12
+ \CatchFileBetweenDelims{\DescEjemplo}{\jobname.tex}{<desc>}{</desc>}[\catcode37=11\catcode13=14\makeatletter]|
+ \catcode`\%=11
+ \makeatletter
+ \regexpatchcmd*{\DescEjemplo}{\cC.\cO[*]*}{\c{begingroup}\c{macrocolor}\c{ttfamily}\c{string}\0\c{endgroup}\c{xspace}}{}{}|
+ \regexpatchcmd*{\DescEjemplo}{(\()(\cL[a-zG]*)(\))}{(\c{begingroup}\c{optcolor}\c{ttfamily}\2\c{endgroup})}{}{}|
+ \xpatchcmd*{\DescEjemplo}{%% }{\item}{}{}|
+ \xpatchcmd*{\DescEjemplo}{%%}{}{}{}|
+ \makeatother
+ {\bfseries Descripci\'on de este ejemplo {\slshape \jobname.tex}:}
+ \begin{itemize}
+  \DescEjemplo
+ \end{itemize}
+ \catcode`\<=13
+ \catcode`\>=13
+ }
+\catcode`\%=14
+\catcode`\|=12
+\makeatother
+%</aux>
 %    \end{macrocode}
 % \Finale
 % \starttodo

Modified: trunk/Master/texmf-dist/source/latex/factura/factura.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/factura/factura.ins	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/source/latex/factura/factura.ins	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,15 +24,16 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 \input docstrip.tex
 \preamble
@@ -55,15 +56,16 @@
 
 This work consists of the files README and factura.dtx
 with its derived files factura.ins, factura.cls, factura.def,
-factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-and factura-beispiel-rechnung.tex.
+factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 
 \endpreamble
 \keepsilent
@@ -78,14 +80,16 @@
 \Msg{}
 \postamble
 \endpostamble
-\def\factuno{factura-ejemplo-factura1.tex}
-\def\factdos{factura-ejemplo-factura2.tex}
-\def\facttres{factura-ejemplo-factura3.tex}
-\def\factcuatro{factura-ejemplo-factura4.tex}
-\def\factcinco{factura-ejemplo-factura5.tex}
-\def\factseis{factura-ejemplo-factura6.tex}
-\def\factsiete{factura-ejemplo-factura7.tex}
-\def\factocho{factura-ejemplo-factura8.tex}
+\def\factuno{factura-ejemplo-factura01.tex}
+\def\factdos{factura-ejemplo-factura02.tex}
+\def\facttres{factura-ejemplo-factura03.tex}
+\def\factcuatro{factura-ejemplo-factura04.tex}
+\def\factcinco{factura-ejemplo-factura05.tex}
+\def\factseis{factura-ejemplo-factura06.tex}
+\def\factsiete{factura-ejemplo-factura07.tex}
+\def\factocho{factura-ejemplo-factura08.tex}
+\def\factnueve{factura-ejemplo-factura09.tex}
+\def\factdiez{factura-ejemplo-factura10.tex}
 \def\repuno{factura-ejemplo-reporte1.tex}
 \def\repdos{factura-ejemplo-reporte2.tex}
 \def\reptres{factura-ejemplo-reporte3.tex}
@@ -92,6 +96,7 @@
 \def\cotiza{factura-ejemplo-cotizacion.tex}
 \def\prefac{factura-ejemplo-prefactura.tex}
 \def\beispiel{factura-beispiel-rechnung.tex}
+\def\auxejemplo{factura-ejemplo-aux.tex}
 \def\firma{factura-ejemplo-firma.tex}
 \def\fondo{factura-ejemplo-fondo.tex}
 \def\membrete{factura-ejemplo-membrete.tex}
@@ -103,6 +108,8 @@
 \generate{\file{\factseis}{\from{\jobname.dtx}{factseis}}}
 \generate{\file{\factsiete}{\from{\jobname.dtx}{factsiete}}}
 \generate{\file{\factocho}{\from{\jobname.dtx}{factocho}}}
+\generate{\file{\factnueve}{\from{\jobname.dtx}{factnueve}}}
+\generate{\file{\factdiez}{\from{\jobname.dtx}{factdiez}}}
 \generate{\file{\repuno}{\from{\jobname.dtx}{repuno}}}
 \generate{\file{\repdos}{\from{\jobname.dtx}{repdos}}}
 \generate{\file{\reptres}{\from{\jobname.dtx}{reptres}}}
@@ -109,6 +116,7 @@
 \generate{\file{\cotiza}{\from{\jobname.dtx}{cotiza}}}
 \generate{\file{\prefac}{\from{\jobname.dtx}{prefac}}}
 \generate{\file{\beispiel}{\from{\jobname.dtx}{beispiel}}}
+\generate{\file{\auxejemplo}{\from{\jobname.dtx}{aux}}}
 \generate{\file{\firma}{\from{\jobname.dtx}{firma}}}
 \generate{\file{\fondo}{\from{\jobname.dtx}{fondo}}}
 \generate{\file{\membrete}{\from{\jobname.dtx}{membrete}}}
@@ -129,6 +137,7 @@
 \Msg{  xelatex factura-ejemplo-firma.tex}
 \Msg{}
 \Msg{Also compile all other examples and recompile \jobname.dtx.}
+\Msg{(factura-ejemplo-aux.tex is not an example!)}
 \Msg{}
 \Msg{To manual update index and changelog, type}
 \Msg{  makeindex -s gind.ist -o \jobname.ind \jobname.idx}

Modified: trunk/Master/texmf-dist/tex/latex/factura/factura.cls
===================================================================
--- trunk/Master/texmf-dist/tex/latex/factura/factura.cls	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/tex/latex/factura/factura.cls	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,44 +24,96 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 \NeedsTeXFormat{LaTeX2e}[1995/12/01]
 \ProvidesClass{factura}
-[2017/07/16 v3.02
+[2017/12/11 v3.40
 Clase para elaborar facturas legales
 en la República Bolivariana de Venezuela.
 ]
 
+\RequirePackage{etoolbox}%  'etoolbox' para los condicionales binarios y para \AtEndPreamble.
+
+%% Condicionales auxiliares que sólo pueden ser usados dentro de un grupo.
+\newbool{Electro}
+\newbool{Descuentos}
+\newbool{IVA}
+\newbool{Subtotal}
+\newbool{SinCantidad}
+\newbool{SinLineasVertInt}
+\newbool{SinLineasVertExt}
+\newbool{SinLineasHoriInt}
+\newbool{SinLineasHoriExt}
+\newbool{DCU}
+\newbool{DUC}
+\newbool{NumItem}
+\newbool{PrimeroDescripcion}
+\newbool{ExpAbajo}\booltrue{ExpAbajo}
+
+%% Condicionales auxiliares para la posición de los objetos fijos cuando son medidos desde la derecha, o desde abajo.
+\newbool{FechaXnegativo}
+\newbool{FechaYnegativo}
+\newbool{FechaYarriba}
+\newbool{CondYnegativo}% no hay CondXnegativo.
+\newbool{CondYarriba}
+\newbool{DenomXnegativo}
+\newbool{DenomYnegativo}
+\newbool{DenomYarriba}
+\newbool{ControlXnegativo}
+\newbool{ControlYnegativo}
+\newbool{ControlYarriba}
+\newbool{FirmasYnegativo}% no hay FirmasXnegativo; hay X_inicial y X_final para las firmas.
+
+%% Condicionales relativos a opciones de la clase.
 \newif\if at prefactura
 \newif\if at cotizacion
-\newif\if at spanish \@spanishtrue
-\newif\if at ivaexpresado \@ivaexpresadotrue
+\newif\if at nospanish
+\newif\if at sinivaexpresado
 \newif\if at todosiva
-\newif\if at confirmas \@confirmastrue
-\newif\if at unafirma \@unafirmafalse
-\newif\if at concondiciones \@concondicionestrue
+\newif\if at sinfirmas
+\newif\if at unafirma
 \newif\if at filas
 \newif\if at agrupado
 \newif\if at centrado
 \newif\if at descuentos
 \newif\if at denom
+\newif\if at vencimiento
 \newif\if at sinnumero
 \newif\if at sintotales
 \newif\if at conlineasha
 \newif\if at linea
-\newif\if at lineacompleta
-\newif\if at lineahastatotal
-\newif\if at lineadesdeinicio
 \newif\if at G
+\newif\if at csv
+\newif\if at cdu \@cdutrue
+\newif\if at dcu
+\newif\if at duc
+\newif\if at expandecuadro
+\newif\if at factura \@facturatrue
+\newif\if at reverso \@reversotrue
+\newif\if at reporte
+\newif\if at impdesc
+\newif\if at centradesc
+\newif\if at sinmarcas
+
+%% Condicionales auxiliares.
+\newif\if at FondoFactura
+\newif\if at FondoReporte
+\newif\if at FondoReporteStar
+\newif\if at Nombre
+\newif\if at PruebaRef
+\newif\if at LineaCompleta
+\newif\if at LineaHastaTotal
+\newif\if at LineaDesdeInicio
 \newif\if at BIR
 \newif\if at BIA
 \newif\if at Exento
@@ -73,85 +125,135 @@
 \newif\if at DescRnum
 \newif\if at DescAnum
 \newif\if at DescEnum
-\newif\if at Descuentos
-\newif\if at csv
-\newif\if at cdu \@cdutrue
-\newif\if at dcu
-\newif\if at duc
-\newif\if at exparriba
-\newif\if at fondofactura
-\newif\if at fondoreporte
-\newif\if at fondoreportestar
-\newif\if at factura \@facturatrue
-\newif\if at reporte
-\newif\if at nombre
-\newif\if at pagado
-\newif\if at impdesc
-\newif\if at centradesc
-\newif\if at sinmarcas
-\newif\if at pruebaref
+\newif\if at DescuentoTotal
 
-\RequirePackage{etoolbox}%  'etoolbox' para los condicionales binarios.
+%% Longitudes para uso interno.
+\newlength{\@TamDatos}
+\newlength{\@TamResumen}
+\newlength{\@TamFinalEncabezado}
+\newlength{\@TamLineaFirmas}
+\newlength{\@TamNumItem}
+\newlength{\@TamCantidad}
+\newlength{\@TamPrecioU}
+\newlength{\@TamPrecioS}
+\newlength{\@TamDescuento}
+\newlength{\@TamIVA}
+\newlength{\@TamPrecioT}
+\newlength{\@GrosorLineaFirmas}
+\newlength{\@GrosorLineaEncabezado}
+\newlength{\@GrosorLineaNotaPrevia}
+\newlength{\@GrosorLineaDescripcion}
+\newlength{\@GrosorLineaCondiciones}
+\newlength{\@GrosorLineaInfoPag}
+\newlength{\@EsquinaLineaEncabezado}
+\newlength{\@EsquinaLineaNotaPrevia}
+\newlength{\@EsquinaLineaDescripcion}
+\newlength{\@EsquinaLineaCondiciones}
+\newlength{\@SombraEncabezado}
+\newlength{\@SombraNotaPrevia}
+\newlength{\@SombraDescripcion}
+\newlength{\@SombraCondiciones}
+\newlength{\@LineaNodoXo}
+\newlength{\@LineaNodoYo}
+\newlength{\@LineaNodoXf}
+\newlength{\@LineaNodoYf}
+\newlength{\@SepTotales}
+\newlength{\@PosFechaX}
+\newlength{\@PosFechaY}
+\newlength{\@PosDenomX}
+\newlength{\@PosDenomY}
+\newlength{\@PosFirmasXuno}
+\newlength{\@PosFirmasXdos}
+\newlength{\@PosFirmasY}
+\newlength{\@PosCondicionesX}
+\newlength{\@PosCondicionesY}
+\newlength{\@PosControlX}
+\newlength{\@PosControlY}
+\newlength{\@EspacioVacioInicial}
+\newlength{\@EspacioVacioFinal}
+\newlength{\@SeparaItemsExtra}
+\newlength{\@SeparaItemsExtraFinal}
+\newlength{\@SeparaInternaEncabezado}
+\newlength{\@SeparaInternaNotaPrevia}
+\newlength{\@SeparaInternaDescripcion}
+\newlength{\@SeparaInternaCondiciones}
+\newlength{\@SeparaDatosResumen}
+\newlength{\@SeparaVertical}
+\newlength{\@SeparaMinTotales}
+\newlength{\@SeparaFilas}
+\newlength{\@SeparaFinLineaDesc}
+\newlength{\@SeparaTelefonoEmail}
+\newlength{\@InicioReporte}
+\newlength{\@FirmaFacturaXcorr}
+\newlength{\@FirmaFacturaYcorr}
+\newlength{\@FirmaReporteXcorr}
+\newlength{\@FirmaReporteYcorr}
+\newlength{\@FirmaReporteTextPos}
+\newlength{\@FirmaReporteFirmaPos}
+\newlength{\@FirmaReporteTamLinea}
+\newlength{\@FirmaReportePosX}
+\newlength{\@FirmaReporteExcesoLinea}
+\newlength{\@TempDimen}
 
-\newbool{Descuentos}
-\newbool{Subtotal}
-\newbool{SinCantidad}
-\newbool{SinLineasVertInt}
-\newbool{SinLineasVertExt}
-\newbool{SinLineasHoriInt}
-\newbool{SinLineasHoriExt}
-\newbool{DCU}
-\newbool{DUC}
-\newbool{NumItem}
-\newbool{PrimeroDescrip}
-\newbool{ExpAbajo}\booltrue{ExpAbajo}
+%% Cajas para uso interno.
+\newbox{\@CajaDatos}
+\newbox{\@CajaResumen}
+\newbox{\@CajaFirmaEmisor}
+\newbox{\@CajaFirmas}
+\newbox{\@CajaFecha}
+\newbox{\@CajaDenom}
+\newbox{\@CajaControl}
+\newbox{\@CajaCond}
+\newbox{\@CajaEspacioVacio}
+\newbox{\@CajaPrueba}
+\newbox{\@CajaCaracterCR}
 
-%% Condicionales auxiliares para la posición de los objetos fijos cuando son medidos desde la derecha, o desde abajo.
-\newbool{FechaXnegativo}
-\newbool{FechaYnegativo}
-\newbool{CondYnegativo}% no hay CondXnegativo.
-\newbool{DenomXnegativo}
-\newbool{DenomYnegativo}
-\newbool{ControlXnegativo}
-\newbool{ControlYnegativo}
-\newbool{FirmasYnegativo}% no hay FirmasXnegativo; hay X_inicial y X_final para las firmas.
+%% Contadores.
+\newcounter{@IVANoGeneral}%  '0' con sólo IVA G, '1' cuando hay IVA R o IVA A, y '2' cuando hay ambos.
+\newcounter{NumItem}%  Número del ítem actual, para uso de algunas macros en el cuadro de la factura y para cuando se usa la opción 'numitem'.
+\newcount\AuxFecha
 
-\DeclareOption{prefactura}{\@prefacturatrue\@denomtrue\@confirmasfalse}%  La prefactura; con el diseño de la forma libre... para enviar por correo electrónico, fax o imprimir preliminarmente.
+\newcommand{\CLASSERROR}[1]{\ClassError{factura}{** #1. **}{}}
+\newcommand{\CLASSWARNING}[1]{\ClassWarning{factura}{** #1. **}{}}
+\newcommand{\CLASSINFO}[1]{\ClassInfo{factura}{** #1. **}{}}
+
+\DeclareOption{prefactura}{\@prefacturatrue\@denomtrue\@sinfirmastrue}%  La prefactura; con el diseño de la forma libre... para enviar por correo electrónico, fax o imprimir preliminarmente.
 \DeclareOption{cotizacion}{\@cotizaciontrue\@denomtrue\@unafirmatrue}%  Cambia la denominación a 'COTIZACIÓN' y no 'FACTURA'.
-\DeclareOption{nospanish}{\@spanishfalse}%  No carga babel en castellano ni la codificación T1 de las letras.
-\DeclareOption{sinfirmas}{\@confirmasfalse}%  No agrega los espacios para firmar.
-\DeclareOption{unafirma}{\@unafirmatrue\@confirmastrue}%  No agrega el espacio para que firme quien recibe.
-\DeclareOption{dosfirmas}{\@unafirmafalse\@confirmastrue}%  Pone las dos firmas para firmar.
+\DeclareOption{nospanish}{\@nospanishtrue}%  No carga babel en castellano ni la codificación T1 de las letras.
+\DeclareOption{sinfirmas}{\@sinfirmastrue}%  No agrega los espacios para firmar.
+\DeclareOption{unafirma}{\@unafirmatrue\@sinfirmasfalse}%  No agrega el espacio para que firme quien recibe.
+\DeclareOption{dosfirmas}{\@unafirmafalse\@sinfirmasfalse}%  Pone las dos firmas para firmar.
 \DeclareOption{descuentos}{\booltrue{Descuentos}\@descuentostrue}%  Para los descuentos individuales.
+\DeclareOption{iva}{\@impdesctrue\booltrue{IVA}}%  Para la columna del IVA.
 \DeclareOption{subtotal}{%  Para la columna extra del subtotal antes del descuento.
  \if at descuentos
   \booltrue{Subtotal}
  \else
-  \ClassWarning{factura}{La opción 'subtotal' no aplica sin descuentos individuales. Sin efecto opción 'subtotal'}{}
+  \CLASSWARNING{La opción 'subtotal' no aplica sin descuentos individuales. Sin efecto opción 'subtotal'}
  \fi}
-\DeclareOption{sincondiciones}{\@concondicionesfalse}%  No agrega el texto con las condiciones del documento.
 \DeclareOption{denom}{\@denomtrue}%  Agrega el texto con la denominación del documento, para las formas libres que no tienen el número de factura.
+\DeclareOption{vencimiento}{\@vencimientotrue}%  Escribe fecha de vencimiento, aún con facturas sin crédito.
 \DeclareOption{sinnumero}{\@sinnumerotrue\@denomtrue}%  Escribir el texto de la denominación del documento pero sin escribir el número.
 \DeclareOption{G}{\@Gtrue}%  Con esta opción sale la letra 'G' en los items con IVA general, y sale el porcentaje en la base imponible general.
 \DeclareOption{filas}{\@filastrue}%  Estilo de totalización en filas.
 \DeclareOption{sintotales}{\@sintotalestrue%  No escribe los totales al final, por ejemplo para cotizaciones de productos similares.
  \if at filas
-  \ClassWarning{factura}{La opción 'sintotales' no aplica para el modo de totalización en filas. Sin efecto opción 'filas'.}{}
+  \CLASSWARNING{La opción 'sintotales' no aplica para el modo de totalización en filas. Sin efecto opción 'filas'}
   \@filasfalse
  \fi
  \if at cotizacion
  \else
-  \ClassWarning{factura}{La opción 'sintotales' no debe usarse en facturas sino en cotizaciones. No es válida una factura sin totales.}{}
+  \CLASSWARNING{La opción 'sintotales' no debe usarse en facturas sino en cotizaciones. No es válida una factura sin totales}
  \fi}
 \DeclareOption{centrado}{%  Total y exento 'centrado'; sólo para estilo 'filas'
  \if at filas
   \@centradotrue
  \else
-  \ClassWarning{factura}{La opción 'centrado' no es compatible con el modo de totalización en columnas. Sin efecto opción 'centrado'.}{}
+  \CLASSWARNING{La opción 'centrado' no es compatible con el modo de totalización en columnas. Sin efecto opción 'centrado'}
  \fi}
 \DeclareOption{agrupado}{%  Agrupados los elementos totalizadores en el modo en columnas.
  \if at filas
-  \ClassWarning{factura}{La opción 'agrupado' no es compatible con el modo de totalización en filas. Sin efecto opción 'agrupado'.}{}
+  \CLASSWARNING{La opción 'agrupado' no es compatible con el modo de totalización en filas. Sin efecto opción 'agrupado'}
  \else
   \@agrupadotrue
  \fi}
@@ -162,22 +264,30 @@
 \DeclareOption{dcu}{%  Descripción, luego cantidad y luego precio unitario.
  \@dcutrue\@cdufalse\@ducfalse
  \booltrue{DCU}\boolfalse{DUC}
- \booltrue{PrimeroDescrip}}
+ \booltrue{PrimeroDescripcion}}
 \DeclareOption{duc}{%  Descripción, luego precio unitario y luego cantidad.
  \if at dcu
-  \ClassWarning{factura}{Las opciones 'duc' y 'dcu' no son compatibles. Sin efecto ambas opciones}{}
-  \boolfalse{PrimeroDescrip}\boolfalse{DCU}\@dcufalse\@cdutrue
+  \CLASSWARNING{Las opciones 'duc' y 'dcu' no son compatibles. Sin efecto ambas opciones}
+  \boolfalse{PrimeroDescripcion}\boolfalse{DCU}\@dcufalse\@cdutrue
  \else
   \@ductrue\@cdufalse\@dcufalse
   \booltrue{DUC}\boolfalse{DCU}
-  \booltrue{PrimeroDescrip}
+  \booltrue{PrimeroDescripcion}
  \fi}
 \DeclareOption{siniva}{\AtBeginDocument{\gdef\@ImpuestoG{0}\gdef\@ImpuestoR{0}\gdef\@ImpuestoA{0}}}%  No cobra IVA.
 \DeclareOption{todosiva}{\@todosivatrue}%  Con esta opción salen todos los IVA así valgan cero.
+\DeclareOption{electro}{%  Parche por el Decreto 3085 de Nikolài.
+ \booltrue{Electro}
+ \gdef\@NotaInterna{\@TextoDescuentoPresidencial}
+ \CLASSINFO{Se estableció el texto aclaratorio del descuento presidencial como 'nota interna'}
+ \if at filas
+  \CLASSWARNING{La opción 'electro' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}
+  \@filasfalse
+ \fi}
 \DeclareOption{sinivaexpresado}{%  Cuando no se cobra IVA y tampoco se quiere que aparezca la totalización del IVA.
- \@ivaexpresadofalse
+ \@sinivaexpresadotrue
  \if at filas
-  \ClassWarning{factura}{La opción 'sinivaexpresado' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}{}
+  \CLASSWARNING{La opción 'sinivaexpresado' no es compatible con la opción 'filas'. Sin efecto la opción 'filas'}
   \@filasfalse
  \else
   \AtBeginDocument{\gdef\@ImpuestoG{0}\gdef\@ImpuestoR{0}\gdef\@ImpuestoA{0}}
@@ -185,14 +295,13 @@
 \DeclareOption{sincantidad}{%  Para no poner el campo de la cantidad.
  \booltrue{SinCantidad}
  \if at dcu
-  \ClassWarning{factura}{La opción 'sincantidad' no es compatible con 'dcu' . Sin efecto opción 'dcu'}{}
-  \@dcufalse\@cdutrue\boolfalse{DCU}\boolfalse{PrimeroDescrip}
+  \CLASSWARNING{La opción 'sincantidad' no es compatible con 'dcu' . Sin efecto opción 'dcu'}
+  \@dcufalse\@cdutrue\boolfalse{DCU}\boolfalse{PrimeroDescripcion}
  \fi
  \if at duc
-  \ClassWarning{factura}{La opción 'sincantidad' no es compatible con 'duc' . Sin efecto opción 'duc'}{}
-  \@ducfalse\@cdutrue\boolfalse{DUC}\boolfalse{PrimeroDescrip}
+  \CLASSWARNING{La opción 'sincantidad' no es compatible con 'duc' . Sin efecto opción 'duc'}
+  \@ducfalse\@cdutrue\boolfalse{DUC}\boolfalse{PrimeroDescripcion}
  \fi}
-
 \DeclareOption{conlineasha}{\@conlineashatrue}%  Una línea horizontal para cada ítem, como las facturas a mano.
 \DeclareOption{sinlineasv}{%  Estilo 'sinlineasv'.
  \booltrue{SinLineasVertExt}\booltrue{SinLineasVertInt}}
@@ -202,16 +311,17 @@
  \booltrue{SinLineasHoriExt}\booltrue{SinLineasHoriInt}}
 \DeclareOption{sinlineashi}{\booltrue{SinLineasHoriInt}}%  Estilo 'sinlineashi'.
 \DeclareOption{sinlineashe}{\booltrue{SinLineasHoriExt}}%  Estilo 'sinlineashe'.
-\DeclareOption{exparriba}{\@exparribatrue\boolfalse{ExpAbajo}}%  Para rellenar con líneas en blanco de manera automática.
-\DeclareOption{sinexpandir}{\boolfalse{ExpAbajo}\@exparribafalse}%  No expande ninguna de las dos partes de la factura.
+\DeclareOption{expandecuadro}{\@expandecuadrotrue\boolfalse{ExpAbajo}}%  Para rellenar con líneas en blanco de manera automática.
+\DeclareOption{sinexpandir}{\boolfalse{ExpAbajo}\@expandecuadrofalse}%  No expande ninguna de las dos partes de la factura.
 \DeclareOption{linea}{%  Para la línea que protege el espacio en blanco.
- \if at exparriba
+ \if at expandecuadro
   \@lineatrue
  \else
-  \ClassWarning{factura}{La opción 'linea' requiere la opción 'exparriba'. Sin efecto opción 'linea'.}{}
+  \CLASSWARNING{La opción 'linea' requiere la opción 'expandecuadro'. Sin efecto opción 'linea'}
  \fi}
 \DeclareOption{conreporte}{\@reportetrue}%  Para imprimir factura y reporte.
-\DeclareOption{soloreporte}{\@reportetrue\@facturafalse}%  Para imprimir sólo el reporte.
+\DeclareOption{soloreporte}{\@reportetrue\@facturafalse\@reversofalse}%  Para imprimir sólo el reporte.
+\DeclareOption{sinreverso}{\@reversofalse}%  Para no imprimir el reverso de la factura.
 \DeclareOption{twoside}{\PassOptionsToClass{twoside}{article}}%  Opción 'twoside' de article para los reportes.
 \DeclareOption{csv}{%  Para la salida en modo csv también.
  \if at factura
@@ -218,7 +328,7 @@
   \@csvtrue
   \if at sintotales\else\AtEndDocument{\@EscribeTotalesEnCSV}\fi
  \else
-  \ClassWarning{factura}{La opción 'csv' require generar la factura. Sin efecto opción 'csv'.}{}
+  \CLASSWARNING{La opción 'csv' require generar la factura. Sin efecto opción 'csv'}
  \fi}
 
 \ProcessOptions\relax
@@ -228,6 +338,7 @@
 \RequirePackage{xparse}%  Algunos comandos los definimos con \NewDocumentCommand.
 \RequirePackage[absolute]{textpos}%  Es necesario 'textpos' para colocar texto en ubicaciones arbitrarias.
 \RequirePackage{geometry}%  'geometry' para ajustar todos los márgenes.
+\RequirePackage{eso-pic}%  Para el comando \AddToShipoutPicture.
 \RequirePackage{xstring}%  Lo usamos sólo para tomar el menos al principio de una longitud.
 \RequirePackage{calc}%  'calc' para hacer aritmética con las dimensiones.
 \RequirePackage{fp-upn}%  Fundamental el paquete 'fp-upn' para todos los cálculos.
@@ -237,71 +348,114 @@
 \RequirePackage{tabularx}%  Con 'tabularx' hacemos la tabla.
 \RequirePackage{environ}%  Con 'environ' podemos usar tabularx dentro del ambiente de la factura y escribir texto en el enddef.
 \RequirePackage{fancyhdr}%  Las cabeceras fancy; así se use solamente en reporte, hay que cargarlo siempre.
+\RequirePackage[calc]{datetime2}%  Para calcular la fecha del vencimiento del crédito.
 
-\AtBeginDocument{%  Da error si algún campo necesario no está definido.
+%% Gracias a Alan Munn y a wipet (Thanks to Alan Munn and wipet).
+%% (https://tex.stackexchange.com/questions/396363/input-a-date-to-datetime2-in-a-format-different-than-iso)
+\def\DTMsavedatex#1#2{%
+ \expandafter \ifx \csname f=\DTMinformat\endcsname \relax
+  \CLASSERROR{\string\DTMsavedatex: formato "\DTMinformat" desconocido}%
+ \else
+  \csname f=\DTMinformat\expandafter\endcsname#2&{#1}%
+ \fi
+}
+\def\DTMfdef#1{\expandafter\def\csname f=#1\endcsname}
+\def\DTMs#1#2{\DTMsavedate{#2}{#1}}
+\DTMfdef{yyyy-mm-dd}#1-#2-#3&{\DTMs{#1-#2-#3}}
+\DTMfdef{yyyy.mm.dd}#1.#2.#3&{\DTMs{#1-#2-#3}}
+\DTMfdef{yyyymmdd}#1#2#3#4#5#6#7#8&{\DTMs{#1#2#3#4-#5#6-#7#8}}
+\DTMfdef{dd-mm-yyyy}#1-#2-#3&{\DTMs{#3-#2-#1}}
+\DTMfdef{dd.mm.yyyy}#1.#2.#3&{\DTMs{#3-#2-#1}}
+\DTMfdef{ddmmyyyy}#1#2#3#4#5#6#7#8&{\DTMs{#5#6#7#8-#3#4-#1#2}}
+\DTMfdef{mm-dd-yyyy}#1-#2-#3&{\DTMs{#3-#1-#2}}
+
+\AtEndPreamble{\DTMsetstyle{\@FormatoFecha}\DTMsetup{datesep=\@FechaSeparadores}\gdef\DTMinformat{\@FormatoFechaEntrada}}
+\def\@Fecha{\DTMusedate{FechaEmision}}
+
+%% Una vez definido todo en el preámbulo los comandos usados para definir campos servirán para mostrar el campo que se definió con ese comando.
+\AtEndPreamble{%
+ \def\RazonSocial{\@RazonSocial}
+ \let\Nombre\RazonSocial
+ \def\RIF{\@RIF}
+ \let\CI\RIF
+ \def\Direccion{\@Direccion}
+ \def\Telefono{\@Telefono}
+ \def\Email{\@Email}
+ \def\Contacto{\@Contacto}
+ \def\Emisor{\@Emisor}
+ \def\Conforme{\@Conforme}
+ \def\Proveedor{\@Proveedor}
+ \def\Credito{\@Credito}
+ \def\Num{\@Num}
+ \def\NumSerieControl{\@NumSerieControl}
+ \def\NumControl{\@NumControl}
+ \def\Condiciones{\@Condiciones}
+ \def\Resumen{\@Resumen}
+ \def\NotaPrevia{\@NotaPrevia}
+ \def\NotaInterna{\@NotaInterna}
+ \def\NotaExterna{\@NotaExterna}}
+
+\AtBeginDocument{%  Efectúa distintos chequeos.
  \if at reporte
-  \ifdefvoid{\@Fecha}{\ClassWarning{factura}{** No se especificó una fecha. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras **}{}}{}%
-  \ifdefvoid{\@Num}{\ClassWarning{factura}{** No se especificó el número de la factura. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras **}{}}{}%
+  \ifdefvoid{\@Num}{\CLASSWARNING{No se especificó el número de la factura. Puede dar error si el título del reporte no se especifica que aparezca en las cabeceras}}{}%
   \ifdefvoid{\@Proveedor}{%
    \ifdefvoid{\@Emisor}
-    {\ClassError{factura}{** Hay que definir el nombre del proveedor cuando se emite un reporte **}{}}%
-    {\ClassWarning{factura}{** Se toma el emisor como el proveedor por no haberse especificado este último **}{}%
+    {\CLASSERROR{Hay que definir el nombre del proveedor cuando se emite un reporte}}%
+    {\CLASSWARNING{Se toma el emisor como el proveedor por no haberse especificado este último}%
     \let\@Proveedor=\@Emisor}}
    {}%
  \fi
- \ifdefvoid{\@RazonSocial}{\ClassError{factura}{** Hay que definir la razón social **}{}}{}%
+ \ifdefvoid{\@RazonSocial}{\CLASSERROR{Hay que definir la razón social}}{}%
  \if at factura
-  \ifdefvoid{\@RIF}{\ClassError{factura}{** Hay que definir el R.I.F. **}{}}{}%
-  \ifdefvoid{\@Direccion}{\ClassError{factura}{** Hay que definir la dirección fiscal **}{}}{}%
-  \ifdefvoid{\@Telefono}{\ClassError{factura}{** Hay que definir un número telefónico **}{}}{}%
-  \ifdefvoid{\@Email}{\ClassWarning{factura}{** Pudiera definirse una dirección de correo electrónico **}{}}{}%
-  \ifdefvoid{\@Fecha}{\ClassError{factura}{** Hay que definir la fecha de emisión **}{}}{}%
-  \if at concondiciones
-   \ifdefvoid{\@Condiciones}{\ClassError{factura}{** Hay que definir las condiciones del documento o usar la opción 'sincondiciones' **}{}}{}%
-  \fi
+  \ifdefvoid{\@RIF}{\CLASSERROR{Hay que definir el R.I.F}}{}%
+  \ifdefvoid{\@Direccion}{\CLASSERROR{Hay que definir la dirección fiscal}}{}%
+  \ifdefvoid{\@Telefono}{\CLASSWARNING{Pudiera definirse un número telefónico}}{}%
+  \ifdefvoid{\@Email}{\CLASSWARNING{Pudiera definirse una dirección de correo electrónico}}{}%
+  \ifdefvoid{\@Condiciones}{\CLASSWARNING{Pudieran definirse las condiciones del documento}}{}%
+  \DTMifsaveddate{FechaEmision}{}{%
+   \CLASSWARNING{No se especificó fecha. Asumiendo la fecha de hoy}%
+   \DTMsavedate{FechaEmision}{\the\year-\the\month-\the\day}}%
   \if at cotizacion
-   \ifdefvoid{\@FondoFactura}{\ClassWarning{factura}{** En la opción para cotizacion se recomienda agregar el fondo **}{}}{}%
+   \ifdefvoid{\@FondoFactura}{\CLASSWARNING{En la opción para cotizacion se recomienda agregar el fondo}}{}%
   \fi
   \if at prefactura
-   \ifdefvoid{\@FondoFactura}{\ClassWarning{factura}{** En la opción para prefactura se recomienda agregar el fondo **}{}}{}%
+   \ifdefvoid{\@FondoFactura}{\CLASSWARNING{En la opción para prefactura se recomienda agregar el fondo}}{}%
   \fi
   \if at sinnumero
    \if at cotizacion
    \else
-    \ClassError{factura}{** La opción para no poner el número sólo es compatible con las cotizaciones **}{}%
+    \CLASSERROR{La opción para no poner el número sólo es compatible con las cotizaciones}%
    \fi
   \fi
   \if at denom
    \if at sinnumero
    \else
-    \ifdefvoid{\@Num}{\ClassError{factura}{** Hay que definir el número de la factura **}{}}{}%
+    \ifdefvoid{\@Num}{\CLASSERROR{Hay que definir el número de la factura}}{}%
    \fi
   \fi
  \fi
- \ifdefvoid{\@Contacto}{\if at nombre\else\ClassWarning{factura}{** Pudiera definirse una persona de contacto **}{}\fi}{}%
+ \ifdefvoid{\@Contacto}{\if at Nombre\else\CLASSWARNING{Pudiera definirse una persona de contacto}\fi}{}%
 }
 
 %% Escribimos el total como comentario en el .log, y avisamos cuando la fecha no sea la de hoy.
 \AtEndDocument{%
- \edef\@Hoy{\ifnum\number\day<10 0\fi\the\day-\ifnum\number\month<10 0\fi\the\month-\the\year}%
- \ifx\undefined\@Fecha
+ \DTMsavenow{Ahora}%
+ \DTMsaveddatediff{FechaEmision}{Ahora}{\AuxFecha}%
+ \ifnum\AuxFecha=0%
  \else
-  \edef\@Fecha{\@Fecha}%
-  \ifx\@Fecha\@Hoy
-  \else
-   \ClassWarning{factura}{** Fecha del documento\space \@Fecha\space distinta de la fecha de hoy. **}{}%
-  \fi
+  \CLASSWARNING{Fecha del documento \@Fecha\space distinta de la fecha de hoy}%
  \fi
  \if at sintotales
  \else
-  \if at factura\ClassInfo{factura}{\@@Total: \space\space\space \Moneda \Total}{}\fi
+  \if at factura\CLASSINFO{\@@Total: \space\space\space \Moneda \Total}\fi
  \fi}
 
-%% La geometría en formato de factura y de reporte.
-%% El margen superior está definido desde el encabezado con los datos del cliente.
-%% El margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
-%% Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
+%% La geometría para la factura, su reverso, y el reporte.
+%% Para la factura, el margen superior está definido desde el encabezado con los datos del cliente;
+%%  el margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
+%%  Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
 \def\GeometriaFactura#1{\gdef\@GeometriaFactura{#1}}
+\def\GeometriaReverso#1{\gdef\@GeometriaReverso{#1}}
 \def\GeometriaReporte#1{\gdef\@GeometriaReporte{#1}}
 
 %% Se utiliza '\@Impuesto' como el factor del impuesto, el cual viene predefinido en '\@Alicuota'.
@@ -319,10 +473,16 @@
 \def\@DescuentoAnum{0}
 \def\@DescuentoEnum{0}
 
-%% \Fecha, \RazonSocial, \Nombre, \RIF, \CI, \Contacto, \Dirección, \Telefono, \Email, \Emisor, \Proveedor.
-\def\Fecha#1{\gdef\@Fecha{#1}}
+%% \Fecha, \FormatoFecha, \Credito, \RazonSocial, \Nombre, \RIF, \CI, \Contacto, \Dirección, \Telefono, \Email, \Conforme, \Emisor, \Proveedor.
+\NewDocumentCommand{\Fecha}{s m g g}{%
+ \IfBooleanTF{#1}
+  {\AtEndPreamble{\DTMsavedate{FechaEmision}{#2-#3-#4}}}
+  {\AtEndPreamble{\DTMsavedatex{FechaEmision}{#2}}}}
+\NewDocumentCommand{\FormatoFecha}{o g g}{%
+ \IfValueT{#1}{\gdef\@FormatoFechaEntrada{#1}}\IfValueT{#2}{\gdef\@FormatoFecha{#2}}\IfValueT{#3}{\gdef\@FechaSeparadores{#3}}}
+\def\Credito#1{\gdef\@Credito{#1}\@vencimientotrue}
 \def\RazonSocial#1{\gdef\@RazonSocial{#1}}
-\def\Nombre#1{\gdef\@RazonSocial{#1}\@nombretrue}
+\def\Nombre#1{\gdef\@RazonSocial{#1}\@Nombretrue}
 \def\RIF#1{\gdef\@RIF{#1}}
 \def\CI#1{\gdef\@RIF{#1}\let\@@RIF\@@CI\let\@CI\@RIF}
 \def\Contacto#1{\gdef\@Contacto{#1}}
@@ -340,23 +500,23 @@
   \gdef\@DescuentoGnum{#2}\gdef\@DescuentoRnum{#2}\gdef\@DescuentoAnum{#2}\gdef\@DescuentoEnum{#2}}
   {\@DescGnumfalse\@DescRnumfalse\@DescAnumfalse\@DescEnumfalse
   \gdef\@DescuentoGporc{#2}\gdef\@DescuentoRporc{#2}\gdef\@DescuentoAporc{#2}\gdef\@DescuentoEporc{#2}}%
- \@DescGtrue\@DescRtrue\@DescAtrue\@DescEtrue\@Descuentostrue}
+ \@DescGtrue\@DescRtrue\@DescAtrue\@DescEtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoG}{s m}{%
  \IfBooleanTF{#1}{\@DescGnumtrue\gdef\@DescuentoGnum{#2}}{\@DescGnumfalse\gdef\@DescuentoGporc{#2}}%
- \@DescGtrue\@Descuentostrue}
+ \@DescGtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoR}{s m}{%
  \IfBooleanTF{#1}{\@DescRnumtrue\gdef\@DescuentoRnum{#2}}{\@DescRnumfalse\gdef\@DescuentoRporc{#2}}%
- \@DescRtrue\@Descuentostrue}
+ \@DescRtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoA}{s m}{%
  \IfBooleanTF{#1}{\@DescAnumtrue\gdef\@DescuentoAnum{#2}}{\@DescAnumfalse\gdef\@DescuentoAporc{#2}}%
- \@DescAtrue\@Descuentostrue}
+ \@DescAtrue\@DescuentoTotaltrue}
 
 \NewDocumentCommand{\DescuentoE}{s m}{%
  \IfBooleanTF{#1}{\@DescEnumtrue\gdef\@DescuentoEnum{#2}}{\@DescEnumfalse\gdef\@DescuentoEporc{#2}}%
- \@DescEtrue\@Descuentostrue}
+ \@DescEtrue\@DescuentoTotaltrue}
 
 \def\Denom#1{\gdef\@Denominacion{#1}}%  La denominación puede ser 'FACTURA', 'COTIZACIÓN' u otra. Se predetermina una de estas dos según las opciones de la clase.
 
@@ -365,7 +525,7 @@
 \def\NumControl#1{\gdef\@NumControl{\nplpadding{\@DigitosNumeracion}\npthousandsep{}\numprint{#1}}}%  Si el número de control no se especifica, toma el mismo que el de la factura
 \def\NumSerieControl#1{\gdef\@NumSerieControl{#1}}%  Si el número de serie de control no se especifica, toma '00'.
 
-%% Información de página: cabeceras de páginas o piés de página.
+%% Información de página: cabeceras de páginas o pies de página.
 \def\InfoPagina#1{\gdef\@InfoPagina{#1}}
 
 %% Texto que esclarece las condiciones del documento.
@@ -374,7 +534,21 @@
 %% Resumen opcional que va a la derecha de los datos del cliente.
 \NewDocumentCommand{\Resumen}{+m}{\gdef\@Resumen{#1}}
 
+\NewDocumentCommand{\NotaPrevia}{+m}{\gdef\@NotaPrevia{#1}}
+
+%% Nota interna al cuadro de la factura y nota externa a él (que sale antes de \Descripcion).
+\NewDocumentCommand{\NotaInterna}{+m}{%
+ \ifdefvoid{\@NotaInterna}{}{\CLASSWARNING{Se sobreescribió la nota interna automática aclaratoria del descuento presidencial}}%
+ \gdef\@NotaInterna{#1}}
+\NewDocumentCommand{\NotaExterna}{+m}{\gdef\@NotaExterna{#1}}
+
 \AtBeginDocument{%
+ % El cálculo de la fecha de vencimiento para cuando haya crédito o fecha de vencimiento explícita.
+ \ifdefvoid{\@Credito}
+  {\gdef\@FechaVencimiento{\DTMusedate{FechaEmision}}}
+  {\DTMsaveddateoffsettojulianday{FechaEmision}{\@Credito}{\AuxFecha}%
+   \DTMsavejulianday{FechaVencimiento}{\number\AuxFecha}%
+   \gdef\@FechaVencimiento{\DTMusedate{FechaVencimiento}}}%
  \ifx\@undefined\@NumControl\let\@NumControl\@Num\fi
  \ifx\@undefined\@NumSerieControl\gdef\@NumSerieControl{00}\fi
  % Establecemos los porcentajes de las alícuotas, y redondeamos los descuentos.
@@ -381,6 +555,7 @@
  \FPupn\@AlicuotaGporc{\@AlicuotaG{} 100 * \@DigitosPorc{} round clip}%
  \FPupn\@AlicuotaRporc{\@AlicuotaR{} 100 * \@DigitosPorc{} round clip}%
  \FPupn\@AlicuotaAporc{\@AlicuotaA{} 100 * \@DigitosPorc{} round clip}%
+ \FPset\@AlicuotaEporc{0}%
  \FPupn\@DescuentoGporc{\@DescuentoGporc{} \@DigitosPorc{} round clip}%
  \FPupn\@DescuentoRporc{\@DescuentoRporc{} \@DigitosPorc{} round clip}%
  \FPupn\@DescuentoAporc{\@DescuentoAporc{} \@DigitosPorc{} round clip}%
@@ -391,40 +566,44 @@
  \FPupn\@DescuentoEfactor{100 \@DescuentoEporc{} /}}
 
 %% Posiciones (X,Y) de los objetos: i) fecha, ii) denominación, iii) condiciones, iv) número de control, v) firmas.
-\def\PosFecha#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosFechaX}{-\templeng}\booltrue{FechaXnegativo}}
-  {\boolfalse{FechaXnegativo}\setlength{\@PosFechaX}{#1}}
+\NewDocumentCommand{\PosFecha}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{FechaYarriba}}{\boolfalse{FechaYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosFechaY}{-\templeng}\booltrue{FechaYnegativo}}
-  {\boolfalse{FechaYnegativo}\setlength{\@PosFechaY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosFechaX}{-\templeng}\booltrue{FechaXnegativo}}
+  {\boolfalse{FechaXnegativo}\setlength{\@PosFechaX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosFechaY}{-\templeng}\booltrue{FechaYnegativo}}
+  {\boolfalse{FechaYnegativo}\setlength{\@PosFechaY}{#3}}}
 
-\def\PosDenom#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosDenomX}{-\templeng}\booltrue{DenomXnegativo}}
-  {\boolfalse{DenomXnegativo}\setlength{\@PosDenomX}{#1}}
+\NewDocumentCommand{\PosDenom}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{DenomYarriba}}{\boolfalse{DenomYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosDenomY}{-\templeng}\booltrue{DenomYnegativo}}
-  {\boolfalse{DenomYnegativo}\setlength{\@PosDenomY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosDenomX}{-\templeng}\booltrue{DenomXnegativo}}
+  {\boolfalse{DenomXnegativo}\setlength{\@PosDenomX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosDenomY}{-\templeng}\booltrue{DenomYnegativo}}
+  {\boolfalse{DenomYnegativo}\setlength{\@PosDenomY}{#3}}}
 
-\def\PosControl#1#2{%
- \IfBeginWith{#1}{-}
-  {\StrBehind{#1}{-}[\templeng]\setlength{\@PosControlX}{-\templeng}\booltrue{ControlXnegativo}}
-  {\boolfalse{ControlXnegativo}\setlength{\@PosControlX}{#1}}
+\NewDocumentCommand{\PosControl}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{ControlYarriba}}{\boolfalse{ControlYarriba}}
  \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosControlY}{-\templeng}\booltrue{ControlYnegativo}}
-  {\boolfalse{ControlYnegativo}\setlength{\@PosControlY}{#2}}}
+  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosControlX}{-\templeng}\booltrue{ControlXnegativo}}
+  {\boolfalse{ControlXnegativo}\setlength{\@PosControlX}{#2}}
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosControlY}{-\templeng}\booltrue{ControlYnegativo}}
+  {\boolfalse{ControlYnegativo}\setlength{\@PosControlY}{#3}}}
 
-\def\PosCond#1#2{%
- \setlength{\@PosCondX}{#1}%
- \IfBeginWith{#2}{-}
-  {\StrBehind{#2}{-}[\templeng]\setlength{\@PosCondY}{-\templeng}\booltrue{CondYnegativo}}
-  {\boolfalse{CondYnegativo}\setlength{\@PosCondY}{#2}}}
-%% 'X' no acepta valores negativos en \PosCond.
+\NewDocumentCommand{\PosCondiciones}{s m m}{
+ \IfBooleanTF{#1}{\booltrue{CondYarriba}}{\boolfalse{CondYarriba}}
+ \setlength{\@PosCondicionesX}{#2}%
+ \IfBeginWith{#3}{-}
+  {\StrBehind{#3}{-}[\templeng]\setlength{\@PosCondicionesY}{-\templeng}\booltrue{CondYnegativo}}
+  {\boolfalse{CondYnegativo}\setlength{\@PosCondicionesY}{#3}}}
+%% 'X' no acepta valores negativos en \PosCondiciones.
 
-\def\PosFirmas#1#2#3{%
- \setlength{\@PosFirmasXuno}{#1}%
- \setlength{\@PosFirmasXdos}{#2}%
+\NewDocumentCommand{\PosFirmas}{m m m}{
+ \setlength{\@PosFirmasXuno}{#1}
+ \setlength{\@PosFirmasXdos}{#2}
  \IfBeginWith{#3}{-}
   {\StrBehind{#3}{-}[\templeng]\setlength{\@PosFirmasY}{-\templeng}\booltrue{FirmasYnegativo}}
   {\boolfalse{FirmasYnegativo}\setlength{\@PosFirmasY}{#3}}}
@@ -431,8 +610,8 @@
 %% La firma se define con un X_inicial, un X_final y un Y_inicial (Xo,Xf,Y)
 
 %% Tamaño y grosor de la línea de las firmas.
-\def\LineaFirmas#1#2{%
- \setlength{\@TamLineaFirmas}{#1}%
+\def\LineaFirmas#1#2{
+ \setlength{\@TamLineaFirmas}{#1}
  \setlength{\@GrosorLineaFirmas}{#2}}
 
 %% Separación mínima horizontal entre los totales en modo de filas y distancia vertical entre esas líneas, fija.
@@ -439,23 +618,53 @@
 \def\SepFilas#1#2{\setlength{\@SeparaMinTotales}{#1}\setlength{\@SeparaFilas}{#2}}
 
 %% Separación vertical entre los elementos de la factura (entre el encabezado y el cuadro de la 'factura', luego desde dicho cuadro hasta la descripción, o hasta los totales en modo de filas).
-\def\SepElementos#1{\setlength{\@SeparaElementos}{#1}}
+\def\SepVertical#1{\setlength{\@SeparaVertical}{#1}}
 
-%% Separación horizontal entre las cajas del encabezado y separación interna entre la línea y el texto.
-\def\SepEncabez#1#2{\setlength{\@SeparaEncabez}{#1}\setlength{\@SeparaInternaEncabez}{#2}}
+%% Separación horizontal entre la caja de los datos del cliente y la caja del resumen.
+\def\SepDatosResumen#1{\setlength{\@SeparaDatosResumen}{#1}}
 
+%% Separación horizontal interna entre la línea y el texto en los datos del cliente y en el resumen.
+\def\SepEncabezado#1{\setlength{\@SeparaInternaEncabezado}{#1}}
+
+%% Separación interna entre la línea y el texto de la nota previa.
+\def\SepNotaPrevia#1{\setlength{\@SeparaInternaNotaPrevia}{#1}}
+
 %% Separación extra entre los elementos en la factura.
 \def\SepItemsExtra#1{\setlength{\@SeparaItemsExtra}{#1}}
 
 %% Separación interna entre la línea y el texto de la descripción.
-\def\SepDescrip#1{\setlength{\@SeparaInternaDescrip}{#1}}
+\def\SepDescripcion#1{\setlength{\@SeparaInternaDescripcion}{#1}}
 
+\def\SepCondiciones#1{\setlength{\@SeparaInternaCondiciones}{#1}}
+
 %% Grosor de la línea de las cajas del encabezado, curvatura de la esquina y sombra.
-\def\LineaEncabez#1#2#3{\setlength{\@GrosorLineaEncabez}{#1}\setlength{\@EsquinaLineaEncabez}{#2}\setlength{\@SombraEncabez}{#3}}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\NewDocumentCommand{\LineaEncabezado}{m g g}{
+ \setlength{\@GrosorLineaEncabezado}{#1}
+ \IfValueT{#2}{\setlength{\@EsquinaLineaEncabezado}{#2}}
+ \IfValueT{#3}{\setlength{\@SombraEncabezado}{#3}}}
 
+%% Grosor de la línea de la nota previa, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\NewDocumentCommand{\LineaNotaPrevia}{m g g}{
+ \setlength{\@GrosorLineaNotaPrevia}{#1}
+ \IfValueT{#2}{\setlength{\@EsquinaLineaNotaPrevia}{#2}}
+ \IfValueT{#3}{\setlength{\@SombraNotaPrevia}{#3}}}
+
 %% Grosor de la línea de la descripción, curvatura de la esquina y sombra.
-\def\LineaDescrip#1#2#3{\setlength{\@GrosorLineaDescrip}{#1}\setlength{\@EsquinaLineaDescrip}{#2}\setlength{\@SombraDescrip}{#3}}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\NewDocumentCommand{\LineaDescripcion}{m g g}{
+ \setlength{\@GrosorLineaDescripcion}{#1}
+ \IfValueT{#2}{\setlength{\@EsquinaLineaDescripcion}{#2}}
+ \IfValueT{#3}{\setlength{\@SombraDescripcion}{#3}}}
 
+%% Grosor de la línea de las condiciones, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\NewDocumentCommand{\LineaCondiciones}{m g g}{
+ \setlength{\@GrosorLineaCondiciones}{#1}
+ \IfValueT{#2}{\setlength{\@EsquinaLineaCondiciones}{#2}}
+ \IfValueT{#3}{\setlength{\@SombraCondiciones}{#3}}}
+
 %% El espacio vertical que hay que avanzar sólo en la primera página del reporte antes de empezar a escribir sobre él. Usable cuando la primera página tiene un membrete y las demás no, es decir, cuando se usa \FondoReporte y no \FondoReporte*.
 \def\InicioReporte#1{\setlength{\@InicioReporte}{#1}}
 
@@ -463,8 +672,14 @@
 %% Esta es la letra de la descripción de los items; y el espacio \baselineskip de *toda* la tabla de la factura se fija en este comando únicamente (se predeterminó 18pt).
 \def\LetraItems#1{\gdef\@LetraItems{#1\selectfont}}
 
+%% Tipo de letra para la nota interna:
+\def\LetraNotaInterna#1{\gdef\@LetraNotaInterna{#1\selectfont}}
+
+%% Tipo de letra para la nota externa:
+\def\LetraNotaExterna#1{\gdef\@LetraNotaExterna{#1\selectfont}}
+
 %% Con este comando se cambia la etra del título de la tabla, es decir, los textos 'Cantidad, 'Descripción', etc...
-\def\LetraTitCuadro#1{\gdef\@LetraTitCuadro{#1\selectfont}}
+\def\LetraTitColumnas#1{\gdef\@LetraTitColumnas{#1\selectfont}}
 
 %% Tipo de letra de los títulos de los totales, por ejemplo los textos: 'B.I. G', 'IVA G'.
 \def\LetraTitTotales#1{\gdef\@LetraTitTotales{#1\selectfont}}
@@ -499,6 +714,9 @@
 %% Tipo de letra para el texto bajo las líneas para firmar.
 \def\LetraFirmas#1{\gdef\@LetraFirmas{#1\selectfont}}
 
+%% Tipo de letra para la nota previa.
+\def\LetraNotaPrevia#1{\gdef\@LetraNotaPrevia{#1\selectfont}}
+
 %% Tipo de letra para las condiciones del documento.
 \def\LetraCondiciones#1{\gdef\@LetraCondiciones{#1\selectfont}}
 
@@ -508,7 +726,7 @@
 %% Letra para la numeración de la factura.
 \def\LetraNumeracion#1{\gdef\@LetraNumeracion{#1\selectfont}}
 
-%% Letra para la fecha de emisión.
+%% Letra para las fechas (emisión y vencimiento).
 \def\LetraFecha#1{\gdef\@LetraFecha{#1\selectfont}}
 
 %% Letra para el título del reporte.
@@ -517,6 +735,9 @@
 %% Letra para las cabeceras de las páginas en el modo reporte.
 \def\LetraInfoPagina#1{\gdef\@LetraInfoPagina{#1\selectfont}}
 
+%% Letra para el reverso de la factura.
+\def\LetraReverso#1{\gdef\@LetraReverso{#1\selectfont}}
+
 %% Letra para el reporte.
 \def\LetraReporte#1{\gdef\@LetraReporte{#1\selectfont}}
 
@@ -527,12 +748,7 @@
   \ifx&#2&\else\setlength{\@FirmaFacturaXcorr}{#2}\fi
   \ifx&#3&\else\setlength{\@FirmaFacturaYcorr}{#3}\fi
   \savebox{\@CajaFirmaEmisor}{#1}
-  \if at reporte
-   \expandafter\AtBeginShipoutNext
-  \else
-   \expandafter\AtEndDocument
-  \fi
-  {%
+  \AtBeginShipoutNext{%
    \begin{textblock*}{\@TamLineaFirmas}%
     (\textwidth+\oddsidemargin+1in-\@TamLineaFirmas/2-\wd\@CajaFirmaEmisor/2-\@PosFirmasXdos+\@FirmaFacturaXcorr,\@PosFirmasY-\ht\@CajaFirmaEmisor-\dp\@CajaFirmaEmisor+\@FirmaFacturaYcorr)%
     \usebox{\@CajaFirmaEmisor}%
@@ -539,19 +755,19 @@
    \end{textblock*}}%
  \fi}
 
-\NewDocumentCommand{\FirmaReporte}{O{} O{0pt} O{0pt} G{\@Proveedor} O{2cm} O{1.5cm}}{% \Firma[imagen][x-corr][y-corr]{texto}[posición en X desde la derecha][tamaño linea]
+\NewDocumentCommand{\FirmaReporte}{O{} O{0pt} O{0pt} G{\@Proveedor} O{\@FirmaReportePosX} O{\@FirmaReporteExcesoLinea}}{% \Firma[imagen][x-corr][y-corr]{texto}[posición en X desde la derecha][tamaño linea]
  \renewcommand{\baselinestretch}{1}\selectfont
- \newif\if at firma@dibujo
+ \newif\if at Firma@Dibujo
  \newbox{\TextoFirma}%
  \newbox{\DibujoFirma}%
- \ifx&#1&\else\savebox{\DibujoFirma}{#1}\@firma at dibujotrue\fi
- \ifx&#2&\else\setlength{\@FirmaReporteXcorr}{#2}\fi
- \ifx&#3&\else\setlength{\@FirmaReporteYcorr}{#3}\fi
+ \ifx&#1&\else\savebox{\DibujoFirma}{#1}\@Firma at Dibujotrue\fi
+ \setlength{\@FirmaReporteXcorr}{#2}%
+ \setlength{\@FirmaReporteYcorr}{#3}%
  \savebox{\TextoFirma}{#4}%
- \ifx&#5&\setlength{\@FirmaReporteTextPos}{2cm}\else\setlength{\@FirmaReporteTextPos}{#5}\fi
- \ifx&#6&\setlength{\@FirmaReporteTamLinea}{1.5cm}\else\setlength{\@FirmaReporteTamLinea}{#6}\fi
+ \setlength{\@FirmaReporteTextPos}{#5}%
+ \setlength{\@FirmaReporteTamLinea}{#6}%
  \@LetraFirmas
- \if at firma@dibujo
+ \if at Firma@Dibujo
   \newlength{\@FirmaReporteoddeven}%
   \setlength{\@FirmaReporteFirmaPos}{\zposy{Firma at zref@PosY}sp}%
  \fi
@@ -565,11 +781,11 @@
  \vspace*{\dp\DibujoFirma}%
  \hfill
  \parbox{\@FirmaReporteTamLinea}{%
-  \if at firma@dibujo\zsaveposy{Firma at zref@PosY}\fi
+  \if at Firma@Dibujo\zsaveposy{Firma at zref@PosY}\fi
   \rule{\@FirmaReporteTamLinea}{\@GrosorLineaFirmas}\\
   \centering{\usebox{\TextoFirma}}}%
  \hspace*{\@FirmaReporteTextPos}\par
- \if at firma@dibujo
+ \if at Firma@Dibujo
   \mbox{}%
   \par
   \ifodd\c at page
@@ -588,7 +804,7 @@
 \newcommand{\FondoFactura}[1]{
  \if at factura
   \RequirePackage{graphicx}
-  \@fondofacturatrue
+  \@FondoFacturatrue
   \gdef\@FondoFactura{#1}
  \fi}
 
@@ -595,10 +811,10 @@
 %% Con \FondoReporte le damos el nombre del archivo que contiene el formato del reporte. Existen dos posibilidades: que dicho fondo salga en todas las páginas o sólo en la primera.
 \NewDocumentCommand{\FondoReporte}{s m}{
  \if at reporte
-  \@fondoreportetrue
+  \@FondoReportetrue
   \RequirePackage{graphicx}
   \gdef\@FondoReporte{#2}
-  \IfBooleanT{#1}{\@fondoreportestartrue}% Con * sale en todas las páginas; sin * sale sólo en la primera página.
+  \IfBooleanT{#1}{\@FondoReporteStartrue}% Con * sale en todas las páginas; sin * sale sólo en la primera página.
  \fi}
 
 %% Comando para establecer desde el preámbulo el estilo de página (\pagestyle) del reporte, tanto para la primera página como para las siguientes.
@@ -609,7 +825,7 @@
 %% El título para el reporte.
 \NewDocumentCommand{\TituloReporte}{s m}{
  \gdef\@TituloReporte{#2}%
- \IfBooleanTF{#1}{% Con '*' sale el título en las cabeceras o piés. Sin '*' no.
+ \IfBooleanTF{#1}{% Con '*' sale el título en las cabeceras o pies. Sin '*' no.
   \gdef\@InfoPagina{\let\\\relax\@InfoPaginaTitulo}}%
  {\let\@InfoPagina\@InfoPaginaNoTitulo}}
 
@@ -617,84 +833,8 @@
 \newcommand{\Cliente}[1]{%
  \IfFileExists{#1.def}{\input{#1.def}}{
   \IfFileExists{#1.tex}{\input{#1.tex}}{
-   \ClassError{factura}{** No existe #1.def ni #1.tex **}{}}}}
+   \CLASSERROR{No existe #1.def ni #1.tex}}}}
 
-%% Comando para mostrar macros con '@'.
-\newcommand{\mostrar}[1]{\csname #1\endcsname}
-
-%% Longitudes para uso interno.
-\newlength{\@TamDatos}
-\newlength{\@TamResumen}
-\newlength{\@TamFinalEncabez}
-\newlength{\@TamLineaFirmas}
-\newlength{\@TamNumItem}
-\newlength{\@TamCantidad}
-\newlength{\@TamDescrip}
-\newlength{\@TamPrecioU}
-\newlength{\@TamPrecioS}
-\newlength{\@TamDescuento}
-\newlength{\@TamPrecioT}
-\newlength{\@GrosorLineaFirmas}
-\newlength{\@GrosorLineaEncabez}
-\newlength{\@GrosorLineaDescrip}
-\newlength{\@EsquinaLineaEncabez}
-\newlength{\@EsquinaLineaDescrip}
-\newlength{\@SombraEncabez}
-\newlength{\@SombraDescrip}
-\newlength{\@LineaNodoXo}
-\newlength{\@LineaNodoYo}
-\newlength{\@LineaNodoXf}
-\newlength{\@LineaNodoYf}
-\newlength{\@SepTotales}
-\newlength{\@PosFechaX}
-\newlength{\@PosFechaY}
-\newlength{\@PosDenomX}
-\newlength{\@PosDenomY}
-\newlength{\@PosFirmasXuno}
-\newlength{\@PosFirmasXdos}
-\newlength{\@PosFirmasY}
-\newlength{\@PosCondX}
-\newlength{\@PosCondY}
-\newlength{\@PosControlX}
-\newlength{\@PosControlY}
-\newlength{\@EspacioVacioInicial}
-\newlength{\@EspacioVacioFinal}
-\newlength{\@SeparaEncabez}
-\newlength{\@SeparaItemsExtra}
-\newlength{\@SeparaItemsExtraFinal}
-\newlength{\@SeparaInternaEncabez}
-\newlength{\@SeparaInternaDescrip}
-\newlength{\@SeparaElementos}
-\newlength{\@SeparaMinTotales}
-\newlength{\@SeparaFilas}
-\newlength{\@SeparaFinLineaDesc}
-\newlength{\@InicioReporte}
-\newlength{\@FirmaFacturaXcorr}
-\newlength{\@FirmaFacturaYcorr}
-\newlength{\@FirmaReporteXcorr}
-\newlength{\@FirmaReporteYcorr}
-\newlength{\@FirmaReporteTextPos}
-\newlength{\@FirmaReporteFirmaPos}
-\newlength{\@FirmaReporteTamLinea}
-\newlength{\@TempDimen}
-
-%% Cajas para uso interno.
-\newbox{\@CajaDatos}
-\newbox{\@CajaResumen}
-\newbox{\@CajaFirmaEmisor}
-\newbox{\@CajaFirmas}
-\newbox{\@CajaFecha}
-\newbox{\@CajaDenom}
-\newbox{\@CajaControl}
-\newbox{\@CajaCond}
-\newbox{\@CajaEspacioVacio}
-\newbox{\@CajaPrueba}
-\newbox{\@CajaCaracterCR}
-
-%% Contadores para uso interno para uso interno:
-\newcounter{@IVANoGeneral}%  '0' con sólo IVA G, '1' cuando hay IVA R o IVA A, y '2' cuando hay ambos.
-\newcounter{@NumItem}%  Número del ítem actual, para uso de algunas macros en el cuadro de la factura y para cuando se usa la opción 'numitem'.
-
 \input{factura.def}%  Cargamos los valores predeterminados.
 
 \if at todosiva
@@ -709,23 +849,22 @@
  \immediate\openout\csv=\jobname.csv
 \fi
 
-\if at spanish
+\if at nospanish
+\else
  \RequirePackage[spanish]{babel}%  Babel en castellano.
  \RequirePackage[T1]{fontenc}%  Codificación T1 para las tipografías.
  \IfFileExists{lmodern.sty}{\RequirePackage{lmodern}}{}
 \fi
 
-\if at exparriba
+\if at expandecuadro
  \RequirePackage{zref-savepos}[2016/05/21]%  Para guardar la posición en 'Y'.
 \fi
 
 \if at reporte
- \RequirePackage{eso-pic}%  Para el comando \AddToShipoutPicture.
  \RequirePackage{zref-savepos}%  Para la firma, que debe ser cargado aquí porque \FirmaReporte no se ejecuta desde el preámbulo.
 \fi
 
 \if at sinmarcas
- \setlength{\@SeparaFinLineaDesc}{0pt}
  \def\@CaracterCR{\mbox{}}
  \def\@CaracterCeldasVacias{\mbox{}}
 \fi
@@ -733,14 +872,14 @@
 %% Comando para escribir el encabezado en la factura.
 \newcommand\@EncabezadoFactura{%
  \ifdefvoid{\@Resumen}{\@EscribeDatos}{\@EscribeDatosResumen}%
- \vspace*{\@SeparaElementos}%
- \if at exparriba\else\vfill\fi}
+ \vspace*{\@SeparaVertical}%
+ \if at expandecuadro\else\vfill\fi}
 
 %% Comando para escribir el encabezado en el reporte.
 \newcommand\@EncabezadoReporte{%
  \vspace*{-\topskip}%
- \if at fondoreporte
-  \if at fondoreportestar
+ \if at FondoReporte
+  \if at FondoReporteStar
   \else
    \vspace*{\@InicioReporte}%
   \fi
@@ -749,49 +888,84 @@
  \@LetraReporte}
 
 %% El ambiente 'factura', usando el paquete 'environ' para su definición, y el comando auxiliar \@FacturaAuxCmd.
-%% Gracias a Heiko Oberdiek y David Carlisle (Thanks to Heiko Oberdiek and David Carlisle).
+%% Gracias a Heiko Oberdiek y a David Carlisle (Thanks to Heiko Oberdiek and David Carlisle).
 %% http://tex.stackexchange.com/questions/108565/know-the-cell-width-with-tabular-or-include-a-paragraph-box-without-specifying
 \NewEnviron{factura}{%
  \expandafter\@FacturaAuxCmd\expandafter{\BODY}%
- \ifnum\value{page}=1\else\ClassError{factura}{** La factura ocupa mas que una pagina **}{}\fi
-}
+ \ifnum\value{page}=1\else\CLASSERROR{La factura ocupa mas que una pagina}\fi}
 
+\NewEnviron{reverso}{%
+ \if at factura
+   \expandafter\newgeometry\expandafter{\@GeometriaReverso}%
+   \topskip1sp% ¡¡No puedo poner 0 porque se genera una página en blanco extra!!
+  \begin{minipage}[t][\textheight-\pagetotal]{\linewidth}%
+   \thispagestyle{empty}%
+   \@LetraReverso\BODY
+  \end{minipage}
+  \clearpage
+ \fi}
+
 %% Comando auxiliar para agregar un carácter al final de cada línea en la descripción dentro del cuadro de la factura si ocupa ésta más de una línea.
-%% Gracias a Gustavo Mezzetti y David Carlisle (Thanks to Gustavo Mezzetti and David Carlisle)
+%% Gracias a Gustavo Mezzetti y a David Carlisle (Thanks to Gustavo Mezzetti and David Carlisle).
 %% http://tex.stackexchange.com/questions/296035/insert-a-special-character-at-each-end-of-line-in-a-paragraph
 %% http://tex.stackexchange.com/questions/248944/how-to-put-before-lines
 \newcommand{\@DescripcionAuxCmd}[2]{%
- \immediate\write\@auxout{\gdef\noexpand\@TamDescrip{\the\linewidth}}% Para poder establecer la línea diagonal hay que saber el tamaño del campo de la descripción.
- \setbox0\hbox{\parbox[t]{\linewidth}{\if at centradesc\centering\arraybackslash\fi#1%
-  \if at impdesc\hfill\ \@EscribeTipoDeImpuesto{#2}\fi%
-  \par\global\count1=\prevgraf}}%
- \ifnum\count1 = 1
-  \if at centradesc\centering\arraybackslash\fi#1%
-  \if at impdesc\vskip-\baselineskip\hfill\ \@EscribeTipoDeImpuesto{#2}\fi
- \else
-  \parbox[t]{\linewidth-\wd\@CajaCaracterCR-\@SeparaFinLineaDesc}{%
+ \if at impdesc\settowidth{\@TempDimen}{\@EscribeTipoDeImpuesto{#2}}\fi
+ \savebox{\@CajaPrueba}{%
+  \parbox[t]{\linewidth}{%
    \David at XStart
    \if at centradesc\centering\arraybackslash\fi
    #1%
    \David at XEnd
-   \par
-   \count0=\prevgraf
-   \count2=\prevgraf
-   \loop
-    \ifnum\count0=\count2
-     \if at impdesc
-      \vskip-\baselineskip
-      \mbox{}\hfill\rlap{\hspace*{\wd\@CajaCaracterCR}\hspace*{\@SeparaFinLineaDesc}\llap{\@EscribeTipoDeImpuesto{#2}}}%
+   \ifdim\@TempDimen=0pt%
+   \else
+    \hfill\kern\@SeparaFinLineaDesc\@EscribeTipoDeImpuesto{#2}%
+   \fi
+   \par\global\count1=\prevgraf}}%
+ \if at sinmarcas
+  \usebox{\@CajaPrueba}%
+ \else
+  \ifnum\count1=1%
+   \usebox{\@CajaPrueba}%
+  \else
+   \ifdim\@TempDimen>\wd\@CajaCaracterCR
+   \else
+    \setlength{\@TempDimen}{\wd\@CajaCaracterCR}%
+   \fi
+   \parbox[t]{\linewidth-\@TempDimen-\@SeparaFinLineaDesc}{%
+    \David at XStart
+    \if at centradesc\centering\arraybackslash\fi
+    #1%
+    \David at XEnd
+    \par
+    \global\count1=\prevgraf% Esto lo necesitamos en otro lado para calcular el espacio extra en los ítems.
+    \count0=\prevgraf
+    \count2=\prevgraf
+    \loop
+     \ifnum\count0=\count2
+      \if at impdesc
+       \vskip-\baselineskip
+       \mbox{}\hfill
+       \rlap{%
+        \hspace*{\@TempDimen}%
+        \hspace*{\@SeparaFinLineaDesc}%
+        \llap{\@EscribeTipoDeImpuesto{#2}}}%
+      \fi
+     \else
+      \mbox{}\hfill
+      \rlap{%
+       \hspace*{\@TempDimen}%
+       \hspace*{\@SeparaFinLineaDesc}%
+       \hspace*{-\wd\@CajaCaracterCR}%
+       \usebox{\@CajaCaracterCR}}%
      \fi
-    \else
-     \mbox{}\hfill\rlap{\hspace*{\@SeparaFinLineaDesc}\usebox{\@CajaCaracterCR}}%
-    \fi
-    \vskip-2\baselineskip
-    \advance\count0 -1
-    \ifnum\count0 > 0
-   \repeat
-   \kern\count2\baselineskip\mbox{}%
-   \strut}%
+     \vskip-2\baselineskip
+     \advance\count0 -1
+     \ifnum\count0 > 0
+    \repeat
+    \kern\count2\baselineskip\mbox{}%
+    \strut}%
+  \fi
  \fi}
 
 %% Comandos auxiliares para colocar en \parbox cada celda.
@@ -820,6 +994,11 @@
  \ifdim\wd\@CajaPrueba > \@TamDescuento \global\@TamDescuento=\wd\@CajaPrueba\fi
  \parbox[t]{\@TamDescuento}{#1}}
 
+\newcommand{\@IVAAuxCmd}[1]{%
+ \savebox{\@CajaPrueba}{#1}%
+ \ifdim\wd\@CajaPrueba > \@TamIVA \global\@TamIVA=\wd\@CajaPrueba\fi
+ \parbox[t]{\@TamIVA}{#1}}
+
 \newcommand{\@PrecioTAuxCmd}[1]{%
  \savebox{\@CajaPrueba}{#1}%
  \ifdim\wd\@CajaPrueba > \@TamPrecioT \global\@TamPrecioT=\wd\@CajaPrueba\fi
@@ -828,11 +1007,11 @@
 %% Presentación de totales en modo de columnas.
 \newcommand{\@EscribeTotalCol}[1]{%
  \expandafter\FPifeq\csname Desc#1\endcsname{0}%
-  \if at ivaexpresado\@EscribeTotalColBI{#1}\fi
+  \if at sinivaexpresado\else\@EscribeTotalColBI{#1}\fi
  \else
   \@EscribeTotalColSubt{#1}%
   \@EscribeTotalColDesc{#1}%
-  \if at ivaexpresado\@EscribeTotalColBI{#1}\fi
+  \if at sinivaexpresado\else\@EscribeTotalColBI{#1}\fi
  \fi}
 
 %% Forma agupada para la presentación de totales en modo de columnas.
@@ -845,7 +1024,8 @@
  \if at BIR\if at DescR\@EscribeTotalColDesc{R}\fi\fi
  \if at DescG\@EscribeTotalColDesc{G}\fi
  \if at BIA\if at DescA\@EscribeTotalColDesc{A}\fi\fi
- \if at ivaexpresado
+ \if at sinivaexpresado
+ \else
   \if at Exento\@EscribeTotalColBI{E}\fi
   \if at BIR\@EscribeTotalColBI{R}\fi
   \@EscribeTotalColBI{G}%
@@ -853,6 +1033,7 @@
   \if at BIR\@EscribeTotalColAlicuota{R}\fi
   \@EscribeTotalColAlicuota{G}%
   \if at BIA\@EscribeTotalColAlicuota{A}\fi
+  \ifbool{Electro}{\@EscribeTotalColAlicuotaGDesc}{}%
  \fi}
 
 \newcommand{\@EscribeTotalColBI}[1]{%
@@ -867,6 +1048,10 @@
  {\@LetraTitTotales \csname @@Alicuota#1\endcsname\ \hfill (\csname @Alicuota#1porc\endcsname\%)}
  & \@LetraNumTotales\numprint{\csname Alicuota#1\endcsname} \\}
 
+\newcommand{\@EscribeTotalColAlicuotaGDesc}{%
+ {\@LetraTitTotales \@@AlicuotaGDesc\ \hfill (\@AlicuotaGDescPorc\%)}
+ & \@LetraNumTotales\numprint{\AlicuotaGDesc} \\}
+
 \newcommand{\@EscribeTotalColSubt}[1]{%
  {\@LetraTitTotales \csname @@Subtotal#1\endcsname}
  & \@LetraNumTotales\numprint{\csname Subt#1\endcsname} \\}
@@ -992,10 +1177,10 @@
  % Hay que abrir un grupo de ejecución porque el cambio en la tipografía altera la celda.
  {\if at G
    \@LetraTipoIVA
-   \ifx#1G\@DenomAlicuotaG\fi% Si tiene IVA general escribimos 'G'.
-   \ifx#1E\@DenomAlicuotaE\fi% Si está exento escribimos '(E)'.
-   \ifx#1R\@DenomAlicuotaR\fi% Si tiene IVA reducido escribimos 'R'.
-   \ifx#1A\@DenomAlicuotaA\fi% Si tiene IVA adicional escribimos 'A'.
+   \ifx#1G\@DenomAlicuotaG\fi
+   \ifx#1R\@DenomAlicuotaR\fi
+   \ifx#1A\@DenomAlicuotaA\fi
+   \ifx#1E\@DenomAlicuotaE\fi
   \fi}}
 
 %% Comando para poner en cero los contadores de los totales porque el ambiente de la factura se evalúa tres veces y los totales se sumarían todos tres veces.
@@ -1015,6 +1200,7 @@
  \FPset\DescA{0}\global\let\DescA\DescA
  \FPset\DescX{0}\global\let\DescX\DescX
  \FPset\AlicuotaG{0}\global\let\AlicuotaG\AlicuotaG
+ \FPset\AlicuotaGDesc{0}\global\let\AlicuotaGDesc\AlicuotaGDesc
  \FPset\AlicuotaR{0}\global\let\AlicuotaR\AlicuotaR
  \FPset\AlicuotaA{0}\global\let\AlicuotaA\AlicuotaA}
 
@@ -1024,7 +1210,18 @@
  \FPifeq\SubtR{0}\else\@CalculaTotalesII{R}\fi
  \FPifeq\SubtA{0}\else\@CalculaTotalesII{A}\fi
  \FPifeq\SubtE{0}\else\@CalculaTotalesII{E}\fi
- \FPupn\Total{\BIE{} \BIR{} + \BIG{} + \BIA{} + \AlicuotaR{} + \AlicuotaG{} + \AlicuotaA{} + \@DigitosMoneda{} round}%
+ \ifbool{Electro}{%
+  \FPiflt\BIG\@AlicuotaGDescLimite
+   \let\@AlicuotaGDesc\@AlicuotaGDescBajo
+  \else
+   \let\@AlicuotaGDesc\@AlicuotaGDescAlto
+  \fi
+  \FPupn\@AlicuotaGDescPorc{\@AlicuotaGDesc{} 100 * \@DigitosPorc{} round clip}%
+  \FPupn\AlicuotaGDesc{\BIG{} \@AlicuotaGDesc{} * \@DigitosMoneda{} round}%
+  \global\let\AlicuotaGDesc\AlicuotaGDesc
+  \global\let\@AlicuotaGDescPorc\@AlicuotaGDescPorc
+  \global\let\@AlicuotaGDesc\@AlicuotaGDesc}{}%
+ \FPupn\Total{\BIE{} \BIR{} + \BIG{} + \BIA{} + \AlicuotaR{} + \AlicuotaG{} + \AlicuotaA{} + \AlicuotaGDesc{} sub \@DigitosMoneda{} round}%
  \global\let\Total\Total}
 
 \newcommand{\@CalculaTotalesII}[1]{%
@@ -1050,7 +1247,7 @@
  % Segunda línea, que sale solamente cuando se usa la opción 'numitem'
  \ifbool{NumItem}{\ifbool{SinLineasVertInt}{}{|}}{}
  % Columna 'X' con DCU, columna fantasma con 'sincantidad' y columna 'c' con CDU.
- \ifbool{PrimeroDescrip}{X}{
+ \ifbool{PrimeroDescripcion}{X}{
   \ifbool{SinCantidad}{l@{\extracolsep{0pt}}}{c}}
  % Tercera línea.
  \ifbool{SinCantidad}{}{\ifbool{SinLineasVertInt}{}{|}}
@@ -1072,9 +1269,13 @@
  \ifbool{Descuentos}{c}{r@{\extracolsep{0pt}}}
  % Séptima línea, que sale solamente cuando hay descuentos.
  \ifbool{Descuentos}{\ifbool{SinLineasVertInt}{}{|}}{}
+ % Columna 'c' para 'iva' y columna 'r' sin espacio si no hay columna de IVA.
+ \ifbool{IVA}{c}{r@{\extracolsep{0pt}}}
+ % Octava línea, que sale solamente cuando hay columna de IVA.
+ \ifbool{IVA}{\ifbool{SinLineasVertInt}{}{|}}{}
  % Columna 'r' siempre.
  r
- % Octava y última línea.
+ % Novena y última línea.
  \ifbool{SinLineasVertExt}{}{|}}
 
 %% Comando auxiliar para abrir la tabla del cuadro de la factura y expandir completamente las columnas.
@@ -1082,18 +1283,28 @@
 
 %% Comando auxiliar para abrir el '\multicolumn' para los totales en el modo de columnas y expandir completamente las columnas cuando hay o no barras verticales.
 \edef\@ColumnasMultiColumnTotalesAuxCmd{%
- \noexpand\multicolumn{7}{\ifbool{SinLineasVertExt}{}{|} r}\begingroup
+ \noexpand\multicolumn{8}{\ifbool{SinLineasVertExt}{}{|} r}\begingroup
    \noexpand\ifdim \noexpand\ht\noexpand\@CajaEspacioVacio=0pt
    \noexpand\else
     \noexpand\if at linea\noexpand\zsaveposx{LineaNodoBCoordX}\noexpand\zsaveposy{LineaNodoBCoordY}\noexpand\fi\noexpand\fi% Fijamos la posición (x,y) final para la línea ya que estaremos justo en el punto donde escribimos el total, y hasta allí llega la línea en el modo de columnas.
     \noexpand\begin{tabular}[b]{@{\noexpand\extracolsep{2\noexpand\tabcolsep}}lr \ifbool{SinLineasVertExt}{}{|}}}
 
+%% Comando auxiliar para abrir el '\multicolumn' de la nota interna y evalúe la presencia o no de las barras verticales.
+\edef\@ColumnasMultiColumnNotaIntAuxCmd{%
+ \noexpand\multicolumn{8}{\ifbool{SinLineasVertExt}{}{|}l\ifbool{SinLineasVertExt}{}{|}}{%
+  \noexpand\parbox[t]{\linewidth-2\tabcolsep-2\arrayrulewidth}{\noexpand\@LetraNotaInterna\noexpand\@NotaInterna\noexpand\strut}}%
+  \noexpand\\}
+
 %% Comando para hacer los cálculos sobre cada ítem y establecer las macros con el contenido de cada ítem introducido.
-\newcommand{\@CalculaItem}[5]{%
- \addtocounter{@NumItem}{1}%
+\NewDocumentCommand{\@CalculaItem}{m m m o m m}{%
+ \addtocounter{NumItem}{1}%
  % Calculamos.
- \FPupn\PrecioU{#4 \@DigitosMoneda{} round}%
- \ifx\\#5\\\FPset\Dcto{0}\else\FPupn\Dcto{#5 \@DigitosPorc{} round clip}\fi% Fijamos en 0 el descuento si no se especifica.
+ \FPupn\PrecioU{#5 \@DigitosMoneda{} round}%
+ \ifbool{Descuentos}
+  {\ifx\\#6\\\FPset\Dcto{0}\else\FPupn\Dcto{#6 \@DigitosPorc{} round clip}\fi}% Fijamos en 0 el descuento si no se especifica en \Item***.
+  {\FPset\Dcto{#6}%
+   \FPifeq\Dcto{0}\else\CLASSWARNING{Se pidió un descuento individual sin dar la opción de la clase 'descuentos'. No se tomará en cuenta.}\fi
+   \FPset\Dcto{0}}% También fijamos en 0 el descuento por si se especifica en \Item*** pero no se pide la opción 'descuentos'.
  \FPupn\PrecioS{#2 \PrecioU{} * \@DigitosMoneda{} round}%
  \FPupn\PrecioT{100 \Dcto{} 100 - / \PrecioS{} * \@DigitosMoneda{} round}%
  \global\let\PrecioU\PrecioU
@@ -1104,57 +1315,63 @@
  \expandafter\FPupn\csname Subt#1\endcsname{\PrecioT{} \csname Subt#1\endcsname{} + \@DigitosMoneda{} round}%
  \global\expandafter\let\csname Subt#1\expandafter\endcsname\csname Subt#1\endcsname
  % Guardamos en macros cada elemento agregado a la factura; por ejemplo: \@Item at i@Cantidad contiene la cantidad que se introdujo para el primer ítem; así mismo con ii@, @iii@, y así mismo también con @Descripcion, @PrecioU, @Descuento y @PrecioT.
- \expandafter\gdef\csname @Item@\romannumeral\value{@NumItem}@Cantidad\endcsname{\numprint{#2}}%
- \expandafter\gdef\csname @Item@\romannumeral\value{@NumItem}@Descripcion\endcsname{#3}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioU\endcsname{\noexpand\numprint{\PrecioU}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioS\endcsname{\noexpand\numprint{\PrecioS}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@Descuento\endcsname{\noexpand\numprint{\Dcto}}%
- \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{@NumItem}@PrecioT\endcsname{\noexpand\numprint{\PrecioT}}}
+ \expandafter\gdef\csname @Item@\romannumeral\value{NumItem}@Cantidad\endcsname{\numprint{#2}}%
+ \expandafter\gdef\csname @Item@\romannumeral\value{NumItem}@Descripcion\endcsname{#3}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioU\endcsname{\noexpand\numprint{\PrecioU}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioS\endcsname{\noexpand\numprint{\PrecioS}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@Descuento\endcsname{\noexpand\numprint{\Dcto}}%
+ \expandafter\global\expandafter\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@IVA\endcsname{%
+  \noexpand\numprint\expandafter{\csname @Alicuota#1porc\endcsname}}%
+ \expandafter\global\expandafter\edef\csname @Item@\romannumeral\value{NumItem}@PrecioT\endcsname{\noexpand\numprint{\PrecioT}}}
 
+%% Macro interna para saber si una etiqueta existe o no.
 \gdef\@pruebaref#1{%
  \expandafter\ifx\csname @Etiqueta@#1\endcsname\relax
-  \ClassWarning{factura}{La etiqueta `#1' no está definida}{}\ignorespaces
-  \@pruebareffalse
+  \CLASSWARNING{La etiqueta `#1' no está definida}\ignorespaces
+  \@PruebaReffalse
  \else
-  \@pruebareftrue
+  \@PruebaReftrue
  \fi}
 
+%% Comandos para las referencias: i) referencia al número de ítem, ii) a la cantidad, iii) a la descripción, iv) al precio unitario, v) al descuento, vi) al precio total.
 \gdef\itemref#1{%
- \ifbool{NumItem}{}{\ClassWarning{factura}{Es recomendable usar la opción 'numitem' para enumerar los ítems}{}}%
- \@pruebaref{#1}\if at pruebaref \csname @Etiqueta@#1\endcsname \fi}
-\gdef\cantref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Cantidad\endcsname \fi}
-\gdef\descref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descripcion\endcsname \fi}
-\gdef\puref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioU\endcsname \fi}
-\gdef\subtref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioS\endcsname \fi}
-\gdef\dctoref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descuento\endcsname \fi}
-\gdef\ptref#1{\@pruebaref{#1}\if at pruebaref \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioT\endcsname \fi}
+ \ifbool{NumItem}{}{\CLASSWARNING{Es recomendable usar la opción 'numitem' para enumerar los ítems}}%
+ \@pruebaref{#1}\if at PruebaRef \csname @Etiqueta@#1\endcsname \fi}
+\gdef\cantref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Cantidad\endcsname \fi}
+\gdef\descref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descripcion\endcsname \fi}
+\gdef\puref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioU\endcsname \fi}
+\gdef\subtref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioS\endcsname \fi}
+\gdef\dctoref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @Descuento\endcsname \fi}
+\gdef\ivaref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @IVA\endcsname \fi}
+\gdef\ptref#1{\@pruebaref{#1}\if at PruebaRef \csname @Item@\expandafter\romannumeral\csname @Etiqueta@#1\endcsname @PrecioT\endcsname \fi}
 
+%% Definimos un comando para la etiqueta, que se define dentro del entorno de la factura para que tenga alcance local; cuando se acaba dicho entorno, el comando \label vuelve a ser lo que está definido en latex.ltx.
 \newcommand{\label at factura}[1]{%
  \expandafter\ifx\csname @Etiqueta@#1\endcsname\relax
-  \expandafter\global\expandafter\edef\csname @Etiqueta@#1\endcsname{\arabic{@NumItem}}\ignorespaces
-  \ClassInfo{factura}{Etiqueta `#1' definida para el ítem \arabic{@NumItem}}{}%
+  \expandafter\global\expandafter\edef\csname @Etiqueta@#1\endcsname{\arabic{NumItem}}\ignorespaces
+  \CLASSINFO{Etiqueta `#1' definida para el ítem \arabic{NumItem}}%
  \else
   \edef\@label at test@uno{\csname @Etiqueta@#1\endcsname}%
-  \edef\@label at test@dos{\the at NumItem}%
+  \edef\@label at test@dos{\theNumItem}%
   \ifx\@label at test@uno\@label at test@dos
   \else
-   \ClassWarning{factura}{La etiqueta `#1' se definió más de una vez}{}\ignorespaces
+   \CLASSWARNING{La etiqueta `#1' se definió más de una vez}\ignorespaces
   \fi
  \fi}
 
 %% Comando auxiliar para la definición del ambiente de la factura; al final de este comando está el texto que va en el enddef del ambiente de la factura.
 \newcommand{\@FacturaAuxCmd}[1]{%
- \if at exparriba
+ \if at expandecuadro
   \setlength{\@EspacioVacioInicial}{\zposy{EspacioVacioInicial}sp}%
   \setlength{\@EspacioVacioFinal}{\zposy{EspacioVacioFinal}sp}%
-  \global\@EspacioVacioInicial=\@EspacioVacioInicial% ¿por qué tendré que globalizarlas?
+  \global\@EspacioVacioInicial=\@EspacioVacioInicial% Hay que globalizarlas
   \global\@EspacioVacioFinal=\@EspacioVacioFinal
-  \savebox{\@CajaEspacioVacio}{\parbox[b][\@EspacioVacioInicial-\@EspacioVacioFinal]{\@TamDescrip}{%
+  \savebox{\@CajaEspacioVacio}{\parbox[b][\@EspacioVacioInicial-\@EspacioVacioFinal]{0pt}{%
    \if at linea
-    \if at lineacompleta
+    \if at LineaCompleta
      \zsaveposy{LineaNodoBCoordY}%
     \else
-     \if at lineahastatotal
+     \if at LineaHastaTotal
      \else
       \zsaveposx{LineaNodoACoordX}\mbox{}\hfill \zsaveposx{LineaNodoBCoordX}\zsaveposy{LineaNodoBCoordY}%
      \fi
@@ -1163,14 +1380,14 @@
   \ifdim \ht\@CajaEspacioVacio=0pt \global\@lineafalse \fi
  \fi
 
- \ifx\undefined\Total\relax\else\ClassError{factura}{** Parece ya haberse usado un entorno de factura **}{}\fi
+ \ifx\undefined\Total\relax\else\CLASSERROR{Parece ya haberse usado un entorno de factura}\fi
  %
  % Comandos \David at SavePos, \David at XStart, \David at XEnd, \David at XPad, \David at XLeft y \David at XRight para poder manejar el salto de línea en las columnas adyacentes a la columna 'X' del tabularx (la descripción), cuando esta ocupa más que una línea.
  % Gracias a David Carlisle (Thanks to David Carlisle).
  % http://tex.stackexchange.com/questions/111203/tabularx-bottom-alignment-on-r-or-l-columns-when-x-column-wraps
  \def\David at SavePos##1{\leavevmode\pdfsavepos\write\@auxout{\gdef\noexpand##1{\the\pdflastypos sp}}}%
- \def\David at XStart{\expandafter\David at SavePos\csname save at start@\romannumeral\value{@NumItem}\endcsname}%
- \def\David at XEnd{\expandafter\David at SavePos\csname save at end@\romannumeral\value{@NumItem}\endcsname}%
+ \def\David at XStart{\expandafter\David at SavePos\csname save at start@\romannumeral\value{NumItem}\endcsname}%
+ \def\David at XEnd{\expandafter\David at SavePos\csname save at end@\romannumeral\value{NumItem}\endcsname}%
  \def\David at XPad##1##2##3{%
   \vtop{%
    \baselineskip\normalbaselineskip
@@ -1189,33 +1406,40 @@
     \repeat
    \fi
    ##3}}%
- \def\David at XLeft##1{\David at XPad{\romannumeral\value{@NumItem}}{\hbox{##1}}{}}%
- \def\David at XRight##1{\David at XPad{\romannumeral\value{@NumItem}}{}{\hbox{##1}}}%
+ \def\David at XLeft##1{\David at XPad{\romannumeral\value{NumItem}}{\hbox{##1}}{}}%
+ \def\David at XRight##1{\David at XPad{\romannumeral\value{NumItem}}{}{\hbox{##1}}}%
  %
  % Caja auxiliar para el caracter de retorno de carro y poder saber si tamaño en el campo de la descripción.
  \savebox{\@CajaCaracterCR}{\@LetraItems\@CaracterCR}
  %
+ % Comando para fijar la separación extra final de cada item, lo cual viene dado por la cantidad de líneas de la descripción,
+ % que está alojado en \count1, definido en \@DescripcionAuxCmd.
+ \def\@CalculaSeparaItemsExtraFinal{%
+  \setlength{\@SeparaItemsExtraFinal}{\numexpr\the\count1\normalbaselineskip-\normalbaselineskip+\@SeparaItemsExtra}%
+  \global\@SeparaItemsExtraFinal=\@SeparaItemsExtraFinal}
+ %
  % Comando interno general para agregar cualquier ítem.
- \newcommand{\@ITEM}[5]{% 1. [R|G|A|E|X]; 2. cantidad; 3. descripción; 4. p/u; 5. dcto.
-  \@CalculaItem{##1}{##2}{##3}{##4}{##5}%
+ \NewDocumentCommand{\@ITEM}{m m m o m m}{%
+  % 1. [R|G|A|E|X]; 2. cantidad; 3. descripción; 4. descripción para el csv (entre corchetes); 5. p/u; 6. dcto.
+  \@CalculaItem{##1}{##2}{##3}{##5}{##6}%
   % Si no es el primer ítem, entonces hace falta \\ para terminar el ítem anterior.
-  \ifnum\value{@NumItem}=1%
+  \ifnum\value{NumItem}=1% Aquí, \@CalculaItem aumenta en 1 el contador NumItem, que si vale 1 significa que aún no hemos procesado la línea 1, es decir, no hay que hacer el salto de línea. La última línea se termina en otro lado.
   \else
-   \setlength{\@SeparaItemsExtraFinal}{\numexpr\the\count1\normalbaselineskip-\normalbaselineskip+\@SeparaItemsExtra}%
+   \@CalculaSeparaItemsExtraFinal
    \\[\@SeparaItemsExtraFinal]
    \if at conlineasha\hline\fi% Líneas para separar cada ítem, si hiciera falta.
   \fi
   % Primer -opcional- campo: El número del ítem.
-  \ifbool{NumItem}{\David at XLeft{\@NumItemAuxCmd{\mbox{}\hfill \@LetraNumeros \arabic{@NumItem}\hfill\mbox{}}}}{}%
+  \ifbool{NumItem}{\David at XLeft{\@NumItemAuxCmd{\mbox{}\hfill \@LetraNumeros \arabic{NumItem}\hfill\mbox{}}}}{}%
   &
   % Segundo campo: Acá puede ir la cantidad (cdu) o la descripción (dcu y duc).
   \ifbool{SinCantidad}{}{%
-   \ifbool{PrimeroDescrip}
+   \ifbool{PrimeroDescripcion}
    {\@DescripcionAuxCmd{##3}{##1}}% dcu y duc.
    {\David at XLeft{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}}}% cdu.
   &
   % Tercer campo: Acá puede ir la descripción (cdu), la cantidad (dcu), o el precio unitario (duc).
-  \ifbool{PrimeroDescrip}{%
+  \ifbool{PrimeroDescripcion}{%
    \if at dcu
     \David at XRight{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}% dcu.
    \else
@@ -1228,7 +1452,7 @@
   {\@DescripcionAuxCmd{##3}{##1}}% cdu.
   &
   % Cuarto campo: Acá puede ir el precio unitario (cdu y dcu) o la cantidad (duc).
-  \FPifeq\PrecioU{##4}\else\ClassWarning{factura}{** Se está introduciendo un precio con más de dos decimales: (##3 - ##4. Redondeado a \PrecioU) **}{}\fi% Advertimos cuando el precio unitario tiene más de dos decimales.
+  \FPifeq\PrecioU{##5}\else\CLASSWARNING{Se está introduciendo un precio con más de dos decimales: (##3 - ##5. Redondeado a \PrecioU)}{}\fi% Advertimos cuando el precio unitario tiene más de dos decimales.
   \ifbool{SinCantidad}{}{%
    \if at duc
     \David at XRight{\@CantidadAuxCmd{\mbox{}\hfill \@LetraNumeros \numprint{##2}\hfill\mbox{}}}% duc.
@@ -1255,7 +1479,15 @@
      \mbox{}\hfill \@LetraNumeros \numprint{\Dcto}\%\hfill\mbox{}%
     \fi}}}{}% Tenemos que usar un condicional booleano porque si no da problemas con el condicional \FPifeq.
   &
-  % Séptimo campo: El total.
+  % Séptimo -opcional- campo: IVA.
+  \ifbool{IVA}{%
+   \David at XRight{\@IVAAuxCmd{%
+    \ifx##1X \hfill \@CaracterItemXVacio \hfill\mbox{}%
+    \else
+     \mbox{}\hfill \@LetraNumeros \numprint{\csname @Alicuota##1porc\endcsname}\%\hfill\mbox{}%
+    \fi}}}{}% Tenemos que usar un condicional booleano porque si no da problemas con el condicional \FPifeq.
+  &
+  % Octavo campo: El total.
   \David at XRight{\@PrecioTAuxCmd{%
    \ifx##1X \hfill \@CaracterItemXVacio \hfill\mbox{}%
    \else
@@ -1263,35 +1495,39 @@
    \fi}}%
   % Escribimos al csv.
   \if at csv
-   \ifbool{SinCantidad}
-    {\if at descuentos
-      \immediate\write\csv{"\unexpanded{##3}","\Dcto","\PrecioT","##1"}%
-     \else
-      \immediate\write\csv{"\unexpanded{##3}","\PrecioT","##1"}%
-     \fi}
-    {\if at cdu
-      \if at descuentos
-       \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\PrecioT","##1"}%
-      \fi
-     \fi
-     \if at dcu
-      \if at descuentos
-       \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\PrecioT","##1"}%
-      \fi
-     \fi
-     \if at duc
-      \if at descuentos
-       \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\Dcto","\PrecioT","##1"}%
-      \else
-       \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\PrecioT","##1"}%
-      \fi
-     \fi}%
-   \fi}%
+   \IfValueTF{##4}{\@EscribeItemsEnCSV{##1}{##2}{##4}}{\@EscribeItemsEnCSV{##1}{##2}{##3}}%
+  \fi}%
  %
+ % Comando para escribir en el .csv.
+ \newcommand{\@EscribeItemsEnCSV}[3]{%
+  \ifbool{SinCantidad}
+  {\if at descuentos
+    \immediate\write\csv{"\unexpanded{##3}","\Dcto","\PrecioT","##1"}%
+   \else
+    \immediate\write\csv{"\unexpanded{##3}","\PrecioT","##1"}%
+   \fi}
+  {\if at cdu
+    \if at descuentos
+     \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"##2","\unexpanded{##3}","\PrecioU","\PrecioT","##1"}%
+    \fi
+   \fi
+   \if at dcu
+    \if at descuentos
+     \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"\unexpanded{##3}","##2","\PrecioU","\PrecioT","##1"}%
+    \fi
+   \fi
+   \if at duc
+    \if at descuentos
+     \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\Dcto","\PrecioT","##1"}%
+    \else
+     \immediate\write\csv{"\unexpanded{##3}","\PrecioU","##2","\PrecioT","##1"}%
+    \fi
+   \fi}}%
+ %
  % Usamos la definición de \label at factura dentro del entorno de la factura para que sea local aquí nada más.
  \let\label\label at factura
  \@LetraItems% Este es el tipo de letra que tendrán los ítems, y en este tipo de letra se define el \baselineskip de toda la factura.
@@ -1299,44 +1535,51 @@
  \ifbool{SinLineasHoriExt}{}{\hline}%
  \@ZERO
  % Estamos en el número del ítem, si aplicara.
- \if at lineadesdeinicio \hspace*{-\tabcolsep}\zsaveposx{LineaNodoACoordX}\hspace*{\tabcolsep}\fi
- \ifbool{NumItem}{\@NumItemAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@NumItem \hfill\mbox{}}}{}%
+ \if at LineaDesdeInicio \hspace*{-\tabcolsep}\zsaveposx{LineaNodoACoordX}\hspace*{\tabcolsep}\fi
+ \ifbool{NumItem}{\@NumItemAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@NumItem \hfill\mbox{}}}{}%
  &
  % Avanzamos a la cantidad, o la descripción.
- \ifbool{SinCantidad}{}{\ifbool{PrimeroDescrip}{\@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}}{\@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}}}%
+ \ifbool{SinCantidad}{}{\ifbool{PrimeroDescripcion}{\@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}}{\@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}}}%
  &% Avanzamos hasta la descripción, la cantidad o el precio unitario.
- \ifbool{SinCantidad}{\@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}}
-  {\if at cdu \@DescripcionAuxCmd{\@LetraTitCuadro \@@Descripcion}{}\fi
-   \if at dcu \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}\fi
-   \if at duc \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioU \space (\Moneda)\hfill\mbox{}}\fi}%
+ \ifbool{SinCantidad}{\@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}}
+  {\if at cdu \@DescripcionAuxCmd{\@LetraTitColumnas \@@Descripcion}{}\fi
+   \if at dcu \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}\fi
+   \if at duc \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioU \space (\Moneda)\hfill\mbox{}}\fi}%
  &% Avanzamos hasta el precio unitario, o la cantidad, o columna fantasma cuando es 'sincantidad'.
  \ifbool{SinCantidad}{}
   {%
    \mbox{}\hfill
    \if at duc
-    \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Cantidad \hfill\mbox{}}%
+    \@CantidadAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Cantidad \hfill\mbox{}}%
    \else
-    \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioU \space (\Moneda)\hfill\mbox{}}%
+    \@PrecioUAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioU \space (\Moneda)\hfill\mbox{}}%
    \fi}%
  &% Avanzamos hasta el subtotal, que puede o no existir,
- \ifbool{Subtotal}{\@PrecioSAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@PrecioS \space (\Moneda)\hfill\mbox{}}}{}%
+ \ifbool{Subtotal}{\@PrecioSAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@PrecioS \space (\Moneda)\hfill\mbox{}}}{}%
  &% Avanzamos hasta el descuento, que puede o no existir.
- \if at descuentos \@DescuentoAuxCmd{\mbox{}\hfill \@LetraTitCuadro \@@Descuento \hfill\mbox{}}\fi
+ \if at descuentos \@DescuentoAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@Descuento \hfill\mbox{}}\fi
+ &% Avanzamos hasta el IVA, que puede o no existir.
+ \ifbool{IVA}{\@IVAAuxCmd{\mbox{}\hfill \@LetraTitColumnas \@@IVA \hfill\mbox{}}}{}
  &% Avanzamos hasta el precio total.
- \@PrecioTAuxCmd{\mbox{}\hfill \@LetraTitCuadro \ifbool{SinCantidad}{\@@Precio}{\@@PrecioT}\space (\Moneda)\hfill\mbox{}}%
- \if at lineacompleta \hspace*{\tabcolsep}\zsaveposx{LineaNodoBCoordX}\hspace*{-\tabcolsep}\fi
+ \@PrecioTAuxCmd{\mbox{}\hfill \@LetraTitColumnas \ifbool{SinCantidad}{\@@Precio}{\@@PrecioT}\space (\Moneda)\hfill\mbox{}}%
+ \if at LineaCompleta \hspace*{\tabcolsep}\zsaveposx{LineaNodoBCoordX}\hspace*{-\tabcolsep}\fi
  \\
  \ifbool{SinLineasHoriInt}{}{\hline}%
  %
  #1% Aquí entran todos los items que el usuario declara dentro del ambiente.
- \\% El último fin de línea se hace aquí.
+ \@CalculaSeparaItemsExtraFinal
+ \\[\@SeparaItemsExtraFinal]% El último fin de línea se hace aquí.
  \if at conlineasha\hline\fi% Se verifica si hace falta una línea horizontal o no.
  \if at filas
-  % Esto en lugar de \if at exparriba para que no se haga una linea vacía en la tabla cuando la caja está vacía.
+  % Esto en lugar de \if at expandecuadro para que no se haga una linea vacía en la tabla cuando la caja está vacía.
   \ifdim \ht\@CajaEspacioVacio=0pt
-   \ifbool{SinLineasHoriExt}{}{\if at conlineasha\else\hline\fi}% Verificamos si hay que poner la línea horizontal. Si está 'conlineasha' ya salió debido a esta opción.
+   \ifdefvoid{\@NotaInterna}{%
+    \ifbool{SinLineasHoriExt}{}{%
+     \if at conlineasha\else\hline\fi}% Verificamos si hay que poner la línea horizontal. Si está 'conlineasha' ya salió debido a esta opción.
+    }{\@ColumnasMultiColumnNotaIntAuxCmd\ifbool{SinLineasHoriExt}{}{\hline}}%
   \else
-   \ifbool{PrimeroDescrip}{&\usebox{\@CajaEspacioVacio}&&&&&\\}{&&\usebox{\@CajaEspacioVacio}&&&&\\}%
+   \ifbool{PrimeroDescripcion}{&\usebox{\@CajaEspacioVacio}&&&&&&\\}{&&\usebox{\@CajaEspacioVacio}&&&&&\\}%
+   \ifdefvoid{\@NotaInterna}{}{\@ColumnasMultiColumnNotaIntAuxCmd}%
    \ifbool{SinLineasHoriExt}{}{\hline}% Siempre que hay relleno se pone la línea acá.
   \fi
  \else
@@ -1345,7 +1588,7 @@
   \ifdim \ht\@CajaEspacioVacio=0pt
   \else
    % Rellenamos la tabla con espacio espúreo, y le agregamos las lineas externas, si aplica.
-   \ifbool{SinLineasVertExt}{\multicolumn{7}{c}{\usebox{\@CajaEspacioVacio}}}{\multicolumn{7}{|c|}{\usebox{\@CajaEspacioVacio}}}\\
+   \ifbool{SinLineasVertExt}{\multicolumn{8}{c}{\usebox{\@CajaEspacioVacio}}}{\multicolumn{8}{|c|}{\usebox{\@CajaEspacioVacio}}}\\
   \fi
   % Si pedimos sin totalizaciones, entonces cerramos la tabla ya, si no, calculamos los totales y los escribimos
   \if at sintotales
@@ -1357,14 +1600,16 @@
     \@EscribeTotalColAgrupado
    \else
     \if at Exento \@EscribeTotalCol{E}\fi
-    \if at BIR\@EscribeTotalCol{R}\if at ivaexpresado\@EscribeTotalColAlicuota{R}\fi\fi
-    \@EscribeTotalCol{G}\if at ivaexpresado\@EscribeTotalColAlicuota{G}\fi
-    \if at BIA\@EscribeTotalCol{A}\if at ivaexpresado\@EscribeTotalColAlicuota{A}\fi\fi
+    \if at BIR\@EscribeTotalCol{R}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{R}\fi\fi
+    \@EscribeTotalCol{G}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{G}\fi
+    \ifbool{Electro}{\@EscribeTotalColAlicuotaGDesc}{}%
+    \if at BIA\@EscribeTotalCol{A}\if at sinivaexpresado\else\@EscribeTotalColAlicuota{A}\fi\fi
    \fi
-   \if at ivaexpresado\cline{2-2}\fi
+   \if at sinivaexpresado\else\cline{2-2}\fi
    \hfill \@LetraTitTotal\@@Total & \@LetraNumTotal\numprint{\Total}\\
    \end{tabular}\endgroup
    \\
+   \ifdefvoid{\@NotaInterna}{}{\@ColumnasMultiColumnNotaIntAuxCmd}%
    \ifbool{SinLineasHoriExt}{}{\hline}%
   \fi
  \fi
@@ -1376,8 +1621,8 @@
  \if at filas
   \@CalculaTotalesI
   \@LetraNumTotales
-  \vspace*{\@SeparaElementos}\par
-  \if at exparriba\else\vfill\fi
+  \vspace*{\@SeparaVertical}\par
+  \if at expandecuadro\else\vfill\fi
   \@GeneraCajasTotalesFilas
   \newbox{\@CajaTotal}%
   \savebox{\@CajaTotal}{{\@LetraTitTotal\@@Total}: \@LetraNumTotal\numprint{\Total}}%
@@ -1425,7 +1670,7 @@
      \if at Exento\usebox{\@CajaBIE}\hspace*{\@SeparaMinTotales}\fi\usebox{\@CajaTotal}%
      \if at centrado\hspace*{\@SepTotales}\fi
     \else% Aquí casi cualquier cosa tiene aspecto feo.
-     \ClassWarning{factura}{Es mejor no usar la opción de totalización en filas en este caso, o disminuir los tamaños de los tipos de letra para la totalización}{}%
+     \CLASSWARNING{Es mejor no usar la opción de totalización en filas en este caso, o disminuir los tamaños de los tipos de letra para la totalización}%
      \centering{%
       \begin{tabular}{r@{\hspace*{\@SeparaMinTotales}}l}
        \usebox{\@CajaBIAliR} & \usebox{\@CajaBIAliA} \\[\@SeparaFilas]
@@ -1436,97 +1681,82 @@
   \fi
  \fi
  \par
- \if at exparriba
+ \if at expandecuadro
   \vspace*{-\@EspacioVacioInicial}%
   \vspace*{\@EspacioVacioFinal}%
   \zsaveposy{EspacioVacioInicial}%
  \fi
  \vfill
- \if at exparriba\zsaveposy{EspacioVacioFinal}\fi
- \vspace*{\@SeparaElementos}\par}
+ \if at expandecuadro\zsaveposy{EspacioVacioFinal}\fi
+ \vspace*{\@SeparaVertical}\par
+ \ifdefvoid{\@NotaExterna}{}{\parbox[t]{\linewidth}{\@LetraNotaExterna\@NotaExterna}\vspace*{\@SeparaVertical}\par}}
 
  \ifbool{SinCantidad}
  % Definamos todos los comandos \Item***. El descuento es opcional; por eso usamos G{0} en \NewDocumentCommand.
  {%
-  \if at descuentos
-   \NewDocumentCommand{\Item}{m m G{0}}{\@ITEM{G}{1}{#1}{#2}{#3}}% Ítem normal.
-   \NewDocumentCommand{\ItemR}{m m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemA}{m m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemE}{m m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}{#2}{#3}}% Ítem con IVA reducido.
-  \else
-   \newcommand{\Item}[2]{\@ITEM{G}{1}{#1}{#2}{0}}% Ítem normal.
-   \newcommand{\ItemR}[2]{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemA}[2]{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemE}[2]{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}{#2}{0}}% Ítem con IVA reducido.
-  \fi
-  \newcommand{\ItemX}[1]{\@ITEM{X}{1}{#1}{0}{0}}% Ítem sin precio.
+  \NewDocumentCommand{\Item}{m o m G{0}}{\@ITEM{G}{1}{#1}[#2]{#3}{#4}}% Ítem normal.
+  \NewDocumentCommand{\ItemR}{m o m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{1}{#1}[#2]{#3}{#4}}% Ítem con IVA reducido.
+  \NewDocumentCommand{\ItemA}{m o m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{1}{#1}[#2]{#3}{#4}}% Ítem con IVA adicional.
+  \NewDocumentCommand{\ItemE}{m o m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{1}{#1}[#2]{#3}{#4}}% Ítem exento de IVA.
+  \NewDocumentCommand{\ItemX}{m o}{\@ITEM{X}{1}{#1}[#2]{0}{0}}% Ítem sin precio.
   \let\ItemG\Item
   \if at csv
    \if at descuentos
-    \immediate\write\csv{"\@@Descripcion","\@@Descuento","\@@Precio \space (\Moneda)"}
+    \immediate\write\csv{"\@@Descripcion","\@@Descuento","\@@Precio \space (\Moneda)","\@@IVA"}%
    \else
-    \immediate\write\csv{"\@@Descripcion","\@@Precio \space (\Moneda)"}
+    \immediate\write\csv{"\@@Descripcion","\@@Precio \space (\Moneda)","\@@IVA"}%
    \fi
   \fi}
  {%
-  \if at descuentos
-   \NewDocumentCommand{\Item}{m m m G{0}}{\@ITEM{G}{#1}{#2}{#3}{#4}}% Ítem normal.
-   \NewDocumentCommand{\ItemR}{m m m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}{#3}{#4}}% Ítem con IVA reducido.
-   \NewDocumentCommand{\ItemA}{m m m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}{#3}{#4}}% Ítem con IVA adicional.
-   \NewDocumentCommand{\ItemE}{m m m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}{#3}{#4}}% Ítem exento de IVA.
-  \else
-   \newcommand{\Item}[3]{\@ITEM{G}{#1}{#2}{#3}{0}}% Ítem normal.
-   \newcommand{\ItemR}[3]{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}{#3}{0}}% Ítem con IVA reducido.
-   \newcommand{\ItemA}[3]{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}{#3}{0}}% Ítem con IVA adicional.
-   \newcommand{\ItemE}[3]{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}{#3}{0}}% Ítem exento de IVA.
-  \fi
-  \newcommand{\ItemX}[2]{\@ITEM{X}{#1}{#2}{0}{0}}% Ítem sin precio.
+  \NewDocumentCommand{\Item}{m m o m G{0}}{\@ITEM{G}{#1}{#2}[#3]{#4}{#5}}% Ítem normal.
+  \NewDocumentCommand{\ItemR}{m m o m G{0}}{\global\@BIRtrue\global\@Gtrue\@ITEM{R}{#1}{#2}[#3]{#4}{#5}}% Ítem con IVA reducido.
+  \NewDocumentCommand{\ItemA}{m m o m G{0}}{\global\@BIAtrue\global\@Gtrue\@ITEM{A}{#1}{#2}[#3]{#4}{#5}}% Ítem con IVA adicional.
+  \NewDocumentCommand{\ItemE}{m m o m G{0}}{\global\@Exentotrue\global\@Gtrue\@ITEM{E}{#1}{#2}[#3]{#4}{#5}}% Ítem exento de IVA.
+  \NewDocumentCommand{\ItemX}{m m o}{\@ITEM{X}{#1}{#2}[#3]{0}{0}}% Ítem sin precio.
   \let\ItemG\Item
   \if at csv
    \if at cdu
     \if at descuentos
-     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Cantidad","\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
    \if at dcu
     \if at descuentos
-     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@Cantidad","\@@PrecioU \space (\Moneda)","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
    \if at duc
     \if at descuentos
-     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@Descuento","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@Descuento","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \else
-     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@PrecioT \space (\Moneda)"}%
+     \immediate\write\csv{"\@@Descripcion","\@@PrecioU \space (\Moneda)","\@@Cantidad","\@@PrecioT \space (\Moneda)","\@@IVA"}%
     \fi
    \fi
   \fi}
 
 \if at factura
- % Los descuentos totales no son compatibles -y no sé si lo serán- con el modo de totalización en filas.
+ % Los descuentos totales no son compatibles -y no creo que lo vayan a ser- con el modo de totalización en filas.
  \if at filas
-  \if at Descuentos
-   \ClassWarning{factura}{La opción 'filas' no es compatible con los descuentos totales; sin efecto opción 'filas'.}{}
+  \if at DescuentoTotal
+   \CLASSWARNING{La opción 'filas' no es compatible con los descuentos totales; sin efecto opción 'filas'}
    \@filasfalse
   \fi
  \fi
+ \if at reverso
+ \else
+   \RenewEnviron{reverso}{}
+ \fi
  \if at cotizacion\def\@Denominacion{\@@DenomCotiza}\else\def\@Denominacion{\@@DenomFactura}\fi%  Fijamos la denominación del documento paras las cotizaciones o facturas, que son casos particulares del modo 'factura'.
- \AtEndPreamble{%  La geometría debe aplicarse aquí.
-  \expandafter\geometry\expandafter{\@GeometriaFactura}}
- \AtBeginDocument{%  Aquí en la factura hay que cargar el estilo de página del reporte, pero con la factura se aplicará \thispagestyle{empty} luego, aunque quedará \pagestyle aplicado desde ahora.
-  \if at fondoreportestar
-   \pagestyle{soloabajo}%  Cuando el fondo es con '*' la información de página va sólo abajo.
-  \else
-   \pagestyle{plain}%  Esto aplica para cuando se define un fondo sin '*' y cuando no se define fondo en el reporte.
-  \fi
+ \AtEndPreamble{\expandafter\geometry\expandafter{\@GeometriaFactura}}%  La geometría debe aplicarse aquí.
+ \AtBeginDocument{%
   \addtolength{\@PosFechaX}{\oddsidemargin+1in}%  Le sumamos el margen izquierdo a las posiciones de las cosas; importante que se haga en un \AtBeginDocument antes de que empiecen a escribirse otras cosas que también se agregan a \AtBeginDocument.
   \addtolength{\@PosDenomX}{\oddsidemargin+1in}%
   \addtolength{\@PosControlX}{\oddsidemargin+1in}%
-  \addtolength{\@PosCondX}{\oddsidemargin+1in}%
+  \addtolength{\@PosCondicionesX}{\oddsidemargin+1in}%
   \addtolength{\@PosFirmasXuno}{\oddsidemargin+1in}%
   \setlength{\parindent}{0pt}%
   \setlength{\lineskip}{0pt}%
@@ -1534,48 +1764,49 @@
   \expandafter\setlength{\@SepTotales}{\the\@SeparaMinTotales plus 1fill}% \@SeparaMinTotales es el mínimo espacio entre los totales en el modo 'filas', y SepTotales es una dimensión interna, estirable, con ese como su mínimo.
   \thispagestyle{empty}%
   \pagenumbering{roman}%
-  \@EncabezadoFactura}
-  \if at reporte
-   \expandafter\AtBeginShipoutNext
-  \else
-   \expandafter\AtEndDocument%  Para la factura no puede estar lo que viene en un \AtBeginDocument porque se inserta un espacio extra que genera una página extra; tiene que estar en \AtEndDocument.
-  \fi
-   {%
+  \@EncabezadoFactura
+  \@EscribeNotaPrevia}
+  \AtBeginShipoutNext{% Antes abría aquí un \AtBeginShipoutNext cuando había reporte y un \AtEndDocument cuando no. No es necesario eso. También lo modifiqué en \FirmaFactura.
    \@CargaFondoFactura
-   \@PosicionaFecha
+   \@PosicionaFechas
    \if at denom\@PosicionaDenom\fi
-   \if at confirmas\@PosicionaFirmas\fi
-   \if at concondiciones\@PosicionaCondiciones\fi
-   \if at prefactura\@PosicionaNumControl\fi}
-
+   \if at prefactura\@PosicionaNumControl\fi
+   \if at sinfirmas\else\@PosicionaFirmas\fi
+   \ifdefvoid{\@Condiciones}{}{\@PosicionaCondiciones}}
  \if at linea
-  \RequirePackage{zref-savepos}%  Para determinar las coordenadas de la línea.
-  \RequirePackage{eso-pic}%  Para poder usar \AtBeginShipoutNext porque si no se hace en el 'shipout' de la página se genera un espacio en blanco extra.
+  \RequirePackage{zref-savepos}
+  % Para determinar las coordenadas de la línea hay que usar \AtBeginShipoutNext porque si no se hace en el 'shipout' de la página se genera un espacio en blanco extra.
   \AtBeginShipoutNext{\if at linea\@DibujaLinea\fi}
    \if at filas
-    \ifbool{SinLineasVertInt}{\@lineacompletatrue}
+    \ifbool{SinLineasVertInt}{\@LineaCompletatrue}
    \else
-    \@lineahastatotaltrue\@lineadesdeiniciotrue
+    \@LineaHastaTotaltrue\@LineaDesdeIniciotrue
    \fi
  \fi
-
  %% El comando para la descripción del servicio prestado.
  \NewDocumentCommand{\Descripcion}{+m}{%
-  \@LetraDescripcion
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaDescrip, line width=\@GrosorLineaDescrip, rounded corners=\@EsquinaLineaDescrip,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraDescrip, shadow yshift=-\@SombraDescrip}]{%
-    \ifbool{ExpAbajo}
-     {\parbox[t][\textheight-\pagetotal-2\@SeparaInternaDescrip-\@GrosorLineaDescrip-\@SombraDescrip]
-      {\textwidth-2\@SeparaInternaDescrip-\@GrosorLineaDescrip-\@SombraDescrip}}%
-     {\parbox[t]{\textwidth-\@SombraDescrip-2\@SeparaInternaDescrip-2\@GrosorLineaDescrip}}%
-    {\setlength{\parindent}{0.5cm}%
-     \setlength{\parskip}{2pt plus 8pt}%
-     \ifbool{ExpAbajo}{\vfill}{}%
-      #1%
-     \ifbool{ExpAbajo}{\vfill}{}}};%
-  \end{tikzpicture}
-  \par\vspace*{\@SombraDescrip}}%
+  {% Abrimos un grupo adicional para que la redefinición del entorno 'tikzpicture' sea local.
+   \@LetraDescripcion
+   % Cuando la línea tiene grosor cero, hacemos que el entorno 'tikzpicture' sea "fake", y redefinimos \node para que obvie los parámetros que le dimos como argumento opcional.
+   \ifdim\@GrosorLineaDescripcion=0pt%
+    \setlength{\@SeparaInternaDescripcion}{0pt}\setlength{\@EsquinaLineaDescripcion}{0pt}\setlength{\@SombraDescripcion}{0pt}%
+    \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+   \fi
+   \begin{tikzpicture}
+    % Expandimos después para poderle pasar el contenido de la macro como argumento opcional a \node.
+    \expandafter\node\expandafter[\@DescripcionTIKZ]{%
+     \ifbool{ExpAbajo}
+      {\parbox[t][\textheight-\pagetotal-2\@SeparaInternaDescripcion-\@GrosorLineaDescripcion-\@SombraDescripcion]
+       {\textwidth-2\@SeparaInternaDescripcion-\@GrosorLineaDescripcion-\@SombraDescripcion}}%
+      {\parbox[t]{\textwidth-\@SombraDescripcion-2\@SeparaInternaDescripcion-2\@GrosorLineaDescripcion}}%
+     {\setlength{\parindent}{0.5cm}%
+      \setlength{\parskip}{2pt plus 8pt}%
+      \ifbool{ExpAbajo}{\vfill}{}%
+       #1%
+      \ifbool{ExpAbajo}{\vfill}{}}}%
+    \ifdim\@GrosorLineaDescripcion=0pt\else ;\fi% El fin del nodo va cuando hay el entorno tikzpicture original.
+   \end{tikzpicture}
+   \par\vspace*{\@SombraDescripcion}}}%
 \else
  \RenewEnviron{factura}{%
   \@ZERO
@@ -1583,6 +1814,7 @@
   \let\@ITEM\@CalculaItem
   \BODY
   \@CalculaTotalesI}
+ \RenewEnviron{reverso}{}
  \NewDocumentCommand{\Descripcion}{+m}{}
 \fi
 
@@ -1601,7 +1833,7 @@
   \@CargaFondoReporte
   \@EncabezadoReporte
   \ifdefvoid{\@EstiloPagReporteResto}{%
-   \if at fondoreportestar%  Si no usamos \EstiloPagReporte entonces se fijará 'soloabajo' cuando se use \FondoReporte* para que sólo use marcas de pie de página, y si no se usó \FondoReporte* entonces se fijará 'plain' que usa cabeceras y piés de página.
+   \if at FondoReporteStar%  Si no usamos \EstiloPagReporte entonces se fijará 'soloabajo' cuando se use \FondoReporte* para que sólo use marcas de pie de página, y si no se usó \FondoReporte* entonces se fijará 'plain' que usa cabeceras y pies de página.
     \pagestyle{soloabajo}%
    \else
     \pagestyle{plain}%
@@ -1608,8 +1840,8 @@
    \fi}
    {\pagestyle{\@EstiloPagReporteResto}}%  Si usamos \EstiloPagReporte en su argumento obligatorio entonces fijamos ese estilo de página.
   \ifdefvoid{\@EstiloPagReporteUno}{%
-   \if at fondoreporte%  Si no le damos a \EstiloPagReporte su argumento opcional, entonces se fijará 'solonumpag' como el estilo de página para la primera página, pero solamente si usamos \FondoReporte, ya que el estilo de página predeterminado al usar \FondoReporte* ya se acaba de fijar y no necesita el caso especial de la primera hoja (\thispagestyle).
-    \if at fondoreportestar
+   \if at FondoReporte%  Si no le damos a \EstiloPagReporte su argumento opcional, entonces se fijará 'solonumpag' como el estilo de página para la primera página, pero solamente si usamos \FondoReporte, ya que el estilo de página predeterminado al usar \FondoReporte* ya se acaba de fijar y no necesita el caso especial de la primera hoja (\thispagestyle).
+    \if at FondoReporteStar
     \else
      \thispagestyle{solonumpag}%
     \fi
@@ -1626,7 +1858,7 @@
 
 %% Comando para el diseño de la forma libre.
 \newcommand{\@CargaFondoFactura}{%
- \if at fondofactura
+ \if at FondoFactura
   \begin{textblock*}{\paperwidth}(0pt,0pt)%
    \includegraphics{\@FondoFactura}%
   \end{textblock*}%
@@ -1635,8 +1867,8 @@
 %% Comando para el fondo del reporte.
 \newcommand{\@CargaFondoReporte}{%
  \begin{textblock*}{\paperwidth}(0pt,0pt)% Tuve que abrir el textblock* aquí para que aplique siempre; de esta manera se corrige un defecto que se produce cuando se usa \vspace* al inicio de la página (dentro de \@EncabezadoReporte).
-  \if at fondoreporte
-   \if at fondoreportestar
+  \if at FondoReporte
+   \if at FondoReporteStar
     \AddToShipoutPictureBG{\includegraphics{\@FondoReporte}}%
    \else
      \noindent\includegraphics{\@FondoReporte}%
@@ -1648,9 +1880,7 @@
 \newcommand{\@PosicionaFirmas}{%
  \savebox{\@CajaFirmas}{%
   \parbox{\textwidth+\oddsidemargin+1in-\@PosFirmasXuno-\@PosFirmasXdos}{\@EstiloFirmas}}%
- \ifbool{FirmasYnegativo}
-  {\addtolength{\@PosFirmasY}{\paperheight-\ht\@CajaFirmas-\dp\@CajaFirmas}}
-  {}%
+ \ifbool{FirmasYnegativo}{\addtolength{\@PosFirmasY}{\paperheight-\ht\@CajaFirmas-\dp\@CajaFirmas}}{}%
  \begin{textblock*}{\wd\@CajaFirmas}(\@PosFirmasXuno,\@PosFirmasY)%
   \usebox{\@CajaFirmas}%
  \end{textblock*}}
@@ -1658,11 +1888,10 @@
 %% Comando que coloca las condiciones del documento.
 \newcommand{\@PosicionaCondiciones}{%
  \savebox{\@CajaCond}{%
-  \parbox{\textwidth+\oddsidemargin+1in-\@PosCondX}{\@EstiloCondiciones}}%
- \ifbool{CondYnegativo}
-  {\addtolength{\@PosCondY}{\paperheight}}% Aquí la caja abre hacia abajo, por eso no restamos el tamaño de la caja (\ht y \dp).
-  {}%
- \begin{textblock*}{\wd\@CajaCond}(\@PosCondX,\@PosCondY)%
+  \parbox{\textwidth+\oddsidemargin+1in-\@PosCondicionesX}{\@EscribeCondiciones}}%
+ \ifbool{CondYnegativo}{\addtolength{\@PosCondicionesY}{\paperheight}}{}%
+ \ifbool{CondYarriba}{\addtolength{\@PosCondicionesY}{-\ht\@CajaCond-\dp\@CajaCond}}{}% Aquí la caja abre hacia abajo, a menos de que usemos \PosCondiciones*
+ \begin{textblock*}{\wd\@CajaCond}(\@PosCondicionesX,\@PosCondicionesY)%
   \usebox{\@CajaCond}%
  \end{textblock*}}
 
@@ -1669,12 +1898,9 @@
 %% Comando que coloca el número de control.
 \newcommand{\@PosicionaNumControl}{%
  \savebox{\@CajaControl}{\@EstiloNumControl}%
- \ifbool{ControlXnegativo}
-  {\addtolength{\@PosControlX}{\textwidth-\wd\@CajaControl}}
-  {}%
- \ifbool{ControlYnegativo}
-  {\addtolength{\@PosControlY}{\paperheight-\ht\@CajaControl-\dp\@CajaControl}}
-  {}%
+ \ifbool{ControlXnegativo}{\addtolength{\@PosControlX}{\textwidth-\wd\@CajaControl}}{}%
+ \ifbool{ControlYnegativo}{\addtolength{\@PosControlY}{\paperheight}}{}%
+ \ifbool{ControlYarriba}{\addtolength{\@PosControlY}{-\ht\@CajaControl-\dp\@CajaControl}}{}%
  \begin{textblock*}{\wd\@CajaControl}(\@PosControlX,\@PosControlY)%
   \usebox{\@CajaControl}%
  \end{textblock*}}
@@ -1682,25 +1908,19 @@
 %% Comando que coloca la denominación del documento.
 \newcommand{\@PosicionaDenom}{%
  \savebox{\@CajaDenom}{\@EstiloDenom}%
- \ifbool{DenomXnegativo}
-  {\addtolength{\@PosDenomX}{\textwidth-\wd\@CajaDenom}}
-  {}%
- \ifbool{DenomYnegativo}
-  {\addtolength{\@PosDenomY}{\paperheight-\ht\@CajaDenom-\dp\@CajaDenom}}
-  {}%
+ \ifbool{DenomXnegativo}{\addtolength{\@PosDenomX}{\textwidth-\wd\@CajaDenom}}{}%
+ \ifbool{DenomYnegativo}{\addtolength{\@PosDenomY}{\paperheight}}{}%
+ \ifbool{DenomYarriba}{\addtolength{\@PosDenomY}{-\ht\@CajaDenom-\dp\@CajaDenom}}{}%
  \begin{textblock*}{\wd\@CajaDenom}(\@PosDenomX,\@PosDenomY)%
   \usebox{\@CajaDenom}%
  \end{textblock*}}
 
-%% Comando que coloca la fecha.
-\newcommand{\@PosicionaFecha}{%
- \savebox{\@CajaFecha}{\@EstiloFecha}%
- \ifbool{FechaXnegativo}
-  {\addtolength{\@PosFechaX}{\textwidth-\wd\@CajaFecha}}
-  {}%
- \ifbool{FechaYnegativo}
-  {\addtolength{\@PosFechaY}{\paperheight-\ht\@CajaFecha-\dp\@CajaFecha}}
-  {}%
+%% Comando que coloca la(s) fecha(s).
+\newcommand{\@PosicionaFechas}{%
+ \savebox{\@CajaFecha}{\@EstiloFechas}%
+ \ifbool{FechaXnegativo}{\addtolength{\@PosFechaX}{\textwidth-\wd\@CajaFecha}}{}%
+ \ifbool{FechaYnegativo}{\addtolength{\@PosFechaY}{\paperheight}}{}%
+ \ifbool{FechaYarriba}{\addtolength{\@PosFechaY}{-\ht\@CajaFecha-\dp\@CajaFecha}}{}%
  \begin{textblock*}{\wd\@CajaFecha}(\@PosFechaX,\@PosFechaY)%
   \usebox{\@CajaFecha}%
  \end{textblock*}}
@@ -1714,73 +1934,104 @@
   \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
   \ifdefvoid{\@TituloReporte}{}{\vspace*{\baselineskip}{\@LetraTitReporte \centering \@TituloReporte \par}}}}
 
-%% Comando que coloca la caja con los datos del cliente.
+%% Comando que coloca las dos cajas del encabezado: la de los datos del cliente y la del resumen.
 \newcommand{\@EscribeDatos}{%
- {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía sea sólo local.
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-   \parbox{\textwidth-\@SombraEncabez-2\@SeparaInternaEncabez-\@GrosorLineaEncabez}{%
-    \hfill {\@LetraTitEnc \@@Datos} \hfill \mbox{}\par
-    {\bfseries \@@RazonSocial} \@RazonSocial
-    \dotfill
-    {\bfseries \@@RIF} {\ttfamily \@RIF}%
-    \par
-    \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
-    {\bfseries \@@Direccion} \@Direccion
-    \par
-    {\bfseries \@@Telefono} {\ttfamily \@Telefono}%
-    \ifdefvoid{\@Email}{}{\hspace*{0.666em}\@CaracterSeparaTelefonoEmail\hspace*{0.666em}{\bfseries \@@Email} {\ttfamily \@Email}}}};%
+ {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía y la redefinición del entorno 'tikzpicture' sean locales.
+  \ifdim\@GrosorLineaEncabezado=0pt%
+   \setlength{\@SeparaInternaEncabezado}{0pt}\setlength{\@EsquinaLineaEncabezado}{0pt}\setlength{\@SombraEncabezado}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@DatosTIKZ]{%
+   \parbox{\textwidth-\@SombraEncabezado-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado}{\@DatosAux}}%
+    \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \par\vspace*{\@SombraEncabez}}}%  Para que textblock* esté en modo vertical.
+  \par\vspace*{\@SombraEncabezado}}}%  Para que textblock* esté en modo vertical.
 
-%% Comandos auxiliares para los datos y el resumen.
-\newcommand{\@DatosAux}{%
- \vfill
- \hfill {\@LetraTitEnc \@@Datos}\hfill \mbox{}\par
- {\bfseries \@@RazonSocial} \@RazonSocial \par
- {\bfseries \@@RIF} {\ttfamily \@RIF} \par
- \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
- {\bfseries \@@Direccion} \@Direccion \par
- {\bfseries \@@Telefono} {\ttfamily \@Telefono} \hfill \par
- \ifdefvoid{\@Email}{}{{\bfseries \@@Email} {\ttfamily \@Email}}%
- \vfill}
-
-\newcommand{\@ResumenAux}{%
- \hfill {\@LetraTitEnc \@@Resumen}\hfill \mbox{}%
- \vfill\@Resumen\vfill}
-
-%% Comando que coloca las dos cajas del encabezado: la de los datos del cliente y la del resumen.
 \newcommand{\@EscribeDatosResumen}{%
- {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía sea sólo local.
+ {\@LetraEncFactura% Abrimos un nuevo grupo para que el cambio de tipografía y la redefinición del entorno 'tikzpicture' sean locales.
+  \ifdim\@GrosorLineaEncabezado=0pt%
+   \setlength{\@SeparaInternaEncabezado}{0pt}\setlength{\@EsquinaLineaEncabezado}{0pt}\setlength{\@SombraEncabezado}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
   \savebox{\@CajaDatos}{%
-   \parbox[t]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-    \@DatosAux}}%
+   \parbox[t]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{\@DatosAux*}}%
   \savebox{\@CajaResumen}{%
-   \parbox[t]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-    \@ResumenAux}}%
+   \parbox[t]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{\@ResumenAux}}%
   \setlength{\@TamDatos}{\ht\@CajaDatos+\dp\@CajaDatos}%
   \setlength{\@TamResumen}{\ht\@CajaResumen+\dp\@CajaResumen}%
   \ifdim\@TamDatos>\@TamResumen
-   \setlength{\@TamFinalEncabez}{\@TamDatos}%
+   \setlength{\@TamFinalEncabezado}{\@TamDatos}%
   \else
-   \setlength{\@TamFinalEncabez}{\@TamResumen}%
+   \setlength{\@TamFinalEncabezadoado}{\@TamResumen}%
   \fi
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-    \parbox[t][\@TamFinalEncabez]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-    \@DatosAux}};%
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@DatosTIKZ]{%
+    \parbox[t][\@TamFinalEncabezado]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{%
+    \@DatosAux*}}%
+   \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \hspace*{\@SeparaEncabez}\hspace*{\@SombraEncabez}%
-  \begin{tikzpicture}
-   \node[draw=black, fill=white, inner sep=\@SeparaInternaEncabez, line width=\@GrosorLineaEncabez, rounded corners=\@EsquinaLineaEncabez,
-         copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabez, shadow yshift=-\@SombraEncabez}]{%
-    \parbox[t][\@TamFinalEncabez]{\textwidth/2-\@SeparaEncabez/2-2\@SeparaInternaEncabez-\@GrosorLineaEncabez-\@SombraEncabez}{%
-     \@ResumenAux}};%
+  \hspace*{\@SeparaDatosResumen}\hspace*{\@SombraEncabezado}%
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@ResumenTIKZ]{%
+    \parbox[t][\@TamFinalEncabezado]{\textwidth/2-\@SeparaDatosResumen/2-2\@SeparaInternaEncabezado-\@GrosorLineaEncabezado-\@SombraEncabezado}{%
+     \@ResumenAux}}%
+   \ifdim\@GrosorLineaEncabezado=0pt\else ;\fi
   \end{tikzpicture}%
-  \par\vspace*{\@SombraEncabez}}}%  El \par es para que textblock* esté en modo vertical.
+  \par\vspace*{\@SombraEncabezado}}}%  El \par es para que textblock* esté en modo vertical.
 
+%% Comando que coloca la caja para la nota previa, con la posibilidad de TikZ.
+\newcommand{\@EscribeNotaPrevia}{%
+ {% Abrimos un nuevo grupo para que la redefinición del entorno 'tikzpicture' sea local.
+  \baselineskip0pt
+  \ifdefvoid{\@NotaPrevia}{}{%
+   \ifdim\@GrosorLineaNotaPrevia=0pt%
+    \setlength{\@SeparaInternaNotaPrevia}{0pt}\setlength{\@EsquinaLineaNotaPrevia}{0pt}\setlength{\@SombraNotaPrevia}{0pt}%
+    \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+   \fi
+   \begin{tikzpicture}%
+    \expandafter\node\expandafter[\@NotaPreviaTIKZ]{%
+    \parbox{\textwidth-\@SombraNotaPrevia-2\@SeparaInternaNotaPrevia-\@GrosorLineaNotaPrevia}{\@EstiloNotaPrevia}}%
+     \ifdim\@GrosorLineaNotaPrevia=0pt\else ;\fi
+   \end{tikzpicture}%
+   \par\vspace*{\@SombraNotaPrevia}\vspace*{\@SeparaVertical}%
+   \if at expandecuadro\else\vfill\fi}}}
+
+%% Comando que coloca la caja para las condiciones, con la posibilidad de TikZ.
+\newcommand{\@EscribeCondiciones}{%
+ {% Abrimos un nuevo grupo para que la redefinición del entorno 'tikzpicture' sea local.
+  \ifdim\@GrosorLineaCondiciones=0pt%
+   \setlength{\@SeparaInternaCondiciones}{0pt}\setlength{\@EsquinaLineaCondiciones}{0pt}\setlength{\@SombraCondiciones}{0pt}%
+   \renewenvironment{tikzpicture}{\NewDocumentCommand{\node}{o +m}{####2}}{}%
+  \fi
+  \begin{tikzpicture}%
+   \expandafter\node\expandafter[\@CondicionesTIKZ]{%
+   \parbox{\textwidth-\@SombraCondiciones-2\@SeparaInternaCondiciones-\@GrosorLineaCondiciones}{\@EstiloCondiciones}}%
+    \ifdim\@GrosorLineaCondiciones=0pt\else ;\fi
+  \end{tikzpicture}%
+  \par\vspace*{\@SombraCondiciones}}}
+
+%% Comandos auxiliares para los datos y el resumen.
+%% En el caso de los datos, la versión \@DatosAux se ejecuta cuando no hay resumen, y la versión \@DatosAux* se ejecuta cuando hay resumen.
+\NewDocumentCommand{\@DatosAux}{s}{%
+ \hfill {\@LetraTitEnc \@@Datos}\hfill \mbox{}\par
+ \IfBooleanT{#1}{\vfill}%
+ {\bfseries \if at Nombre \@@Nombre \else \@@RazonSocial \fi} \@RazonSocial
+ \IfBooleanTF{#1}{\par}{\dotfill}%
+ {\bfseries \@@RIF} {\ttfamily \@RIF}\par
+ \ifdefvoid{\@Contacto}{}{{\bfseries \@@Contacto} \@Contacto \par}%
+ {\bfseries \@@Direccion} \@Direccion \par
+ \ifdefvoid{\@Telefono}{}{{\bfseries \@@Telefono} {\ttfamily \@Telefono}}%
+ \ifdefvoid{\@Email}
+  {\par}
+  {\IfBooleanTF{#1}
+   {\par}
+   {\ifdefvoid{\@Telefono}{}{\hspace*{\@SeparaTelefonoEmail}\@CaracterSeparaTelefonoEmail\hspace*{\@SeparaTelefonoEmail}}}%
+  {\bfseries \@@Email} {\ttfamily \@Email}}%
+ \IfBooleanT{#1}{\vfill}}
+
+\newcommand{\@ResumenAux}{\hfill {\@LetraTitEnc \@@Resumen}\hfill \mbox{}\vfill\@Resumen\vfill}
+
 %% Comando que coloca la línea diagonal.
 \newcommand{\@DibujaLinea}{%
  \@LetraItems% Volvemos a fijar el \baselineskip de la tabla.
@@ -1796,7 +2047,8 @@
   \if at DescA \if at BIA \addtolength{\@LineaNodoYo}{2\baselineskip}\fi\fi
   \if at DescE \if at Exento \addtolength{\@LineaNodoYo}{2\baselineskip}\fi\fi
   \addtolength{\@LineaNodoYo}{\baselineskip/2}%
-  \if at ivaexpresado
+  \if at sinivaexpresado
+  \else
    \addtolength{\@LineaNodoYo}{2\baselineskip}%
    \if at BIR\addtolength{\@LineaNodoYo}{2\baselineskip}\fi
    \if at BIA\addtolength{\@LineaNodoYo}{2\baselineskip}\fi
@@ -1816,32 +2068,26 @@
  \if at csv
   \if at Exento
    \if at DescE
-    \immediate\write\csv{Totales: \@@SubtotalE: \Moneda \SubtE}%
-    \immediate\write\csv{Totales: \@@DescuentoE: \Moneda \DescE}%
+    \immediate\write\csv{Totales: \@@SubtotalE: \Moneda \SubtE^^JTotales: \@@DescuentoE: \Moneda \DescE}%
    \fi
    \immediate\write\csv{Totales: \@@BIE: \Moneda \BIE}%
   \fi
   \if at BIR
    \if at DescE
-    \immediate\write\csv{Totales: \@@SubtotalR: \Moneda \SubtR}%
-    \immediate\write\csv{Totales: \@@DescuentoR: \Moneda \DescR}%
+    \immediate\write\csv{Totales: \@@SubtotalR: \Moneda \SubtR^^JTotales: \@@DescuentoR: \Moneda \DescR}%
    \fi
-   \immediate\write\csv{Totales: \@@BIR: \Moneda \BIR}%
-  \immediate\write\csv{Totales: \@@AlicuotaR: \Moneda \AlicuotaR}%
+   \immediate\write\csv{Totales: \@@BIR: \Moneda \BIR^^JTotales: \@@AlicuotaR: \Moneda \AlicuotaR}%
   \fi
   \if at DescG
-   \immediate\write\csv{Totales: \@@SubtotalG: \Moneda \SubtG}%
-   \immediate\write\csv{Totales: \@@DescuentoG: \Moneda \DescG}%
+   \immediate\write\csv{Totales: \@@SubtotalG: \Moneda \SubtG^^JTotales: \@@DescuentoG: \Moneda \DescG}%
   \fi
-  \immediate\write\csv{Totales: \@@BIG: \Moneda \BIG}%
-  \immediate\write\csv{Totales: \@@AlicuotaG: \Moneda \AlicuotaG}%
+  \immediate\write\csv{Totales: \@@BIG: \Moneda \BIG^^JTotales: \@@AlicuotaG: \Moneda \AlicuotaG}%
+  \FPifeq\AlicuotaGDesc{0}\else\immediate\write\csv{Totales: \@@AlicuotaGDesc: \Moneda \AlicuotaGDesc}\fi
   \if at BIA
    \if at DescA
-    \immediate\write\csv{Totales: \@@SubtotalA: \Moneda \SubtA}%
-    \immediate\write\csv{Totales: \@@DescuentoA: \Moneda \DescA}%
+    \immediate\write\csv{Totales: \@@SubtotalA: \Moneda \SubtA^^JTotales: \@@DescuentoA: \Moneda \DescA}%
    \fi
-   \immediate\write\csv{Totales: \@@BIA: \Moneda \BIA}%
-   \immediate\write\csv{Totales: \@@AlicuotaA: \Moneda \AlicuotaA}%
+   \immediate\write\csv{Totales: \@@BIA: \Moneda \BIA^^JTotales: \@@AlicuotaA: \Moneda \AlicuotaA}%
   \fi
   \immediate\write\csv{Totales: \@@Total: \Moneda \Total}%
   \immediate\closeout\csv

Modified: trunk/Master/texmf-dist/tex/latex/factura/factura.def
===================================================================
--- trunk/Master/texmf-dist/tex/latex/factura/factura.def	2017-12-12 22:35:24 UTC (rev 46052)
+++ trunk/Master/texmf-dist/tex/latex/factura/factura.def	2017-12-12 22:35:59 UTC (rev 46053)
@@ -24,39 +24,47 @@
 %% 
 %% This work consists of the files README and factura.dtx
 %% with its derived files factura.ins, factura.cls, factura.def,
-%% factura-ejemplo-firma.tex, factura-ejemplo-fondo.tex,
-%% factura-ejemplo-membrete.tex, factura-ejemplo-cotizacion.tex,
-%% factura-ejemplo-prefactura.tex, factura-ejemplo-factura1.tex
-%% factura-ejemplo-factura2.tex, factura-ejemplo-factura3.tex,
-%% factura-ejemplo-factura4.tex, factura-ejemplo-factura5.tex,
-%% factura-ejemplo-factura6.tex, factura-ejemplo-factura7.tex,
-%% factura-ejemplo-factura8.tex, factura-ejemplo-reporte1.tex,
-%% factura-ejemplo-reporte2.tex, factura-ejemplo-reporte3.tex,
-%% and factura-beispiel-rechnung.tex.
+%% factura-ejemplo-aux.tex, factura-ejemplo-firma.tex,
+%% factura-ejemplo-fondo.tex, factura-ejemplo-membrete.tex,
+%% factura-ejemplo-cotizacion.tex, factura-ejemplo-prefactura.tex,
+%% factura-ejemplo-factura01.tex, factura-ejemplo-factura02.tex,
+%% factura-ejemplo-factura03.tex, factura-ejemplo-factura04.tex,
+%% factura-ejemplo-factura05.tex, factura-ejemplo-factura06.tex,
+%% factura-ejemplo-factura07.tex, factura-ejemplo-factura08.tex,
+%% factura-ejemplo-factura09.tex, factura-ejemplo-factura10.tex,
+%% factura-ejemplo-reporte1.tex, factura-ejemplo-reporte2.tex,
+%% factura-ejemplo-reporte3.tex and factura-beispiel-rechnung.tex.
 %% 
 \ProvidesFile{factura.def}
-[2017/07/16 v3.02
-Archivo valores iniciales y condiciones de borde para factura.cls
+[2017/12/11 v3.40
+Archivo de valores iniciales y condiciones de borde para factura.cls
 ]
 
-%% La geometría en formato de factura y de reporte.
-%% El margen superior está definido desde el encabezado con los datos del cliente.
-%% El margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
-%% Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
-\GeometriaFactura{letterpaper,vmargin={5cm,5.5cm},  hmargin={1cm,1cm},footskip=0pt,  headsep=0pt,    headheight=0pt}
+%% La geometría para la factura, su reverso, y el reporte.
+%% Para la factura, el margen superior está definido desde el encabezado con los datos del cliente;
+%%  el margen inferior está definido hasta el final de la descripción (o del cuadro de la factura si no hay descripción).
+%%  Hay elementos que salen fuera de estos márgenes, como las firmas, las condiciones del documento, la numeración y la fecha.
+\GeometriaFactura{letterpaper,vmargin={5.2cm,5.5cm},hmargin={1cm,1cm},footskip=0pt,  headsep=0pt,    headheight=0pt}
+\GeometriaReverso{letterpaper,vmargin={1cm,1cm},    hmargin={1cm,1cm},footskip=0cm,  headsep=0pt,    headheight=0pt}
 \GeometriaReporte{letterpaper,vmargin={2.8cm,2.5cm},hmargin={3cm,2cm},footskip=1.2cm,headsep=0.777cm,headheight=1.5cm}
 
-%% Porcentajes de los distintos IVA (general, reducido y adicional):
+%% Factores para los distintos IVA y el límite para el descuento:
 \def\@AlicuotaG{0.12}
+\def\@AlicuotaGDescBajo{0.03}
+\def\@AlicuotaGDescAlto{0.05}
+\def\@AlicuotaGDescLimite{2000000}
 \def\@AlicuotaR{0.08}
-\def\@AlicuotaA{0.22}
+\def\@AlicuotaA{0.27}
 
-%% i) separador de miles, ii) separador decimal, iii) número de decimales para la moneda iv) y para los porcentajes, v) número de dígitos de la numeración de la factura:
+%% i) separador de miles, ii) separador decimal, iii) número de decimales para la moneda iv) y para los porcentajes, v) número de dígitos de la numeración de la factura, vi) formato de la fecha, vii) separadores para la fecha.
 \npthousandsep{.}
 \npdecimalsign{,}
 \def\@DigitosMoneda{2}
 \def\@DigitosPorc{2}
 \def\@DigitosNumeracion{5}
+\def\@FormatoFecha{ddmmyyyy}
+\def\@FormatoFechaEntrada{dd-mm-yyyy}
+\def\@FechaSeparadores{-}
 
 %% La moneda:
 \def\Moneda{Bs.}
@@ -67,17 +75,41 @@
 \def\@DenomAlicuotaA{A}
 \def\@DenomAlicuotaE{(E)}
 
+%% El texto predeterminado para la nota interna por el descuento presidencial.
+\def\@TextoDescuentoPresidencial{Se aplica un descuento del \@AlicuotaGDescPorc\% al IVA General seg\'un Decreto Presidencial 3085 en Gaceta Oficial 41239.}
+
 %% Macros que guardan textos que corresponden a nombres de campos:
 \def\@@Fecha{Fecha de emisi\'on:}
+\def\@@FechaVencimiento{Fecha de vencimiento:}
+\def\@@Control{N\textordmasculine\space CONTROL}
+\def\@@Datos{Datos del cliente}
+\def\@@Resumen{Resumen del servicio}
+\def\@@DenomFactura{FACTURA}
+\def\@@DenomCotiza{COTIZACI\'ON}
 \def\@@RazonSocial{Raz\'on social:}
+\def\@@Nombre{Nombre:}
+\def\@@RIF{R.I.F.:}
+\def\@@CI{C.I.:}
+\def\@@Direccion{Direcci\'on fiscal:}
+\def\@@Telefono{Tel\'efono:}
+\def\@@Email{E-mail:}
+\def\@@Contacto{Persona de contacto:}
+\def\@@Proveedor{Proveedor:}
+\def\@@Cliente{Cliente:}
+\def\@@Emisor{Por el emisor}
+\def\@@Conforme{Recib\'i conforme}
+\def\@@Pagado{PAGADO}
 \def\@@NumItem{\#}
 \def\@@Cantidad{Cantidad}
 \def\@@Descripcion{Descripci\'on}
+\def\@@Precio{Precio}
 \def\@@PrecioU{Precio U.}
 \def\@@PrecioS{Subtotal}
+\def\@@Descuento{Dcto.}
+\def\@@IVA{IVA}
 \def\@@PrecioT{Precio T.}
-\def\@@Precio{Precio}
 \def\@@AlicuotaG{IVA G}
+\def\@@AlicuotaGDesc{Descuento IVA G}
 \def\@@AlicuotaR{IVA R}
 \def\@@AlicuotaA{IVA A}
 \def\@@BIG{BI G}
@@ -85,7 +117,6 @@
 \def\@@BIA{BI A}
 \def\@@BIE{Exento}% La base imponible exenta. ;)
 \def\@@Total{TOTAL}
-\def\@@Descuento{Dcto.}
 \def\@@DescuentoG{Descuento G}
 \def\@@DescuentoR{Descuento R}
 \def\@@DescuentoA{Descuento A}
@@ -94,22 +125,6 @@
 \def\@@SubtotalR{Subtotal R}
 \def\@@SubtotalA{Subtotal A}
 \def\@@SubtotalE{Subtotal E}
-\def\@@RIF{R.I.F.:}
-\def\@@CI{C.I.:}
-\def\@@Contacto{Persona de contacto:}
-\def\@@Direccion{Direcci\'on fiscal:}
-\def\@@Telefono{Tel\'efono:}
-\def\@@Email{E-mail:}
-\def\@@Datos{Datos del cliente}
-\def\@@Resumen{Resumen del servicio}
-\def\@@Conforme{Recib\'i conforme}
-\def\@@Emisor{Por el emisor}
-\def\@@Pagado{PAGADO}
-\def\@@DenomFactura{FACTURA}
-\def\@@DenomCotiza{COTIZACI\'ON}
-\def\@@Control{N\textordmasculine\space CONTROL}
-\def\@@Proveedor{Proveedor:}
-\def\@@Cliente{Cliente:}
 
 %% i) carácter para separar el teléfono del e-mail del cliente,
 %% ii) carácter para los campos vacíos cuando se usa \ItemX,
@@ -125,21 +140,29 @@
   \draw[line width=0.075ex] (0,0) arc (20:70:0.75ex) + (0,0) arc (-70:-20:0.75ex) ++ (0.8ex,0.55ex) arc (0:-100:1ex);
  \end{tikzpicture}}}
 
-%% Separación entre la última letra y el carácter que indica que se continúa en la línea siguiente en la descripción cuando ocupa más de una línea. No vale la pena hacer una macro para cambiar esto.
-\setlength{\@SeparaFinLineaDesc}{0.05cm}
-
 %% Separación entre el inicio de una columna en la tabla y el inicio del texto.
 \tabcolsep=0.15cm
 
+%% Separación entre la última letra y el carácter que indica que se continúa en la línea siguiente en la descripción cuando ocupa más de una línea.
+\setlength{\@SeparaFinLineaDesc}{0.15cm}
+
+%% Separación entre el teléfono y el carácter \@CaracterSeparaTelefonoEmail, y luego desde ese carácter hasta el email,
+%% para cuando no hay resumen.
+\setlength{\@SeparaTelefonoEmail}{0.666em}
+
 %% Grosor de la línea de 'fancyhdr' para las cabeceras, en aquellas donde haya línea.
-\def\@GrosorLineaInfoPag{0.4pt}
+\setlength{\@GrosorLineaInfoPag}{0.4pt}
 
+%% Posición en X desde la derecha y excedente en la línea de la firma.
+\setlength{\@FirmaReportePosX}{2cm}
+\setlength{\@FirmaReporteExcesoLinea}{1.5cm}
+
 %% Posiciones (X,Y) de los objetos: i) fecha, ii) denominación, iii) condiciones, iv) número de control, v) firmas.
-\PosFecha{-0cm}{4.3cm}
-\PosDenom{0cm}{4.3cm}
-\PosControl{0cm}{-2.5cm}
-\PosCond{0cm}{-5.3cm}
-%% 'X' no acepta valores negativos en \PosCond.
+\PosFecha*{-0cm}{5cm}
+\PosDenom*{0cm}{5cm}
+\PosControl*{0cm}{-2.4cm}
+\PosCondiciones{0cm}{-5.3cm}
+%% 'X' no acepta valores negativos en \PosCondiciones.
 \PosFirmas{5cm}{1cm}{-2.4cm}
 %% La firma se define con un X_inicial, un X_final y un Y_inicial (Xo,Xf,Y)
 
@@ -150,23 +173,41 @@
 \SepFilas{0.8cm}{2.5pt}
 
 %% Separación vertical entre los elementos de la factura (entre el encabezado y el cuadro de la 'factura', luego desde dicho cuadro hasta la descripción, o hasta los totales en modo de filas).
-\SepElementos{0.2cm}
+\SepVertical{0.2cm}
 
-%% Separación horizontal entre las cajas del encabezado y separación interna entre la línea y el texto.
-\SepEncabez{0.2cm}{6pt}
+%% Separación horizontal entre la caja de los datos del cliente y la caja del resumen.
+\SepDatosResumen{0.2cm}
 
+%% Separación horizontal interna entre la línea y el texto en los datos del cliente y en el resumen.
+\SepEncabezado{6pt}
+
+%% Separación interna entre la línea y el texto de la nota previa.
+\SepNotaPrevia{6pt}
+
 %% Separación extra entre los elementos en la factura.
 \SepItemsExtra{0pt}
 
 %% Separación interna entre la línea y el texto de la descripción.
-\SepDescrip{6pt}
+\SepDescripcion{6pt}
 
+\SepCondiciones{5pt}
+
 %% Grosor de la línea de las cajas del encabezado, curvatura de la esquina y sombra.
-\LineaEncabez{0.4pt}{10pt}{0pt}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\LineaEncabezado{0.4pt}{10pt}{0pt}
 
+%% Grosor de la línea de la nota previa, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\LineaNotaPrevia{0.4pt}{7pt}{0pt}
+
 %% Grosor de la línea de la descripción, curvatura de la esquina y sombra.
-\LineaDescrip{0.4pt}{0pt}{4pt}
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\LineaDescripcion{0.4pt}{0pt}{4pt}
 
+%% Grosor de la línea de las condiciones, curvatura de la esquina y sombra.
+%% (si pedimos linea de 0pt, todo queda en cero y no se abre el ambiente TikZ).
+\LineaCondiciones{0pt}{0pt}{0pt}
+
 %% El espacio vertical que hay que avanzar sólo en la primera página del reporte antes de empezar a escribir sobre él. Usable cuando la primera página tiene un membrete y las demás no, es decir, cuando se usa \FondoReporte y no \FondoReporte*.
 \InicioReporte{1.6cm}
 
@@ -174,8 +215,14 @@
 %% Esta es la letra de la descripción de los items; y el espacio \baselineskip de *toda* la tabla de la factura se fija en este comando únicamente (se predeterminó 18pt).
 \LetraItems{\fontsize{14}{18}}
 
+%% Tipo de letra para la nota interna:
+\LetraNotaInterna{\fontsize{11}{13}\itshape}
+
+%% Tipo de letra para la nota externa:
+\LetraNotaExterna{\fontsize{14}{16.8}}
+
 %% Con este comando se cambia la etra del título de la tabla, es decir, los textos 'Cantidad, 'Descripción', etc...
-\LetraTitCuadro{\fontsize{10}{10}\bfseries}
+\LetraTitColumnas{\fontsize{10}{10}\bfseries}
 
 %% Tipo de letra de los títulos de los totales, por ejemplo los textos: 'B.I. G', 'IVA G'.
 \LetraTitTotales{\fontsize{12}{12}\bfseries}
@@ -210,6 +257,9 @@
 %% Tipo de letra para el texto bajo las líneas para firmar.
 \LetraFirmas{\fontsize{12}{12}}
 
+%% Tipo de letra para la nota previa.
+\LetraNotaPrevia{\fontsize{11}{12.5}}
+
 %% Tipo de letra para las condiciones del documento.
 \LetraCondiciones{\fontsize{12}{12}}
 
@@ -219,8 +269,8 @@
 %% Letra para la numeración de la factura.
 \LetraNumeracion{\fontsize{14}{14}\bfseries\color{red}}
 
-%% Letra para la fecha de emisión.
-\LetraFecha{\fontsize{14}{14}}
+%% Letra para las fechas (emisión y vencimiento).
+\LetraFecha{\fontsize{14}{15}}
 
 %% Letra para el título del reporte.
 \LetraTitReporte{\fontsize{16}{22}\bfseries}
@@ -228,29 +278,50 @@
 %% Letra para las cabeceras de las páginas en el modo reporte.
 \LetraInfoPagina{\fontsize{12}{12}\slshape}
 
+%% Letra para el reverso de la factura.
+\LetraReverso{\fontsize{10}{12}}
+
 %% Letra para el reporte.
 \LetraReporte{\fontsize{12}{20}}
 
+%% Diseño hecho en TikZ para los datos del cliente, el resumen, la nota previa, la descripción y las condiciones.
+\def\@DatosTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaEncabezado, line width=\@GrosorLineaEncabezado, rounded corners=\@EsquinaLineaEncabezado, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraEncabezado, shadow yshift=-\@SombraEncabezado}}
+
+\let\@ResumenTIKZ\@DatosTIKZ
+
+\def\@NotaPreviaTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaNotaPrevia, line width=\@GrosorLineaNotaPrevia, rounded corners=\@EsquinaLineaNotaPrevia, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraNotaPrevia, shadow yshift=-\@SombraNotaPrevia}}
+
+\def\@DescripcionTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaDescripcion, line width=\@GrosorLineaDescripcion, rounded corners=\@EsquinaLineaDescripcion, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraDescripcion, shadow yshift=-\@SombraDescripcion}}
+
+\def\@CondicionesTIKZ{%
+ draw=black, fill=white, inner sep=\@SeparaInternaCondiciones, line width=\@GrosorLineaCondiciones, rounded corners=\@EsquinaLineaCondiciones, copy shadow={top color=black, bottom color=black, shadow xshift=\@SombraCondiciones, shadow yshift=-\@SombraCondiciones}}
+
 %% El diseño de las distintas partes de la hoja.
-\newcommand{\@EstiloFirmas}{%
+\newcommand{\@EstiloFirmas}{
  \@LetraFirmas
  \if at unafirma
  \else
-  \parbox{\@TamLineaFirmas}{%
+  \parbox{\@TamLineaFirmas}{
    \rule{\@TamLineaFirmas}{\@GrosorLineaFirmas}
-   \centering \ifdefvoid{\@Conforme}{\@@Conforme}{\@Conforme}}%
+   \centering \ifdefvoid{\@Conforme}{\@@Conforme}{\@Conforme}}
  \fi
  \hfill
- \parbox{\@TamLineaFirmas}{%
+ \parbox{\@TamLineaFirmas}{
   \rule{\@TamLineaFirmas}{\@GrosorLineaFirmas}
   \centering \ifdefvoid{\@Emisor}{\if at cotizacion \@@Emisor \else \@@Pagado \fi}{\@Emisor}}}
 
+\newcommand{\@EstiloNotaPrevia}{\@LetraNotaPrevia \@NotaPrevia}
+
 \newcommand{\@EstiloCondiciones}{\@LetraCondiciones \@Condiciones}
 
 \newcommand{\@EstiloNumControl}{%
+ \renewcommand{\baselinestretch}{0}\selectfont
  \begin{tabular}{@{\extracolsep{0pt}}l}
-  \@LetraDenom \@@Control \\
-  {\@LetraDenom\@NumSerieControl-}\space\@LetraNumeracion\@NumControl
+  \@LetraDenom \@@Control \\[.4em]
+  {\@LetraDenom\@NumSerieControl-}\space\@LetraNumeracion\@NumControl \\
  \end{tabular}}
 
 \newcommand{\@EstiloDenom}{%
@@ -260,13 +331,19 @@
   \space\space{\@LetraNumeracion N\textordmasculine\space\@Num}%
  \fi}
 
-\newcommand{\@EstiloFecha}{\@LetraFecha\@@Fecha{\ttfamily\ \@Fecha}}
+\newcommand*{\@EstiloFechas}{%
+ \renewcommand{\baselinestretch}{0}%
+ \setlength{\tabcolsep}{0pt}%
+ \@LetraFecha\begin{tabular}{r@{\extracolsep{1ex}}l@{\extracolsep{0pt}}}
+ \@@Fecha & \ttfamily\@Fecha \\[.3em]
+ \if at vencimiento \@@FechaVencimiento & \ttfamily\@FechaVencimiento \\ \else \vspace*{-.3em}\fi
+ \end{tabular}}
 
 \newcommand{\@InfoPaginaNoTitulo}{\@LetraInfoPagina Reporte correspondiente a la factura n\'umero \@Num \space de fecha \@Fecha}
 
 \newcommand{\@InfoPaginaTitulo}{\@LetraInfoPagina \@TituloReporte \space - \@Proveedor \space - \@Fecha}
 
-%% Estilos de página: normal, sólo cabeceras, sólo piés de página y sólo número de página al pié.
+%% Estilos de página: normal, sólo cabeceras, sólo pies de página y sólo número de página al pie.
 \fancypagestyle{plain}{%
  \expandafter\ps at fancy
  \fancyhf{}%



More information about the tex-live-commits mailing list