Skip to content
Extraits de code Groupes Projets
Valider 404d0e6c rédigé par Rémi - Le Filament's avatar Rémi - Le Filament
Parcourir les fichiers

[MIG] migration to 15.0

parent ec1e9901
Aucune branche associée trouvée
Aucune étiquette associée trouvée
1 requête de fusion!1Refactor reports
Affichage de avec 812 ajouts et 174 suppressions
# Configuration for known file extensions
[*.{css,js,json,less,md,py,rst,sass,scss,xml,yaml,yml}]
charset = utf-8
end_of_line = lf
indent_size = 4
indent_style = space
insert_final_newline = true
trim_trailing_whitespace = true
[*.{json,yml,yaml,rst,md}]
indent_size = 2
# Do not configure editor for libs and autogenerated content
[{*/static/{lib,src/lib}/**,*/static/description/index.html,*/readme/../README.rst}]
charset = unset
end_of_line = unset
indent_size = unset
indent_style = unset
insert_final_newline = false
trim_trailing_whitespace = false
env:
browser: true
es6: true
# See https://github.com/OCA/odoo-community.org/issues/37#issuecomment-470686449
parserOptions:
ecmaVersion: 2019
overrides:
- files:
- "**/*.esm.js"
parserOptions:
sourceType: module
# Globals available in Odoo that shouldn't produce errorings
globals:
_: readonly
$: readonly
fuzzy: readonly
jQuery: readonly
moment: readonly
odoo: readonly
openerp: readonly
owl: readonly
# Styling is handled by Prettier, so we only need to enable AST rules;
# see https://github.com/OCA/maintainer-quality-tools/pull/618#issuecomment-558576890
rules:
accessor-pairs: warn
array-callback-return: warn
callback-return: warn
capitalized-comments:
- warn
- always
- ignoreConsecutiveComments: true
ignoreInlineComments: true
complexity:
- warn
- 15
constructor-super: warn
dot-notation: warn
eqeqeq: warn
global-require: warn
handle-callback-err: warn
id-blacklist: warn
id-match: warn
init-declarations: error
max-depth: warn
max-nested-callbacks: warn
max-statements-per-line: warn
no-alert: warn
no-array-constructor: warn
no-caller: warn
no-case-declarations: warn
no-class-assign: warn
no-cond-assign: error
no-const-assign: error
no-constant-condition: warn
no-control-regex: warn
no-debugger: error
no-delete-var: warn
no-div-regex: warn
no-dupe-args: error
no-dupe-class-members: error
no-dupe-keys: error
no-duplicate-case: error
no-duplicate-imports: error
no-else-return: warn
no-empty-character-class: warn
no-empty-function: error
no-empty-pattern: error
no-empty: warn
no-eq-null: error
no-eval: error
no-ex-assign: error
no-extend-native: warn
no-extra-bind: warn
no-extra-boolean-cast: warn
no-extra-label: warn
no-fallthrough: warn
no-func-assign: error
no-global-assign: error
no-implicit-coercion:
- warn
- allow: ["~"]
no-implicit-globals: warn
no-implied-eval: warn
no-inline-comments: warn
no-inner-declarations: warn
no-invalid-regexp: warn
no-irregular-whitespace: warn
no-iterator: warn
no-label-var: warn
no-labels: warn
no-lone-blocks: warn
no-lonely-if: error
no-mixed-requires: error
no-multi-str: warn
no-native-reassign: error
no-negated-condition: warn
no-negated-in-lhs: error
no-new-func: warn
no-new-object: warn
no-new-require: warn
no-new-symbol: warn
no-new-wrappers: warn
no-new: warn
no-obj-calls: warn
no-octal-escape: warn
no-octal: warn
no-param-reassign: warn
no-path-concat: warn
no-process-env: warn
no-process-exit: warn
no-proto: warn
no-prototype-builtins: warn
no-redeclare: warn
no-regex-spaces: warn
no-restricted-globals: warn
no-restricted-imports: warn
no-restricted-modules: warn
no-restricted-syntax: warn
no-return-assign: error
no-script-url: warn
no-self-assign: warn
no-self-compare: warn
no-sequences: warn
no-shadow-restricted-names: warn
no-shadow: warn
no-sparse-arrays: warn
no-sync: warn
no-this-before-super: warn
no-throw-literal: warn
no-undef-init: warn
no-undef: error
no-unmodified-loop-condition: warn
no-unneeded-ternary: error
no-unreachable: error
no-unsafe-finally: error
no-unused-expressions: error
no-unused-labels: error
no-unused-vars: error
no-use-before-define: error
no-useless-call: warn
no-useless-computed-key: warn
no-useless-concat: warn
no-useless-constructor: warn
no-useless-escape: warn
no-useless-rename: warn
no-void: warn
no-with: warn
operator-assignment: [error, always]
prefer-const: warn
radix: warn
require-yield: warn
sort-imports: warn
spaced-comment: [error, always]
strict: [error, function]
use-isnan: error
valid-jsdoc:
- warn
- prefer:
arg: param
argument: param
augments: extends
constructor: class
exception: throws
func: function
method: function
prop: property
return: returns
virtual: abstract
yield: yields
preferType:
array: Array
bool: Boolean
boolean: Boolean
number: Number
object: Object
str: String
string: String
requireParamDescription: false
requireReturn: false
requireReturnDescription: false
requireReturnType: false
valid-typeof: warn
yoda: warn
[flake8]
max-line-length = 88
max-complexity = 16
# B = bugbear
# B9 = bugbear opinionated (incl line length)
select = C,E,F,W,B,B9
# E203: whitespace before ':' (black behaviour)
# E501: flake8 line length (covered by bugbear B950)
# W503: line break before binary operator (black behaviour)
ignore = E203,E501,W503
per-file-ignores=
__init__.py:F401
.* # Byte-compiled / optimized / DLL files
*.pyc __pycache__/
!.gitignore *.py[cod]
/.venv
/.pytest_cache
# C extensions
*.so
# Distribution / packaging
.Python
env/
bin/
build/
develop-eggs/
dist/
eggs/
lib64/
parts/
sdist/
var/
*.egg-info/
.installed.cfg
*.egg
*.eggs
# Installer logs
pip-log.txt
pip-delete-this-directory.txt
# Unit test / coverage reports
htmlcov/
.tox/
.coverage
.cache
nosetests.xml
coverage.xml
# Translations
*.mo
# Pycharm
.idea
# Eclipse
.settings
# Visual Studio cache/options directory
.vs/
.vscode
# OSX Files
.DS_Store
# Django stuff:
*.log
# Mr Developer
.mr.developer.cfg
.project
.pydevproject
# Rope
.ropeproject
# Sphinx documentation
docs/_build/
# Backup files
*~
*.swp
# OCA rules
!static/lib/
[settings]
; see https://github.com/psf/black
multi_line_output=3
include_trailing_comma=True
force_grid_wrap=0
combine_as_imports=True
use_parentheses=True
line_length=88
known_odoo=odoo
known_odoo_addons=odoo.addons
sections=FUTURE,STDLIB,THIRDPARTY,ODOO,ODOO_ADDONS,FIRSTPARTY,LOCALFOLDER
default_section=THIRDPARTY
ensure_newline_before_comments = True
exclude: |
(?x)
# NOT INSTALLABLE ADDONS
# END NOT INSTALLABLE ADDONS
# Files and folders generated by bots, to avoid loops
^setup/|/static/description/index\.html$|
# We don't want to mess with tool-generated files
.svg$|/tests/([^/]+/)?cassettes/|^.copier-answers.yml$|^.github/|
# Maybe reactivate this when all README files include prettier ignore tags?
^README\.md$|
# Library files can have extraneous formatting (even minimized)
/static/(src/)?lib/|
# Repos using Sphinx to generate docs don't need prettying
^docs/_templates/.*\.html$|
# You don't usually want a bot to modify your legal texts
(LICENSE.*|COPYING.*)
default_language_version:
python: python3
node: "14.18.0"
repos:
- repo: local
hooks:
# These files are most likely copier diff rejection junks; if found,
# review them manually, fix the problem (if needed) and remove them
- id: forbidden-files
name: forbidden files
entry: found forbidden files; remove them
language: fail
files: "\\.rej$"
- repo: https://github.com/oca/maintainer-tools
rev: dfba427ba03900b69e0a7f2c65890dc48921d36a
hooks:
# update the NOT INSTALLABLE ADDONS section above
- id: oca-update-pre-commit-excluded-addons
- id: oca-fix-manifest-website
args: ["https://le-filament.com"]
- repo: https://github.com/myint/autoflake
rev: v1.4
hooks:
- id: autoflake
args:
- --expand-star-imports
- --ignore-init-module-imports
- --in-place
- --remove-all-unused-imports
- --remove-duplicate-keys
- --remove-unused-variables
- repo: https://github.com/psf/black
rev: 22.3.0
hooks:
- id: black
- repo: https://github.com/pre-commit/mirrors-prettier
rev: v2.4.1
hooks:
- id: prettier
name: prettier (with plugin-xml)
additional_dependencies:
- "prettier@2.4.1"
- "@prettier/plugin-xml@1.1.0"
args:
- --plugin=@prettier/plugin-xml
files: \.(css|htm|html|js|json|jsx|less|md|scss|toml|ts|xml|yaml|yml)$
- repo: https://github.com/pre-commit/mirrors-eslint
rev: v7.32.0
hooks:
- id: eslint
verbose: true
args:
- --color
- --fix
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.0.1
hooks:
- id: trailing-whitespace
# exclude autogenerated files
exclude: /README\.rst$|\.pot?$
- id: end-of-file-fixer
# exclude autogenerated files
exclude: /README\.rst$|\.pot?$
- id: debug-statements
- id: fix-encoding-pragma
args: ["--remove"]
- id: check-case-conflict
- id: check-docstring-first
- id: check-executables-have-shebangs
- id: check-merge-conflict
# exclude files where underlines are not distinguishable from merge conflicts
exclude: /README\.rst$|^docs/.*\.rst$
- id: check-symlinks
- id: check-xml
- id: mixed-line-ending
args: ["--fix=lf"]
- repo: https://github.com/asottile/pyupgrade
rev: v2.29.0
hooks:
- id: pyupgrade
args: ["--keep-percent-format"]
- repo: https://github.com/PyCQA/isort
rev: 5.9.3
hooks:
- id: isort
name: isort except __init__.py
args:
- --settings=.
exclude: /__init__\.py$
- repo: https://gitlab.com/PyCQA/flake8
rev: 3.9.2
hooks:
- id: flake8
name: flake8
additional_dependencies: ["flake8-bugbear==21.9.2"]
- repo: https://github.com/OCA/pylint-odoo
rev: 7.0.2
hooks:
- id: pylint_odoo
name: pylint with optional checks
args:
- --rcfile=.pylintrc
- --exit-zero
verbose: true
- id: pylint_odoo
args:
- --rcfile=.pylintrc-mandatory
# Defaults for all prettier-supported languages.
# Prettier will complete this with settings from .editorconfig file.
bracketSpacing: false
printWidth: 88
proseWrap: always
semi: true
trailingComma: "es5"
xmlWhitespaceSensitivity: "strict"
[MASTER]
load-plugins=pylint_odoo
score=n
[ODOOLINT]
readme_template_url="https://github.com/OCA/maintainer-tools/blob/master/template/module/README.rst"
manifest_required_authors=Le Filament
manifest_required_keys=license
manifest_deprecated_keys=description,active
license_allowed=AGPL-3,GPL-2,GPL-2 or any later version,GPL-3,GPL-3 or any later version,LGPL-3
valid_odoo_versions=15.0
[MESSAGES CONTROL]
disable=all
# This .pylintrc contains optional AND mandatory checks and is meant to be
# loaded in an IDE to have it check everything, in the hope this will make
# optional checks more visible to contributors who otherwise never look at a
# green travis to see optional checks that failed.
# .pylintrc-mandatory containing only mandatory checks is used the pre-commit
# config as a blocking check.
enable=anomalous-backslash-in-string,
api-one-deprecated,
api-one-multi-together,
assignment-from-none,
attribute-deprecated,
class-camelcase,
dangerous-default-value,
dangerous-view-replace-wo-priority,
development-status-allowed,
duplicate-id-csv,
duplicate-key,
duplicate-xml-fields,
duplicate-xml-record-id,
eval-referenced,
eval-used,
incoherent-interpreter-exec-perm,
license-allowed,
manifest-author-string,
manifest-deprecated-key,
manifest-required-author,
manifest-required-key,
manifest-version-format,
method-compute,
method-inverse,
method-required-super,
method-search,
openerp-exception-warning,
pointless-statement,
pointless-string-statement,
print-used,
redundant-keyword-arg,
redundant-modulename-xml,
reimported,
relative-import,
return-in-init,
rst-syntax-error,
sql-injection,
too-few-format-args,
translation-field,
translation-required,
unreachable,
use-vim-comment,
wrong-tabs-instead-of-spaces,
xml-syntax-error,
attribute-string-redundant,
character-not-valid-in-resource-link,
consider-merging-classes-inherited,
context-overridden,
create-user-wo-reset-password,
dangerous-filter-wo-user,
dangerous-qweb-replace-wo-priority,
deprecated-data-xml-node,
deprecated-openerp-xml-node,
duplicate-po-message-definition,
except-pass,
file-not-used,
invalid-commit,
manifest-maintainers-list,
missing-newline-extrafiles,
missing-readme,
missing-return,
odoo-addons-relative-import,
old-api7-method-defined,
po-msgstr-variables,
po-syntax-error,
renamed-field-parameter,
resource-not-exist,
str-format-used,
test-folder-imported,
translation-contains-variable,
translation-positional-used,
unnecessary-utf8-coding-comment,
website-manifest-key-not-valid-uri,
xml-attribute-translatable,
xml-deprecated-qweb-directive,
xml-deprecated-tree-attribute,
# messages that do not cause the lint step to fail
consider-merging-classes-inherited,
create-user-wo-reset-password,
dangerous-filter-wo-user,
deprecated-module,
file-not-used,
invalid-commit,
missing-manifest-dependency,
missing-newline-extrafiles,
missing-readme,
no-utf8-coding-comment,
odoo-addons-relative-import,
old-api7-method-defined,
redefined-builtin,
too-complex,
unnecessary-utf8-coding-comment
[REPORTS]
msg-template={path}:{line}: [{msg_id}({symbol}), {obj}] {msg}
output-format=colorized
reports=no
[MASTER]
load-plugins=pylint_odoo
score=n
[ODOOLINT]
readme_template_url="https://github.com/OCA/maintainer-tools/blob/master/template/module/README.rst"
manifest_required_authors=Le Filament
manifest_required_keys=license
manifest_deprecated_keys=description,active
license_allowed=AGPL-3,GPL-2,GPL-2 or any later version,GPL-3,GPL-3 or any later version,LGPL-3
valid_odoo_versions=15.0
[MESSAGES CONTROL]
disable=all
enable=anomalous-backslash-in-string,
api-one-deprecated,
api-one-multi-together,
assignment-from-none,
attribute-deprecated,
class-camelcase,
dangerous-default-value,
dangerous-view-replace-wo-priority,
development-status-allowed,
duplicate-id-csv,
duplicate-key,
duplicate-xml-fields,
duplicate-xml-record-id,
eval-referenced,
eval-used,
incoherent-interpreter-exec-perm,
license-allowed,
manifest-author-string,
manifest-deprecated-key,
manifest-required-author,
manifest-required-key,
manifest-version-format,
method-compute,
method-inverse,
method-required-super,
method-search,
openerp-exception-warning,
pointless-statement,
pointless-string-statement,
print-used,
redundant-keyword-arg,
redundant-modulename-xml,
reimported,
relative-import,
return-in-init,
rst-syntax-error,
sql-injection,
too-few-format-args,
translation-field,
translation-required,
unreachable,
use-vim-comment,
wrong-tabs-instead-of-spaces,
xml-syntax-error,
attribute-string-redundant,
character-not-valid-in-resource-link,
consider-merging-classes-inherited,
context-overridden,
create-user-wo-reset-password,
dangerous-filter-wo-user,
dangerous-qweb-replace-wo-priority,
deprecated-data-xml-node,
deprecated-openerp-xml-node,
duplicate-po-message-definition,
except-pass,
file-not-used,
invalid-commit,
manifest-maintainers-list,
missing-newline-extrafiles,
missing-readme,
missing-return,
odoo-addons-relative-import,
old-api7-method-defined,
po-msgstr-variables,
po-syntax-error,
renamed-field-parameter,
resource-not-exist,
str-format-used,
test-folder-imported,
translation-contains-variable,
translation-positional-used,
unnecessary-utf8-coding-comment,
website-manifest-key-not-valid-uri,
xml-attribute-translatable,
xml-deprecated-qweb-directive,
xml-deprecated-tree-attribute
[REPORTS]
msg-template={path}:{line}: [{msg_id}({symbol}), {obj}] {msg}
output-format=colorized
reports=no
# -*- coding: utf-8 -*-
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from . import models from . import models
# -*- coding: utf-8 -*-
{ {
'name': 'Le Filament - Training', "name": "Le Filament - Training",
'version': '14.0.1.0.0', "version": "15.0.1.0.0",
'summary': 'Training sessions managment', "summary": "Training sessions managment",
'license': 'AGPL-3', "license": "AGPL-3",
'author': 'LE FILAMENT', "author": "Le Filament",
'category': 'LE FILAMENT', "depends": ["base", "account", "sale", "partner_firstname"],
'depends': ['base', 'account', 'sale', 'partner_firstname'], "contributors": [
'contributors': [ "Benjamin Rivier <benjamin@le-filament.com>",
'Benjamin Rivier <benjamin@le-filament.com>',
], ],
'website': 'http://www.le-filament.com', "website": "https://le-filament.com",
'data': [ "data": [
'data/ir_module_category.xml', "data/ir_module_category.xml",
'security/training_security.xml', "security/training_security.xml",
'security/ir.model.access.csv', "security/ir.model.access.csv",
'data/training_data.xml', "data/training_data.xml",
'views/account_move_view.xml', "views/account_move_view.xml",
'views/assets.xml', "views/partner_view.xml",
'views/partner_view.xml', "views/sale_order_view.xml",
'views/sale_order_view.xml', "views/training_course_view.xml",
'views/training_course_view.xml', "views/training_training_view.xml",
'views/training_training_view.xml', "views/training_session_view.xml",
'views/training_session_view.xml', "report/report_agreement.xml",
'report/report_agreement.xml', "report/report_attestation.xml",
'report/report_attestation.xml', "report/report_attendance_sheet.xml",
'report/report_attendance_sheet.xml', "report/report_program.xml",
'report/report_program.xml',
], ],
"assets": {
"web.assets_common": [
"lefilament_training/static/src/scss/style.scss",
],
"web.report_assets_pdf": [
"lefilament_training/static/src/scss/style.scss",
],
},
} }
<?xml version="1.0" encoding="utf-8" ?> <?xml version="1.0" encoding="utf-8" ?>
<!-- Copyright 2019 Le Filament (<https://www.le-filament.com>) <!-- Copyright 2019-2022 Le Filament (<https://le-filament.com>)
License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). --> License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
<odoo> <odoo>
<data>
<record model="ir.module.category" id="module_category_training"> <record model="ir.module.category" id="module_category_training">
<field name="name">Formation</field> <field name="name">Formation</field>
<field name="description">Gestionnaire de formation</field> <field name="description">Gestionnaire de formation</field>
<field name="sequence">230</field> <field name="sequence">230</field>
</record> </record>
</data>
</odoo> </odoo>
<?xml version="1.0" encoding="utf-8" ?> <?xml version="1.0" encoding="utf-8" ?>
<odoo> <!-- Copyright 2019-2022 Le Filament (<https://le-filament.com>)
<data noupdate="1"> License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
<odoo noupdate="1">
<!-- Training sequences --> <!-- Training sequences -->
<record id="sequence_payment_customer_invoice" model="ir.sequence"> <record id="sequence_payment_customer_invoice" model="ir.sequence">
<field name="name">Training Agreement sequence</field> <field name="name">Training Agreement sequence</field>
...@@ -12,5 +13,4 @@ ...@@ -12,5 +13,4 @@
<field eval="False" name="company_id" /> <field eval="False" name="company_id" />
<field name="padding">3</field> <field name="padding">3</field>
</record> </record>
</data>
</odoo> </odoo>
# -*- coding: utf-8 -*-
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from . import account_move from . import account_move
from . import partner from . import partner
from . import sale_order from . import sale_order
......
# -*- coding: utf-8 -*- # Copyright 2019-2022 Le Filament (<https://le-filament.com>)
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models, fields from odoo import fields, models
class AccountInvoiceTraining(models.Model): class AccountInvoiceTraining(models.Model):
_inherit = ['account.move'] _inherit = ["account.move"]
training_id = fields.Many2one( training_id = fields.Many2one(comodel_name="training.training", string="Formation")
comodel_name='training.training',
string='Formation')
# -*- coding: utf-8 -*- # Copyright 2019-2022 Le Filament (<https://le-filament.com>)
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models, fields from odoo import fields, models
class PartnerTraining(models.Model): class PartnerTraining(models.Model):
_inherit = ['res.partner'] _inherit = ["res.partner"]
is_opco = fields.Boolean('OPCO') is_opco = fields.Boolean("OPCO")
# -*- coding: utf-8 -*- # Copyright 2019-2022 Le Filament (<https://le-filament.com>)
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models, fields from odoo import fields, models
class SaleOrderTraining(models.Model): class SaleOrderTraining(models.Model):
_inherit = 'sale.order' _inherit = "sale.order"
training_id = fields.Many2one( training_id = fields.Many2one(comodel_name="training.training", string="Formation")
comodel_name='training.training',
string='Formation')
# -*- coding: utf-8 -*- # Copyright 2019-2022 Le Filament (<https://le-filament.com>)
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models, fields, api from odoo import api, fields, models
class TrainingProgram(models.Model): class TrainingProgram(models.Model):
_name = 'training.course' _name = "training.course"
_description = 'Training courses' _description = "Training courses"
_inherit = 'mail.thread' _inherit = "mail.thread"
name = fields.Char(string='Nom', required=True,) name = fields.Char(
description = fields.Text(string='Description') string="Nom",
objective = fields.Text(string='Objectif') required=True,
method = fields.Text(string='Méthodologie') )
means = fields.Text(string='Moyens Pédagogiques') description = fields.Text()
control = fields.Text(string='Suivi') objective = fields.Text(string="Objectif")
evaluation = fields.Text(string='Modalités évaluation') method = fields.Text(string="Méthodologie")
means = fields.Text(string="Moyens Pédagogiques")
control = fields.Text(string="Suivi")
evaluation = fields.Text(string="Modalités évaluation")
nature = fields.Text(string="Nature de l'action") nature = fields.Text(string="Nature de l'action")
acquis = fields.Text(string="Acquis de la formation") acquis = fields.Text(string="Acquis de la formation")
students_profile = fields.Text(string='Profil des stagiaires') students_profile = fields.Text(string="Profil des stagiaires")
session_ids = fields.Many2many( session_ids = fields.Many2many(
comodel_name='training.course.session', comodel_name="training.course.session",
relation='program_course_rel', relation="program_course_rel",
column1='program_id', column1="program_id",
column2='course_id', column2="course_id",
string='Sessions',) string="Sessions",
)
duration_total = fields.Integer( duration_total = fields.Integer(
string='Durée totale', string="Durée totale", compute="_compute_sessions", default=0, store=True
compute='_compute_sessions', )
default=0,
store=True)
session_count = fields.Integer( session_count = fields.Integer(
string="Nb Sessions", string="Nb Sessions", compute="_compute_sessions", default=0, store=True
compute='_compute_sessions', )
default=0,
store=True)
# ------------------------------------------------------ # ------------------------------------------------------
# Compute # Compute
# ------------------------------------------------------ # ------------------------------------------------------
@api.depends('session_ids') @api.depends("session_ids")
def _compute_sessions(self): def _compute_sessions(self):
self.session_count = len(self.session_ids) self.session_count = len(self.session_ids)
self.duration_total = sum(self.session_ids.mapped('duration')) self.duration_total = sum(self.session_ids.mapped("duration"))
class TrainingProgramSession(models.Model): class TrainingProgramSession(models.Model):
_name = 'training.course.session' _name = "training.course.session"
_description = 'Training course sessions' _description = "Training course sessions"
name = fields.Char(string='Nom', required=True,) name = fields.Char(
description = fields.Text(string='Description') string="Nom",
required=True,
)
description = fields.Text()
course_id = fields.Many2many( course_id = fields.Many2many(
comodel_name='training.course', comodel_name="training.course",
relation='program_course_rel', relation="program_course_rel",
column1='course_id', column1="course_id",
column2='program_id', column2="program_id",
string='Programmes',) string="Programmes",
duration = fields.Integer(string='Durée (h)', default=4) )
sequence = fields.Integer(string='Séquence', default=10) duration = fields.Integer(string="Durée (h)", default=4)
sequence = fields.Integer(string="Séquence", default=10)
# -*- coding: utf-8 -*- # Copyright 2019-2022 Le Filament (<https://le-filament.com>)
# © 2019 Le Filament (<http://www.le-filament.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import models, fields from odoo import fields, models
class TrainingSession(models.Model): class TrainingSession(models.Model):
_name = 'training.session' _name = "training.session"
_description = 'Training sessions' _description = "Training sessions"
_order = "sequence,id" _order = "sequence,id"
_rec_name = 'session_id' _rec_name = "session_id"
session_id = fields.Many2one( session_id = fields.Many2one(
comodel_name='training.course.session', comodel_name="training.course.session", string="Session", required=True
string='Session', )
required=True)
training_id = fields.Many2one( training_id = fields.Many2one(
comodel_name='training.training', comodel_name="training.training",
string='Formation', string="Formation",
ondelete='cascade', ondelete="cascade",
required=True) required=True,
)
customer_id = fields.Many2one( customer_id = fields.Many2one(
comodel_name='res.partner', comodel_name="res.partner",
string='Client', string="Client",
related='training_id.customer_id', related="training_id.customer_id",
store=True) store=True,
date = fields.Datetime('Date',) )
user_id = fields.Many2one( date = fields.Datetime()
comodel_name='res.users', user_id = fields.Many2one(comodel_name="res.users", string="Formateur")
string='Formateur') date_delay = fields.Integer(string="Durée (h)")
date_delay = fields.Integer(string='Durée (h)') sequence = fields.Integer(string="Séquence", default=10)
sequence = fields.Integer(string='Séquence', default=10)
0% Chargement en cours ou .
You are about to add 0 people to the discussion. Proceed with caution.
Veuillez vous inscrire ou vous pour commenter