server-tools/base_time_window
OCA-git-bot fc9f3cd2da [BOT] post-merge updates 2025-01-07 08:57:15 +00:00
..
data [IMP] base_time_window: black, isort 2023-02-21 22:46:25 +01:00
i18n Translated using Weblate (Italian) 2024-01-08 17:35:11 +00:00
models base_time_window: Add helper functions to get next Date matching weekday 2024-08-09 15:56:10 +02:00
readme [MIG] base_time_window: Migration to 14.0 2023-02-21 22:46:25 +01:00
security [IMP] base_time_window: black, isort 2023-02-21 22:46:25 +01:00
static/description [BOT] post-merge updates 2025-01-07 08:57:15 +00:00
tests base_time_window: Add helper functions to get next Date matching weekday 2024-08-09 15:56:10 +02:00
README.rst [BOT] post-merge updates 2025-01-07 08:57:15 +00:00
__init__.py Adapt module to v13.0 and new usage 2023-02-21 22:46:25 +01:00
__manifest__.py [BOT] post-merge updates 2025-01-07 08:57:15 +00:00

README.rst

================
Base Time Window
================

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

.. |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-OCA%2Fserver--tools-lightgray.png?logo=github
    :target: https://github.com/OCA/server-tools/tree/16.0/base_time_window
    :alt: OCA/server-tools
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
    :target: https://translation.odoo-community.org/projects/server-tools-16-0/server-tools-16-0-base_time_window
    :alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
    :target: https://runboat.odoo-community.org/builds?repo=OCA/server-tools&target_branch=16.0
    :alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module provides base classes and models to manage time windows through
`time.window.mixin`.

**Table of contents**

.. contents::
   :local:

Usage
=====

Example implementation for the mixin can be found in module `test_base_time_window`.

As a time window will always be linked to a related model thourgh a M2o relation,
when defining the new model inheriting the mixin, one should pay attention to the
following points in order to have the overlapping check work properly:

- Define class property `_overlap_check_field`: This must state the M2o field to
  use for the to check of overlapping time window records linked to a specific
  record of the related model.

- Add the M2o field to the related model in the `api.constrains`:


For example:

.. code-block:: python

    class PartnerTimeWindow(models.Model):
        _name = 'partner.time.window'
        _inherit = 'time.window.mixin'

        partner_id = fields.Many2one(
            res.partner', required=True, index=True, ondelete='cascade'
        )

        _overlap_check_field = 'partner_id'

        @api.constrains('partner_id')
        def check_window_no_overlaps(self):
            return super().check_window_no_overlaps()

Known issues / Roadmap
======================

* Storing times using `float_time` widget requires extra processing to ensure
  computations are done in the right timezone, because the value is not stored
  as UTC in the database, and must therefore be related to a `tz` field.

  `float_time` in this sense should only be used for durations and not for a
  "point in time" as this is always needs a Date for a timezone conversion to
  be done properly. (Because a conversion from UTC to e.g. Europe/Brussels won't
  give the same result in winter or summer because of Daylight Saving Time).

  Therefore the right move would be to use a `resource.calendar` to define time
  windows using Datetime with recurrences.

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

Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-tools/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/OCA/server-tools/issues/new?body=module:%20base_time_window%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
~~~~~~~

* ACSONE SA/NV
* Camptocamp

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

* Laurent Mignon <laurent.mignon@acsone.eu>
* Akim Juillerat <akim.juillerat@camptocamp.com>

Trobz

* Dung Tran <dungtd@trobz.com>

Other credits
~~~~~~~~~~~~~

The development of this module has been financially supported by:

* Camptocamp

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

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
   :alt: Odoo Community Association
   :target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

This module is part of the `OCA/server-tools <https://github.com/OCA/server-tools/tree/16.0/base_time_window>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.