[FIX] Schedule jobs even if their next time has passed.
[odoo/odoo.git] / addons / report_task / report_task.py
index 12643af..8f10ac4 100644 (file)
+# -*- encoding: utf-8 -*-
 ##############################################################################
 #
-# Copyright (c) 2004-2006 TINY SPRL. (http://tiny.be) All Rights Reserved.
+#    OpenERP, Open Source Management Solution  
+#    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>). All Rights Reserved
+#    $Id$
 #
-# $Id: project.py 1005 2005-07-25 08:41:42Z nicoe $
+#    This program is free software: you can redistribute it and/or modify
+#    it under the terms of the GNU General Public License as published by
+#    the Free Software Foundation, either version 3 of the License, or
+#    (at your option) any later version.
 #
-# WARNING: This program as such is intended to be used by professional
-# programmers who take the whole responsability of assessing all potential
-# consequences resulting from its eventual inadequacies and bugs
-# End users who are looking for a ready-to-use solution with commercial
-# garantees and support are strongly adviced to contract a Free Software
-# Service Company
+#    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 General Public License for more details.
 #
-# This program is Free Software; you can redistribute it and/or
-# modify it under the terms of the GNU General Public License
-# as published by the Free Software Foundation; either version 2
-# 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 General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+#    You should have received a copy of the GNU General Public License
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 #
 ##############################################################################
 
 from osv import fields,osv
+import mx.DateTime
 
 class  report_task_user_pipeline_open (osv.osv):
-       _name = "report.task.user.pipeline.open"
-       _description = "Tasks by user and project"
-       _auto = False
-       _columns = {
-               'user_id':fields.many2one('res.users', 'User', readonly=True),
-               'task_nbr': fields.float('Task Number', readonly=True),
-               'task_hrs': fields.float('Task Hours', readonly=True),
-               'task_progress': fields.float('Task Progress', readonly=True),
-               'company_id' : fields.many2one('res.company', 'Company'),
-       }
-
-       def init(self, cr):
-               cr.execute('''
-                       create or replace view report_task_user_pipeline_open as (
-                               select
-                                       u.id as id,
-                                       u.id as user_id,
-                                       u.company_id as company_id,
-                                       count(t.*) as task_nbr,
-                                       sum(t.planned_hours) as task_hrs,
-                                       sum(t.planned_hours * (100 - t.progress) / 100) as task_progress
-                               from
-                                       res_users u
-                               left join project_task t on (u.id = t.user_id)
-                               group by
-                                       u.id, u.company_id
-                       )
-               ''')
+    _name = "report.task.user.pipeline.open"
+    _description = "Tasks by user and project"
+    _auto = False
+    _columns = {
+        'user_id':fields.many2one('res.users', 'User', readonly=True),
+        'task_nbr': fields.float('Task Number', readonly=True),
+        'task_hrs': fields.float('Task Hours', readonly=True),
+        'task_progress': fields.float('Task Progress', readonly=True),
+        'company_id' : fields.many2one('res.company', 'Company'),
+        'task_state': fields.selection([('draft', 'Draft'),('open', 'Open'),('pending', 'Pending'), ('cancelled', 'Cancelled'), ('done', 'Done'),('no','No Task')], 'Status', readonly=True),
+    }
+
+    def init(self, cr):
+        cr.execute('''
+            create or replace view report_task_user_pipeline_open as (
+                select
+                    min(t.id) as id,
+                    u.id as user_id,
+                    u.company_id as company_id,
+                    count(t.*) as task_nbr,
+                    sum(t.planned_hours) as task_hrs,
+                    sum(t.planned_hours * (100 - t.progress) / 100) as task_progress,
+                    case when t.state is null then 'no' else t.state end as task_state
+                from
+                    res_users u
+                left join 
+                    project_task t on (u.id = t.user_id)
+                where
+                    u.active
+                group by
+                    u.id, u.company_id, t.state
+            )
+        ''')
 report_task_user_pipeline_open()
 
