Browse Source

Para imprimir factura legal Paradata

sebastian 5 years ago
commit
b56752ee7d

+ 20 - 0
__init__.py

@@ -0,0 +1,20 @@
+# -*- encoding: utf-8 -*-
+################################################################################
+#    This program is free software: you can redistribute it and/or modify       #
+#    it under the terms of the GNU Affero General Public License as             #
+#    published by the Free Software Foundation, either version 3 of the         #
+#    License, or (at your option) any later version.                            #
+#                                                                               #
+#    This program is distributed in the hope that it will be useful,            #
+#    but WITHOUT ANY WARRANTY; without even the implied warranty of             #
+#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the              #
+#    GNU Affero General Public License for more details.                        #
+#                                                                               #
+#    You should have received a copy of the GNU Affero General Public License   #
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.      #
+#                                                                               #
+#################################################################################
+###################################################################################
+# Product Brand is an Openobject module wich enable Brand management for products #
+###################################################################################
+from . import factura_venta_paradata, account_invoice, res_currency

BIN
__init__.pyc


+ 42 - 0
__openerp__.py

@@ -0,0 +1,42 @@
+# -*- encoding: utf-8 -*-
+#################################################################################
+#                                                                               #
+#                                                                               #
+#    This program is free software: you can redistribute it and/or modify       #
+#    it under the terms of the GNU Affero General Public License as             #
+#    published by the Free Software Foundation, either version 3 of the         #
+#    License, or (at your option) any later version.                            #
+#                                                                               #
+#    This program is distributed in the hope that it will be useful,            #
+#    but WITHOUT ANY WARRANTY; without even the implied warranty of             #
+#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the              #
+#    GNU Affero General Public License for more details.                        #
+#                                                                               #
+#    You should have received a copy of the GNU Affero General Public License   #
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.      #
+#                                                                               #
+#################################################################################
+###################################################################################
+# Product features is an Openobject module with enable features management for products #
+###################################################################################
+{
+    'name': 'Factura de Venta Legal Paradata',
+    'version': '0.1',
+    'category': 'Product',
+    'description': """
+Factura Venta Legal Paradata
+==========================
+
+Formato para imprimir la factura legal de Paradata
+
+    """,
+    'author': 'Eiru/Sebastian Penayo',
+    'website': 'http://www.eiru.com',
+    'depends': ['base','account'],
+    'data': [
+        'factura_venta_paradata.xml',
+        'account_invoice_view.xml',
+        'res_currency_view.xml'
+    ],
+    'installable': True,
+}

+ 41 - 0
account_invoice.py

@@ -0,0 +1,41 @@
+# -*- encoding: utf-8 -*-
+#################################################################################
+#                                                                               #
+#                                                                               #
+#    This program is free software: you can redistribute it and/or modify       #
+#    it under the terms of the GNU Affero General Public License as             #
+#    published by the Free Software Foundation, either version 3 of the         #
+#    License, or (at your option) any later version.                            #
+#                                                                               #
+#    This program is distributed in the hope that it will be useful,            #
+#    but WITHOUT ANY WARRANTY; without even the implied warranty of             #
+#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the              #
+#    GNU Affero General Public License for more details.                        #
+#                                                                               #
+#    You should have received a copy of the GNU Affero General Public License   #
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.      #
+#                                                                               #
+#################################################################################
+
+from openerp import models, fields, api
+
+class account_invoice(models.Model):
+    _inherit = 'account.invoice'
+    _name = 'account.invoice'
+
+    contado = fields.Boolean('Contado')
+    credito = fields.Boolean('Crédito')
+
+    _defaults = {
+        'contado': True
+    }
+
+    @api.one
+    @api.onchange('credito')
+    def cambiar_estado_credito(self):
+        self.contado = not self.credito
+
+    @api.one
+    @api.onchange('contado')
+    def cambiar_estado_contado(self):
+        self.credito = not self.contado

BIN
account_invoice.pyc


+ 17 - 0
account_invoice_view.xml

@@ -0,0 +1,17 @@
+<?xml version="1.0" encoding="utf-8"?>
+
+<openerp>
+    <data>
+        <record id="account_invoice_cred_cont" model="ir.ui.view">
+            <field name="name">account.invoice.cred.cont</field>
+            <field name="model">account.invoice</field>
+            <field name="inherit_id" ref="account.invoice_form" />
+            <field name="arch" type="xml">
+                <field name="fiscal_position" position="after">
+                        <field name="contado"/>
+                        <field name="credito"/>
+                </field>
+            </field>
+        </record>
+    </data>
+</openerp>

