Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
a6b1a6d
added volunteer_company_holiday, extended recurrent_generator, draft …
Genepi314 Feb 19, 2026
fe0dfa4
cancel holiday shift operational, still lacks company implementation,…
Genepi314 Feb 20, 2026
79748ee
commit before switching branch
Genepi314 Feb 23, 2026
e7198ae
draft test_cancel_holiday_shift with company + correct README
Genepi314 Feb 24, 2026
acc87b7
Add models and views for volunteer leaves, volunteer leave types, and…
Genepi314 Mar 3, 2026
a584534
Refacto _cancel_holiday_shift, now using a dictionary and filters by …
Genepi314 Mar 3, 2026
130eeb9
Add tracking to is_maintained_during_holiday (bool) in generator.
Genepi314 Mar 3, 2026
5218d91
Add freezegun for test_company_holiday
Genepi314 Mar 4, 2026
642f6cf
Syntax and decorator fixes in volunteer_company_holidayù
Genepi314 Mar 4, 2026
be54c46
Add company for volunteer_leave, record rules for all models, row com…
Genepi314 Mar 4, 2026
57a9f43
Add cron and function to cancel volunteer participations during their…
Genepi314 Mar 5, 2026
5e83781
small fix _cancel_volunteer_leave_participation().
Genepi314 Mar 5, 2026
e260401
Add test for _cancel_volunteer_leave_participation().
Genepi314 Mar 5, 2026
8488f36
Add demo data for company holiday, volunteer leave and volunteer leav…
Genepi314 Mar 9, 2026
15a6db1
draft new function to uncancel shifts in volunteer_company_holiday (f…
Genepi314 Mar 10, 2026
e9688bd
removed copy of method in volunteer_leave, add config for notificatio…
Genepi314 Mar 12, 2026
8b1dc76
Add method to send notification for end of volunteer leave, add confi…
Genepi314 Mar 17, 2026
6992be1
add badge on shift form view if on holiday, models volunteer_shift an…
Genepi314 Mar 21, 2026
432576c
Changed time range to 12 months, for demonstration purpose.
Genepi314 Mar 21, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions setup/volunteer_holiday/odoo/addons/volunteer_holiday
6 changes: 6 additions & 0 deletions setup/volunteer_holiday/setup.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import setuptools

setuptools.setup(
setup_requires=['setuptools-odoo'],
odoo_addon=True,
)
70 changes: 70 additions & 0 deletions volunteer_holiday/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
=================
Volunteer Holiday
=================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:d68150a24904527787d7cde7a5cb68c88f101992b43ec7c25f9a3450eb8d6184
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-beescoop%2FObeesdoo-lightgray.png?logo=github
:target: https://github.com/beescoop/Obeesdoo/tree/16.0/volunteer_holiday
:alt: beescoop/Obeesdoo

|badge1| |badge2| |badge3|

Add volunteer and company holidays to volunteer app, and manage shifts and generators accordingly.

**Table of contents**

.. contents::
:local:

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/beescoop/Obeesdoo/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/beescoop/Obeesdoo/issues/new?body=module:%20volunteer_holiday%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~

* Coop IT Easy SC

Contributors
~~~~~~~~~~~~

* `Coop IT Easy SC <https://coopiteasy.be>`_:

* Geneviève Ernould

Maintainers
~~~~~~~~~~~

.. |maintainer-remytms| image:: https://github.com/remytms.png?size=40px
:target: https://github.com/remytms
:alt: remytms

Current maintainer:

|maintainer-remytms|

This module is part of the `beescoop/Obeesdoo <https://github.com/beescoop/Obeesdoo/tree/16.0/volunteer_holiday>`_ project on GitHub.

You are welcome to contribute.
6 changes: 6 additions & 0 deletions volunteer_holiday/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# SPDX-FileCopyrightText: 2025 Coop IT Easy SC
#
# SPDX-License-Identifier: AGPL-3.0-or-later

from . import models
from . import wizards
34 changes: 34 additions & 0 deletions volunteer_holiday/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# SPDX-FileCopyrightText: 2026 Coop IT Easy SC
#
# SPDX-License-Identifier: AGPL-3.0-or-later

{
"name": "Volunteer Holiday",
"summary": "Add holidays for companies and volunteers",
"version": "16.0.0.5.0",
"category": "Volunteer management",
"website": "https://github.com/beescoop/Obeesdoo",
"author": "Coop IT Easy SC",
"maintainers": ["remytms"],
"license": "AGPL-3",
"application": False,
"depends": ["base", "volunteer", "mail"],
"data": [
"data/cron.xml",
"security/ir.model.access.csv",
"security/volunteer_security.xml",
"views/volunteer_shift_views.xml",
"views/res_config_settings_views.xml",
"views/volunteer_shift_generator_views.xml",
"views/volunteer_company_holiday_view.xml",
"views/volunteer_volunteer_view.xml",
"views/volunteer_volunteer_leave_type_view.xml",
"views/volunteer_volunteer_leave_view.xml",
"views/volunteer_menu.xml",
],
"demo": [
"demo/volunteer_company_holiday_demo.xml",
"demo/volunteer_volunteer_leave_type_demo.xml",
"demo/volunteer_volunteer_leave_demo.xml",
],
}
1 change: 1 addition & 0 deletions volunteer_holiday/controllers/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import controllers
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You should remove the controllers directory if your have nothing more than the __init__.py file in it.

48 changes: 48 additions & 0 deletions volunteer_holiday/data/cron.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<?xml version="1.0" encoding="utf-8" ?>
<!--
SPDX-FileCopyrightText: 2025 Coop IT Easy SC

SPDX-License-Identifier: AGPL-3.0-or-later
-->
<odoo noupdate="0">

<record id="ir_cron_cancel_holiday_shift" model="ir.cron">
<field
name="name"
>Volunteer: Cancel Generated Shifts During Company Holidays</field>
<field name="model_id" ref="model_volunteer_company_holiday" />
<field name="state">code</field>
<field name="code">model._cancel_holiday_shift()</field>
<field name="interval_number">24</field>
<field name="interval_type">hours</field>
<field name="numbercall">-1</field>
<field name="doall" eval="False" />
</record>

<record id="ir_cron_cancel_volunteer_leave_participation" model="ir.cron">
<field
name="name"
>Volunteer: Cancel Participations During Volunteer Leaves</field>
<field name="model_id" ref="model_volunteer_volunteer_leave" />
<field name="state">code</field>
<field name="code">model._cancel_volunteer_leave_participation()</field>
<field name="interval_number">24</field>
<field name="interval_type">hours</field>
<field name="numbercall">-1</field>
<field name="doall" eval="False" />
</record>

<record id="ir_cron_send_leave_end_notification" model="ir.cron">
<field
name="name"
>Notification: Send a Reminder to Volunteers Before their Leave Ends</field>
<field name="model_id" ref="model_volunteer_volunteer" />
<field name="state">code</field>
<field name="code">model._send_notification_end_leave()</field>
<field name="interval_number">24</field>
<field name="interval_type">hours</field>
<field name="numbercall">-1</field>
<field name="doall" eval="False" />
</record>

</odoo>
37 changes: 37 additions & 0 deletions volunteer_holiday/demo/volunteer_company_holiday_demo.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
<?xml version="1.0" encoding="utf-8" ?>
<!--
SPDX-FileCopyrightText: 2025 Coop IT Easy SC

SPDX-License-Identifier: AGPL-3.0-or-later
-->
<odoo>
<record
id="volunteer_company_holiday_demo_christmas"
model="volunteer.company.holiday"
>
<field name="name">Christmas Holidays</field>
<field
name="start_date"
eval="(datetime.today().replace(month=12, day=24)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Starting with python 3.9 (odoo 16.0 uses 3.10), prefer using isformat() instead of strftime for standard iso formatting.

See method here.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After some tests on these cases, neither strftime() nor isoformat() seems to be required. On my side, loading works fine without any formatting. That said, I'm not sure of all the details behind it.

/>
<field
name="end_date"
eval="(datetime.today().replace(month=12, day=25)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat()

/>
</record>

<record
id="volunteer_company_holiday_demo_store_inventory"
model="volunteer.company.holiday"
>
<field name="name">Store Inventory</field>
<field
name="start_date"
eval="(datetime.today().replace(month=7, day=1)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
<field
name="end_date"
eval="(datetime.today().replace(month=7, day=7)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
</record>
</odoo>
42 changes: 42 additions & 0 deletions volunteer_holiday/demo/volunteer_volunteer_leave_demo.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
<?xml version="1.0" encoding="utf-8" ?>
<!--
SPDX-FileCopyrightText: 2025 Coop IT Easy SC

SPDX-License-Identifier: AGPL-3.0-or-later
-->
<odoo>
<record
id="volunteer_volunteer_leave_demo_vol_a_leave"
model="volunteer.volunteer.leave"
>
<field name="volunteer_id" ref="volunteer.volunteer_demo_a" />
<field name="type_id" ref="volunteer_volunteer_leave_type_demo_vacation" />
<field
name="start_date"
eval="(datetime.now().date() + timedelta(weeks=4, days=4)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
<field
name="end_date"
eval="(datetime.now().date() + timedelta(weeks=4, days=14)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
</record>

<record
id="volunteer_volunteer_leave_demo_vol_c_leave"
model="volunteer.volunteer.leave"
>
<field name="volunteer_id" ref="volunteer.volunteer_demo_c" />
<field
name="type_id"
ref="volunteer_volunteer_leave_type_demo_parental_leave"
/>
<field
name="start_date"
eval="(datetime.now().date() + timedelta(days=4)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
<field
name="end_date"
eval="(datetime.now().date() + timedelta(weeks=9, days=4)).strftime('%Y-%m-%d')"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isoformat

/>
</record>
</odoo>
31 changes: 31 additions & 0 deletions volunteer_holiday/demo/volunteer_volunteer_leave_type_demo.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?xml version="1.0" encoding="utf-8" ?>
<!--
SPDX-FileCopyrightText: 2025 Coop IT Easy SC

SPDX-License-Identifier: AGPL-3.0-or-later
-->
<odoo>
<record
id="volunteer_volunteer_leave_type_demo_sick_leave"
model="volunteer.volunteer.leave.type"
>
<field name="name">Sick Leave</field>
<field name="description">Leave due to illness</field>
</record>

<record
id="volunteer_volunteer_leave_type_demo_parental_leave"
model="volunteer.volunteer.leave.type"
>
<field name="name">Parental Leave</field>
<field name="description">Leave due to pregnancy/childcare</field>
</record>

<record
id="volunteer_volunteer_leave_type_demo_vacation"
model="volunteer.volunteer.leave.type"
>
<field name="name">Vacation</field>
<field name="description">Vacation</field>
</record>
</odoo>
11 changes: 11 additions & 0 deletions volunteer_holiday/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# SPDX-FileCopyrightText: 2025 Coop IT Easy SC
#
# SPDX-License-Identifier: AGPL-3.0-or-later

from . import res_company
from . import volunteer_company_holiday
from . import volunteer_shift_recurrent_generator
from . import volunteer_volunteer
from . import volunteer_volunteer_leave_type
from . import volunteer_volunteer_leave
from . import volunteer_shift
22 changes: 22 additions & 0 deletions volunteer_holiday/models/res_company.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# SPDX-FileCopyrightText: 2025 Coop IT Easy SC
#
# SPDX-License-Identifier: AGPL-3.0-or-later

from odoo import fields, models


class ResCompany(models.Model):
_inherit = ["res.company"]

nb_days_before_leave_end = fields.Integer(
string="Number of days for notification before end of leave",
default=7,
)

_sql_constraints = [
(
"nb_days_is_pos",
"CHECK (nb_days_before_leave_end > 0)",
"The number of days cannot be null or negative.",
),
]
Loading
Loading