Skip to content
Snippets Groups Projects
  1. Jun 28, 2023
    • pedrambiria's avatar
      [FIX] microsoft_calendar: keep sync_stopped status · 80e52caa
      pedrambiria authored
      
      Before this commit, if you stopped sync with microsoft, and
      refereshed the calendar, it would change the button back to
      synced status.
      
      opw-3382311
      
      closes odoo/odoo#126661
      
      X-original-commit: 1e0e4e8a
      Signed-off-by: default avatarArnaud Joset (arj) <arj@odoo.com>
      Signed-off-by: default avatarPedram Bi Ria (pebr) <pebr@odoo.com>
      80e52caa
    • divy-odoo's avatar
      [FIX] web, website, portal: fix the text color contrast over background · 313220ed
      divy-odoo authored
      
      1. Introduce primary variable to simplified overridden value of
         `$min-contrast-ratio` and document its need.
      
      2. Reduce `$min-contrast-ratio` to 2.9 to solve the inconsistency with
         the previous version 15.0 of text color over some background color.
         Of course it won't restore everything to the way it was: we still
         want the version 16.0 to be an evolution over version 15.0 using what
         bootstrap recommended to compare contrasts. But as going from 3.0 to
         2.9 should not impact existing websites too much and solve use cases
         we feel need solving, we feel it is an ok change.
      
      3. Restore override of the `color-contrast` method that will now
         handle the transparent colors. Before this commit, a color-contrast
         function was just considering RGB value only, after this commit it
         will consider RGBA value, relying (by default) on the fact the body
         background is the background behind the colors we are comparing.
      
      task-3241031
      
      closes odoo/odoo#118304
      
      Signed-off-by: default avatarQuentin Smetz (qsm) <qsm@odoo.com>
      313220ed
    • Géry Debongnie's avatar
      [IMP] web: update owl to 2.1.4 · b26a66d9
      Géry Debongnie authored
      Release notes:
      https://github.com/odoo/owl/releases/tag/v2.1.4
      
      
      
      This release contains mostly devtools improvements, but there are three
      small bug fixes as well:
      
      [FIX] blockdom: properly merge dynamic class values
      [FIX] parser: make t-on stricter
      [FIX] compiler: apply translations to t-set text body
      
      closes odoo/odoo#126656
      
      Signed-off-by: default avatarNicolas Seinlet (nse) <nse@odoo.com>
      b26a66d9
    • Claire Bretton (clbr)'s avatar
      [FIX] l10n_ch: Fix return tax type · 3070079d
      Claire Bretton (clbr) authored
      
      The return tax should only be used through its parent tax,
      we don't want it to be accessible directly on bills or invoices.
      
      opw-3347425 (2nd issue)
      
      closes odoo/odoo#126653
      
      X-original-commit: c8fdceab
      Signed-off-by: default avatarBrice Bartoletti (bib) <bib@odoo.com>
      Signed-off-by: default avatarClaire Bretton (clbr) <clbr@odoo.com>
      3070079d
    • Gauthier Wala (gawa)'s avatar
      [FIX] account: tour had wrong taxes and was too fast · 5a502137
      Gauthier Wala (gawa) authored
      
      Added a saveForm to wait for the compute/onchange to proc on the save
      Added a tax, to be independent of localizations
      Changed the product, to have a product with an amount that won't be
      impacted by difference of default decimal place from localizations.
      
      Fixes runbot error 22093
      
      closes odoo/odoo#126399
      
      Signed-off-by: default avatarWilliam André (wan) <wan@odoo.com>
      5a502137
    • Julien Van Roy's avatar
      [FIX] mail: UTF-8 text/xml attachment and omitted charset · 4822eafa
      Julien Van Roy authored
      When parsing an email containing an xml attachment, the `email` python
      module will decode the base64 attachment using the charset or ascii if
      the charset is missing.
      
      In some cases, the payload is in UTF-8 but the charset is omitted. This
      results in replacement characters for the non ASCII characters.
      
      The solution is to force the charset to UTF-8, since it is a superset of
      ASCII that should not be a problem.
      
      NB1: Omitting the charset for text/xml is not recommended. See the RFC
      (section 6.4): https://www.ietf.org/rfc/rfc2376.txt
      
      
      
      opw-3144519
      
      closes odoo/odoo#126392
      
      X-original-commit: 3b489509
      Signed-off-by: default avatarJulien Castiaux (juc) <juc@odoo.com>
      Signed-off-by: default avatarJulien Van Roy (juvr) <juvr@odoo.com>
      4822eafa
    • Enric Tobella's avatar
      [FIX] maintenance: Allow to see your created maintenances requests · 703f03e0
      Enric Tobella authored
      
      closes odoo/odoo#126213
      
      X-original-commit: df1badee
      Signed-off-by: default avatarWilliam Henrotin (whe) <whe@odoo.com>
      703f03e0
    • Quentin De Paoli's avatar
      [FIX] hr_expense: copy the expense_id field on account.move.line · a5ce910b
      Quentin De Paoli authored
      
      That field is used at many places in the code to force the computation of taxes in price included mode in the bills. The problem is that if that bill gets reversed, the computation needs to stay the same other the bill and the reversal do not cancel each other, for no apparent reason. In the same way, if you manually duplicate a bill, you'd expect to get exactly the same computation as before.
      
      Use case:
      1. create an expense, total $115 with a 15% tax (excluded)
      2. process it and post the bill. Check that you have a bill for a total of $115 ($100 untaxed + $15 tax)
      3. reset the expense to draft
      4. Check the disaster: the bill got partially reversed by an entry wich tax isn't included ($115 untaxed + 15% tax)
      
      opw-3333599
      
      closes odoo/odoo#126267
      
      Signed-off-by: default avatarWilliam André (wan) <wan@odoo.com>
      a5ce910b
    • Thomas Lefebvre (thle)'s avatar
      [FIX] hr_recruitment: parse email and partner name · 55168536
      Thomas Lefebvre (thle) authored
      
      Issue:
      ------
      When applying for a job via an alias mail,
      it is sometimes possible to get the wrong information
      for the applicant's name and email.
      
      For example:
      Applicant's Name: "FirstName SecondName
      Email: "FirstName SecondName" <name@example.com>
      
      Because of this, it is not possible to send an e-mail
      (for example, to set up a meeting)
      because the latter is erroneous.
      
      Cause:
      ------
      Many e-mail services add the name associated with the e-mail in the header.
      
      Example of a sent e-mail (can be retrieved with "Show original"):
      ```eml
      MIME-Version: 1.0
      Date: Wed, 21 Jun 2023 12:09:34 +0200
      Message-ID: <CAHbiOmS_PHojqKMhoji9iev4I6pzuJ1=dVHgLKNh3SOS_mw7+w@mail.gmail.com>
      Subject: Subject test
      From: FirstName SecondName <name@example.com>
      To: team-recruitment@company.com
      Content-Type: multipart/alternative; boundary="000000000000f7db4305fea0f6c3"
      
      --000000000000f7db4305fea0f6c3
      Content-Type: text/plain; charset="UTF-8"
      
      Message test
      
      --000000000000f7db4305fea0f6c3
      Content-Type: text/html; charset="UTF-8"
      
      <div dir="ltr">Message test<br></div>
      
      --000000000000f7db4305fea0f6c3--
      ```
      
      Solution:
      ---------
      Use `_parse_partner_name` method
      to correctly parse the e-mail
      and partner's name.
      
      Note:
      -----
      Not add `email_from` in `_primary_email` field.
      Otherwise, they will be override with the "raw" value.
      
      opw-3347313
      
      closes odoo/odoo#125927
      
      Signed-off-by: default avatarKevin Baptiste <kba@odoo.com>
      55168536
    • Julien Mougenot's avatar
      [FIX] web: Allow TempusDominus to parse its own values · a0f6bcb0
      Julien Mougenot authored
      
      Before this commit, in other numbering systems than "latn", the time
      pickers did not allow to select hours/minutes/seconds. This was because
      the lib (TempusDominus) would use `parseInt` internally to retrieve the
      selected value, which was not a latin number in other numbering systems.
      
      This commit changes 2 things directly in the lib file:
      
      - allow the internal `getMoment` function to accept a second 'format'
      parameter;
      
      - use that same `getMoment` function to parse the text of the selected
      value, effectively using moment to both parse and format the values
      displayed in the picker and ensuring consistency.
      
      OPW-3258034
      
      closes odoo/odoo#126547
      
      X-original-commit: 3072cb56
      Signed-off-by: default avatarBruno Boi (boi) <boi@odoo.com>
      Signed-off-by: default avatarJulien Mougenot (jum) <jum@odoo.com>
      a0f6bcb0
    • Robin Lejeune (role)'s avatar
      [FIX] website: trigger visibility with prefilled form input · 074dbb68
      Robin Lejeune (role) authored
      Form fields can be prefilled since [1] and their visibility
      conditionally linked to other fields since [2].
      1. This commit ensures prepopulated fields trigger the conditional
      visibility mechanism (A), including when said field is first hidden,
      then conditionally displayed (B).
      2. Until [3], with a chain of visibility conditions, when one of them
      was "contains", "does not contain" or a date-related condition, a
      traceback was raised (C). This commit corrects the fix from [3] to
      prevent this behavior now that the reason has been identified.
      3. Tests are also set up to enforce these fixes.
      
      Steps to reproduce (A):
      - Drop a form
      - Make field A depend on field B being set
      - Have field B be autopopulated from user mail
      - Save and check the form: A won't be shown despite B being set
      - Removing one letter or typing anything in the input B will trigger
      the visibility of A.
      - Expected result: B should immediately appear.
      
      Steps to reproduce (B):
      - Drop a form
      - Make field A depend on field B being set
      - Have field B be autopopulated and depend on field C being set
      - Field C is empty by default
      - Save: only field C is shown. Type a letter: field B appears, but not
      field A.
      - Expected result: both should appear.
      Note: this bug only occurs when field A is before field B.
      
      Steps to reproduce (C) (until [3]):
      - Drop a form
      - Field A depends on B containing "abc"
      - Field B depends on C being set
      - Save and type something in C: there is a traceback.
      
      task-3335536
      
      [1]: https://github.com/odoo/odoo/commit/54873d2
      [2]: https://github.com/odoo/odoo/commit/2dcbfec
      [3]: https://github.com/odoo/odoo/commit/2714469
      
      
      
      closes odoo/odoo#126424
      
      X-original-commit: ad67d744
      Signed-off-by: default avatarBenoit Socias (bso) <bso@odoo.com>
      074dbb68
    • Kevin Baptiste's avatar
      [FIX] hr_org_chart: refresh OrgChart on manager change · cbd5feed
      Kevin Baptiste authored
      
      Setting or changing the manager of an employee would not refresh the
      OrgChart.
      
      task-3381781
      
      closes odoo/odoo#126040
      
      Signed-off-by: default avatarKevin Baptiste <kba@odoo.com>
      cbd5feed
  2. Jun 27, 2023
    • Manisha Tulsiyani's avatar
      [FIX] web: fix percent-pie widget for float values · ee4e679a
      Manisha Tulsiyani authored
      
      Previously, the percent-pie widget was returning the value itself instead
      of rounding them in case of float. After this fix, it will give proper
      round off values for float fields.
      
      closes odoo/odoo#122816
      
      Signed-off-by: default avatarAaron Bohy (aab) <aab@odoo.com>
      ee4e679a
    • Mahdi Cheikh Rouhou (macr)'s avatar
      [FIX] website_sale_product_configurator : show correct available qty in product page · f73c214e
      Mahdi Cheikh Rouhou (macr) authored
      
      When you add items in the cart it always show the number of available left in stock of the previous state for example :
      1- cart is empty it shows 20 items
      2- add one into cart - it shows 20 items left in stock (should be 19)
      3- add another one into cart - it show 19 items left in stock (should be 18)
      
      Steps to reproduce the error :
      1 - Go to one of the product and make sure that it has some available quantity
      2 - Go to sale configuration on the product and remove "out-of-stock : continue selling" and add show available qty only if below 5000 for example
      3 - Go the web page of the product and try to add some items into the cart you will see that the stock message is wrong
      
      The origin of the problem is that when we have optional products activated , it will launch a product configurator modal. After posting the update in the database there is no call to the function that updates the stock message.
      
      opw-3341377
      
      closes odoo/odoo#125660
      
      X-original-commit: b95f0576
      Signed-off-by: default avatarMahdi Cheikh Rouhou (macr) <macr@odoo.com>
      f73c214e
    • Thomas Lefebvre (thle)'s avatar
      [FIX] web: keep the possibility of creating a record with form view · 0d218ef6
      Thomas Lefebvre (thle) authored
      
      Issue:
      ------
      When a list view is editable and we add a `Group By`,
      the create button in the header is no longer available.
      This is annoying when we are working with default filters
      and do not have any records.
      
      Solution:
      ---------
      Add the "New" button in the header of the list view
      and redirect to the form view when we use it.
      
      opw-3304692
      
      closes odoo/odoo#125529
      
      Signed-off-by: default avatarFrancois Georis (fge) <fge@odoo.com>
      0d218ef6
    • stcc-odoo's avatar
      [FIX] sale: fix pill variant styling · 38ca6bc3
      stcc-odoo authored
      
      Enterprise PR: odoo/enterprise#42551
      
      Steps to reproduce:
      
      1. Install website_sale
      2. Create product P
      	- Go to Attributes & Variants tab
      	- Add a line
      	- Create and edit attribute "PILL"
      		- Display Type = Pills
      		- Add some attribute values
      		- Save & Close
      	- Add the attribute values in the list view
      	- Save the product
      3. Go to website product page
      
      Issue:
      
      The pills have a visible radio button inside, requiring users to click
      on the radio button to change the variant. In V15, there was no radio
      button, and users could click anywhere on the variant container to
      change the variant.
      
      The change in behaviour happened because the jquery code for handling
      button clicks has changed. In V15 jquery, clicking a button would
      trigger a change event, which would then be captured by the owl event
      selector `change [data-attribute_exclusions]`, and the
      `onChangeVariant` method was called.
      
      In version 16, jQuery no longer triggers a change event when clicking
      a button.
      
      Solution:
      
      Hide the radio input visually, then convert the variant text to a
      label. When clicking on the label, the corresponding radio input
      is checked.
      
      This means that the whole button is not clickable anymore, only the
      text.
      
      opw-3185147
      
      closes odoo/odoo#123100
      
      Signed-off-by: default avatarValentin Chevalier <vcr@odoo.com>
      38ca6bc3
    • Mohit Beniwal's avatar
      [FIX] base: prevent error while uploading record of type properties · b80d4294
      Mohit Beniwal authored
      
      This error occurs when user import records having value in 'properties' column
      which is of datatype, 'properties' and while trying to get attribute from
      getattr to get value of converter it is getting default value None. That's why
      this error is produced, 'NoneType' object is not callable.
      
      Steps to reproduce:
      1) Install 'CRM' module.
      2) Open 'CRM' module and in it click on 'List' view.
      3) Open any record and add value for field 'Add a property'.
      4) Export that records.
      5) Now click on 'Favourites' > 'Import records'.
      6) Now click on 'UPLOAD FILE' button > upload that exported file.
      7) Now click on 'TEST' button, error will be generated.
      
      By applying this, user will be able to import record of datatype
      'properties'.
      
      Sentry-4128524668
      
      closes odoo/odoo#122817
      
      Signed-off-by: default avatarRémy Voet (ryv) <ryv@odoo.com>
      b80d4294
    • Hubert Van de Walle (huvw)'s avatar
      [FIX] purchase: valid autocomplete for purchase.bill.union · 4485d1ca
      Hubert Van de Walle (huvw) authored
      
      Steps to reproduce
      ==================
      
      - Go to Accounting > Vendor Bills
      - Create a new record
      - Click on the Auto-Complete field > Search more
      - In the search bar, search for a reference
      
      -> str is not a function
      
      Cause of the issue
      ==================
      
      The search filter is declared as such:
      ```xml
      <
        field name="name"
        string="Reference"
        filter_domain="['|', ('name','ilike',self), ('reference','=like',str(self)+'%')]"
      />
      ```
      
      This domain is evaluated in javascript by basic python interpreter.
      
      Going from 15 to 16, it has been rewritten. The str function isn't
      present anymore in `py_builtin.js`.
      
      Solution
      ========
      
      Since this is the last remaining usage of this function and `self` is
      already a string, we can simply replace `str(self)` by `self`
      
      opw-3383708
      
      closes odoo/odoo#126501
      
      Signed-off-by: default avatarHubert Van De Walle <huvw@odoo.com>
      4485d1ca
    • Moens Alexandre's avatar
      [FIX] l10n_sa_edi : neutralize · 16990ef7
      Moens Alexandre authored
      
      closes odoo/odoo#126428
      
      Signed-off-by: default avatarJosse Colpaert <jco@odoo.com>
      16990ef7
    • Nasreddin Boulif (bon)'s avatar
      [FIX] im_livechat: display chatbot in website or user language · cb9c0037
      Nasreddin Boulif (bon) authored
      
      Steps to reproduce:
      
        - Install the module `crm_livechat`
        - Activate another language (e.g. fr_FR)
        - Open a new incognito window and go to the website
        - On website, switch to the activated language
        - Open contact page
        - Open the chatbot
      
      Issue:
      
        The chatbot is displayed in `en_US`.
      
      Cause:
      
        The chatbot is displayed in the current user language (not website
        language).
        Public user have by default `en_US` as language.
      
      Solution:
      
        Retrieve the chatbot with the website activated language if set,
        otherwise, retrieve the chatbot in the user language.
        Fallback on `en_US`.
      
      opw-3284807
      
      closes odoo/odoo#126341
      
      Signed-off-by: default avatarMatthieu Stockbauer (tsm) <tsm@odoo.com>
      cb9c0037
    • Günter Bailey's avatar
      [CLA] signature for Brawn1 · 6b66ef3f
      Günter Bailey authored
      
      closes odoo/odoo#126464
      
      X-original-commit: 842f2292
      Signed-off-by: default avatarMartin Trigaux (mat) <mat@odoo.com>
      6b66ef3f
    • Mathieu Walravens's avatar
      [FIX] stock: prevent merging quants during import · a381b6fd
      Mathieu Walravens authored
      
      Before this commit:
      When importing `stock.quant` with two lines with the same product and
      different counted quantities, only the last line is taken.
      
      After this commit:
      Each line creates a `stock.quant`, even if a similar Quant exists.
      The records will be merged at a later time by `_merge_quants`.
      
      Steps to reproduce:
      1. Create a storable product
      2. Go to Inventory > Operations > Inventory Adjustments
      3. Create a file with two lines with the same product,
          and different counted quantities
      5. Favourites > Import Records & upload the file
      
      OPW-3340017
      
      closes odoo/odoo#126458
      
      X-original-commit: 45f7368222ead5df600992c66f0da56b3a7e959a
      Signed-off-by: default avatarWilliam Henrotin (whe) <whe@odoo.com>
      Signed-off-by: default avatarWalravens Mathieu (wama) <wama@odoo.com>
      a381b6fd
    • akr's avatar
      [I18N] Add translation files for l10n_sa_edi · 1688e0ec
      akr authored
      
      Adding base translation files for l10n_sa_edi as well as arabic translation
      
      closes odoo/odoo#125555
      
      X-original-commit: 52e96a5c
      Signed-off-by: default avatarJosse Colpaert <jco@odoo.com>
      1688e0ec
    • moerradi's avatar
      [IMP] website: Show "Edit in Website Builder" for terms and conditions · fe581e98
      moerradi authored
      
      Prveiously the "Edit in Website Builder" button was not shown for terms
      and conditions if website is installed, it was shown only if the
      website_sale module was installed. This commit fixes that.
      
      task-3342876
      
      closes odoo/odoo#122874
      
      Signed-off-by: default avatarBrice Bartoletti (bib) <bib@odoo.com>
      fe581e98
    • Sylvain LE GAL's avatar
    • Benjamin Vray's avatar
      [FIX] web, website, web_editor: fix popup scrollbar · 1199c78c
      Benjamin Vray authored
      Steps to reproduce the bug:
      
      - Drag and drop several snippets onto a web page in edit mode to make
      the vertical scrollbar appear.
      - Drag and drop a popup onto the page.
      - Drag and drop snippets into the popup so that the height of the popup
      exceeds the height of the viewport.
      - Try to scroll the popup downwards by clicking and dragging on the
      scrollbar (not using the mouse wheel).
      - Bug: the page is scrolled instead of the popup.
      
      Note: This bug occurs in Chrome (not in Firefox).
      
      This issue occurs because two scrollbars are present at the same
      location (one for the page and one for the popup) and they overlap each
      other. Normally, Bootstrap removes the scrollbar from the body when a
      modal is opened, and this behavior was adapted for the #wrapwrap element
      with this commit [1]. However, when transitioning to Bootstrap 5, the
      code that overrides Bootstrap was removed instead of being adapted (this
      was done in this commit [2]).
      
      In later commits [3] and [4], we continued to remove code that updated
      the scrollbar based on the opening of a modal because this code was
      causing errors due to the fact that it was incomplete without the part
      removed by commit [2].
      
      This commit restores the original behavior (before the deletions made by
      the aforementioned commits) by restoring the missing code and properly
      adapting it to Bootstrap 5.
      
      [1]: https://github.com/odoo/odoo/commit/9cf8b97fe40444b44ebb6e6fb992bc658a087d32
      [2]: https://github.com/odoo/odoo/commit/0b94da214b7017e8580e671cbaa68ade6de2fbc7
      [3]: https://github.com/odoo/odoo/commit/cb7cf77ed080e86f800af61c9a3dc4ad36ad6cfb
      [4]: https://github.com/odoo/odoo/commit/51939d09f84579f61f1ff77aacd754beba036dc2
      
      
      
      task-3102275
      
      closes odoo/odoo#112091
      
      Signed-off-by: default avatarBenoit Socias (bso) <bso@odoo.com>
      1199c78c
    • Benoit Socias's avatar
      [IMP] website: test unsplash beacon · 9ab5f20a
      Benoit Socias authored
      
      This commit ensures that the unsplash beacon calls home when an unsplash
      image appears on a page.
      
      To achieve this it patches the RPC call when the test URL contains the
      test name as parameter. The patch cancels the actual beacon call to
      avoid polluting data during the test, but marks the image as having had
      its beacon message sent. The test then simply checks if this marker
      appears on the image.
      
      task-3360109
      
      closes odoo/odoo#126370
      
      X-original-commit: 1b9e8103
      Signed-off-by: default avatarOutagant Mehdi (mou) <mou@odoo.com>
      Signed-off-by: default avatarBenoit Socias (bso) <bso@odoo.com>
      9ab5f20a
    • Mohit Beniwal's avatar
      [FIX] base: prevent json decoder error for default values · b57bed75
      Mohit Beniwal authored
      
      JSONDecoderError occurs when users enters invalid JSON format data in
      'Default Value' field inside 'User-defined Defaults' and wherever this field is
      being accessed to get default value this traceback will be generated.
      
      Steps to reproduce:
      1) Install 'Contacts' module.
      2) Open 'Settings' > 'Technical' > 'User-defined Defaults'.
      3) Click on record 'Language' > 'EDIT' button > in 'Default Value' field enter
         any improper JSON format data (e.g 'Maa' : FI ) .
      4) Now, open 'Contacts' module > click on 'CREATE' button and traceback would be
         generated.
      
      By applying this, it will check for proper JSON format.
      
      Sentry-4169062951
      
      closes odoo/odoo#126239
      
      X-original-commit: 0e6e322d
      Signed-off-by: default avatarRémy Voet (ryv) <ryv@odoo.com>
      b57bed75
  3. Jun 26, 2023
Loading