+ 33 - 0
factura_venta_paradata.py

@@ -0,0 +1,33 @@
+from openerp import api, models
+from num2words import num2words
+
+
+
+class report_factura_paradata(models.AbstractModel):
+    _name = 'report.factura_venta_paradata.report_factura_paradata'
+
+    @api.multi
+    def render_html(self, data=None):
+        report_obj = self.env['report']
+        report = report_obj._get_report_from_name('factura_venta_paradata.report_factura_paradata')
+        docargs = {
+            'doc_ids': self._ids,
+            'doc_model': report.model,
+            'docs': self.env[report.model].browse(self._ids),
+            'convertir':self.convertir,
+            'calcular_precio':self.calcular_precio,
+        }
+        return report_obj.render('factura_venta_paradata.report_factura_paradata', docargs)
+
+    def convertir(self,nro,moneda):
+        letra = num2words(nro,lang="es")
+        letra = letra.capitalize()
+
+        if not moneda:
+            moneda=''
+
+        letra = letra +' '+moneda
+        return letra
+
+    def calcular_precio(self,precio):
+        return (precio*1.1)

BIN
factura_venta_paradata.pyc


+ 312 - 0
factura_venta_paradata.xml

@@ -0,0 +1,312 @@
+<?xml version="1.0" encoding="utf-8"?>
+<openerp>
+<data>
+
+     <report id="factura_venta_paradata"
+        model="account.invoice"
+        string="Factura Legal"
+        report_type="qweb-html"
+        name="factura_venta_paradata.report_factura_paradata"
+        file="factura_venta_paradata.report_factura_paradata"
+     />
+
+    <template id="report_header_custom" inherit_id="report.external_layout_header">
+         <xpath expr="//div[@class='header']" position="replace">
+            <div class ="header">
+            </div>
+         </xpath>
+    </template>
+
+    <template id="external_layout_footer" inherit_id="report.external_layout_footer">
+        <xpath expr="//div[@class='footer']"  position="replace">
+            <div class ="footer">
+            </div>
+        </xpath>
+    </template>
+
+    <template id="report_factura_paradata">
+        <t t-call="report.html_container">
+            <t t-call="report.external_layout">
+			    <t t-foreach="[1,2,3]" t-as="i">
+                <div class="page">
+                    <style type="text/css">
+                        body{
+                            font-size: 2.67mm;
+                            font-family: Arial, Helvetica, sans-serif;
+                        }
+                        div{
+                            padding: 0px;
+                        }
+                        .pagina{
+                            width:19.3cm;
+                        }
+                        .logo{
+                            height: 0.02cm;
+                            width: 100%;
+                            top: 0px;
+                        }
+                        .fecha_emision_data{
+                            width: 9cm;
+                            font-size: 2.4mm;
+                            padding-left: 6.3cm;
+                            float: left;
+                            min-height: 0.6cm;
+                        }
+                        .ruc_data{
+                             width: 8cm;
+                             font-size: 2.4mm;
+                             font-family: Arial, Helvetica, sans-serif;
+                             float: left;
+                             padding-left: 3.5cm;
+                             min-height: 0.6cm;
+                         }
+                        .linea2{
+                            position: relative;
+                            top: -0.12cm;
+                            min-height: 0.4cm;
+                         }
+                        .razon_data{
+                            width: 14.5cm;
+                            float: left;
+                            font-size: 2.3mm;
+                            padding-left: 6.3cm;
+                            min-height: 0.5cm;
+                        }
+
+                        .linea3{
+                            position: relative;
+                            top: -0.12cm;
+                            min-height: 0.4cm;
+                         }
+                        .direccion_data{
+                            width: 11.0cm;
+                            font-size: 2.2mm;
+                            font-family: Arial, Helvetica, sans-serif;
+                            float: left;
+                            padding-left: 6.0cm;
+                            min-height: 0.5cm;
+                        }
+                        .linea4{
+                            position: relative;
+                            top: -0.12cm;
+                            min-height: 0.4cm;
+                         }
+                        .telefono_data{
+                            width: 8.3cm;
+                            float: left;
+                            padding-left: 2.5cm;
+                            min-height: 0.4cm;
+                        }
+                        .linea5{
+                            position: relative;
+                            top: -0.12cm;
+                            min-height: 0.4cm;
+                         }
+                         .contado_x{
+                             width: 1cm;
+                             float: left;
+                             padding-left: 0.2cm;
+                             min-height: 0.5cm;
+                         }
+                         .credito_x{
+                             width: 1.8cm;
+                             float: left;
+                             padding-left: 1.7cm;
+                             min-height: 0.5cm;
+                         }
+                         .nota_remision_data{
+                             width: 8.3cm;
+                             float: left;
+                             padding-left: 2.5cm;
+                             min-height: 0.5cm;
+                         }
+
+                        .cab-articulos{
+                            height: 0.39cm;
+                            clear: both;
+                        }
+                        .articulos{
+                            height: 4.59cm;
+                        }
+                        .art-col1{
+						    padding-left: 0.0cm;
+                            width:0.5cm;
+                            text-align: center;
+                        }
+                        .art-col2{
+                            padding-left: 0.5cm;
+                            width:9.5cm;
+                        }
+                        .art-col3{
+                            width:1.8cm;
+                            text-align: right;
+                        }
+                        .art-col4{
+                            width:2.4cm;
+                            text-align: right;
+                        }
+                        .art-col5{
+                            width:2.5cm;
+                            text-align: right;
+                        }
+                        .art-col6{
+                            width:1.9cm;
+                            text-align: right;
+                        }
+						.logo1{
+                            height: 4.12cm;
+                            width: 100%;
+                            top: 0px;
+                        }
+                        .logo2{
+                            height: 4.11cm;
+                            width: 100%;
+                            top: 0px;
+                        }
+                        .subtotal_data{
+                            width: 6cm;
+                            float: left;
+                            padding-top: 0.002cm;
+                            padding-left: 2.3cm;
+                            min-height: 0.2cm;
+                        }
+                        .subtotal_excentas{
+                            width: 1.8cm;
+                            float: left;
+                            text-align: right;
+							 padding-left: 10cm;
+                            padding-top: 0.7cm;
+                            min-height: 0.2cm;
+                        }
+                        .subtotal_5{
+                            width: 1cm;
+                            float: left;
+							padding-left: 1cm;
+                            text-align: right;
+                            padding-top: 0.7cm;
+                            min-height: 0.2cm;
+                        }
+                        .subtotal_10{
+                            width: 2.3cm;
+                            float: left;
+							padding-left: 0.8cm;
+                            text-align: left;
+                            padding-top: 0.7cm;
+                            min-height: 0.2cm;
+                        }
+                        .total_pagar_data{
+                            width: 16.4cm;
+                            float: left;
+                            padding-top: 0.01mm;
+                            padding-left: 4.8cm;
+                            min-height: 0.7cm;
+                        }
+                        .total_pagar{
+                            width: 2.3cm;
+                            float: right;
+                            padding-top: 0.01mm;
+                            padding-left: 0.8cm;
+                            min-height: 0.7cm;
+                        }
+                        .iva_5_data{
+                            width: 5cm;
+                            float: left;
+                            padding-top: 0.04mm;
+                            padding-left: 4.7cm;
+                            min-height: 0.25cm;
+                        }
+                        .iva_10_data{
+                            width: 5.2cm;
+                            float: left;
+                            padding-left: 3.1cm;
+                            padding-top: 0.04mm;
+                            min-height: 0.25cm;
+                        }
+                        .iva_total_data{
+                            width: 7cm;
+                            float: left;
+                            padding-left: 4.25cm;
+                            padding-top: 0.04mm;
+                            min-height: 0.25cm;
+                        }
+
+                    </style>
+                    <t t-foreach="docs" t-as="o">
+                        <div class="pagina">
+                            <div class="logo"> </div>
+                            <div class="linea1">
+                                <div class="fecha_emision_data"><span t-field="o.date_invoice" t-field-options='{"format": "dd MMM yyyy"}'/></div>
+                                <div class="ruc_data"><span t-field="o.partner_id.ruc"/></div>
+                            </div>
+
+                            <div class="linea2">
+                                <div class="razon_data"><span t-field="o.partner_id.name"/></div>
+                            </div>
+
+                            <div class="linea3">
+                                <div class="direccion_data">
+                                    <t t-f="o.partner_id.street"><span t-field="o.partner_id.street"/></t>
+                                    <t t-f="not o.partner_id.street"> </t>
+                                </div>
+
+                            </div>
+
+                            <div class="linea4">
+                                <div class="telefono_data"><span t-field="o.partner_id.phone"/></div>
+                                <div class="nota_remision_data"> </div>
+                            </div>
+							<div class="linea5">
+                                <div class="contado_x">
+                                    <t t-if="o.contado == True">X</t>
+                                    <t t-if="o.contado == False"></t>
+                                </div>
+                                <div class="credito_x">
+                                    <t t-if="o.credito == True">X</t>
+                                    <t t-if="o.credito == False"></t>
+                                </div>
+                            </div>
+                            <div class="cab-articulos"> </div>
+                            <div class="articulos">
+
+                                <table class="tab-articulos">
+                                    <tr t-foreach="o.invoice_line" t-as="l">
+                                        <td class="art-col1"><span t-esc="'%.0f'%l.quantity"/></td>
+                                        <td class="art-col2"><span t-field="l.product_id.name"/></td>
+                                        <td class="art-col3"><span t-esc="'{0:,.0f}'.format(l.price_unit)"/></td>
+                                        <td class="art-col4"> </td>
+                                        <td class="art-col5"> </td>
+                                        <td class="art-col6"><span t-esc="'{0:,.0f}'.format((l.quantity * l.price_unit))"/></td>
+                                   </tr>
+                                </table>
+                            </div>
+
+                             <div class="subtotal_data"> </div>
+                             <div class="subtotal_excentas"> </div>
+                             <div class="subtotal_5"> </div>
+                             <td style="font-size:7.0px;">
+                                <div class="subtotal_10"><span t-esc="'{0:,.0f}'.format(o.amount_total)"/></div>
+                            </td>
+                            <div class="total_pagar_data">Gs.: <span t-esc="convertir(o.amount_total,o.currency_id.en_letras)"/></div>
+                            <div class="total_pagar"><span t-esc="'{0:,.0f}'.format(o.amount_total)"/></div>
+
+
+                             <div class="iva_5_data"> </div>
+                             <div class="iva_10_data"><span t-esc="'{0:,.0f}'.format(o.amount_tax)"/></div>
+                             <div class="iva_total_data"><span t-esc="'{0:,.0f}'.format(o.amount_tax)"/></div>
+                        </div>
+                        <t t-if="i == 1">
+                            <div class="logo1"> </div>
+                        </t>
+                        <t t-if="i == 2">
+                            <div class="logo2"> </div>
+                        </t>
+
+                    </t>
+                </div>
+				</t>
+            </t>
+        </t>
+    </template>
+
+</data>
+</openerp>

