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
    • Patvirtinimai
    • 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
    • Estate Managament
    • 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

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

  • CRM
  • e-Commerce
  • Apskaita
  • Atsarga
  • PoS
  • Projektas
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Žymos (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Žymos (View all)
odoo accounting v14 pos v15
About this forum
Pagalba

Can I generate Customer Invoices directly from done / completed Delivery Orders?

Prenumeruoti

Get notified when there's activity on this post

This question has been flagged
invoicedeliveryorderfromgeneratequickstart
1 Atsakyti
232 Rodiniai
Portretas
Community Question

I have several Customers who place multiple Sales Orders during each month. 

We invoice them once a month.

Each Sales Order typically needs to be delivered via multiple Delivery Orders.

The standard Invoice does merge all Sales Orders but what we would really like is to show which lines were delivered from each Delivery and each Sales Order.

How can we do this?

0
Portretas
Atmesti
Portretas
Ray Carnes (ray)
Best Answer
Here is something we have been prototyping, this may be improved as we test more cases, and may need to be modified.

First, create a field x_invoiced on the stock.picking model so Deliver Orders can be marked if they are Invoiced this way.

Next, create an Execute Code Server Action so you can add an option to the Action Menu when you select multiple Delivery Orders at month end.

if records.filtered(lambda p:p.picking_type_code != 'outgoing'):
raise UserError("Only Delivery Orders can be Invoiced!")
if records.filtered(lambda p:p.state != 'done'):
raise UserError("Only Done Delivery Orders can be Invoiced!")
delivered_moves = env['stock.move'].search([('picking_id', 'in', records.ids),('state', '=', 'done'),
('sale_line_id', '!=', False)], order='picking_id asc, id asc')

if not delivered_moves:
raise UserError("No delivered items found that are linked to a Sales Order Line.")

records = records.sorted(lambda p:p.date_done)

move_groups = {}
for move in delivered_moves:
partner = move.picking_id.partner_id
company = move.picking_id.company_id
currency = company.currency_id

key = (partner.id, currency.id, company.id)
if key not in move_groups:
move_groups[key] = {'moves': env['stock.move'], 'pickings': set()}
move_groups[key]['moves'] += move
move_groups[key]['pickings'].add(move.picking_id.id)

new_invoices = env['account.move']
sequence = 10

for key, data in move_groups.items():
partner_id, currency_id, company_id = key
partner = env['res.partner'].browse(partner_id)
company = env['res.company'].browse(company_id)
invoice_line_vals_list = []
pickings_in_group = env['stock.picking'].browse(list(data['pickings']))
sequential_pickings = records & pickings_in_group
for picking in sequential_pickings:
picking_moves = data['moves'].filtered(lambda m: m.picking_id.id == picking.id)
if not picking_moves:
continue
sale_order = picking.sale_id
picking_name = picking.name
comment_text = f'{picking_name}'
if sale_order:
comment_text += f' from {sale_order.name}'
comment_text += f' shipped {picking.date_done.day}/{picking.date_done.month}'
if picking.carrier_tracking_ref:
comment_text += f" via tracking# {picking.carrier_tracking_ref}"
comment_line_vals = {
'display_type': 'line_section',
'name': comment_text,
'sequence': sequence,
}
invoice_line_vals_list.append((0, 0, comment_line_vals))

sequence+=1
for move in picking_moves:
sale_line = move.sale_line_id
quantity_to_invoice = move.quantity
product_line_vals = sale_line._prepare_invoice_line(quantity=quantity_to_invoice)
product_line_vals.update({
'sequence': sequence,
'sale_line_ids': [(6, 0, [sale_line.id])],
})
invoice_line_vals_list.append((0, 0, product_line_vals))
sequence+=1

picking.write({'x_invoiced': True})
picking_names = sequential_pickings.mapped('name')
origin_string = ", ".join(picking_names)
order_names_with_duplicates = sequential_pickings.mapped('origin')
unique_order_names = list(set(order_names_with_duplicates))
unique_order_names.sort()
reference_string = ", ".join(unique_order_names)

invoice_vals = {
'move_type': 'out_invoice',
'partner_id': partner_id,
'currency_id': currency_id,
'company_id': company_id,
'invoice_origin': origin_string,
'ref': reference_string,
'invoice_user_id': env.user.id,
'invoice_line_ids': invoice_line_vals_list,
}

invoice = env['account.move'].create(invoice_vals)
new_invoices += invoice
if new_invoices:
if len(new_invoices) == 1:
invoice = new_invoices[0]
action = {
'type': 'ir.actions.act_window',
'name': 'Created Invoice',
'res_model': 'account.move',
'view_mode': 'form',
'res_id': invoice.id, # Specify the ID of the single record to open
}
else:
action = {
'type': 'ir.actions.act_window',
'name': 'Created Invoices',
'res_model': 'account.move',
'view_mode': 'list,form',
'domain': [('id', 'in', new_invoices.ids)],
}

Impact:

Both the Invoice PDF and the Portal View of the Invoice reflect this same breakdown.

Note: your Odoo Digital Advisor or Odoo Partner can help you if you don't have the skills to do this, or have further questions or concerns about this approach. This is a prototype and not a solution.

2
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
The delivery and paid checkbox do not marked
invoice delivery order
Portretas
Portretas
1
kov. 15
5140
Printing Delivery Order error
delivery order
Portretas
0
kov. 15
5925
Invoicing External Trade Mx_loc: How to show the number of reliable exporter on the pdfs and xml of customer invoices Solved
invoice quickstart Mexico
Portretas
1
bal. 23
2980
[Odoo 16] Invoices go straight to "paid" when I register a payment Solved
accounting invoice quickstart
Portretas
Portretas
Portretas
3
lapkr. 22
6432
From Sales order to Delivery and Invoice in one step Solved
invoice delivery salesorder
Portretas
Portretas
Portretas
Portretas
3
lapkr. 22
5143
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 ภาษาไทย 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