Overslaan naar inhoud
Odoo Menu
  • Aanmelden
  • Probeer het gratis
  • Apps
    Financiën
    • Boekhouding
    • Facturatie
    • Onkosten
    • Spreadsheet (BI)
    • Documenten
    • Ondertekenen
    Verkoop
    • CRM
    • Verkoop
    • Kassasysteem winkel
    • Kassasysteem Restaurant
    • Abonnementen
    • Verhuur
    Websites
    • Websitebouwer
    • E-commerce
    • Blog
    • Forum
    • Live Chat
    • E-learning
    Bevoorradingsketen
    • Voorraad
    • Productie
    • PLM
    • Inkoop
    • Onderhoud
    • Kwaliteit
    Personeelsbeheer
    • Werknemers
    • Werving & Selectie
    • Verlof
    • Evaluaties
    • Aanbevelingen
    • Wagenpark
    Marketing
    • Sociale media-marketing
    • E-mailmarketing
    • Sms-marketing
    • Evenementen
    • Marketingautomatisering
    • Enquêtes
    Diensten
    • Project
    • Urenstaten
    • Buitendienst
    • Helpdesk
    • Planning
    • Afspraken
    Productiviteit
    • Chat
    • Artificiële Intelligentie
    • IoT
    • VoIP
    • Kennis
    • WhatsApp
    Apps van derden Odoo Studio Odoo Cloud Platform
  • Bedrijfstakken
    Detailhandel
    • Boekhandel
    • kledingwinkel
    • Meubelwinkel
    • Supermarkt
    • Bouwmarkt
    • Speelgoedwinkel
    Horeca & Hospitality
    • Bar en café
    • Restaurant
    • Fastfood
    • Gastenverblijf
    • Drankenhandelaar
    • Hotel
    Vastgoed
    • Makelaarskantoor
    • Architectenbureau
    • Bouw
    • Vastgoedbeheer
    • Tuinieren
    • Vereniging van mede-eigenaren
    Consulting
    • Accountantskantoor
    • Odoo Partner
    • Marketingbureau
    • Advocatenkantoor
    • Talentenwerving
    • Audit & Certificering
    Productie
    • Textiel
    • Metaal
    • Meubels
    • Eten
    • Brouwerij
    • Relatiegeschenken
    Gezondheid & Fitness
    • Sportclub
    • Opticien
    • Fitnesscentrum
    • Wellness-medewerkers
    • Apotheek
    • Kapper
    Diensten
    • Klusjesman
    • IT-hardware & ondersteuning
    • Zonne-energiesystemen
    • Schoenmaker
    • Schoonmaakdiensten
    • HVAC-diensten
    Andere
    • Non-profitorganisatie
    • Milieuagentschap
    • Verhuur van Billboards
    • Fotograaf
    • Fietsleasing
    • Softwareverkoper
    Alle bedrijfstakken bekijken
  • Community
    Leren
    • Tutorials
    • Documentatie
    • Certificeringen
    • Training
    • Blog
    • Podcast
    Versterk het onderwijs
    • Onderwijsprogramma
    • Scale Up! Business Game
    • Odoo bezoeken
    Download de Software
    • Downloaden
    • Vergelijk edities
    • Releases
    Werk samen
    • Github
    • Forum
    • Evenementen
    • Vertalingen
    • Partner worden
    • Diensten voor partners
    • Registreer je accountantskantoor
    Diensten
    • Vind een partner
    • Vind een boekhouder
    • Een adviseur ontmoeten
    • Implementatiediensten
    • Klantreferenties
    • Ondersteuning
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Vraag een demo aan
  • Prijzen
  • Help
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Help

how to create the Scheduled Actions for timesheet attendance reporting module

Inschrijven

Ontvang een bericht wanneer er activiteit is op deze post

Deze vraag is gerapporteerd
ScheduledActions
2 Antwoorden
5544 Weergaven
Avatar
vijay Yadav

Hi Team,

 I have created a scheduler action for timesheet reminder for the next day morning at 8 am if user forget to enter the working hours .  

python code:

from datetime import datetime, timedelta

from odoo import api, fields, models

class TimesheetReminder(models.TransientModel):

    _name = 'timesheet.reminder'


    @api.model

    def send_timesheet_reminder(self):

        # Find employees with missing timesheets for the previous day

        today = fields.Date.today()

        yesterday = today - timedelta(days=1)


        employees_with_missing_timesheets = self.env['hr.employee'].search([

            ('user_id', '!=', False),

            ('timesheet_ids.date', '=', yesterday),

            ('timesheet_ids.state', '!=', 'done'),

        ])


        # Send reminder emails

        for employee in employees_with_missing_timesheets:

            template = self.env.ref('your_module.email_template_id')

            template.send_mail(employee.user_id.id, force_send=True)


while unbale to find the module.email_template_id  ..


