Skip to Content
Odoo Menu
  • Prisijungti
  • Išbandykite nemokamai
  • Programėlės
    Finansai
    • Apskaita
    • Pateikimas apmokėjimui
    • Sąnaudos
    • Skaičiuoklė (BI)
    • Dokumentai
    • Pasirašymas
    Pardavimai
    • CRM
    • Pardavimai
    • Kasų sistema - Parduotuvė
    • Kasų sistema - Restoranas
    • Prenumeratos
    • Nuoma
    Svetainės
    • Svetainių kūrėjimo įrankis
    • El. Prekyba
    • Internetinis Tinklaraštis
    • Forumas
    • Tiesioginis pokalbis
    • eMokymasis
    Tiekimo grandinė
    • Atsarga
    • Gamyba
    • PLM
    • Įsigijimai
    • Priežiūra
    • Kokybė
    Žmogaus ištekliai
    • Darbuotojai
    • Įdarbinimas
    • Atostogos
    • Įvertinimai
    • Rekomendacijos
    • Transporto priemonės
    Rinkodara
    • Socialinė rinkodara
    • Rinkodara el. paštu
    • SMS rinkodara
    • Renginiai
    • Rinkodaros automatizavimas
    • Apklausos
    Paslaugos
    • Projektas
    • Darbo laiko žiniaraščiai
    • Priežiūros tarnyba
    • Pagalbos tarnyba
    • Planavimas
    • Rezervacijos
    Produktyvumas
    • Diskucija
    • Artificial Intelligence
    • IoT
    • VoIP
    • Žinių biblioteka
    • WhatsApp
    Trečiųjų šalių programos Odoo Studija Odoo debesijos platforma
  • Pramonės šakos
    Mažmeninė prekyba
    • Knygynas
    • Drabužių parduotuvė
    • Baldų parduotuvė
    • Maisto prekių parduotuvė
    • Techninės įrangos parduotuvė
    • Žaislų parduotuvė
    Food & Hospitality
    • Barai ir pub'ai
    • Restoranas
    • Greitasis maistas
    • Guest House
    • Gėrimų platintojas
    • Hotel
    Nekilnojamasis turtas
    • Real Estate Agency
    • Architektūros įmonė
    • Konstrukcija
    • Property Management
    • Sodininkauti
    • Turto savininkų asociacija
    Konsultavimas
    • Accounting Firm
    • Odoo Partneris
    • Marketing Agency
    • Teisinė firma
    • Talentų paieška
    • Auditai & sertifikavimas
    Gamyba
    • Textile
    • Metal
    • Furnitures
    • Maistas
    • Brewery
    • Įmonių dovanos
    Sveikata & Fitnesas
    • Sporto klubas
    • Akinių parduotuvė
    • Fitneso Centras
    • Sveikatos praktikai
    • Vaistinė
    • Kirpėjas
    Trades
    • Handyman
    • IT įranga ir palaikymas
    • Saulės energijos sistemos
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    Kiti
    • Nonprofit Organization
    • Aplinkos agentūra
    • Reklaminių stendų nuoma
    • Fotografavimas
    • Dviračių nuoma
    • Programinės įrangos perpardavėjas
    Browse all Industries
  • Bendrija
    Mokykitės
    • Mokomosios medžiagos
    • Dokumentacija
    • Sertifikatai
    • Mokymai
    • Internetinis Tinklaraštis
    • Tinklalaidės
    Skatinkite švietinimą
    • Švietimo programa
    • Scale Up! Verslo žaidimas
    • Aplankykite Odoo
    Gaukite programinę įrangą
    • Atsisiųsti
    • Palyginkite versijas
    • Leidimai
    Bendradarbiauti
    • Github
    • Forumas
    • Renginiai
    • Vertimai
    • Tapkite partneriu
    • Services for Partners
    • Registruokite jūsų apskaitos įmonę
    Gaukite paslaugas
    • Susiraskite partnerį
    • Susirask buhalterį
    • Susitikti su konsultantu
    • Diegimo paslaugos
    • Klientų rekomendavimas
    • Palaikymas
    • Atnaujinimai
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Gaukite demo
  • Kainodara
  • Pagalba
