69 lines
2.6 KiB
Python
69 lines
2.6 KiB
Python
|
|
from openerp import tools
|
|
from openerp.osv import fields,osv
|
|
from openerp.addons.decimal_precision import decimal_precision as dp
|
|
|
|
class hr_timesheet_report(osv.osv):
|
|
_name = "hr.timesheet.report"
|
|
_description = "Timesheet"
|
|
_auto = False
|
|
_columns = {
|
|
'date': fields.date('Date', readonly=True),
|
|
'name': fields.char('Description', size=64,readonly=True),
|
|
'product_id' : fields.many2one('product.product', 'Product',readonly=True),
|
|
'journal_id' : fields.many2one('account.analytic.journal', 'Journal',readonly=True),
|
|
'general_account_id' : fields.many2one('account.account', 'General Account', readonly=True),
|
|
'user_id': fields.many2one('res.users', 'User',readonly=True),
|
|
'account_id': fields.many2one('account.analytic.account', 'Analytic Account',readonly=True),
|
|
'company_id': fields.many2one('res.company', 'Company',readonly=True),
|
|
'cost': fields.float('Cost', readonly=True, digits_compute=dp.get_precision('Account')),
|
|
'quantity': fields.float('Time', readonly=True), # TDE FIXME master: rename into time
|
|
}
|
|
|
|
def _select(self):
|
|
select_str = """
|
|
SELECT min(hat.id) as id,
|
|
aal.date as date,
|
|
sum(aal.amount) as cost,
|
|
sum(aal.unit_amount) as quantity,
|
|
aal.account_id as account_id,
|
|
aal.journal_id as journal_id,
|
|
aal.product_id as product_id,
|
|
aal.general_account_id as general_account_id,
|
|
aal.user_id as user_id,
|
|
aal.company_id as company_id,
|
|
aal.currency_id as currency_id
|
|
"""
|
|
return select_str
|
|
|
|
def _from(self):
|
|
from_str = """
|
|
account_analytic_line as aal
|
|
inner join hr_analytic_timesheet as hat ON (hat.line_id=aal.id)
|
|
"""
|
|
return from_str
|
|
|
|
def _group_by(self):
|
|
group_by_str = """
|
|
GROUP BY aal.date,
|
|
aal.account_id,
|
|
aal.product_id,
|
|
aal.general_account_id,
|
|
aal.journal_id,
|
|
aal.user_id,
|
|
aal.company_id,
|
|
aal.currency_id
|
|
"""
|
|
return group_by_str
|
|
|
|
def init(self, cr):
|
|
# self._table = hr_timesheet_report
|
|
tools.drop_view_if_exists(cr, self._table)
|
|
cr.execute("""CREATE or REPLACE VIEW %s as (
|
|
%s
|
|
FROM ( %s )
|
|
%s
|
|
)""" % (self._table, self._select(), self._from(), self._group_by()))
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|