Maintainers
+Maintainers
This module is part of the coopiteasy/cie-timesheet project on GitHub.
You are welcome to contribute.
diff --git a/hr_timesheet_overtime/README.rst b/hr_timesheet_overtime/README.rst index 328e663..861db99 100644 --- a/hr_timesheet_overtime/README.rst +++ b/hr_timesheet_overtime/README.rst @@ -29,6 +29,32 @@ Computes overtime hours according to employee's contracts. .. contents:: :local: +Known issues / Roadmap +====================== + +There is a problem with the way this module handles rates for overtime. If the +rate ever changes, things will start to break. + +At time of writing (2024-06-28), the way a rate is computed for a date is by +looking _exclusively_ at the corresponding day of the week. This should be more +robust. + +Furthermore, when inserting hours worked, the actual hours worked get lost. You +(try to) write a value to ``unit_amount``, but an augmented value gets written +to the field instead. This is rather ugly. + +We can improve this by relying on the computation of ``unit_amount`` in Odoo +≥16: create a new field ``hours_worked``, which contains the actual hours worked +sans rate. Then, compute ``unit_amount`` from ``hours_worked`` (in a more robust +fashion than is presently the case). In the interface, show ``hours_worked`` +more prominently than ``unit_amount`` as the main editable field. + +To make this module subsequently compatible with ``hr_timesheet_begin_end``, +``hours_worked`` must be computed from ``time_stop`` and ``time_start``, and +``unit_amount`` must use this module's computation method instead of +``hr_timesheet_begin_end``'s. The compatibility layer should go into its own +module. + Bug Tracker =========== diff --git a/hr_timesheet_overtime/readme/ROADMAP.rst b/hr_timesheet_overtime/readme/ROADMAP.rst new file mode 100644 index 0000000..08e5a7f --- /dev/null +++ b/hr_timesheet_overtime/readme/ROADMAP.rst @@ -0,0 +1,22 @@ +There is a problem with the way this module handles rates for overtime. If the +rate ever changes, things will start to break. + +At time of writing (2024-06-28), the way a rate is computed for a date is by +looking _exclusively_ at the corresponding day of the week. This should be more +robust. + +Furthermore, when inserting hours worked, the actual hours worked get lost. You +(try to) write a value to ``unit_amount``, but an augmented value gets written +to the field instead. This is rather ugly. + +We can improve this by relying on the computation of ``unit_amount`` in Odoo +≥16: create a new field ``hours_worked``, which contains the actual hours worked +sans rate. Then, compute ``unit_amount`` from ``hours_worked`` (in a more robust +fashion than is presently the case). In the interface, show ``hours_worked`` +more prominently than ``unit_amount`` as the main editable field. + +To make this module subsequently compatible with ``hr_timesheet_begin_end``, +``hours_worked`` must be computed from ``time_stop`` and ``time_start``, and +``unit_amount`` must use this module's computation method instead of +``hr_timesheet_begin_end``'s. The compatibility layer should go into its own +module. diff --git a/hr_timesheet_overtime/static/description/index.html b/hr_timesheet_overtime/static/description/index.html index 802d4a3..b0b4321 100644 --- a/hr_timesheet_overtime/static/description/index.html +++ b/hr_timesheet_overtime/static/description/index.html @@ -366,25 +366,47 @@
Computes overtime hours according to employee’s contracts.
Table of contents
There is a problem with the way this module handles rates for overtime. If the +rate ever changes, things will start to break.
+At time of writing (2024-06-28), the way a rate is computed for a date is by +looking _exclusively_ at the corresponding day of the week. This should be more +robust.
+Furthermore, when inserting hours worked, the actual hours worked get lost. You +(try to) write a value to unit_amount, but an augmented value gets written +to the field instead. This is rather ugly.
+We can improve this by relying on the computation of unit_amount in Odoo +≥16: create a new field hours_worked, which contains the actual hours worked +sans rate. Then, compute unit_amount from hours_worked (in a more robust +fashion than is presently the case). In the interface, show hours_worked +more prominently than unit_amount as the main editable field.
+To make this module subsequently compatible with hr_timesheet_begin_end, +hours_worked must be computed from time_stop and time_start, and +unit_amount must use this module’s computation method instead of +hr_timesheet_begin_end’s. The compatibility layer should go into its own +module.
+Bugs are tracked on GitHub 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 @@ -392,15 +414,15 @@
Do not contact contributors directly about support or help with technical issues.
This module is part of the coopiteasy/cie-timesheet project on GitHub.
You are welcome to contribute.