~openerp-commiter/openobject-addons/trunk-extra-addons

« back to all changes in this revision

Viewing changes to point_of_sale/report/pos_lines.py

  • Committer: Mantavya Gajjar
  • Date: 2009-12-01 10:19:51 UTC
  • mfrom: (4060.1.16 trunk-extra-addons)
  • Revision ID: mga@tinyerp.com-20091201101951-cpznxoapupixro3p
[MERGE]: merging from same branch

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# -*- encoding: utf-8 -*-
 
2
##############################################################################
 
3
#
 
4
#    OpenERP, Open Source Management Solution
 
5
#    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>). All Rights Reserved
 
6
#    $Id$
 
7
#
 
8
#    This program is free software: you can redistribute it and/or modify
 
9
#    it under the terms of the GNU General Public License as published by
 
10
#    the Free Software Foundation, either version 3 of the License, or
 
11
#    (at your option) any later version.
 
12
#
 
13
#    This program is distributed in the hope that it will be useful,
 
14
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
15
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
16
#    GNU General Public License for more details.
 
17
#
 
18
#    You should have received a copy of the GNU General Public License
 
19
#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
20
#
 
21
##############################################################################
 
22
 
 
23
import time
 
24
from report import report_sxw
 
25
 
 
26
 
 
27
class pos_lines(report_sxw.rml_parse):
 
28
 
 
29
    def __init__(self, cr, uid, name, context):
 
30
        super(pos_lines, self).__init__(cr, uid, name, context)
 
31
        self.total = 0.0
 
32
        self.localcontext.update({
 
33
                'time': time,
 
34
                'total_quantity': self.__total_quantity__,
 
35
                'taxes':self.__taxes__,
 
36
 
 
37
        })
 
38
 
 
39
    def __total_quantity__(self, obj):
 
40
        tot = 0
 
41
        for line in obj.lines:
 
42
            tot += line.qty
 
43
        self.total = tot
 
44
        return self.total
 
45
 
 
46
    def __taxes__(self,obj):
 
47
        self.cr.execute ( " Select acct.name from pos_order as po " \
 
48
                              " LEFT JOIN pos_order_line as pol ON po.id = pol.order_id " \
 
49
                              " LEFT JOIN product_taxes_rel as ptr ON pol.product_id = ptr.prod_id " \
 
50
                              " LEFT JOIN account_tax as acct ON acct.id = ptr.tax_id " \
 
51
                              " WHERE pol.id = %d" %(obj.id))
 
52
        res=self.cr.fetchone()[0]
 
53
        return res
 
54
 
 
55
 
 
56
report_sxw.report_sxw('report.pos.lines', 'pos.order', 'addons/point_of_sale/report/pos_lines.rml', parser=pos_lines)
 
57
 
 
58
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
 
59