You need to be registered to interact with the community.
All Posts People Badges
Žymos (View all)
Sales Invoicing version14 salesorder sales
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Žymos (View all)
Sales Invoicing version14 salesorder sales
About this forum
  1. Sales
  2. Forumas

Sale order line V15 problem

Prenumeruoti

Get notified when there's activity on this post

This question has been flagged
salessale.order.formsales.order
2 Replies
2962 Rodiniai
Portretas
Frucco IT Solutions, Romain Frucco

Hello,

I'm trying to create a product from Form sale\.order\.line,\ from\ an\ other\ existant\ product\.

If\ i'm\ taking\ a\ sale\.order\.line\ that\ exist\ it\ works,\ but\ if\ i'm\ trying\ to\ Add\ a\ new\ product\ i'm\ taking\ an\ error\.

Following\ you\ will\ find\ my\ code\ :


Code

/\#\ \-\*\-\ coding:\ utf\-8\ \-\*\-

from\ odoo\ import\ api,\ fields,\ models,\ tools,\ _,\ SUPERUSER_ID
from\ odoo\.exceptions\ import\ ValidationError,\ RedirectWarning,\ UserError
from\ odoo\.osv\ import\ expression
import\ logging

_logger\ =\ logging\.getLogger\(__name__\)

class\ SaleOrderLineNU\(models\.Model\):
\ \ \ \ \#\ \ Bug\ At\ least\ one\ model\ cache\ has\ been\ invalidated,\ signaling\ through\ the\ database
\ \ \ \ cutLength\ =\ fields\.Float\(string='Cut\ Length',\ digits=\(2,\ 0\)\)
\ \ \ \ length\ =\ fields\.Float\(string='Length',\ digits=\(2,\ 0\)\)

\ \ \ \ _inherit\ =\ "sale\.order\.line"

\ \ \ \ def\ majPrice\(self,\ line,\ qty=False\):
\ \ \ \ \ \ \ \ mrp_bom\ =\ self\.env\['mrp\.bom'\]\ \ \#\ recuperation\ fichier\ python
\ \ \ \ \ \ \ \ bom_report\ =\ self\.env\['report\.mrp\.report_bom_structure'\]\ \ \#\ recuperation\ fichier\ python
\ \ \ \ \ \ \ \ if\ line\.product_id\ and\ line\.product_uom_qty:\ \ \#\ si\ un\ produit\ avec\ identifiant\ et\ qty
\ \ \ \ \ \ \ \ \ \ \ \ bom\ =\ mrp_bom\._bom_find\(products=line\.product_id\)\ \ \#\ recuperation\ du\ resultat\ de\ la\ fonction\ _bom_find
\ \ \ \ \ \ \ \ \ \ \ \ if\ bom:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ price\ =\ bom_report\._get_bom\(
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ bom_id=bom\[line\.product_id\]\.id,\ product_id=str\(line.product_id.id),
line_qty=line.product_uom_qty, line_id=False,
level=False)['total'] / line.product_uom_qty # Recuperation du resultat de la fonction _get_bom['total']/qty
# _logger.warning("MAJ %s: %s", line.product_uom_qty, price)
return price

@api.onchange('product_uom_qty')
def _compute_so_line_bom_price(self, qty=False):
"""Compute: Product BoM Cost Price.
Compute the BoM Cost Price using _bom_find method of MRP BoM object and
_get_bom method of BoM Structure and Cost Report
(BoM > Smart Button: Structure & Cost).
put this price in purchase_price in order_line and standard_price in product
for pricelist calculation
:return: None
"""

for res in self: # pour chaque ligne
price = 0
price = SaleOrderLineNU.majPrice(self, res)
self.purchase_price = price # Pousse le tarif dans le prix d'achat du devis
res.product_id.standard_price = price # Pousse le tarif dans la fiche produit en coût pour calcul du prix de vente basé sur le coût

@api.onchange('product_id')
def recupBomInfoSale(self):
mrp_bom = self.env['mrp.bom'] # recuperation fichier python
if self.product_id and '5' in self.product_id.route_ids: # a Verifier
bom = mrp_bom._bom_find(products=self.product_id)
if bom:
if len(bom[self.product_id].bom_line_ids) == 1:
self.length = bom[self.product_id].bom_line_ids.product_qty * 1000 # ok

