Skip to Content
Odoo Menu
  • Zaloguj się
  • Wypróbuj za darmo
  • Aplikacje
    Finanse
    • Księgowość
    • Fakturowanie
    • Wydatki
    • Arkusz kalkulacyjny (BI)
    • Dokumenty
    • Podpisy
    Sprzedaż
    • CRM
    • Sprzedaż
    • PoS Sklep
    • PoS Restauracja
    • Subskrypcje
    • Wypożyczalnia
    Strony Internetowe
    • Kreator Stron Internetowych
    • eCommerce
    • Blog
    • Forum
    • Czat na Żywo
    • eLearning
    Łańcuch dostaw
    • Magazyn
    • Produkcja
    • PLM
    • Zakupy
    • Konserwacja
    • Jakość
    Zasoby Ludzkie
    • Pracownicy
    • Rekrutacja
    • Urlopy
    • Ocena pracy
    • Polecenia Pracownicze
    • Flota
    Marketing
    • Marketing Społecznościowy
    • E-mail Marketing
    • SMS Marketing
    • Wydarzenia
    • Automatyzacja Marketingu
    • Ankiety
    Usługi
    • Projekt
    • Ewidencja czasu pracy
    • Usługi Terenowe
    • Helpdesk
    • Planowanie
    • Spotkania
    Produktywność
    • Dyskusje
    • Zatwierdzenia
    • IoT
    • VoIP
    • Baza wiedzy
    • WhatsApp
    Aplikacje trzecich stron Studio Odoo Odoo Cloud Platform
  • Branże
    Sprzedaż detaliczna
    • Księgarnia
    • Sklep odzieżowy
    • Sklep meblowy
    • Sklep spożywczy
    • Sklep z narzędziami
    • Sklep z zabawkami
    Żywienie i hotelarstwo
    • Bar i Pub
    • Restauracja
    • Fast Food
    • Pensjonat
    • Dystrybutor napojów
    • Hotel
    Agencja nieruchomości
    • Agencja nieruchomości
    • Biuro architektoniczne
    • Budowa
    • Zarządzanie nieruchomościami
    • Ogrodnictwo
    • Stowarzyszenie właścicieli nieruchomości
    Doradztwo
    • Biuro księgowe
    • Partner Odoo
    • Agencja marketingowa
    • Kancelaria prawna
    • Agencja rekrutacyjna
    • Audyt i certyfikacja
    Produkcja
    • Tekstylia
    • Metal
    • Meble
    • Jedzenie
    • Browar
    • Prezenty firmowe
    Zdrowie & Fitness
    • Klub sportowy
    • Salon optyczny
    • Centrum fitness
    • Praktycy Wellness
    • Apteka
    • Salon fryzjerski
    Transakcje
    • Złota rączka
    • Wsparcie Sprzętu IT
    • Systemy energii słonecznej
    • Szewc
    • Firma sprzątająca
    • Usługi HVAC
    Inne
    • Organizacja non-profit
    • Agencja Środowiskowa
    • Wynajem billboardów
    • Fotografia
    • Leasing rowerów
    • Sprzedawca oprogramowania
    Przeglądaj wszystkie branże
  • Community
    Ucz się
    • Samouczki
    • Dokumentacja
    • Certyfikacje
    • Szkolenie
    • Blog
    • Podcast
    Pomóż w nauce innym
    • Program Edukacyjny
    • Scale Up! Gra biznesowa
    • Odwiedź Odoo
    Skorzystaj z oprogramowania
    • Pobierz
    • Porównaj edycje
    • Wydania
    Współpracuj
    • Github
    • Forum
    • Wydarzenia
    • Tłumaczenia
    • Zostań partnerem
    • Usługi dla partnerów
    • Zarejestruj swoją firmę rachunkową
    Skorzystaj z usług
    • Znajdź partnera
    • Znajdź księgowego
    • Spotkaj się z doradcą
    • Usługi wdrożenia
    • Opinie klientów
    • Wsparcie
    • Aktualizacje
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Zaplanuj demo
  • Cennik
  • Pomoc

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Księgowość
  • Zapasy
  • PoS
  • Projekt
  • MRP
All apps
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
Wszystkie posty Osoby Odznaki
Tagi (Zobacz wszystko)
odoo accounting v14 pos v15
O tym forum
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
Wszystkie posty Osoby Odznaki
Tagi (Zobacz wszystko)
odoo accounting v14 pos v15
O tym forum
Pomoc

I need to add inverse function for a margin field,

Zaprenumeruj

Otrzymaj powiadomienie o aktywności w tym poście

To pytanie dostało ostrzeżenie
decimalcomputeinversedecimal-accuracyDecimal-precision
1571 Widoki
Awatar
Jenish M

In purchase.order.line i have added some fields and their respective inverse method to change the corresponding fields 

class PurchaseOrderInherit(models.Model):
_inherit = "purchase.order.line"

mrp = fields.Float("MRP")
​margin = fields.Float("Mark Down%", compute="_compute_margin", inverse="_inverse_margin", digits='Product Price', store=True,
help="(MRP Excl. - Cost Excl.) / MRP Excl.")
margin_up = fields.Float("Mark Up %", compute="_compute_margin", inverse="_inverse_margin_up", digits='Product Price', store=True,
help="(MRP Excl. - Cost Excl.) / Cost Excl.")
margin_status = fields.Char("Change in Margin%", compute="_compute_margin_status", store=True)
margin_prev = fields.Float("Margin Prev %", store=True)
disc_amount = fields.Float("Disc. Amount", compute="_compute_disc_amount", inverse="_inverse_disc_amount",
help="Discount Amount for Total Quantity", store="True", digits='Product Price')