+ 92 - 0
numbers_to_letters.py

@@ -0,0 +1,92 @@
+# -*- coding: utf-8 -*-
+import unittest
+
+def numero_to_letras(numero):
+	indicador = [("",""),("MIL","MIL"),("MILLON","MILLONES"),("MIL","MIL"),("BILLON","BILLONES")]
+	entero = int(numero)
+	decimal = int(round((numero - entero)*100))
+	#print 'decimal : ',decimal
+	contador = 0
+	numero_letras = ""
+	numero_letrasd = ""
+
+	while entero >0:
+		a = entero % 1000
+		if contador == 0:
+			en_letras = convierte_cifra(a,1).strip()
+		else :
+			en_letras = convierte_cifra(a,0).strip()
+		if a==0:
+			numero_letras = en_letras+" "+numero_letras
+		elif a==1:
+			if contador in (1,3):
+				numero_letras = indicador[contador][0]+" "+numero_letras
+			else:
+				numero_letras = en_letras+" "+indicador[contador][0]+" "+numero_letras
+		else:
+			numero_letras = en_letras+" "+indicador[contador][1]+" "+numero_letras
+
+		numero_letras = numero_letras.strip()
+		contador = contador + 1
+		entero = int(entero / 1000)
+
+
+	contadord=0
+	while decimal >0:
+		d = decimal % 1000
+		if contadord == 0:
+			en_letrasd = convierte_cifra(d,1).strip()
+
+		numero_letrasd =" COM "+str(en_letrasd.strip())
+		contadord = contadord + 1
+		decimal = int(decimal / 1000)
+
+	numero_letras = numero_letras+ str(numero_letrasd)
+	# print 'numero: ',numero
+	# print numero_letras
+	return numero_letras
+
+
+
+def convierte_cifra(numero,sw):
+	lista_centana = ["",("CIEN","CIENTO"),"DOSCIENTOS","TRESCIENTOS","CUATROCIENTOS","QUINIENTOS","SEISCIENTOS","SETECIENTOS","OCHOCIENTOS","NOVECIENTOS"]
+	lista_decena = ["",("DIEZ","ONCE","DOCE","TRECE","CATORCE","QUINCE","DIECISEIS","DIECISIETE","DIECIOCHO","DIECINUEVE"),
+					("VEINTE","VEINTI"),("TREINTA","TREINTA Y "),("CUARENTA" , "CUARENTA Y "),
+					("CINCUENTA" , "CINCUENTA Y "),("SESENTA" , "SESENTA Y "),
+					("SETENTA" , "SETENTA Y "),("OCHENTA" , "OCHENTA Y "),
+					("NOVENTA" , "NOVENTA Y ")
+				]
+	lista_unidad = ["",("UN" , "UNO"),"DOS","TRES","CUATRO","CINCO","SEIS","SIETE","OCHO","NUEVE"]
+	centena = int (numero / 100)
+	decena = int((numero -(centena * 100))/10)
+	unidad = int(numero - (centena * 100 + decena * 10))
+	#print "centena: ",centena, "decena: ",decena,'unidad: ',unidad
+	texto_centena = ""
+	texto_decena = ""
+	texto_unidad = ""
+
+	#Validad las centenas
+	texto_centena = lista_centana[centena]
+	if centena == 1:
+		if (decena + unidad)!=0:
+			texto_centena = texto_centena[1]
+		else :
+	 		texto_centena = texto_centena[0]
+
+
+	#Valida las decenas
+	texto_decena = lista_decena[decena]
+	if decena == 1 :
+		 texto_decena = texto_decena[unidad]
+ 	elif decena > 1 :
+ 		if unidad != 0 :
+ 			texto_decena = texto_decena[1]
+ 		else:
+ 			texto_decena = texto_decena[0]
+ 	#Validar las unidades
+ 	#print "texto_unidad: ",texto_unidad
+ 	if decena != 1:
+ 		texto_unidad = lista_unidad[unidad]
+ 		if unidad == 1:
+ 			texto_unidad = texto_unidad[sw]
+ 	return "%s %s %s" %(texto_centena,texto_decena,texto_unidad)