def cut_article(self):
DuplicateArticleNUprod.createArticle(self)

class SaleOrder(models.Model):

_inherit = "sale.order"

@api.onchange('order_line')
def calculationQty1OnCreate(self):
sale_order_line = self.env['sale.order.line'] # recuperation fichier python
if self.order_line != 0:
for res in self.order_line:
if res.product_uom_qty == 1:

price = SaleOrderLineNU.majPrice(self.order_line, res)
res.purchase_price = price # Pousse le tarif dans le prix d'achat du devis
res.product_id.standard_price = price # Pousse le tarif dans la fiche produit en coût pour calcul du prix de vente basé sur le coût
sale_order_line._onchange_discount() # MAJ du tarif

class DuplicateArticleNUprod(models.Model):

_inherit = "product.product"
# Bug si order_line n'existe pas il faut donc ajouter un article au devis le sauvegarder et aprés modifier cet article
def createArticle(self):

productModule = self.env['product.template']
newProduct = productModule.create([{
'name': _('Coupe de %s L:%s', self\.product_id\.name,\ int\(self\.cutLength\)\),
\ \ \ \ \ \ \ \ \ \ \ \ 'sale_ok':\ True,
\ \ \ \ \ \ \ \ \ \ \ \ 'detailed_type':\ 'product',
\ \ \ \ \ \ \ \ \ \ \ \ 'default_code':\ self\.product_id\.default_code\ \+\ '/'\ \+\ str\(int\(self\.cutLength\)\),
\ \ \ \ \ \ \ \ \ \ \ \ 'route_ids':\ \[5\],
\ \ \ \ \ \ \ \ \ \ \ \ 'uom_id':\ 1,
\ \ \ \ \ \ \ \ \ \ \ \ 'purchase_ok':\ False,
\ \ \ \ \ \ \ \ \ \ \ \ 'categ_id':self\.product_id\.categ_id\.id,
\ \ \ \ \ \ \ \ \}\]\)

\ \ \ \ \ \ \ \ bomModule\ =\ self\.env\['mrp\.bom'\]
\ \ \ \ \ \ \ \ bomId\ =\ bomModule\.create\(\[\{
\ \ \ \ \ \ \ \ \ \ \ \ 'product_tmpl_id':\ newProduct\.id,
\ \ \ \ \ \ \ \ \ \ \ \ 'product_qty':\ 1,
\ \ \ \ \ \ \ \ \ \ \ \ 'code':\ newProduct\.name,
\ \ \ \ \ \ \ \ \ \ \ \ 'type':\ 'normal',
\ \ \ \ \ \ \ \ \ \ \ \ 'operation_ids':\ \[
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \(0,\ 0,\ \{
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ 'name':\ 'Sciage',
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ 'workcenter_id':\ 1,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ 'time_cycle_manual':\ 3,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ 'sequence':\ 1,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \}
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \),
\ \ \ \ \ \ \ \ \ \ \ \ \]
\ \ \ \ \ \ \ \ \}\]\)

\ \ \ \ \ \ \ \ bomLineModule\ =\ self\.env\['mrp\.bom\.line'\]
\ \ \ \ \ \ \ \ bomLineModule\.create\(\[\{
\ \ \ \ \ \ \ \ \ \ \ \ 'bom_id':\ bomId\.id,
\ \ \ \ \ \ \ \ \ \ \ \ 'product_id':\ self\.product_id\.id,
\ \ \ \ \ \ \ \ \ \ \ \ 'product_tmpl_id':\ self.product_id.product_tmpl_id.id,
'product_qty': self.cutLength / 1000,
}])

return True


Error

