Initial commit: OCA Technical packages (595 packages)

This commit is contained in:
Ernad Husremovic 2025-08-29 15:43:03 +02:00
commit 2cc02aac6e
24950 changed files with 2318079 additions and 0 deletions

View file

@ -0,0 +1,47 @@
# Point of Sale HR- Extra Access Right
Odoo addon: pos_hr_access_right
## Installation
```bash
pip install odoo-bringout-oca-pos-pos_hr_access_right
```
## Dependencies
This addon depends on:
- pos_hr
- pos_access_right
## Manifest Information
- **Name**: Point of Sale HR- Extra Access Right
- **Version**: 16.0.1.0.1
- **Category**: Point Of Sale
- **License**: AGPL-3
- **Installable**: True
## Source
Based on [OCA/pos](https://github.com/OCA/pos) branch 16.0, addon `pos_hr_access_right`.
## 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 Pos_hr_access_right Module - pos_hr_access_right
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 pos_hr_access_right. 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,6 @@
# Dependencies
This addon depends on:
- [pos_hr](../../odoo-bringout-oca-ocb-pos_hr)
- [pos_access_right](../../odoo-bringout-oca-pos-pos_access_right)

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 pos_hr_access_right or install in UI.

View file

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

View file

@ -0,0 +1,12 @@
# Models
Detected core models and extensions in pos_hr_access_right.
```mermaid
classDiagram
class pos_session
```
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: pos_hr_access_right. Provides features documented in upstream Odoo 16 under this addon.
- Source: OCA/OCB 16.0, addon pos_hr_access_right
- License: LGPL-3

View file

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

View file

@ -0,0 +1,8 @@
# Security
This module does not define custom security rules or access controls beyond Odoo defaults.
Default Odoo security applies:
- Base user access through standard groups
- Model access inherited from dependencies
- No custom row-level security rules

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 pos_hr_access_right
```

View file

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

View file

@ -0,0 +1,101 @@
====================================
Point of Sale HR- Extra Access Right
====================================
..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:a777818020fc035609018e45c33d2b4e07d93544d8ee83b765beb711a319fb81
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
.. |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%2Fpos-lightgray.png?logo=github
:target: https://github.com/OCA/pos/tree/16.0/pos_hr_access_right
:alt: OCA/pos
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/pos-16-0/pos-16-0-pos_hr_access_right
: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/pos&target_branch=16.0
:alt: Try me on Runboat
|badge1| |badge2| |badge3| |badge4| |badge5|
This module extends the pos_access_right functionality to enable support for multiple
employees operating as cashiers within the same Point of Sale session.
**Table of contents**
.. contents::
:local:
Configuration
=============
Once installed, you must assign the appropriate access rights
to the users linked to the respective employees.
Employees who are not linked to a user will inherit the permissions
of the currently logged-in user.
Usage
=====
To use this functionality, simply enable the option for multiple employees
per session and add the desired employees.
Bug Tracker
===========
Bugs are tracked on `GitHub Issues <https://github.com/OCA/pos/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/pos/issues/new?body=module:%20pos_hr_access_right%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
~~~~~~~
* Binhex
Contributors
~~~~~~~~~~~~
* `Binhex <https://www.binhex.cloud>`_:
* Adasat Torres de León <a.torres@binhex.cloud>
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-adasatorres| image:: https://github.com/adasatorres.png?size=40px
:target: https://github.com/adasatorres
:alt: adasatorres
Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:
|maintainer-adasatorres|
This module is part of the `OCA/pos <https://github.com/OCA/pos/tree/16.0/pos_hr_access_right>`_ project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

View file

@ -0,0 +1 @@
from . import models

View file

@ -0,0 +1,20 @@
# Copyright 2025 Binhex - Adasat Torres de León
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
{
"name": "Point of Sale HR- Extra Access Right",
"version": "16.0.1.0.1",
"category": "Point Of Sale",
"summary": "Point of Sale HR - Extra Access Right for certain actions",
"author": "Binhex ,Odoo Community Association (OCA)",
"website": "https://github.com/OCA/pos",
"license": "AGPL-3",
"depends": ["pos_hr", "pos_access_right"],
"data": [],
"assets": {
"point_of_sale.assets": [
"pos_hr_access_right/static/src/js/*.js",
]
},
"maintainers": ["adasatorres"],
"installable": True,
}

View file

@ -0,0 +1,19 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * pos_hr_access_right
#
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: pos_hr_access_right
#: model:ir.model,name:pos_hr_access_right.model_pos_session
msgid "Point of Sale Session"
msgstr "Sesija POS-a"

View file

@ -0,0 +1,22 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * pos_hr_access_right
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2025-06-04 10:26+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.10.4\n"
#. module: pos_hr_access_right
#: model:ir.model,name:pos_hr_access_right.model_pos_session
msgid "Point of Sale Session"
msgstr "Sessione punto vendita"

View file

@ -0,0 +1,19 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * pos_hr_access_right
#
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: pos_hr_access_right
#: model:ir.model,name:pos_hr_access_right.model_pos_session
msgid "Point of Sale Session"
msgstr ""

View file

@ -0,0 +1 @@
from . import pos_session

View file

@ -0,0 +1,26 @@
# Copyright 2025 Binhex - Adasat Torres de León
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models
class PosSession(models.Model):
_inherit = "pos.session"
def _get_pos_ui_hr_employee(self, params):
employee_vals = super()._get_pos_ui_hr_employee(params)
for employee in employee_vals:
user_id = employee.get("user_id", False)
if not user_id:
user_id = self.env.user.id
user = self.env["res.users"].browse(user_id)
groups = user.groups_id
config = self.config_id
employee.update(
hasGroupPayment=config.group_payment_id in groups,
hasGroupDiscount=config.group_discount_id in groups,
hasGroupNegativeQty=config.group_negative_qty_id in groups,
hasGroupPriceControl=config.group_change_unit_price_id in groups,
hasGroupMultiOrder=config.group_multi_order_id in groups,
hasGroupDeleteOrder=config.group_delete_order_id in groups,
)
return employee_vals

View file

@ -0,0 +1,4 @@
Once installed, you must assign the appropriate access rights
to the users linked to the respective employees.
Employees who are not linked to a user will inherit the permissions
of the currently logged-in user.

View file

@ -0,0 +1,3 @@
* `Binhex <https://www.binhex.cloud>`_:
* Adasat Torres de León <a.torres@binhex.cloud>

View file

@ -0,0 +1,2 @@
This module extends the pos_access_right functionality to enable support for multiple
employees operating as cashiers within the same Point of Sale session.

View file

@ -0,0 +1,2 @@
To use this functionality, simply enable the option for multiple employees
per session and add the desired employees.

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.2 KiB

View file

@ -0,0 +1,443 @@
<!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>Point of Sale HR- Extra Access Right</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" id="point-of-sale-hr-extra-access-right">
<h1 class="title">Point of Sale HR- Extra Access Right</h1>
<!-- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:a777818020fc035609018e45c33d2b4e07d93544d8ee83b765beb711a319fb81
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
<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/licence-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/OCA/pos/tree/16.0/pos_hr_access_right"><img alt="OCA/pos" src="https://img.shields.io/badge/github-OCA%2Fpos-lightgray.png?logo=github" /></a> <a class="reference external image-reference" href="https://translation.odoo-community.org/projects/pos-16-0/pos-16-0-pos_hr_access_right"><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/pos&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 extends the pos_access_right functionality to enable support for multiple
employees operating as cashiers within the same Point of Sale session.</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">
<h1><a class="toc-backref" href="#toc-entry-1">Configuration</a></h1>
<p>Once installed, you must assign the appropriate access rights
to the users linked to the respective employees.
Employees who are not linked to a user will inherit the permissions
of the currently logged-in user.</p>
</div>
<div class="section" id="usage">
<h1><a class="toc-backref" href="#toc-entry-2">Usage</a></h1>
<p>To use this functionality, simply enable the option for multiple employees
per session and add the desired employees.</p>
</div>
<div class="section" id="bug-tracker">
<h1><a class="toc-backref" href="#toc-entry-3">Bug Tracker</a></h1>
<p>Bugs are tracked on <a class="reference external" href="https://github.com/OCA/pos/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/pos/issues/new?body=module:%20pos_hr_access_right%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">
<h1><a class="toc-backref" href="#toc-entry-4">Credits</a></h1>
<div class="section" id="authors">
<h2><a class="toc-backref" href="#toc-entry-5">Authors</a></h2>
<ul class="simple">
<li>Binhex</li>
</ul>
</div>
<div class="section" id="contributors">
<h2><a class="toc-backref" href="#toc-entry-6">Contributors</a></h2>
<ul class="simple">
<li><a class="reference external" href="https://www.binhex.cloud">Binhex</a>:<ul>
<li>Adasat Torres de León &lt;<a class="reference external" href="mailto:a.torres&#64;binhex.cloud">a.torres&#64;binhex.cloud</a>&gt;</li>
</ul>
</li>
</ul>
</div>
<div class="section" id="maintainers">
<h2><a class="toc-backref" href="#toc-entry-7">Maintainers</a></h2>
<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/adasatorres"><img alt="adasatorres" src="https://github.com/adasatorres.png?size=40px" /></a></p>
<p>This module is part of the <a class="reference external" href="https://github.com/OCA/pos/tree/16.0/pos_hr_access_right">OCA/pos</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>
</body>
</html>

View file

@ -0,0 +1,19 @@
odoo.define("pos_hr_access_right.ActionpadWidget", function (require) {
"use strict";
const Registries = require("point_of_sale.Registries");
const ActionpadWidget = require("pos_access_right.ActionpadWidget");
const PosHRActionpadWidget = (OriginalActionpadWidget) =>
class extends OriginalActionpadWidget {
get hasPaymentControlRights() {
if (this.env.pos.config.module_pos_hr)
return this.env.pos.cashier.hasGroupPayment;
return super.hasPaymentControlRights;
}
};
Registries.Component.extend(ActionpadWidget, PosHRActionpadWidget);
return ActionpadWidget;
});

View file

@ -0,0 +1,29 @@
odoo.define("pos_hr_access_right.NumpadWidget", function (require) {
"use strict";
const Registries = require("point_of_sale.Registries");
const NumpadWidget = require("pos_access_right.NumpadWidget");
const PosHRNumpadWidget = (OriginalNumpadWidget) =>
class extends OriginalNumpadWidget {
get hasManualDiscount() {
if (this.env.pos.config.module_pos_hr)
return this.env.pos.cashier.hasGroupDiscount;
return super.hasManualDiscount;
}
get hasMinusControlRights() {
if (this.env.pos.config.module_pos_hr)
return this.env.pos.cashier.hasGroupNegativeQty;
return super.hasMinusControlRights;
}
get hasPriceControlRights() {
if (this.env.pos.config.module_pos_hr)
return this.env.pos.cashier.hasGroupPriceControl;
return super.hasPriceControlRights;
}
};
Registries.Component.extend(NumpadWidget, PosHRNumpadWidget);
return NumpadWidget;
});

View file

@ -0,0 +1,28 @@
odoo.define("pos_hr_access_right.TicketScreen", function (require) {
"use strict";
const Registries = require("point_of_sale.Registries");
const TicketScreen = require("pos_access_right.TicketScreen");
const PosHRTicketScreen = (OriginalTicketScreen) =>
class extends OriginalTicketScreen {
get hasNewOrdersControlRights() {
if (this.env.pos.config.module_pos_hr)
return this.env.pos.cashier.hasGroupMultiOrder;
return super.hasNewOrdersControlRights;
}
async _onDeleteOrder({detail: order}) {
if (
this.env.pos.config.module_pos_hr &&
!this.env.pos.cashier.hasGroupDeleteOrder
)
return;
return super._onDeleteOrder({detail: order});
}
};
Registries.Component.extend(TicketScreen, PosHRTicketScreen);
return TicketScreen;
});

View file

@ -0,0 +1 @@
from . import test_pos_hr_access_right

View file

@ -0,0 +1,119 @@
# Copyright 2025 Binhex - Adasat Torres de León
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import Command
from odoo.tests import new_test_user, tagged
from odoo.tests.common import HttpCase
@tagged("post_install", "-at_install")
class TestPosHRAccessRight(HttpCase):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.main_pos_config = cls.env.ref("point_of_sale.pos_config_main")
cls.company_id = cls.env.ref("base.main_company")
cls.env = cls.env(context={"company_id": cls.company_id.id})
cls.admin = cls.env.ref("base.user_admin")
cls.user = new_test_user(
cls.env,
name="Test User",
login="test_user",
groups="""base.group_user,pos_access_right.group_negative_qty,
pos_access_right.group_discount""",
)
cls.user2 = new_test_user(
cls.env,
name="Test User 2",
login="test_user_2",
groups="""base.group_user,pos_access_right.group_change_unit_price,
pos_access_right.group_multi_order""",
)
cls.user3 = new_test_user(
cls.env,
name="Test User 3",
login="test_user_3",
groups="""base.group_user,pos_access_right.group_delete_order,
pos_access_right.group_payment""",
)
cls.emp = cls.env["hr.employee"].create(
{
"name": "Test Employee",
"company_id": cls.company_id.id,
"user_id": cls.user.id,
}
)
cls.emp2 = cls.env["hr.employee"].create(
{
"name": "Test Employee 2",
"company_id": cls.company_id.id,
"user_id": cls.user2.id,
}
)
cls.emp3 = cls.env["hr.employee"].create(
{
"name": "Test Employee 3",
"company_id": cls.company_id.id,
"user_id": cls.user3.id,
}
)
cls.emp4 = cls.env["hr.employee"].create(
{
"name": "Test Employee 4",
"company_id": cls.company_id.id,
}
)
cls.main_pos_config.write(
{
"module_pos_hr": True,
"employee_ids": [
Command.set([cls.emp.id, cls.emp2.id, cls.emp3.id, cls.emp4.id])
],
}
)
cls.pos_session_id = cls.env["pos.session"].create(
{"user_id": cls.admin.id, "config_id": cls.main_pos_config.id}
)
def test_get_pos_ui_hr_employee(self):
values = self.pos_session_id._get_pos_ui_hr_employee(
self.pos_session_id._loader_params_hr_employee()
)
self.assertTrue(values)
self.assertEqual(len(values), 5)
self.assertEqual(values[0]["hasGroupPayment"], True)
self.assertEqual(values[1]["hasGroupPayment"], False)
self.assertEqual(values[2]["hasGroupPayment"], False)
self.assertEqual(values[3]["hasGroupPayment"], True)
self.assertEqual(values[4]["hasGroupPayment"], True)
self.assertEqual(values[0]["hasGroupDiscount"], True)
self.assertEqual(values[1]["hasGroupDiscount"], True)
self.assertEqual(values[2]["hasGroupDiscount"], False)
self.assertEqual(values[3]["hasGroupDiscount"], False)
self.assertEqual(values[4]["hasGroupDiscount"], True)
self.assertEqual(values[0]["hasGroupNegativeQty"], True)
self.assertEqual(values[1]["hasGroupNegativeQty"], True)
self.assertEqual(values[2]["hasGroupNegativeQty"], False)
self.assertEqual(values[3]["hasGroupNegativeQty"], False)
self.assertEqual(values[4]["hasGroupNegativeQty"], True)
self.assertEqual(values[0]["hasGroupPriceControl"], True)
self.assertEqual(values[1]["hasGroupPriceControl"], False)
self.assertEqual(values[2]["hasGroupPriceControl"], True)
self.assertEqual(values[3]["hasGroupPriceControl"], False)
self.assertEqual(values[4]["hasGroupPriceControl"], True)
self.assertEqual(values[0]["hasGroupMultiOrder"], True)
self.assertEqual(values[1]["hasGroupMultiOrder"], False)
self.assertEqual(values[2]["hasGroupMultiOrder"], True)
self.assertEqual(values[3]["hasGroupMultiOrder"], False)
self.assertEqual(values[4]["hasGroupMultiOrder"], True)
self.assertEqual(values[0]["hasGroupDeleteOrder"], True)
self.assertEqual(values[1]["hasGroupDeleteOrder"], False)
self.assertEqual(values[2]["hasGroupDeleteOrder"], False)
self.assertEqual(values[3]["hasGroupDeleteOrder"], True)
self.assertEqual(values[4]["hasGroupDeleteOrder"], True)

View file

@ -0,0 +1,43 @@
[project]
name = "odoo-bringout-oca-pos-pos_hr_access_right"
version = "16.0.0"
description = "Point of Sale HR- Extra Access Right - Point of Sale HR - Extra Access Right for certain actions"
authors = [
{ name = "Ernad Husremovic", email = "hernad@bring.out.ba" }
]
dependencies = [
"odoo-bringout-oca-pos-pos_hr>=16.0.0",
"odoo-bringout-oca-pos-pos_access_right>=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 = ["pos_hr_access_right"]
[tool.rye]
managed = true
dev-dependencies = [
"pytest>=8.4.1",
]