+class  report_closed_task(osv.osv):
+    _name = "report.closed.task"
+    _description = "Closed Task Report"
+    _auto = False
+    _columns = {
+        'sequence': fields.integer('Sequence', readonly=True),
+        'name': fields.char('Task summary', size=128, readonly=True),
+        'project_id': fields.many2one('project.project', 'Project', readonly=True),
+        'user_id': fields.many2one('res.users', 'Assigned to', readonly=True),
+        'date_deadline': fields.datetime('Deadline', readonly=True),
+        'planned_hours': fields.float('Planned Hours', readonly=True),
+        'delay_hours': fields.float('Delay Hours', readonly=True),
+        'progress': fields.float('Progress (%)', readonly=True),
+        'priority' : fields.selection([('4','Very Low'), ('3','Low'), ('2','Medium'), ('1','Urgent'), ('0','Very urgent')], 'Importance', readonly=True),
+        'state': fields.selection([('draft', 'Draft'),('open', 'In Progress'),('pending', 'Pending'), ('cancelled', 'Cancelled'), ('done', 'Done')], 'Status', readonly=True),
+        'remaining_hours': fields.float('Remaining Hours', readonly=True),
+        'date_close' : fields.datetime('Date Closed', readonly=True)
+    }
+
+    def init(self, cr):
+        cr.execute('''
+            create or replace view report_closed_task as (
+                select
+                   tsk.id as id, tsk.sequence as sequence, tsk.name as name,
+                   tsk.project_id as project_id, tsk.user_id as user_id,
+                   tsk.date_deadline as date_deadline, tsk.planned_hours as planned_hours,
+                   tsk.delay_hours as delay_hours, tsk.progress as progress,
+                   tsk.priority as priority, tsk.state as state,
+                   tsk.remaining_hours as remaining_hours, tsk.date_close as date_close
+                from
+                    project_task tsk
+                where
+                    (tsk.date_close <= CURRENT_DATE AND tsk.date_close > (CURRENT_DATE-15))
+            )
+        ''')
+report_closed_task()
+
+class report_timesheet_task_user(osv.osv):
+    _name = "report.timesheet.task.user"
+    _auto = False
+    _order = "name"
+    
+    def _get_task_hours(self, cr, uid, ids, name,args,context):
+        result = {}
+        for record in self.browse(cr, uid, ids,context):
+            last_date = mx.DateTime.strptime(record.name, '%Y-%m-%d') + mx.DateTime.RelativeDateTime(months=1) - 1
+            task_obj=self.pool.get('project.task.work')
+            task_ids = task_obj.search(cr,uid,[('user_id','=',record.user_id.id),('date','>=',record.name),('date','<=',last_date.strftime('%Y-%m-%d'))])
+            tsk_hrs = task_obj.read(cr,uid,task_ids,['hours','date','user_id'])
+            total = 0.0
+            for hrs in tsk_hrs:
+                total += hrs['hours']
+            result[record.id] = total
+        return result
+    
+    def get_hrs_timesheet(self, cr, uid, ids, name,args,context):
+        result = {}
+        sum = 0.0
+        for record in self.browse(cr, uid, ids, context):
+            last_date = mx.DateTime.strptime(record.name, '%Y-%m-%d') + mx.DateTime.RelativeDateTime(months=1) - 1
+            obj=self.pool.get('hr_timesheet_sheet.sheet.day')
+            sheet_ids = obj.search(cr,uid,[('sheet_id.user_id','=',record.user_id.id),('name','>=',record.name),('name','<=',last_date.strftime('%Y-%m-%d'))])
+            data_days = obj.read(cr,uid,sheet_ids,['name','sheet_id.user_id','total_attendance'])
+            total = 0.0
+            for day_attendance in data_days:
+                total += day_attendance['total_attendance']
+            result[record.id] = total
+        return result
+        
+    _columns = {
+        'name': fields.date('Month',readonly=True),
+        'user_id': fields.many2one('res.users', 'User',readonly=True),
+        'timesheet_hrs': fields.function(get_hrs_timesheet, method=True, string="Timesheet Hours"),
+        'task_hrs': fields.function(_get_task_hours, method=True, string="Task Hours"),
+      }
+    
+    
+    def init(self, cr):   
+       cr.execute(""" create or replace view report_timesheet_task_user as (
+        select  
+         ((r.id*12)+to_number(months.m_id,'99'))::integer as id,
+               months.name as name,
+               r.id as user_id
+        from res_users r,
+                (select to_char(p.date,'YYYY-MM-01') as name,
+            to_char(p.date,'MM') as m_id
+                from project_task_work p 
+    
+            union 
+                select to_char(h.name,'YYYY-MM-01') as name,
+                to_char(h.name,'MM') as m_id
+                from hr_timesheet_sheet_sheet_day h) as months) """)
+
+report_timesheet_task_user()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: