You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
3.1 KiB
59 lines
3.1 KiB
# -*- coding: utf-8 -*-
|
|
from datetime import datetime
|
|
from odoo import models, fields
|
|
|
|
|
|
class HrPopupReminder(models.Model):
|
|
_name = 'hr.reminder'
|
|
|
|
name = fields.Char(string='Title', required=True)
|
|
model_name = fields.Many2one('ir.model', help="Choose the model name", string="Model", required=True, ondelete='cascade', domain="[('model', 'like','hr')]")
|
|
model_field = fields.Many2one('ir.model.fields', string='Field', help="Choose the field",
|
|
domain="[('model_id', '=',model_name),('ttype', 'in', ['datetime','date'])]",
|
|
required=True, ondelete='cascade')
|
|
search_by = fields.Selection([('today', 'Today'),
|
|
('set_period', 'Set Period'),
|
|
('set_date', 'Set Date'), ],
|
|
required=True, string="Search By")
|
|
days_before = fields.Integer(string='Reminder before', help="NUmber of days before the reminder")
|
|
active = fields.Boolean(string="Active", default=True)
|
|
# exclude_year = fields.Boolean(string="Consider day alone")
|
|
reminder_active = fields.Boolean(string="Reminder Active", help="Reminder active")
|
|
date_set = fields.Date(string='Select Date', help="Select the reminder set date")
|
|
date_from = fields.Date(string="Start Date", help="Start date")
|
|
date_to = fields.Date(string="End Date", help="End date")
|
|
expiry_date = fields.Date(string="Reminder Expiry Date", help="Expiry date")
|
|
company_id = fields.Many2one('res.company', string='Company', required=True, help="Company",
|
|
default=lambda self: self.env.user.company_id)
|
|
|
|
def reminder_scheduler(self):
|
|
print("hlooo")
|
|
now = fields.Datetime.from_string(fields.Datetime.now())
|
|
print("8888",now)
|
|
today = fields.Date.today()
|
|
print("2222")
|
|
obj = self.env['hr.reminder'].search([])
|
|
for i in obj:
|
|
if i.search_by != "today":
|
|
if i.expiry_date and datetime.strptime(str(today), "%Y-%m-%d") == datetime.strptime(str(i.expiry_date), "%Y-%m-%d"):
|
|
i.active = False
|
|
else:
|
|
if i.search_by == "set_date":
|
|
d1 = datetime.strptime(str(i.date_set), "%Y-%m-%d")
|
|
d2 = datetime.strptime(str(today), "%Y-%m-%d")
|
|
daydiff = abs((d2 - d1).days)
|
|
if daydiff <= i.days_before:
|
|
i.reminder_active = True
|
|
else:
|
|
i.reminder_active = False
|
|
elif i.search_by == "set_period":
|
|
d1 = datetime.strptime(str(i.date_from), "%Y-%m-%d")
|
|
d2 = datetime.strptime(str(today), "%Y-%m-%d")
|
|
daydiff = abs((d2 - d1).days)
|
|
if daydiff <= i.days_before:
|
|
i.reminder_active = True
|
|
else:
|
|
i.reminder_active = False
|
|
else:
|
|
i.reminder_active = True
|
|
|
|
|