@api.depends("mrp", "product_qty", "price_subtotal", "product_id")
def _compute_margin(self):
for rec in self:
if rec.mrp and rec.price_subtotal:
base_amount = self._get_tax_amount(rec.product_id, rec.mrp) * rec.product_qty
rec.margin = (base_amount - rec.price_subtotal) / base_amount * 100 if base_amount else 0
rec.margin_up = (base_amount - rec.price_subtotal) / rec.price_subtotal * 100 if rec.price_subtotal else 0
else:
rec.margin = False
rec.margin_up = False

@api.onchange('margin_up')
def _inverse_margin_up(self):
for rec in self:
if rec.product_id and rec.margin_up not in (False, 0):
if rec.price_subtotal:
base_amount = rec.price_subtotal * (1 + rec.margin_up / 100)
rec.mrp = round(rec.product_qty and self._get_mrp_from_base_amount(rec.product_id, base_amount) / rec.product_qty)

@api.onchange('margin')
def _inverse_margin(self):
for rec in self:
base_amount = self._get_tax_amount(rec.product_id, rec.mrp)
if base_amount != 0 and rec.discount != 100:
rec.price_unit = (base_amount * (1 - rec.margin / 100)) / (1 - rec.discount / 100)

def _get_mrp_from_base_amount(self, product, base_amount):
taxes = product.taxes_id.filtered(
lambda x: x.company_id.id == self.env.company.id
or x.company_id.id == self.env.company.parent_id.id
)
tax_amount = sum(taxes.mapped('amount'))
mrp = base_amount * (1 + tax_amount / 100)
return mrp

def _get_tax_amount(self, product, price):
taxes_id = product.taxes_id.filtered(
lambda x: x.company_id.id == self.env.company.id
or x.company_id.id == self.env.company.parent_id.id
)
if taxes_id:
amount = taxes_id.compute_all(
price, product=product, partner=self.env["res.partner"]
)
amount = amount["total_excluded"]
else:
amount = price
return amount

# update margin status
@api.depends("mrp", "price_unit")
def _compute_margin_status(self):
for rec in self:
margin_prev = False
if rec.product_id.id:
margin_prev = (
self.env["purchase.order.line"]
.search(
[
("product_id", "=", rec.product_id.id),
("partner_id", "=", rec.partner_id.id),
("order_id", "!=", rec.order_id._origin.id),
("company_id", '=', self.env.company.id),
],
order="create_date desc",
limit=1,
)
.margin
)
rec.margin_prev = margin_prev
if margin_prev == False:
rec.margin_status = "NA"
elif rec.margin > margin_prev:
rec.margin_status = str(round(rec.margin - margin_prev, 1)) + " ⇑"
elif rec.margin == margin_prev:
rec.margin_status = str(round(rec.margin - margin_prev, 1)) + " ⇔"
elif rec.margin rec.margin_status = str(round(rec.margin - margin_prev, 1)) + " ⇓"

@api.depends('discount')
def _compute_disc_amount(self):
for rec in self:
if rec.discount:
rec.disc_amount = rec.price_unit * rec.product_qty * (rec.discount / 100)
else:
rec.disc_amount = 0.0

@api.onchange('disc_amount')
def _inverse_disc_amount(self):
for rec in self:
if rec.price_unit and rec.product_qty:
rec.discount = (rec.disc_amount / (rec.price_unit * rec.product_qty)) * 100

I have added all the inverse function as api.onchange() but it triggers whenever the field updates it results some unwanted values is there anything i can do
if anyone knows help me

0
Awatar
Odrzuć
Podoba Ci się ta dyskusja? Dołącz do niej!

Stwórz konto dzisiaj, aby cieszyć się ekskluzywnymi funkcjami i wchodzić w interakcje z naszą wspaniałą społecznością!

Zarejestruj się
Powiązane posty Odpowiedzi Widoki Czynność
The decimal precision in the sum tree view does not follow the decimal precision in the field
decimal-accuracy Decimal-precision odoo16features
Awatar
0
gru 23
1560
Inverse function on compute field Rozwiązane
compute inverse odoo10
Awatar
Awatar
1
lis 24
41462
Inverse function for making the compute field editable Rozwiązane
editable compute inverse odoo12
Awatar
Awatar
Awatar
Awatar
3
sie 24
15111
Removing decimal amount from listed price on website
decimal pricing website_builder decimal-accuracy
Awatar
Awatar
1
maj 24
2474
The translation does not change when I change the nameUA field in the view
fields translations compute inverse
Awatar
Awatar
Awatar
2
lut 24
4565
Społeczność
  • Samouczki
  • Dokumentacja
  • Forum
Open Source
  • Pobierz
  • Github
  • Runbot
  • Tłumaczenia
Usługi
  • Hosting Odoo.sh
  • Wsparcie
  • Aktualizacja
  • Indywidualne rozwiązania
  • Edukacja
  • Znajdź księgowego
  • Znajdź partnera
  • Zostań partnerem
O nas
  • Nasza firma
  • Zasoby marki
  • Skontaktuj się z nami
  • Oferty pracy
  • Wydarzenia
  • Podcast
  • Blog
  • Klienci
  • Informacje prawne • Prywatność
  • Bezpieczeństwo Odoo
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo to pakiet aplikacji biznesowych typu open source, które zaspokoją wszystkie potrzeby Twojej firmy: CRM, eCommerce, księgowość, inwentaryzacja, punkt sprzedaży, zarządzanie projektami itp.

Unikalną wartością Odoo jest to, że jest jednocześnie bardzo łatwe w użyciu i w pełni zintegrowane.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now