Initial commit: OCA Mrp packages (117 packages)

This commit is contained in:
Ernad Husremovic 2025-08-29 15:43:05 +02:00
commit 277e84fd7a
4403 changed files with 395154 additions and 0 deletions

View file

@ -0,0 +1,46 @@
# HR Timesheet Predefined Description
Odoo addon: hr_timesheet_predefined_description
## Installation
```bash
pip install odoo-bringout-oca-timesheet-hr_timesheet_predefined_description
```
## Dependencies
This addon depends on:
- hr_timesheet
## Manifest Information
- **Name**: HR Timesheet Predefined Description
- **Version**: 16.0.1.0.0
- **Category**: Timesheet
- **License**: AGPL-3
- **Installable**: True
## Source
Based on [OCA/timesheet](https://github.com/OCA/timesheet) branch 16.0, addon `hr_timesheet_predefined_description`.
## License
This package maintains the original AGPL-3 license from the upstream Odoo project.
## Documentation
- Overview: doc/OVERVIEW.md
- Architecture: doc/ARCHITECTURE.md
- Models: doc/MODELS.md
- Controllers: doc/CONTROLLERS.md
- Wizards: doc/WIZARDS.md
- Reports: doc/REPORTS.md
- Security: doc/SECURITY.md
- Install: doc/INSTALL.md
- Usage: doc/USAGE.md
- Configuration: doc/CONFIGURATION.md
- Dependencies: doc/DEPENDENCIES.md
- Troubleshooting: doc/TROUBLESHOOTING.md
- FAQ: doc/FAQ.md

View file

@ -0,0 +1,32 @@
# Architecture
```mermaid
flowchart TD
U[Users] -->|HTTP| V[Views and QWeb Templates]
V --> C[Controllers]
V --> W[Wizards Transient Models]
C --> M[Models and ORM]
W --> M
M --> R[Reports]
DX[Data XML] --> M
S[Security ACLs and Groups] -. enforces .-> M
subgraph Hr_timesheet_predefined_description Module - hr_timesheet_predefined_description
direction LR
M:::layer
W:::layer
C:::layer
V:::layer
R:::layer
S:::layer
DX:::layer
end
classDef layer fill:#eef8ff,stroke:#6ea8fe,stroke-width:1px
```
Notes
- Views include tree/form/kanban templates and report templates.
- Controllers provide website/portal routes when present.
- Wizards are UI flows implemented with `models.TransientModel`.
- Data XML loads data/demo records; Security defines groups and access.

View file

@ -0,0 +1,3 @@
# Configuration
Refer to Odoo settings for hr_timesheet_predefined_description. Configure related models, access rights, and options as needed.

View file

@ -0,0 +1,3 @@
# Controllers
This module does not define custom HTTP controllers.

View file

@ -0,0 +1,5 @@
# Dependencies
This addon depends on:
- [hr_timesheet](../../odoo-bringout-oca-ocb-hr_timesheet)

View file

@ -0,0 +1,4 @@
# FAQ
- Q: Which Odoo version? A: 16.0 (OCA/OCB packaged).
- Q: How to enable? A: Start server with --addon hr_timesheet_predefined_description or install in UI.

View file

@ -0,0 +1,7 @@
# Install
```bash
pip install odoo-bringout-oca-timesheet-hr_timesheet_predefined_description"
# or
uv pip install odoo-bringout-oca-timesheet-hr_timesheet_predefined_description"
```

View file

@ -0,0 +1,13 @@
# Models
Detected core models and extensions in hr_timesheet_predefined_description.
```mermaid
classDiagram
class timesheet_predefined_description
class account_analytic_line
```
Notes
- Classes show model technical names; fields omitted for brevity.
- Items listed under _inherit are extensions of existing models.

View file

@ -0,0 +1,6 @@
# Overview
Packaged Odoo addon: hr_timesheet_predefined_description. Provides features documented in upstream Odoo 16 under this addon.
- Source: OCA/OCB 16.0, addon hr_timesheet_predefined_description
- License: LGPL-3

View file

@ -0,0 +1,3 @@
# Reports
This module does not define custom reports.

View file

@ -0,0 +1,41 @@
# Security
Access control and security definitions in hr_timesheet_predefined_description.
## Access Control Lists (ACLs)
Model access permissions defined in:
- **[ir.model.access.csv](../hr_timesheet_predefined_description/security/ir.model.access.csv)**
- 2 model access rules
## Record Rules
Row-level security rules defined in:
## Security Groups & Configuration
Security groups and permissions defined in:
- **[timesheet_predefined_description_security.xml](../hr_timesheet_predefined_description/security/timesheet_predefined_description_security.xml)**
```mermaid
graph TB
subgraph "Security Layers"
A[Users] --> B[Groups]
B --> C[Access Control Lists]
C --> D[Models]
B --> E[Record Rules]
E --> F[Individual Records]
end
```
Security files overview:
- **[ir.model.access.csv](../hr_timesheet_predefined_description/security/ir.model.access.csv)**
- Model access permissions (CRUD rights)
- **[timesheet_predefined_description_security.xml](../hr_timesheet_predefined_description/security/timesheet_predefined_description_security.xml)**
- Security groups, categories, and XML-based rules
Notes
- Access Control Lists define which groups can access which models
- Record Rules provide row-level security (filter records by user/group)
- Security groups organize users and define permission sets
- All security is enforced at the ORM level by Odoo

View file

@ -0,0 +1,5 @@
# Troubleshooting
- Ensure Python and Odoo environment matches repo guidance.
- Check database connectivity and logs if startup fails.
- Validate that dependent addons listed in DEPENDENCIES.md are installed.

View file

@ -0,0 +1,7 @@
# Usage
Start Odoo including this addon (from repo root):
```bash
python3 scripts/nix_odoo_web_server.py --db-name mydb --addon hr_timesheet_predefined_description
```

View file

@ -0,0 +1,3 @@
# Wizards
This module does not include UI wizards.

View file

@ -0,0 +1,124 @@
.. image:: https://odoo-community.org/readme-banner-image
:target: https://odoo-community.org/get-involved?utm_source=readme
:alt: Odoo Community Association
===================================
HR Timesheet Predefined Description
===================================
..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:d49f071b26fd7efee436cc462f62c231e33374592303f5c037922c5700d0de08
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
.. |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/license-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%2Ftimesheet-lightgray.png?logo=github
:target: https://github.com/OCA/timesheet/tree/16.0/hr_timesheet_predefined_description
:alt: OCA/timesheet
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/timesheet-16-0/timesheet-16-0-hr_timesheet_predefined_description
: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/timesheet&target_branch=16.0
:alt: Try me on Runboat
|badge1| |badge2| |badge3| |badge4| |badge5|
This module allows you to manage predefined descriptions for timesheets in Odoo.
**Table of contents**
.. contents::
:local:
Configuration
=============
**Add Predefined Descriptions:**
#. Go to *Timesheets* > *Configuration* > *Predefined Descriptions*.
#. Click on *Create*.
#. Enter the description name.
#. In a multi-company environment, check the company visibility.
#. Save.
**Modify Predefined Descriptions:**
#. Go to *Timesheets* > *Configuration* > *Predefined Descriptions*.
#. Click on an existing description.
#. Type the new description.
NOTE: These changes are not retro-actively applied to existing timesheets.
Usage
=====
**Create and Select Predefined Descriptions:**
#. When entering or editing a timesheet, simply select a predefined description from the
Predefined Description dropdown.
#. The Description field will be automatically filled based on the selected predefined
description.
**Override Descriptions if Necessary:**
#. You can manually edit the description in the timesheet if needed.
Bug Tracker
===========
Bugs are tracked on `GitHub Issues <https://github.com/OCA/timesheet/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/timesheet/issues/new?body=module:%20hr_timesheet_predefined_description%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
~~~~~~~
* Tecnativa
Contributors
~~~~~~~~~~~~
* `Tecnativa <https://www.tecnativa.com>`_:
* Juan José Seguí
* Pedro M. Baeza
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.
.. |maintainer-juanjosesegui-tecnativa| image:: https://github.com/juanjosesegui-tecnativa.png?size=40px
:target: https://github.com/juanjosesegui-tecnativa
:alt: juanjosesegui-tecnativa
Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:
|maintainer-juanjosesegui-tecnativa|
This module is part of the `OCA/timesheet <https://github.com/OCA/timesheet/tree/16.0/hr_timesheet_predefined_description>`_ project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

View file

@ -0,0 +1,26 @@
# Copyright 2024 Tecnativa - Juan José Seguí
# Copyright 2024 Tecnativa - Pedro M. Baeza
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
{
"name": "HR Timesheet Predefined Description",
"version": "16.0.1.0.0",
"category": "Timesheet",
"summary": "Predefined descriptions for timesheet entries",
"license": "AGPL-3",
"author": "Tecnativa, Odoo Community Association (OCA)",
"website": "https://github.com/OCA/timesheet",
"installable": True,
"auto_install": False,
"depends": ["hr_timesheet"],
"data": [
"security/ir.model.access.csv",
"security/timesheet_predefined_description_security.xml",
"views/account_analytic_line_views.xml",
"views/timesheet_predefined_description_views.xml",
],
"demo": [
"demo/hr_timesheet_predefined_description_demo.xml",
],
"maintainers": ["juanjosesegui-tecnativa"],
}

View file

@ -0,0 +1,26 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo noupdate="1">
<!-- Predefined Description 1 -->
<record
id="timesheet_predefined_description_1"
model="timesheet.predefined.description"
>
<field name="name">Development Task</field>
</record>
<!-- Predefined Description 2 -->
<record
id="timesheet_predefined_description_2"
model="timesheet.predefined.description"
>
<field name="name">Bug Fixing</field>
</record>
<!-- Predefined Description 3 -->
<record
id="timesheet_predefined_description_3"
model="timesheet.predefined.description"
>
<field name="name">Meeting with Client</field>
</record>
</odoo>

View file

@ -0,0 +1,80 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_timesheet_predefined_description
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_account_analytic_line
msgid "Analytic Line"
msgstr "Analitička stavka"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__company_id
msgid "Company"
msgstr "Preduzeće"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_uid
msgid "Created by"
msgstr "Kreirao"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_date
msgid "Created on"
msgstr "Kreirano"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__name
msgid "Description"
msgstr "Opis"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__display_name
msgid "Display Name"
msgstr "Prikazani naziv"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__id
msgid "ID"
msgstr "ID"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description____last_update
msgid "Last Modified on"
msgstr "Zadnje mijenjano"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_uid
msgid "Last Updated by"
msgstr "Zadnji ažurirao"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_date
msgid "Last Updated on"
msgstr "Zadnje ažurirano"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__predefined_description_id
msgid "Predefined Description"
msgstr "Predefinirani opis"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_timesheet_predefined_description
msgid "Predefined Description for Timesheets"
msgstr "Predefinirani opis za radne listove"
#. module: hr_timesheet_predefined_description
#: model:ir.actions.act_window,name:hr_timesheet_predefined_description.action_timesheet_predefined_description
#: model:ir.ui.menu,name:hr_timesheet_predefined_description.menu_timesheet_predefined_description
msgid "Predefined Descriptions"
msgstr "Predefinirani opisi"

View file

@ -0,0 +1,87 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_timesheet_predefined_description
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2024-09-19 09:06+0000\n"
"Last-Translator: Víctor Martínez <victor.martinez@tecnativa.com>\n"
"Language-Team: none\n"
"Language: es\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 5.6.2\n"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_account_analytic_line
msgid "Analytic Line"
msgstr "Línea analítica"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__company_id
msgid "Company"
msgstr "Compañía"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_uid
msgid "Created by"
msgstr "Creado por"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_date
msgid "Created on"
msgstr "Creado el"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__name
msgid "Description"
msgstr "Descripción"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__display_name
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__display_name
msgid "Display Name"
msgstr "Nombre mostrado"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__id
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__id
msgid "ID"
msgstr "ID"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line____last_update
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description____last_update
msgid "Last Modified on"
msgstr "Última modificación el"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_uid
msgid "Last Updated by"
msgstr "Última actualización por"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_date
msgid "Last Updated on"
msgstr "Última actualización el"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__predefined_description_id
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_hr_timesheet_switch__predefined_description_id
msgid "Predefined Description"
msgstr "Descripción predefinida"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_timesheet_predefined_description
msgid "Predefined Description for Timesheets"
msgstr "Descripción predefinida para partes de horas"
#. module: hr_timesheet_predefined_description
#: model:ir.actions.act_window,name:hr_timesheet_predefined_description.action_timesheet_predefined_description
#: model:ir.ui.menu,name:hr_timesheet_predefined_description.menu_timesheet_predefined_description
msgid "Predefined Descriptions"
msgstr "Descripciones predefinidas"

View file

@ -0,0 +1,80 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_timesheet_predefined_description
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_account_analytic_line
msgid "Analytic Line"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__company_id
msgid "Company"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_uid
msgid "Created by"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_date
msgid "Created on"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__name
msgid "Description"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__display_name
msgid "Display Name"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__id
msgid "ID"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description____last_update
msgid "Last Modified on"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_uid
msgid "Last Updated by"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_date
msgid "Last Updated on"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__predefined_description_id
msgid "Predefined Description"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_timesheet_predefined_description
msgid "Predefined Description for Timesheets"
msgstr ""
#. module: hr_timesheet_predefined_description
#: model:ir.actions.act_window,name:hr_timesheet_predefined_description.action_timesheet_predefined_description
#: model:ir.ui.menu,name:hr_timesheet_predefined_description.menu_timesheet_predefined_description
msgid "Predefined Descriptions"
msgstr ""

View file

@ -0,0 +1,87 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * hr_timesheet_predefined_description
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2025-01-15 10:06+0000\n"
"Last-Translator: mymage <stefano.consolaro@mymage.it>\n"
"Language-Team: none\n"
"Language: it\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 5.6.2\n"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_account_analytic_line
msgid "Analytic Line"
msgstr "Riga analitica"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__company_id
msgid "Company"
msgstr "Azienda"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_uid
msgid "Created by"
msgstr "Creato da"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__create_date
msgid "Created on"
msgstr "Creato il"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__name
msgid "Description"
msgstr "Descrizione"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__display_name
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__display_name
msgid "Display Name"
msgstr "Nome visualizzato"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__id
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__id
msgid "ID"
msgstr "ID"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line____last_update
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description____last_update
msgid "Last Modified on"
msgstr "Ultima modifica il"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_uid
msgid "Last Updated by"
msgstr "Ultimo aggiornamento di"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_timesheet_predefined_description__write_date
msgid "Last Updated on"
msgstr "Ultimo aggiornamento il"
#. module: hr_timesheet_predefined_description
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_account_analytic_line__predefined_description_id
#: model:ir.model.fields,field_description:hr_timesheet_predefined_description.field_hr_timesheet_switch__predefined_description_id
msgid "Predefined Description"
msgstr "Descrizione predefinita"
#. module: hr_timesheet_predefined_description
#: model:ir.model,name:hr_timesheet_predefined_description.model_timesheet_predefined_description
msgid "Predefined Description for Timesheets"
msgstr "Descrizione predefinita per fogli ore"
#. module: hr_timesheet_predefined_description
#: model:ir.actions.act_window,name:hr_timesheet_predefined_description.action_timesheet_predefined_description
#: model:ir.ui.menu,name:hr_timesheet_predefined_description.menu_timesheet_predefined_description
msgid "Predefined Descriptions"
msgstr "Descrizioni predefinite"

View file

@ -0,0 +1,4 @@
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from . import hr_timesheet_predefined_description
from . import account_analytic_line

View file

@ -0,0 +1,39 @@
# Copyright 2024 Tecnativa - Juan José Seguí
# Copyright 2024 Tecnativa - Pedro M. Baeza
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from odoo import api, fields, models
class AccountAnalyticLine(models.Model):
_inherit = "account.analytic.line"
predefined_description_id = fields.Many2one(
comodel_name="timesheet.predefined.description", string="Predefined Description"
)
@api.model
def _adjust_name_from_predefined_description(self, vals):
"""Set description on the analytic line if no valid description is provided in
the dictionary vals and there's a predefined description.
"""
if "predefined_description_id" in vals and (vals.get("name") or "/") == "/":
description = self.env["timesheet.predefined.description"].browse(
vals["predefined_description_id"]
)
vals["name"] = description.name
@api.model_create_multi
def create(self, vals_list):
for vals in vals_list:
self._adjust_name_from_predefined_description(vals)
return super().create(vals_list)
def write(self, vals):
self._adjust_name_from_predefined_description(vals)
return super().write(vals)
@api.onchange("predefined_description_id")
def _onchange_predefined_description(self):
if self.predefined_description_id:
self.name = self.predefined_description_id.name

View file

@ -0,0 +1,16 @@
# Copyright 2024 Tecnativa - Juan José Seguí
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from odoo import fields, models
class TimesheetPredefinedDescription(models.Model):
_name = "timesheet.predefined.description"
_description = "Predefined Description for Timesheets"
name = fields.Char(string="Description", required=True)
company_id = fields.Many2one(
comodel_name="res.company",
string="Company",
default=lambda self: self.env.company,
)

View file

@ -0,0 +1,15 @@
**Add Predefined Descriptions:**
#. Go to *Timesheets* > *Configuration* > *Predefined Descriptions*.
#. Click on *Create*.
#. Enter the description name.
#. In a multi-company environment, check the company visibility.
#. Save.
**Modify Predefined Descriptions:**
#. Go to *Timesheets* > *Configuration* > *Predefined Descriptions*.
#. Click on an existing description.
#. Type the new description.
NOTE: These changes are not retro-actively applied to existing timesheets.

View file

@ -0,0 +1,4 @@
* `Tecnativa <https://www.tecnativa.com>`_:
* Juan José Seguí
* Pedro M. Baeza

View file

@ -0,0 +1 @@
This module allows you to manage predefined descriptions for timesheets in Odoo.

View file

@ -0,0 +1,10 @@
**Create and Select Predefined Descriptions:**
#. When entering or editing a timesheet, simply select a predefined description from the
Predefined Description dropdown.
#. The Description field will be automatically filled based on the selected predefined
description.
**Override Descriptions if Necessary:**
#. You can manually edit the description in the timesheet if needed.

View file

@ -0,0 +1,3 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_timesheet_predefined_description_user,timesheet.predefined.description.user,model_timesheet_predefined_description,hr_timesheet.group_hr_timesheet_user,1,0,0,0
access_timesheet_predefined_description_admin,timesheet.predefined.description.admin,model_timesheet_predefined_description,hr_timesheet.group_timesheet_manager,1,1,1,1
1 id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
2 access_timesheet_predefined_description_user timesheet.predefined.description.user model_timesheet_predefined_description hr_timesheet.group_hr_timesheet_user 1 0 0 0
3 access_timesheet_predefined_description_admin timesheet.predefined.description.admin model_timesheet_predefined_description hr_timesheet.group_timesheet_manager 1 1 1 1

View file

@ -0,0 +1,8 @@
<odoo>
<record id="timesheet_predefined_description_rule" model="ir.rule">
<field name="name">Predefined Descriptions: multi-company access</field>
<field name="model_id" ref="model_timesheet_predefined_description" />
<field name="global" eval="True" />
<field name="domain_force">[('company_id', 'in', company_ids + [False])]</field>
</record>
</odoo>

View file

@ -0,0 +1,469 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="generator" content="Docutils: https://docutils.sourceforge.io/" />
<title>README.rst</title>
<style type="text/css">
/*
:Author: David Goodger (goodger@python.org)
:Id: $Id: html4css1.css 9511 2024-01-13 09:50:07Z milde $
:Copyright: This stylesheet has been placed in the public domain.
Default cascading style sheet for the HTML output of Docutils.
Despite the name, some widely supported CSS2 features are used.
See https://docutils.sourceforge.io/docs/howto/html-stylesheets.html for how to
customize this style sheet.
*/
/* used to remove borders from tables and images */
.borderless, table.borderless td, table.borderless th {
border: 0 }
table.borderless td, table.borderless th {
/* Override padding for "table.docutils td" with "! important".
The right padding separates the table cells. */
padding: 0 0.5em 0 0 ! important }
.first {
/* Override more specific margin styles with "! important". */
margin-top: 0 ! important }
.last, .with-subtitle {
margin-bottom: 0 ! important }
.hidden {
display: none }
.subscript {
vertical-align: sub;
font-size: smaller }
.superscript {
vertical-align: super;
font-size: smaller }
a.toc-backref {
text-decoration: none ;
color: black }
blockquote.epigraph {
margin: 2em 5em ; }
dl.docutils dd {
margin-bottom: 0.5em }
object[type="image/svg+xml"], object[type="application/x-shockwave-flash"] {
overflow: hidden;
}
/* Uncomment (and remove this text!) to get bold-faced definition list terms
dl.docutils dt {
font-weight: bold }
*/
div.abstract {
margin: 2em 5em }
div.abstract p.topic-title {
font-weight: bold ;
text-align: center }
div.admonition, div.attention, div.caution, div.danger, div.error,
div.hint, div.important, div.note, div.tip, div.warning {
margin: 2em ;
border: medium outset ;
padding: 1em }
div.admonition p.admonition-title, div.hint p.admonition-title,
div.important p.admonition-title, div.note p.admonition-title,
div.tip p.admonition-title {
font-weight: bold ;
font-family: sans-serif }
div.attention p.admonition-title, div.caution p.admonition-title,
div.danger p.admonition-title, div.error p.admonition-title,
div.warning p.admonition-title, .code .error {
color: red ;
font-weight: bold ;
font-family: sans-serif }
/* Uncomment (and remove this text!) to get reduced vertical space in
compound paragraphs.
div.compound .compound-first, div.compound .compound-middle {
margin-bottom: 0.5em }
div.compound .compound-last, div.compound .compound-middle {
margin-top: 0.5em }
*/
div.dedication {
margin: 2em 5em ;
text-align: center ;
font-style: italic }
div.dedication p.topic-title {
font-weight: bold ;
font-style: normal }
div.figure {
margin-left: 2em ;
margin-right: 2em }
div.footer, div.header {
clear: both;
font-size: smaller }
div.line-block {
display: block ;
margin-top: 1em ;
margin-bottom: 1em }
div.line-block div.line-block {
margin-top: 0 ;
margin-bottom: 0 ;
margin-left: 1.5em }
div.sidebar {
margin: 0 0 0.5em 1em ;
border: medium outset ;
padding: 1em ;
background-color: #ffffee ;
width: 40% ;
float: right ;
clear: right }
div.sidebar p.rubric {
font-family: sans-serif ;
font-size: medium }
div.system-messages {
margin: 5em }
div.system-messages h1 {
color: red }
div.system-message {
border: medium outset ;
padding: 1em }
div.system-message p.system-message-title {
color: red ;
font-weight: bold }
div.topic {
margin: 2em }
h1.section-subtitle, h2.section-subtitle, h3.section-subtitle,
h4.section-subtitle, h5.section-subtitle, h6.section-subtitle {
margin-top: 0.4em }
h1.title {
text-align: center }
h2.subtitle {
text-align: center }
hr.docutils {
width: 75% }
img.align-left, .figure.align-left, object.align-left, table.align-left {
clear: left ;
float: left ;
margin-right: 1em }
img.align-right, .figure.align-right, object.align-right, table.align-right {
clear: right ;
float: right ;
margin-left: 1em }
img.align-center, .figure.align-center, object.align-center {
display: block;
margin-left: auto;
margin-right: auto;
}
table.align-center {
margin-left: auto;
margin-right: auto;
}
.align-left {
text-align: left }
.align-center {
clear: both ;
text-align: center }
.align-right {
text-align: right }
/* reset inner alignment in figures */
div.align-right {
text-align: inherit }
/* div.align-center * { */
/* text-align: left } */
.align-top {
vertical-align: top }
.align-middle {
vertical-align: middle }
.align-bottom {
vertical-align: bottom }
ol.simple, ul.simple {
margin-bottom: 1em }
ol.arabic {
list-style: decimal }
ol.loweralpha {
list-style: lower-alpha }
ol.upperalpha {
list-style: upper-alpha }
ol.lowerroman {
list-style: lower-roman }
ol.upperroman {
list-style: upper-roman }
p.attribution {
text-align: right ;
margin-left: 50% }
p.caption {
font-style: italic }
p.credits {
font-style: italic ;
font-size: smaller }
p.label {
white-space: nowrap }
p.rubric {
font-weight: bold ;
font-size: larger ;
color: maroon ;
text-align: center }
p.sidebar-title {
font-family: sans-serif ;
font-weight: bold ;
font-size: larger }
p.sidebar-subtitle {
font-family: sans-serif ;
font-weight: bold }
p.topic-title {
font-weight: bold }
pre.address {
margin-bottom: 0 ;
margin-top: 0 ;
font: inherit }
pre.literal-block, pre.doctest-block, pre.math, pre.code {
margin-left: 2em ;
margin-right: 2em }
pre.code .ln { color: gray; } /* line numbers */
pre.code, code { background-color: #eeeeee }
pre.code .comment, code .comment { color: #5C6576 }
pre.code .keyword, code .keyword { color: #3B0D06; font-weight: bold }
pre.code .literal.string, code .literal.string { color: #0C5404 }
pre.code .name.builtin, code .name.builtin { color: #352B84 }
pre.code .deleted, code .deleted { background-color: #DEB0A1}
pre.code .inserted, code .inserted { background-color: #A3D289}
span.classifier {
font-family: sans-serif ;
font-style: oblique }
span.classifier-delimiter {
font-family: sans-serif ;
font-weight: bold }
span.interpreted {
font-family: sans-serif }
span.option {
white-space: nowrap }
span.pre {
white-space: pre }
span.problematic, pre.problematic {
color: red }
span.section-subtitle {
/* font-size relative to parent (h1..h6 element) */
font-size: 80% }
table.citation {
border-left: solid 1px gray;
margin-left: 1px }
table.docinfo {
margin: 2em 4em }
table.docutils {
margin-top: 0.5em ;
margin-bottom: 0.5em }
table.footnote {
border-left: solid 1px black;
margin-left: 1px }
table.docutils td, table.docutils th,
table.docinfo td, table.docinfo th {
padding-left: 0.5em ;
padding-right: 0.5em ;
vertical-align: top }
table.docutils th.field-name, table.docinfo th.docinfo-name {
font-weight: bold ;
text-align: left ;
white-space: nowrap ;
padding-left: 0 }
/* "booktabs" style (no vertical lines) */
table.docutils.booktabs {
border: 0px;
border-top: 2px solid;
border-bottom: 2px solid;
border-collapse: collapse;
}
table.docutils.booktabs * {
border: 0px;
}
table.docutils.booktabs th {
border-bottom: thin solid;
text-align: left;
}
h1 tt.docutils, h2 tt.docutils, h3 tt.docutils,
h4 tt.docutils, h5 tt.docutils, h6 tt.docutils {
font-size: 100% }
ul.auto-toc {
list-style-type: none }
</style>
</head>
<body>
<div class="document">
<a class="reference external image-reference" href="https://odoo-community.org/get-involved?utm_source=readme">
<img alt="Odoo Community Association" src="https://odoo-community.org/readme-banner-image" />
</a>
<div class="section" id="hr-timesheet-predefined-description">
<h1>HR Timesheet Predefined Description</h1>
<!-- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:d49f071b26fd7efee436cc462f62c231e33374592303f5c037922c5700d0de08
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
<p><a class="reference external image-reference" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external image-reference" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/license-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/OCA/timesheet/tree/16.0/hr_timesheet_predefined_description"><img alt="OCA/timesheet" src="https://img.shields.io/badge/github-OCA%2Ftimesheet-lightgray.png?logo=github" /></a> <a class="reference external image-reference" href="https://translation.odoo-community.org/projects/timesheet-16-0/timesheet-16-0-hr_timesheet_predefined_description"><img alt="Translate me on Weblate" src="https://img.shields.io/badge/weblate-Translate%20me-F47D42.png" /></a> <a class="reference external image-reference" href="https://runboat.odoo-community.org/builds?repo=OCA/timesheet&amp;target_branch=16.0"><img alt="Try me on Runboat" src="https://img.shields.io/badge/runboat-Try%20me-875A7B.png" /></a></p>
<p>This module allows you to manage predefined descriptions for timesheets in Odoo.</p>
<p><strong>Table of contents</strong></p>
<div class="contents local topic" id="contents">
<ul class="simple">
<li><a class="reference internal" href="#configuration" id="toc-entry-1">Configuration</a></li>
<li><a class="reference internal" href="#usage" id="toc-entry-2">Usage</a></li>
<li><a class="reference internal" href="#bug-tracker" id="toc-entry-3">Bug Tracker</a></li>
<li><a class="reference internal" href="#credits" id="toc-entry-4">Credits</a><ul>
<li><a class="reference internal" href="#authors" id="toc-entry-5">Authors</a></li>
<li><a class="reference internal" href="#contributors" id="toc-entry-6">Contributors</a></li>
<li><a class="reference internal" href="#maintainers" id="toc-entry-7">Maintainers</a></li>
</ul>
</li>
</ul>
</div>
<div class="section" id="configuration">
<h2><a class="toc-backref" href="#toc-entry-1">Configuration</a></h2>
<p><strong>Add Predefined Descriptions:</strong></p>
<ol class="arabic simple">
<li>Go to <em>Timesheets</em> &gt; <em>Configuration</em> &gt; <em>Predefined Descriptions</em>.</li>
<li>Click on <em>Create</em>.</li>
<li>Enter the description name.</li>
<li>In a multi-company environment, check the company visibility.</li>
<li>Save.</li>
</ol>
<p><strong>Modify Predefined Descriptions:</strong></p>
<ol class="arabic simple">
<li>Go to <em>Timesheets</em> &gt; <em>Configuration</em> &gt; <em>Predefined Descriptions</em>.</li>
<li>Click on an existing description.</li>
<li>Type the new description.</li>
</ol>
<p>NOTE: These changes are not retro-actively applied to existing timesheets.</p>
</div>
<div class="section" id="usage">
<h2><a class="toc-backref" href="#toc-entry-2">Usage</a></h2>
<p><strong>Create and Select Predefined Descriptions:</strong></p>
<ol class="arabic simple">
<li>When entering or editing a timesheet, simply select a predefined description from the
Predefined Description dropdown.</li>
<li>The Description field will be automatically filled based on the selected predefined
description.</li>
</ol>
<p><strong>Override Descriptions if Necessary:</strong></p>
<ol class="arabic simple">
<li>You can manually edit the description in the timesheet if needed.</li>
</ol>
</div>
<div class="section" id="bug-tracker">
<h2><a class="toc-backref" href="#toc-entry-3">Bug Tracker</a></h2>
<p>Bugs are tracked on <a class="reference external" href="https://github.com/OCA/timesheet/issues">GitHub Issues</a>.
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
<a class="reference external" href="https://github.com/OCA/timesheet/issues/new?body=module:%20hr_timesheet_predefined_description%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**">feedback</a>.</p>
<p>Do not contact contributors directly about support or help with technical issues.</p>
</div>
<div class="section" id="credits">
<h2><a class="toc-backref" href="#toc-entry-4">Credits</a></h2>
<div class="section" id="authors">
<h3><a class="toc-backref" href="#toc-entry-5">Authors</a></h3>
<ul class="simple">
<li>Tecnativa</li>
</ul>
</div>
<div class="section" id="contributors">
<h3><a class="toc-backref" href="#toc-entry-6">Contributors</a></h3>
<ul class="simple">
<li><a class="reference external" href="https://www.tecnativa.com">Tecnativa</a>:<ul>
<li>Juan José Seguí</li>
<li>Pedro M. Baeza</li>
</ul>
</li>
</ul>
</div>
<div class="section" id="maintainers">
<h3><a class="toc-backref" href="#toc-entry-7">Maintainers</a></h3>
<p>This module is maintained by the OCA.</p>
<a class="reference external image-reference" href="https://odoo-community.org">
<img alt="Odoo Community Association" src="https://odoo-community.org/logo.png" />
</a>
<p>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.</p>
<p>Current <a class="reference external" href="https://odoo-community.org/page/maintainer-role">maintainer</a>:</p>
<p><a class="reference external image-reference" href="https://github.com/juanjosesegui-tecnativa"><img alt="juanjosesegui-tecnativa" src="https://github.com/juanjosesegui-tecnativa.png?size=40px" /></a></p>
<p>This module is part of the <a class="reference external" href="https://github.com/OCA/timesheet/tree/16.0/hr_timesheet_predefined_description">OCA/timesheet</a> project on GitHub.</p>
<p>You are welcome to contribute. To learn how please visit <a class="reference external" href="https://odoo-community.org/page/Contribute">https://odoo-community.org/page/Contribute</a>.</p>
</div>
</div>
</div>
</div>
</body>
</html>

View file

@ -0,0 +1,3 @@
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from . import test_account_analytic_line

View file

@ -0,0 +1,52 @@
# Copyright 2024 Tecnativa - Juan José Seguí
# Copyright 2024 Tecnativa - Pedro M. Baeza
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from odoo.tests import Form, TransactionCase
class TestAccountAnalyticLine(TransactionCase):
@classmethod
def setUpClass(cls):
super(TestAccountAnalyticLine, cls).setUpClass()
cls.AccountAnalyticAccount = cls.env["account.analytic.account"]
cls.PredefinedDescription = cls.env["timesheet.predefined.description"]
cls.AccountAnalyticLine = cls.env["account.analytic.line"]
cls.AnalyticPlan = cls.env["account.analytic.plan"]
cls.plan = cls.AnalyticPlan.create({"name": "Test Plan"})
cls.description = "Test Predefined Description"
cls.predefined_description = cls.PredefinedDescription.create(
{"name": cls.description}
)
cls.analytic_account = cls.AccountAnalyticAccount.create(
{
"name": "Test Account",
"plan_id": cls.plan.id,
}
)
cls.analytic_line = cls.AccountAnalyticLine.create(
{
"name": "Original Description",
"account_id": cls.analytic_account.id,
}
)
def test_onchange_predefined_description(self):
with Form(self.analytic_line) as form:
form.predefined_description_id = self.predefined_description
self.assertEqual(form.name, self.description)
def test_create_predefined_description(self):
line = self.analytic_line.create(
{
"account_id": self.analytic_account.id,
"predefined_description_id": self.predefined_description.id,
},
)
self.assertEqual(line.name, self.description)
def test_write_predefined_description(self):
self.analytic_line.write(
{"predefined_description_id": self.predefined_description.id}
)
self.assertEqual(self.analytic_line.name, self.description)

View file

@ -0,0 +1,34 @@
<odoo>
<record id="view_analytic_line_form_inherit" model="ir.ui.view">
<field name="name">account.analytic.line.form.inherit</field>
<field name="model">account.analytic.line</field>
<field name="inherit_id" ref="hr_timesheet.hr_timesheet_line_tree" />
<field name="arch" type="xml">
<field name="name" position="before">
<field name="predefined_description_id" optional="hide" />
</field>
</field>
</record>
<record id="view_account_analytic_line_form" model="ir.ui.view">
<field name="model">account.analytic.line</field>
<field name="inherit_id" ref="analytic.view_account_analytic_line_form" />
<field name="arch" type="xml">
<field name="name" position="before">
<field name="predefined_description_id" />
</field>
</field>
</record>
<record id="view_project_task_form_inherit" model="ir.ui.view">
<field name="name">project.task.form.inherit.predefined_description</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_form2" />
<field name="arch" type="xml">
<xpath
expr="//field[@name='timesheet_ids']/tree/field[@name='name']"
position="before"
>
<field name="predefined_description_id" optional="hide" />
</xpath>
</field>
</record>
</odoo>

View file

@ -0,0 +1,27 @@
<odoo>
<record id="view_timesheet_predefined_description_tree" model="ir.ui.view">
<field name="name">timesheet.predefined.description.tree</field>
<field name="model">timesheet.predefined.description</field>
<field name="arch" type="xml">
<tree editable="bottom">
<field name="name" />
<field name="company_id" groups="base.group_multi_company" />
</tree>
</field>
</record>
<record id="action_timesheet_predefined_description" model="ir.actions.act_window">
<field name="name">Predefined Descriptions</field>
<field name="res_model">timesheet.predefined.description</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="view_timesheet_predefined_description_tree" />
</record>
<menuitem
id="menu_timesheet_predefined_description"
name="Predefined Descriptions"
parent="hr_timesheet.hr_timesheet_menu_configuration"
action="action_timesheet_predefined_description"
/>
</odoo>

View file

@ -0,0 +1,42 @@
[project]
name = "odoo-bringout-oca-timesheet-hr_timesheet_predefined_description"
version = "16.0.0"
description = "HR Timesheet Predefined Description - Predefined descriptions for timesheet entries"
authors = [
{ name = "Ernad Husremovic", email = "hernad@bring.out.ba" }
]
dependencies = [
"odoo-bringout-oca-ocb-hr_timesheet>=16.0.0",
"requests>=2.25.1"
]
readme = "README.md"
requires-python = ">= 3.11"
classifiers = [
"Development Status :: 5 - Production/Stable",
"Intended Audience :: Developers",
"License :: OSI Approved :: GNU Lesser General Public License v3 (LGPLv3)",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12",
"Topic :: Office/Business",
]
[project.urls]
homepage = "https://github.com/bringout/0"
repository = "https://github.com/bringout/0"
[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"
[tool.hatch.metadata]
allow-direct-references = true
[tool.hatch.build.targets.wheel]
packages = ["hr_timesheet_predefined_description"]
[tool.rye]
managed = true
dev-dependencies = [
"pytest>=8.4.1",
]