from odoo import models, fields, api import re from odoo.exceptions import ValidationError from datetime import datetime, timedelta class sos_inside_sales_leads(models.Model): _name = 'sos_inside_sales_leads' _description = 'Sosaley Customers Management' _rec_name="company_name" company_name = fields.Char(string="Company Name") lead_generated_by = fields.Many2one( 'res.users', string='Lead Generated By', default=lambda self: self.env.user, readonly=True ) entry_date = fields.Date(string="Date", default=fields.Date.today) moved_on = fields.Date(string="Moved On") location = fields.Char(string="Location") website_url = fields.Char(string="Website URL") vertical_domain = fields.Many2one('sos_vertical_domain',string="Domain / Industry", ondelete="cascade") line_ids_contacts = fields.One2many('sos_leads_contact_lines', 'ref_id', string="Contact Details",copy=True) remarks=fields.Text(string="Remarks") linkedin_profile = fields.Char(string="Linkedin profile") products = fields.Selection( [ ('BHMS 1.2V', 'BHMS 1.2V'), ('BHMS 2V', 'BHMS 2V'), ('BHMS 12V', 'BHMS 12V'), ('BMS-HV', 'BMS-HV'), ('BMS-LV 100A', 'BMS-LV 100A'), ('BMS-LV 40A', 'BMS-LV 40A'), ('SBMS 55A', 'SBMS 55A'), ('MC 250W', 'MC 250W'), ('HeartTarang', 'HeartTarang') ], string="Product Interested In") source = fields.Selection( [ ('website', 'Website'), ('expo', 'Expo'), ('cold_calls', 'Cold Calls'), ('linkedin', 'Linkedin') ], string="Source") meeting_scheduled = fields.Selection( [ ('Online', 'Online'), ('Offline', 'Offline') ], string="Meeting Schedule") expo_name = fields.Char(string="Expo Name") move_to_sales = fields.Many2many('res.users',string="Move Lead to") cc_mail = fields.Many2one('res.users',string="CC to") move_div_display = fields.Boolean(default=False,string="Moved to Sales") line_ids = fields.One2many('sos_inside_sales_activities_line', 'ref_id', string="Action") week = fields.Char(string="Week") reporting_to = fields.Many2one('res.users', string='Reporting To') @api.model def create(self, vals): create_uid = vals.get('create_uid', self.env.uid) create_user = self.env['res.users'].browse(create_uid) # Check if reporting_to exists before accessing .id vals['reporting_to'] = create_user.reporting_to.id if create_user.reporting_to else False record = super(sos_inside_sales_leads, self).create(vals) return record TARGET_PER_WEEK = 4 def action_moveto_sales(self): if self.move_to_sales: #Target Starts entry_date = fields.Date.today() self.moved_on = entry_date start_of_week = entry_date - timedelta(days=entry_date.weekday()) # Monday end_of_week = start_of_week + timedelta(days=6) # Sunday # Determine week number first_day_of_month = entry_date.replace(day=1) week_number = ((entry_date - first_day_of_month).days // 7) + 1 # Exclude Saturdays for 2nd and 4th week if week_number in [2, 4]: end_of_week = start_of_week + timedelta(days=4) # Friday self.week = f"{start_of_week.strftime('%d/%m/%Y')} to {end_of_week.strftime('%d/%m/%Y')}" sos_lines = self.env['sos_target_tracker'].search([ ('week', '=', self.week), ('inside_sales_executive', '=', self.lead_generated_by.id) ]) new_week_entry = sos_lines.weekly_entries_count + 1 if new_week_entry < self.TARGET_PER_WEEK: remaining = self.TARGET_PER_WEEK - new_week_entry weekly_status = f"{remaining} more to achieve this week's target." elif new_week_entry == self.TARGET_PER_WEEK: weekly_status = "Target achieved for this week!" else: weekly_status = "Well performed! Exceeded weekly target!" if sos_lines: sos_lines.write({'weekly_entries_count': new_week_entry,'entry_date':self.entry_date, 'weekly_status':weekly_status}) else: self.env['sos_target_tracker'].create({ 'entry_date': self.entry_date, 'inside_sales_executive': self.lead_generated_by.id, 'week': f"{start_of_week.strftime('%d/%m/%Y')} to {end_of_week.strftime('%d/%m/%Y')}", 'weekly_entries_count':1 }) #Target Ends for user in self.move_to_sales: body_html = f"""

Below Lead is moved to Sales

""" subject = f"New Lead Received - {self.company_name}" send_email = self.env['sos_common_scripts'] send_email.send_direct_email(self.env,"sos_inside_sales_leads",self.id,user.login,subject,body_html,self.cc_mail.login) new_record = self.env['sos_sales_leads'].create({ 'company_name': self.company_name, 'transferred_on': fields.Date.today(), 'location':self.location, 'website_url':self.website_url, 'vertical_domain':self.vertical_domain.id, 'linkedin_profile':self.linkedin_profile, 'products':self.products, 'source':'inside_sales', 'expo_name':self.expo_name, 'lead_generated_by':self.env.user.id }) if new_record: self.move_div_display = True return { 'type': 'ir.actions.client', 'tag': 'display_notification', 'params': { 'message': "Moved Successfully", 'type': 'success', 'sticky': False } } class SOS_Leads_Line(models.Model): _name = 'sos_leads_contact_lines' _description = 'Leads Contact Lines' ref_id = fields.Many2one('sos_inside_sales_leads', string="Customers", ondelete="cascade") name = fields.Char(string="Name") dept = fields.Char(string="Designation") email = fields.Char(string="Email Id") mobile_number = fields.Char(string="Contact Number") set_as_primary = fields.Boolean(string="Set Primary") @api.model def create(self, vals): record = super(SOS_Leads_Line, self).create(vals) if not self.env['sos_leads_contact_lines'].search([ ('ref_id', '=', record.ref_id.id), ('set_as_primary', '=', True) ]): # Set the created record as primary record.set_as_primary = True return record def write(self, vals): res = super(SOS_Leads_Line, self).write(vals) if 'set_as_primary' in vals and vals['set_as_primary']: for record in self: self.env['sos_leads_contact_lines'].search([ ('ref_id', '=', record.ref_id.id), ('id', '!=', record.id) ]).write({'set_as_primary': False}) return res class sos_inside_sales_activities_lines(models.Model): _name = 'sos_inside_sales_activities_line' _description = 'Inside Sales executive activities log lines' ref_id = fields.Many2one('sos_inside_sales_leads', ondelete="cascade") action_date = fields.Date(string="Action Date") remarks = fields.Text(string="Remarks")