Skip to content
Snippets Groups Projects
  1. Oct 30, 2022
  2. Oct 24, 2022
  3. Oct 23, 2022
  4. Oct 21, 2022
  5. Oct 20, 2022
  6. Oct 17, 2022
  7. Oct 16, 2022
  8. Oct 10, 2022
  9. Oct 09, 2022
  10. Oct 07, 2022
    • Audric Onockx (auon)'s avatar
      [FIX] hr,hr_contract,resource: allocate hours before resource creation · 6a61d1c4
      Audric Onockx (auon) authored
      
      Steps :
      - On a new DB (no demo data). Say created at 15:00. - Go to planning.
      - Add a shift for today.
      - Set the dates from 08:00 to 17:00.
      
      Issue :
      The 'Allocated Time' = 02:00.
      
      Cause :
      We used to count from the resource creation min to the departure max. So, in this case, not from 08:00, but from 15:00.
      While this might seem logical, it confuses users in onboarding.
      
      Fix :
      Calculate the whole time, regardless of the resource lifespan.
      
      Notes :
      - Similar issues solved with this commit :
      > Once the shift validated, the avatar progress bar uses
      the same allocated time.
      > Same in Project Task gantt view.
      - When contract is installed, if the resource does not have a contract, the Allocated Time = 0. Now, it is calculated from the resource calendar.
      
      task-2983993
      
      closes odoo/odoo#102392
      
      Related: odoo/enterprise#32378
      Signed-off-by: default avatarLaurent Stukkens (ltu) <ltu@odoo.com>
      6a61d1c4
    • Rob Coekaerts's avatar
      [IMP] hr_homeworking: remove module · b3ad5886
      Rob Coekaerts authored
      
      The current homeworking module doesn't answer the standard of quality.
      For now It will be removed from the settings and app store so it is not visible
      to any users. It will return after it has been reviewed and  improved.
      
      task-2995332
      
      closes odoo/odoo#101093
      
      Related: odoo/enterprise#31762
      Signed-off-by: default avatarYannick Tivisse (yti) <yti@odoo.com>
      b3ad5886
  11. Oct 06, 2022
  12. Oct 04, 2022
    • Martin Trigaux's avatar
      [I18N] *: export 16.0 source terms · 011d7aac
      Martin Trigaux authored
      
      closes odoo/odoo#102045
      
      Related: odoo/enterprise#32243
      Signed-off-by: default avatarMartin Trigaux (mat) <mat@odoo.com>
      011d7aac
    • FrancoisGe's avatar
      [FIX] web: click on m2o_avatar in editable/multiEdit list · ad597d41
      FrancoisGe authored
      
      The goal of this commit is to fix the behaviour of clicking on a field
      with the "many2one_avatar" widget in a list view.
      
      Expected behaviour when clicking on a field with the "many2one_avatar" widget:
      - Editable list view: switch row to edit
      - Multi_edit list view with selected record: switch row to edit
      - Other case: open the many2one_avatar record in a form view
      
      Before this commit, clicking on a field with the "many2one_avatar" widget always
      opens the record in a form view.
      
      After this commit, the expected behaviour when clicking on a field with
      the "many2one_avatar" widget is respected.
      
      closes odoo/odoo#101737
      
      Signed-off-by: default avatarAaron Bohy (aab) <aab@odoo.com>
      ad597d41
  13. Oct 02, 2022
  14. Oct 01, 2022
    • Louis Wicket (wil)'s avatar
      [IMP] mail, *: refactor patch API to look like model definitions · 7d23491b
      Louis Wicket (wil) authored
      
      Model patches are now defined using the `registerPatch` function. This
      function takes an object as argument which keys match those of a model
      definition.
      
      Benefits:
      + More consistent shape between model definitions and patch definitions
      + No need to import one function to each type of patch
      + No need to repeat the model name for each type of patch
      + No need to import the original definition
      
      Task-2998282.
      
      * = calendar, crm, hr, im_livechat, note, rating, sms, snailmail,
          website_livechat, website_slides
      
      closes odoo/odoo#101282
      
      Related: odoo/enterprise#31866
      Signed-off-by: default avatarSébastien Theys (seb) <seb@odoo.com>
      7d23491b
  15. Sep 29, 2022
  16. Sep 26, 2022
    • Kevin Baptiste's avatar
      [FIX] hr: add missing fields on tree view · 8893c575
      Kevin Baptiste authored
      
      The domain of `work_location_id` requires the company_id and address_id
      which were missing from the tree view, showing a traceback when trying
      to change that field.
      
      closes odoo/odoo#101182
      
      X-original-commit: 8376adc1
      Signed-off-by: default avatarKevin Baptiste <kba@odoo.com>
      8893c575
    • Michael (mcm)'s avatar
      [IMP] web: remove readonly mode of form view · 77824ad4
      Michael (mcm) authored
      
      This commit does multiple things:
      - The readonly mode of form view is removed but not for the fields.
        it means that the fields in the view are always in edit mode except
        if we force them to be readonly.
      - The control panel is revamped to take less vertical space and shows now
        the record editing (dirtiness)/validity status after editing the record.
      - The record is saved only when leaving the view or by clicking the save
        button when hovering the record status in the control panel.
      - The record can still be discarded by clicking the discard button when
        hovering the status text in control panel.
      
      task id: 2822553
      
      Part-of: odoo/odoo#100570
      Co-authored-by: default avatarluvi <luvi@odoo.com>
      77824ad4
  17. Sep 25, 2022
  18. Sep 24, 2022
  19. Sep 23, 2022
  20. Sep 22, 2022
    • Xavier-Do's avatar
      [FIX] hr: fix l10n_mx install · 919c1f36
      Xavier-Do authored
      
      When installing l10n_mx, a error occurs
      
          Traceback (most recent call last):
          File "/data/build/odoo/odoo/service/server.py", line 1289, in preload_registries
              registry = Registry.new(dbname, update_module=update_module)
          File "<decorator-gen-15>", line 2, in new
          File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
              return func(inst, *args, **kwargs)
          File "/data/build/odoo/odoo/modules/registry.py", line 91, in new
              odoo.modules.load_modules(registry, force_demo, status, update_module)
          File "/data/build/odoo/odoo/modules/loading.py", line 482, in load_modules
              processed_modules += load_marked_modules(cr, graph,
          File "/data/build/odoo/odoo/modules/loading.py", line 371, in load_marked_modules
              loaded, processed = load_module_graph(
          File "/data/build/odoo/odoo/modules/loading.py", line 206, in load_module_graph
              registry.setup_models(cr)
          File "/data/build/odoo/odoo/modules/registry.py", line 289, in setup_models
              model._setup_fields()
          File "/data/build/odoo/odoo/models.py", line 3294, in _setup_fields
              field.setup(self)
          File "/data/build/odoo/odoo/fields.py", line 512, in setup
              self.setup_nonrelated(model)
          File "/data/build/odoo/odoo/fields.py", line 4524, in setup_nonrelated
              m2m = model.pool._m2m
          AttributeError: 'Registry' object has no attribute '_m2m'
      
      Since #99438 hr is sintalled automatically
      This means that when doing a -i l10n_mx, hr is installed too
      
      hr will conditionnaly call a button_immediate_install in this case.
      
      What's going on after that: It's a mess
      
      button_immediate_install will create another registry
      This registry will be present on some models that will ne used later
      by the initial registry creating the missing _m2m case
      
      For the record, here are some of the strange and key element during
      the install
      
          2022-09-21 16:31:27,691 2579263 INFO test_mx odoo.modules.loading: loading 1 modules...
          2022-09-21 16:31:27,691 2579263 INFO test_mx odoo.modules.loading: Loading module base (1/1)
          ...
          2022-09-21 16:31:36,222 2579263 INFO test_mx odoo.modules.loading: Module base loaded in 8.53s, 8902 queries (+8902 other)
          2022-09-21 16:31:36,222 2579263 INFO test_mx odoo.modules.loading: 1 modules loaded in 8.53s, 8902 queries (+8902 extra)
          2022-09-21 16:31:36,240 2579263 INFO test_mx odoo.modules.loading: updating modules list
          2022-09-21 16:31:36,241 2579263 INFO test_mx odoo.addons.base.models.ir_module: ALLOW access to module.update_list on [] to user __system__ #1 via n/a
          2022-09-21 16:31:36,943 2579263 INFO test_mx odoo.addons.base.models.ir_module: ALLOW access to module.button_install on ['Mexico - Accounting'] to user __system__ #1 via n/a
          ...
          2022-09-21 16:31:49,775 2579263 INFO test_mx odoo.modules.loading: Loading module base_install_request (26/78)
          ...
          2022-09-21 16:31:50,043 2579263 INFO test_mx odoo.addons.base.models.ir_module: ALLOW access to module.button_install on ['Project', 'Email Marketing', 'Employees', 'Knowledge', 'Sign', 'Planning', 'Appointments', 'Surveys'] to user __system__ #1 via n/a
          2022-09-21 16:31:50,167 2579263 INFO test_mx odoo.modules.loading: Module base_install_request loaded in 0.39s, 228 queries (+228 other)
          ...
          2022-09-21 16:32:10,816 2579263 INFO test_mx odoo.modules.loading: Loading module l10n_mx (55/78)
          ...
          2022-09-21 16:32:17,618 2579263 INFO test_mx odoo.modules.loading: Module l10n_mx loaded in 6.80s, 4302 queries (+4332 other)
          ...
          2022-09-21 16:32:50,371 2579263 INFO test_mx odoo.modules.loading: Loading module hr (35/112)
          2022-09-21 16:32:57,594 2579263 INFO test_mx odoo.addons.base.models.ir_module: ALLOW access to module.button_immediate_install on ['Employees - Mexico'] to user __system__ #1 via n/a
          2022-09-21 16:32:57,594 2579263 INFO test_mx odoo.addons.base.models.ir_module: User #1 triggered module installation
          2022-09-21 16:32:57,595 2579263 INFO test_mx odoo.addons.base.models.ir_module: ALLOW access to module.button_install on ['Employees - Mexico'] to user __system__ #1 via n/a
          ...
          2022-09-21 16:32:58,558 2579263 ERROR test_mx odoo.modules.registry: Creating Registry <odoo.modules.registry.Registry object at 0x7f02cc0e8130>
          Stack (most recent call last):
          File "/home/xdo/osrc/master/odoo/odoo-bin", line 8, in <module>
              odoo.cli.main()
          File "/home/xdo/osrc/master/odoo/odoo/cli/command.py", line 56, in main
              o.run(args)
          File "/home/xdo/osrc/master/odoo/odoo/cli/server.py", line 179, in run
              main(args)
          File "/home/xdo/osrc/master/odoo/odoo/cli/server.py", line 173, in main
              rc = odoo.service.server.start(preload=preload, stop=stop)
          File "/home/xdo/osrc/master/odoo/odoo/service/server.py", line 1391, in start
              rc = server.run(preload, stop)
          File "/home/xdo/osrc/master/odoo/odoo/service/server.py", line 570, in run
              rc = preload_registries(preload)
          File "/home/xdo/osrc/master/odoo/odoo/service/server.py", line 1289, in preload_registries
              registry = Registry.new(dbname, update_module=update_module)
          File "<decorator-gen-15>", line 2, in new
          File "/home/xdo/osrc/master/odoo/odoo/tools/func.py", line 87, in locked
              return func(inst, *args, **kwargs)
          File "/home/xdo/osrc/master/odoo/odoo/modules/registry.py", line 91, in new
              odoo.modules.load_modules(registry, force_demo, status, update_module)
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 482, in load_modules
              processed_modules += load_marked_modules(cr, graph,
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 371, in load_marked_modules
              loaded, processed = load_module_graph(
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 248, in load_module_graph
              getattr(py_module, post_init)(cr, registry)
          File "/home/xdo/osrc/master/odoo/addons/hr/__init__.py", line 19, in _install_hr_localization
              l10n_mx.button_immediate_install()
          File "<decorator-gen-74>", line 2, in button_immediate_install
          File "/home/xdo/osrc/master/odoo/odoo/addons/base/models/ir_module.py", line 75, in check_and_log
              return method(self, *args, **kwargs)
          File "/home/xdo/osrc/master/odoo/odoo/addons/base/models/ir_module.py", line 486, in button_immediate_install
              return self._button_immediate_function(type(self).button_install)
          File "/home/xdo/osrc/master/odoo/odoo/addons/base/models/ir_module.py", line 607, in _button_immediate_function
              registry = modules.registry.Registry.new(self._cr.dbname, update_module=True)
          File "<decorator-gen-15>", line 2, in new
          File "/home/xdo/osrc/master/odoo/odoo/tools/func.py", line 87, in locked
              return func(inst, *args, **kwargs)
          File "/home/xdo/osrc/master/odoo/odoo/modules/registry.py", line 79, in new
              registry.init(db_name)
          File "/home/xdo/osrc/master/odoo/odoo/modules/registry.py", line 115, in init
              _logger.error(self, stack_info=True)
          2022-09-21 16:32:58,580 2579263 INFO test_mx odoo.modules.loading: loading 1 modules...
          2022-09-21 16:32:58,581 2579263 INFO test_mx odoo.modules.loading: Loading module base (1/1)
          ...
          2022-09-21 16:33:35,294 2579263 INFO test_mx odoo.modules.loading: Loading module base_install_request (30/85)
          ...
          2022-09-21 16:33:35,745 2579263 INFO test_mx odoo.modules.loading: Module base_install_request loaded in 0.45s, 131 queries (+131 other)
          ...
          2022-09-21 16:34:05,789 2579263 INFO test_mx odoo.modules.loading: Loading module l10n_mx (62/85)
          ...
          2022-09-21 16:34:28,497 2579263 INFO test_mx odoo.modules.loading: Loading module hr (35/113)
          ...
          2022-09-21 16:34:32,067 2579263 INFO test_mx odoo.modules.loading: Module hr loaded in 3.57s, 4092 queries (+4092 other)
          2022-09-21 16:34:32,067 2579263 INFO test_mx odoo.modules.loading: Loading module link_tracker (37/113)
          ...
          2022-09-21 16:34:32,690 2579263 INFO test_mx odoo.modules.loading: Module link_tracker loaded in 0.62s, 267 queries (+267 other)
          ...
          2022-09-21 16:35:04,063 2579263 INFO test_mx odoo.modules.loading: Modules loaded.
          2022-09-21 16:35:04,068 2579263 INFO test_mx odoo.modules.registry: Registry loaded in 125.514s
          2022-09-21 16:35:04,068 2579263 INFO test_mx odoo.addons.base.models.ir_module: getting next ir.actions.todo()
          2022-09-21 16:35:04,071 2579263 INFO test_mx odoo.addons.base.models.ir_module: next action is "Open Menu"
          2022-09-21 16:35:04,094 2579263 INFO test_mx odoo.modules.loading: Module hr loaded in 133.72s, 4344 queries (+81420 other)
          ...
          2022-09-21 16:35:04,094 2579263 INFO test_mx odoo.modules.loading: Loading module link_tracker (37/112)
          2022-09-21 16:35:04,163 2579263 ERROR test_mx odoo.modules.registry:
          setuping model: ir.model.fields()
          registry on model: <odoo.modules.registry.Registry object at 0x7f02cc0e8130>
          registry calling setup_models: <odoo.modules.registry.Registry object at 0x7f02e92399d0>
      
          2022-09-21 16:35:04,164 2579263 WARNING test_mx odoo.modules.loading: Transient module states were reset
          2022-09-21 16:35:04,165 2579263 ERROR test_mx odoo.modules.registry: Failed to load registry
          2022-09-21 16:35:04,165 2579263 CRITICAL test_mx odoo.service.server: Failed to initialize database `test_mx`.
          Traceback (most recent call last):
          File "/home/xdo/osrc/master/odoo/odoo/service/server.py", line 1289, in preload_registries
              registry = Registry.new(dbname, update_module=update_module)
          File "<decorator-gen-15>", line 2, in new
          File "/home/xdo/osrc/master/odoo/odoo/tools/func.py", line 87, in locked
              return func(inst, *args, **kwargs)
          File "/home/xdo/osrc/master/odoo/odoo/modules/registry.py", line 91, in new
              odoo.modules.load_modules(registry, force_demo, status, update_module)
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 482, in load_modules
              processed_modules += load_marked_modules(cr, graph,
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 371, in load_marked_modules
              loaded, processed = load_module_graph(
          File "/home/xdo/osrc/master/odoo/odoo/modules/loading.py", line 206, in load_module_graph
              registry.setup_models(cr)
          File "/home/xdo/osrc/master/odoo/odoo/modules/registry.py", line 293, in setup_models
              model._setup_fields()
          File "/home/xdo/osrc/master/odoo/odoo/models.py", line 3294, in _setup_fields
              field.setup(self)
          File "/home/xdo/osrc/master/odoo/odoo/fields.py", line 512, in setup
              self.setup_nonrelated(model)
          File "/home/xdo/osrc/master/odoo/odoo/fields.py", line 4524, in setup_nonrelated
              m2m = model.pool._m2m
          AttributeError: 'Registry' object has no attribute '_m2m'
      
      Naive fix here: use button_install instead of button_immediate_install
      (not even sure this is 100% correct)
      
      All calls to button_immediate_install should be fixed maybe to avoid
      a registryloadingception
      
      closes odoo/odoo#100755
      
      Signed-off-by: default avatarYannick Tivisse (yti) <yti@odoo.com>
      919c1f36
    • Alexandre Kühn's avatar
      [IMP] mail, *: introduce public livechat bundle · a01367ed
      Alexandre Kühn authored
      
      *: hr, im_livechat, snailmail, website_livechat
      
      This commit introduces the public livechat bundle, which
      contains the models that are specifically used in public livechat.
      
      Doing so reduces the amount of model and data in frontend and
      external lib, which makes the page load faster.
      
      Task-2990182
      Task-2990191
      
      closes odoo/odoo#100683
      
      Related: odoo/enterprise#31559
      Signed-off-by: default avatarAlexandre Kühn (aku) <aku@odoo.com>
      a01367ed
  21. Sep 21, 2022
  22. Sep 20, 2022
  23. Sep 18, 2022
  24. Sep 16, 2022
  25. Sep 15, 2022
    • Chong Wang (cwg)'s avatar
      [IMP] core: store translated fields as JSONB columns · ef00294e
      Chong Wang (cwg) authored
      
      Translated fields no longer use the model ir.translation.  Instead they store
      all their values as JSON, and store them into JSONB columns in the model's
      table.  The field's column value is either NULL or a JSON dict mapping language
      codes to text (the field's value in the corresponding language), and must
      contain an entry for key 'en_US' (as it is used as a fallback for all other
      languages).  Empty text is allowed in translation values, but not NULL.
      
      Here are examples for a field with translate=True:
      
          NULL
          {"en_US": "Foo"}
          {"en_US": "Foo", "fr_FR": "Bar", "nl_NL": "Baz"}
          {"en_US": "Foo", "fr_FR": "", "nl_NL": "Baz"}
      
      Like before, writing False to the field makes it NULL, i.e., False in all
      languages.  However, writing "" to the field makes its value empty in the
      current language, but does not discard the values in the other languages.
      
      Here are examples for a field with translate=xml_translate:
      
          NULL
          {"en_US": "<div>Foo<p>Bar</p></div>", "fr_FR": "<div>Fou<p>Barre</p></div>"}
      
      Change for callable(translate) fields: one can now write any value in any
      language on such a field.  The new value will be adapted in all languages, based
      on the mapping of terms between languages in the old values.  Basically the
      structure of the value must remain the same in all languages, like before.
      
      Reading a translated field is now both simpler and faster than the former
      implementation.  We fetch the value of the field in the current language by
      coalescing its value with the 'en_US' value of the field:
      
          SELECT id, COALESCE(name->>'fr_FR', name->>'en_US') AS name ...
      
      The raw cache of the field contains either None or a dict which is conceptually
      a subset of the JSON value in database (except for missing languages).  For the
      sake of simplicity, most cache operations deal with the dict and return the text
      value in the current language.
      
      Trigram indexes have been adapted to the new storing strategy, and should enable
      to search in any language.  Before this change, only the source value of the
      field ('en_US') could be indexed.
      
      Computed stored translated fields are not supported by the framework, because of
      the complexity of the computation itself: the field would need to be computed in
      all active languages.  We chose to not provide any hook to compute a field in
      all languages at once, and the framework always invokes a compute method once to
      recompute it.
      
      Code translations are no longer stored into the database.  They become static,
      and are extracted from the PO files when needed.  The worker simply uses a cache
      with extracted code translations for performance.  This is reasonable, since
      fr_FR code translations for all modules takes around 2MB of memory, and the
      cache can be shared among all registries in the worker.  Changing code
      translations requires to update the corresponding PO file and reloading the
      worker(s).
      
      Performance summary:
       (+) reading 'model' translated fields is faster
       (+) reading 'model_terms' translated fields is much faster (no need to inject
           translations into the source value)
       (+) searching translated fields with operator 'ilike' is much faster when the
           field is indexed with 'trigram'
       (+) updating translated fields requires less ORM flushing
       (-) importing translations from PO files is 2x slower
      
      Some extra fixes:
       - make field 'name' of ir.actions.actions translated; because of the PG
         inheritance, this is necessary to make the column definition consistent in
         all models that inherit from ir.actions.actions.
       - add some backend API for the web/website client for editing translations
       - move methods get_field_string() to model ir.model.fields
       - move _load_module_terms to model ir.module.module
       - adapt tests in test_impex, test_new_api
       - because env.lang is injected into SQL queries, its returned value is
         now guaranteed to correspond to a valid active language or None
       - remove wizard to insert missing translations (no longer makes sense)
      
      task-id: 2081307
      
      Co-authored-by: default avatarFabien Pinckaers <fp@openerp.com>
      Co-authored-by: default avatarRaphael Collet <rco@odoo.com>
      ef00294e
    • Dossogne Bertrand's avatar
      [FIX] hr: allow onboarding plan access for officers · 3f3d4370
      Dossogne Bertrand authored
      
      taskID 2969653
      
      closes odoo/odoo#99407
      
      Signed-off-by: default avatarKevin Baptiste <kba@odoo.com>
      3f3d4370
  26. Sep 14, 2022
Loading