Skip to content
Snippets Groups Projects
  1. Nov 25, 2022
  2. Nov 24, 2022
    • Aurélien Warnon's avatar
      [FIX] base: allow user to modify its own preferences · 490d4804
      Aurélien Warnon authored
      
      The res.users model functions a bit uniquely since it should allow a user to
      modify their own parameters but turns off model edition priviledges by default.
      See "SELF_WRITEABLE_FIELDS".
      
      This implies that ir_ui_view#_postprocess_access_rights method will by default
      turn off record edition, by automatically adding a 'edit="false"' attribute on
      the form node when the frontend calls 'get_views'.
      
      This will in turn prevent the user from modifying its preferences as it will
      set the form view in readonly mode.
      (It was apparently ignored pre-OWL, hence why we only have this issue now).
      
      To fix the issue, we force the edition by manually setting 'edit="1"' on our
      "view_users_form_simple_modif" form.
      Allowing the end-user to modify their own settings again.
      
      A tour was added to ensure this behavior.
      Note that tour steps need to be adapted in the 'hr' module, as this module
      changes the flow of modifying user preferences.
      
      Task-3067001
      
      closes odoo/odoo#106125
      
      Signed-off-by: default avatarThibault Delavallee (tde) <tde@openerp.com>
      490d4804
    • Odoo Translation Bot's avatar
  3. Nov 23, 2022
  4. Nov 22, 2022
  5. Nov 20, 2022
  6. Nov 14, 2022
    • FrancoisGe's avatar
      [FIX] *: override save checks that the save is valid · 46b93da5
      FrancoisGe authored
      
      The goal of this commit is to avoid the execution of code depending
      on the validity of the save of a Record.
      
      Before this commit, several override save functions in Record execute
      code after the record's save without checking if the record's save has
      taken place.
      
      Override before:
      export class NewRecord extends Record {
          async save() {
              const isSaved = await super.save(...arguments);
              // doAction
              return isSaved;
          }
      }
      
      Override after:
      export class NewRecord extends Record {
          async save() {
              const isSaved = await super.save(...arguments);
              if (isSaved) {
                  // doAction
              }
              return isSaved;
          }
      }
      
      How to reproduce the problem:
          Go to a form view with a Record having its save override function.
          Edit a record in such a way to have an invalid field
          Click on the save button
      
      Before this commit:
      The doAction is executed
      
      After this commit:
      The doAction is not executed
      
      Real use case
      - Go to the form view of a lead in CRM
      - Change stage
      - Clear the name field
      - Click on save button
      
      Before this commit:
      A call to get_rainbowman_message is made
      
      After this commit:
      No call to get_rainbowman_message is made.
      
      closes odoo/odoo#105468
      
      Related: odoo/enterprise#33817
      Signed-off-by: default avatarAaron Bohy (aab) <aab@odoo.com>
      46b93da5
  7. Nov 13, 2022
  8. Nov 06, 2022
  9. Oct 30, 2022
  10. Oct 24, 2022
  11. Oct 23, 2022
  12. Oct 21, 2022
  13. Oct 20, 2022
  14. Oct 17, 2022
  15. Oct 16, 2022
  16. Oct 10, 2022
  17. Oct 09, 2022
  18. 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
  19. Oct 06, 2022
  20. 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
  21. Oct 02, 2022
  22. 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
  23. Sep 29, 2022
  24. 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
  25. Sep 25, 2022
  26. Sep 24, 2022
  27. Sep 23, 2022
  28. 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
Loading