BIN
numbers_to_letters.pyc


+ 26 - 0
res_currency.py

@@ -0,0 +1,26 @@
+# -*- encoding: utf-8 -*-
+#################################################################################
+#                                                                               #
+#                                                                               #
+#    This program is free software: you can redistribute it and/or modify       #
+#    it under the terms of the GNU Affero General Public License as             #
+#    published by the Free Software Foundation, either version 3 of the         #
+#    License, or (at your option) any later version.                            #
+#                                                                               #
+#    This program is distributed in the hope that it will be useful,            #
+#    but WITHOUT ANY WARRANTY; without even the implied warranty of             #
+#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the              #
+#    GNU Affero General Public License for more details.                        #
+#                                                                               #
+#    You should have received a copy of the GNU Affero General Public License   #
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.      #
+#                                                                               #
+#################################################################################
+
+from openerp import models, fields
+
+class res_currency(models.Model):
+    _inherit = 'res.currency'
+    _name = 'res.currency'
+
+    en_letras = fields.Char('En letras')

BIN
res_currency.pyc


+ 16 - 0
res_currency_view.xml

@@ -0,0 +1,16 @@
+<?xml version="1.0" encoding="utf-8"?>
+
+<openerp>
+    <data>
+        <record id="res_currency_en_letras" model="ir.ui.view">
+            <field name="name">res.currency.en.letras</field>
+            <field name="model">res.currency</field>
+            <field name="inherit_id" ref="base.view_currency_form" />
+            <field name="arch" type="xml">
+                <field name="symbol" position="after">
+                    <field name="en_letras"/>
+                </field>
+            </field>
+        </record>
+    </data>
+</openerp>

BIN
static/description/icon.png