2021-12-07 23:00:38,125 28644 ERROR FMB011221 odoo.sql_db: bad query: INSERT INTO "sale_order_line" ("id", "create_date", "create_uid", "customer_lead", "cutLength", "discount", "display_type", "invoice_status", "is_delivery", "length", "name", "price_unit", "product_id", "product_packaging_id", "product_packaging_qty", "product_uom", "product_uom_qty", "purchase_price", "qty_delivered", "qty_delivered_manual", "route_id", "sequence", "write_date", "write_uid") VALUES (nextval('sale_order_line_id_seq'), '2021-12-07 23:00:38.114232', 7, 0.0, '567', '0.00', NULL, 'no', false, '0', '[TGF0208.8] TIGE FILETEE M20 CLASS 8.8', '0.00', 234, NULL, 0.0, 6, '1.00', '0.00', '0.00', '0.00', NULL, 12, '2021-12-07 23:00:38.114232', 7) RETURNING id
ERROR: null value in column "order_id" of relation "sale_order_line" violates not-null constraint
DETAIL: Failing row contains (110, null, [TGF0208.8] TIGE FILETEE M20 CLASS 8.8, 12, no, 0.00, null, null, null, null, null, null, 0.00, 234, 1.00, 6, null, 0.00, 0.00, null, null, null, null, null, null, null, null, null, null, null, 0, null, null, 0, 7, 2021-12-07 23:00:38.114232, 7, 2021-12-07 23:00:38.114232, null, null, null, 0.00, f, 567, 0).

2021-12-07 23:00:38,150 28644 WARNING FMB011221 odoo.http: L'opération ne peut pas être terminée:
- Créer / mettre à jour: un champ obligatoire n'est pas défini.
- Supprimer: un autre modèle nécessite la suppression de l'enregistrement. Si possible, archivez-le.

Modèle: Sales Order Line (sale.order.line), Champ : Order Reference (order_id) 


Can you help me?


Sincerely


0
Portretas
Atmesti
Portretas
Jainesh Shah(Aktiv Software)
Best Answer

Hello Romain,

As per your code, while creating a sale order line, order_id is missing, so you need to give the id of the sale order, because in the database the connection between Sale order and line is many2one - one2many. 

Once you will add the order_id. It'll work.

I hope this will help you.

Thanks & Regards,
Email: odoo@aktivsoftware.com
Skype: kalpeshmaheshwari

0
Portretas
Atmesti
Portretas
Cybrosys Techno Solutions Pvt.Ltd
Best Answer

Hi,

While creating sale.order.line we need to pass data to mandatory fields in that model where order_id is required in model sale.order.line please add appropriate order_id for that sale order line.

Regards

0
Portretas
Atmesti
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Registracija
Related Posts Replies Rodiniai Veikla
How to display changes to Delivered Quantities in Sales Orders in Chatter Solved
sales sales.order
Portretas
Portretas
1
kov. 25
3706
Sales stay in "To Invoice" despite already being paid.
sales sales.order
Portretas
Portretas
1
geg. 24
3770
How to Hide the (Create request Pricing button) after creating pricing on the sales screen
sales sale.order.form
Portretas
Portretas
1
gruod. 22
3935
Confirm Quotation button is not showing on the Sales Order (Quotation) Form Odoo 17.
sales sales.order odoo17
Portretas
Portretas
Portretas
2
birž. 25
3258
Modify invoice content make it disconnect with its sales order
sales invoice sales.order
Portretas
Portretas
1
saus. 25
3625
Bendrija
  • Mokomosios medžiagos
  • Dokumentacija
  • Forumas
Atvirasis kodas
  • Atsisiųsti
  • Github
  • Runbot
  • Vertimai
Paslaugos
  • Odoo.sh talpinimas
  • Palaikymas
  • Atnaujinti
  • Pritaikytas programavimo kūrimas
  • Švietimas
  • Susirask buhalterį
  • Susiraskite partnerį
  • Tapkite partneriu
Apie mus
  • Mūsų įmonė
  • Prekės ženklo turtas
  • Susisiekite su mumis
  • Darbo pasiūlymai
  • Renginiai
  • Tinklalaidės
  • Internetinis Tinklaraštis
  • Klientai
  • Teisinis • Privatumas
  • Saugumas
الْعَرَبيّة 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 Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo yra atvirojo kodo verslo programų rinkinys, kuris apima visas įmonės poreikius: CRM, El. Prekybą, Apskaitą, Atsargų, Kasų sistemą, Projektų valdymą ir kt.

Unikali Odoo vertės pasiūla – būti tuo pačiu metu labai lengvai naudojama ir visiškai integruota sistema.

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