91 lines
3.9 KiB
Python
91 lines
3.9 KiB
Python
# -*- encoding: utf-8 -*-
|
|
##############################################################################
|
|
#
|
|
# OpenERP, Open Source Management Solution
|
|
# Copyright (C) 2004-2008 Tiny SPRL (<http://tiny.be>). All Rights Reserved
|
|
# $Id$
|
|
#
|
|
# 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.
|
|
#
|
|
# 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, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
##############################################################################
|
|
|
|
import time
|
|
import mx.DateTime
|
|
from mx.DateTime import RelativeDateTime, now, DateTime, localtime
|
|
|
|
from osv import osv, fields
|
|
|
|
# Object creating periods quickly
|
|
# changed that stop_date is created with hour 23:59:00 when it was 00:00:00 stop date was excluded from period
|
|
class stock_period_createlines(osv.osv_memory):
|
|
_name = "stock.period.createlines"
|
|
|
|
def _get_new_period_start(self, cr, uid, context=None):
|
|
cr.execute("select max(date_stop) from stock_period")
|
|
result = cr.fetchone()
|
|
last_date = result and result[0] or False
|
|
if last_date:
|
|
period_start = mx.DateTime.strptime(last_date,"%Y-%m-%d %H:%M:%S")+ RelativeDateTime(days=1)
|
|
period_start = period_start - RelativeDateTime(hours=period_start.hour, minutes=period_start.minute, seconds=period_start.second)
|
|
else:
|
|
period_start = mx.DateTime.today()
|
|
return period_start.strftime('%Y-%m-%d')
|
|
|
|
|
|
_columns = {
|
|
'name': fields.char('Period Name', size=64),
|
|
'date_start': fields.date('Start Date', required=True),
|
|
'date_stop': fields.date('End Date', required=True),
|
|
'period_ids': fields.one2many('stock.period', 'planning_id', 'Periods'),
|
|
}
|
|
_defaults={
|
|
'date_start': _get_new_period_start,
|
|
}
|
|
|
|
def create_stock_periods(self, cr, uid, ids, context=None):
|
|
interval = context.get('interval',0)
|
|
name = context.get('name','Daily')
|
|
period_obj = self.pool.get('stock.period')
|
|
lines = []
|
|
for p in self.browse(cr, uid, ids, context=context):
|
|
dt = p.date_start
|
|
ds = mx.DateTime.strptime(p.date_start, '%Y-%m-%d')
|
|
while ds.strftime('%Y-%m-%d') < p.date_stop:
|
|
if name =='Daily':
|
|
de = ds + RelativeDateTime(days=interval, minutes =-1)
|
|
new_name = de.strftime('%Y-%m-%d')
|
|
ds = ds + RelativeDateTime(days=interval) + 1
|
|
if name =="Weekly":
|
|
de = ds + RelativeDateTime(days=interval, minutes =-1)
|
|
new_name = de.strftime('%Y, week %W')
|
|
ds = ds + RelativeDateTime(days=interval) + 1
|
|
if name == "Monthly":
|
|
de = ds + RelativeDateTime(months=interval, minutes=-1)
|
|
new_name = ds.strftime('%Y/%m')
|
|
ds = ds + RelativeDateTime(months=interval)
|
|
lines.append(period_obj.create(cr, uid, {
|
|
'name': new_name,
|
|
'date_start': ds.strftime('%Y-%m-%d'),
|
|
'date_stop': de.strftime('%Y-%m-%d %H:%M:%S'),
|
|
}))
|
|
return {
|
|
'domain': "[('id','in', ["+','.join(map(str, lines))+"])]",
|
|
'view_type': 'form',
|
|
"view_mode": 'tree, form',
|
|
'res_model': 'stock.period',
|
|
'type': 'ir.actions.act_window',
|
|
}
|
|
|
|
stock_period_createlines()
|