Getting below error :  forbidden opcode(s) in "# Available variables:\n# - env: Odoo Environment on which the action is triggered\n# - model: Odoo Model of the record on which the action is triggered; is a void recordset\n# - record: record on which the action is triggered; may be void\n# - records: recordset of all records on which the action is triggered in multi-mode; may be void\n# - time, datetime, dateutil, timezone: useful Python libraries\n# - float_compare: Odoo function to compare floats based on specific precisions\n# - log: log(message, level='info'): logging function to record debug information in ir.logging table\n# - UserError: Warning Exception to use with raise\n# - Command: x2Many commands namespace\n# To return an action, assign: action = {...}\n\nfrom datetime import datetime, timedelta\nfrom odoo import api, fields, models\nclass TimesheetReminder(models.TransientModel):\n _name = 'timesheet.reminder'\n\n @api.model\n def send_timesheet_reminder(self):\n # Find employees with missing timesheets for the previous day\n today = fields.Date.today()\n yesterday = today - timedelta(days=1)\n\n employees_with_missing_timesheets = self.env['hr.employee'].search([\n ('user_id', '!=', False),\n ('timesheet_ids.date', '=', yesterday),\n ('timesheet_ids.state', '!=', 'done'),\n ])\n\n # Send reminder emails\n for employee in employees_with_missing_timesheets:\n template = self.env.ref('your_module.email_template_id')\n template.send_mail(employee.user_id.id, force_send=True)\n\n# Add this function to the Scheduled Action": IMPORT_NAME, IMPORT_FROM, LOAD_BUILD_CLASS




Thanks and Regards
Vijay Yadav


0
Avatar
Annuleer
Avatar
Cybrosys Techno Solutions Pvt.Ltd
Beste antwoord

Hi,

The execution of python is a bit different in the scheduled action script


You should try this instead


today = datetime.datetime.today()

yesterday = today - datetime.timedelta(1)


employees_with_missing_timesheets = env['hr.employee'].search([

    ('user_id', '!=', False),

    ('timesheet_ids.date', '=', yesterday),

    ('timesheet_ids.state', '!=', 'done'),

])

for employee in employees_with_missing_timesheets:

    template = env.ref('your_module.email_template_id')

    template.send_mail(employee.user_id.id, force_send=True)


Hope it helps

2
Avatar
Annuleer
Avatar
vijay Yadav
Auteur Beste antwoord

hi @cybrosys Team,

will this code help with web code editor  and how do we know module and template id for this line of code  your_module.email_template_id' please suggest 

 

getting this error 

 File "C:\Users\www.abcom.in\Desktop\odoo engineering\odoo\odoo\tools\safe_eval.py", line 376, in safe_eval
    raise ValueError('%s: "%s" while evaluating\n%r' % (ustr(type(e)), ustr(e), expr))
ValueError: : "Invalid field hr.employee.timesheet_ids in leaf ('timesheet_ids.state', '!=', 'done')" while evaluating
"today = datetime.datetime.today()\r\n\r\nyesterday = today - datetime.timedelta(1)\r\n\r\n\r\n\r\nemployees_with_missing_timesheets = env['hr.employee'].search([\r\n\r\n    ('user_id', '!=', False),\r\n\r\n    ('timesheet_ids.date', '=', yesterday),\r\n\r\n    ('timesheet_ids.state', '!=', 'done'),\r\n\r\n])\r\n\r\nfor employee in employees_with_missing_timesheets:\r\n\r\n    template = env.ref('your_module.email_template_id')\r\n\r\n    template.send_mail(employee.user_id.id, force_send=True)"


0
Avatar
Annuleer
Geniet je van het gesprek? Blijf niet alleen lezen, doe ook mee!

Maak vandaag nog een account aan om te profiteren van exclusieve functies en deel uit te maken van onze geweldige community!

Aanmelden
Gerelateerde posts Antwoorden Weergaven Activiteit
Reference Next Execution date in Scheduled Action code
ScheduledActions
Avatar
Avatar
1
mei 24
4938
Scheduled action to assign unpaid leave in attendance where no check in and check out is marked
attendance ScheduledActions
Avatar
Avatar
1
jul. 25
2266
How to configure the scheduled action to automate the validation of the receipts in one of your warehouses
AutomatedActions ScheduledActions
Avatar
Avatar
2
jan. 24
3303
Automated actions Opgelost
product ScheduledActions
Avatar
Avatar
1
mei 23
3025
Update every res.partner via scheduled action
update res.partner ScheduledActions
Avatar
Avatar
Avatar
3
jul. 23
4370
Community
  • Tutorials
  • Documentatie
  • Forum
Open Source
  • Downloaden
  • Github
  • Runbot
  • Vertalingen
Diensten
  • Odoo.sh Hosting
  • Ondersteuning
  • Upgrade
  • Gepersonaliseerde ontwikkelingen
  • Onderwijs
  • Vind een boekhouder
  • Vind een partner
  • Partner worden
Over ons
  • Ons bedrijf
  • Merkelementen
  • Neem contact met ons op
  • Vacatures
  • Evenementen
  • Podcast
  • Blog
  • Klanten
  • Juridisch • Privacy
  • Beveiliging
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk Slovenščina Español (América Latina) Español Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo is een suite van open source zakelijke apps die aan al je bedrijfsbehoeften voldoet: CRM, E-commerce, boekhouding, inventaris, kassasysteem, projectbeheer, enz.

Odoo's unieke waardepropositie is om tegelijkertijd zeer gebruiksvriendelijk en volledig geïntegreerd te zijn.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now