تخطي للذهاب إلى المحتوى
أودو القائمة
  • تسجيل الدخول
  • جرب مجاناً
  • التطبيقات
    المالية
    • المحاسبة
    • فوترة
    • النفقات
    • جدول البيانات (BI)
    • المستندات
    • توقيع إلكتروني
    المبيعات
    • إدارة علاقات العملاء
    • المبيعات
    • نقطة البيع للمتاجر
    • نقطة البيع للمطاعم
    • الاشتراكات
    • تأجير
    المواقع الإلكترونية
    • أداة بناء المواقع الإلكترونية
    • متاجر إلكترونية
    • مدونة
    • المنتدى
    • دردشة مباشرة
    • التعليم الإلكتروني
    سلسلة التوريد
    • المستودعات
    • التصنيع
    • إدارة دورة حياة المنتج
    • المشتريات
    • الصيانة
    • الجودة
    الموارد البشرية
    • موظفون
    • التوظيف
    • إجازة عمل
    • التقييمات
    • الإحالات
    • تطبيق الأسطول
    التسويق
    • التسويق الإجتماعي
    • التسويق عبر البريد الإلكتروني
    • التسويق عبر الرسائل النصية
    • فعاليات
    • أتمتة التسويق
    • الاستطلاعات
    الخدمات
    • المشاريع
    • الجداول الزمنية
    • الخدمة الميدانية
    • مكتب المساعدة
    • التخطيط
    • مواعيد
    اﻹنتاجية
    • مناقشة
    • الموافقات
    • إنترنت الأشياء "IoT"
    • بروتوكول ربط المحادثات الصوتية عبر الإنترنت
    • المعرفة
    • WhatsApp
    التطبيقات الخارجية ستوديو أودو منصة أودو السحابية
  • قطاعات الأعمال
    البيع بالتجزئة
    • متجر كتب
    • متجر ملابس
    • متجر أثاث
    • متجر بقالة
    • متجر معدات
    • متجر ألعاب
    الطعام والضيافة
    • بار وحانة
    • المطعم
    • مطعم للوجبات السريعة
    • نزل للضيوف
    • موزّع مشروبات
    • فندق
    العقارات
    • وكالة عقارات
    • شركة هندسة معمارية
    • البناء
    • إدارة العقارات
    • العناية بالحدائق
    • اتحاد مُلاّك العقارات
    استشارة
    • مؤسسة محاسبية
    • شريك أودو
    • وكالة تسويقية
    • منشأة قانونية
    • استقطاب المواهب
    • التدقيق والتوثيق
    التصنيع
    • الأقمشة
    • معدني
    • الأثاث
    • الطعام
    • مصنع خمور
    • هدايا الشركات
    الصحة واللياقة البدنية
    • نادي رياضي
    • متجر نظارات
    • مركز لياقة بدنية
    • الممارسون الصحيون
    • صيدلية
    • صالون تصفيف الشعر
    التجارة
    • عامل صيانة
    • الأجهزة والمعدات التقنية ودعمها
    • أنظمة الطاقة الشمسية
    • صانع أحذية
    • خدمات التنظيف
    • خدمات التكييف (HVAC)
    غير ذلك
    • منظمة غير ربحية
    • وكالة بيئية
    • تأجير لوحات إعلانية
    • تصوير
    • تأجير دراجات
    • بائع وسيط للبرمجيات
    تصفح كافة قطاعات الأعمال
  • مجتمع أودو
    تعلم
    • دروس
    • التوثيق
    • شهادات
    • التدريب
    • مدونة
    • بودكاست
    قم بتعزيز التعليم
    • برنامج تعليم
    • Scale UP! لعبة الأعمال
    • قم بزيارة أودو
    احصل على البرنامج
    • تحميل
    • قارنْ الإصدارات
    • إطلاق
    تعاون
    • جيت هاب "Github"
    • المنتدى
    • فعاليات
    • الترجمات
    • كنْ شريكاً
    • خدمات الشركاء
    • سجل مكتب المحاسبة الخاص بك
    احصل على الخدمات
    • اعثر على شريك
    • اعثر على محاسب
    • قابل أحد مرشدي الأعمال
    • خدمات التنفيذ
    • مراجع العملاء
    • الدعم
    • الترقيات
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    الحصول على عرض توضيحي
  • الأسعار
  • المساعدة

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

  • إدارة علاقات العملاء
  • e-Commerce
  • المحاسبة
  • المخزون
  • PoS
  • المشروع
  • MRP
All apps
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
المساعدة

Can Odoo automatically pick the Cheapest Vendor listed in the Purchase tab of a Product when generating an RFQ?

اشتراك

تسلم الإشعارات عندما يكون هناك نشاط في هذا المنشور

لقد تم الإبلاغ عن هذا السؤال
automaticpricelowPurchase
5 الردود
14333 أدوات العرض
الصورة الرمزية
Community Question

I have multiple Vendors for several Products.

I would like Odoo to automatically select the Vendor with the cheapest price (the prices change each month) when generating an RFQ (draft Purchase Order). 

Is this possible.

0
الصورة الرمزية
إهمال
الصورة الرمزية
Friedrich Sauer
أفضل إجابة

Hi all, 

I converted this to an automated action that works in v17. 




My code:

def sort_seller_ids(self):
    for rec in self:
       
        seller_ids = self.env['product.supplierinfo'].search([('product_tmpl_id', 'in', [rec.product_tmpl_id.id])])
        rec.product_tmpl_id.message_post(body=f'seller_ids: {seller_ids}')
       
        seller_prices = {}
       
        for seller in seller_ids:
            # seller's ID --> key and their price --> value
            seller_prices[seller.id] = seller.price
           
        # Sort the dictionary by price in ascending order
        sorted_seller_ids = sorted(seller_prices, key=seller_prices.get, reverse=False)
       
        # Update the sequence of seller_ids based on the sorted order
        for sequence, seller_id in enumerate(sorted_seller_ids, start=1):
            seller = seller_ids.filtered_domain([('id', '=', seller_id)])
            if seller:
                seller.write({'sequence': sequence})


sort_seller_ids(record)

Removing the drag handles is not obligatory, but they have no funcionality anymore.


Best,

Friedrich

2
الصورة الرمزية
إهمال
Chris TRINGHAM

Hi Friedrich - I'm not a Python programmer, but from my testing it seems as if this is putting the highest price first. Also, is there any way to make this work as a Server Action (to do a mass update)?

Friedrich Sauer

Hi Chris, you are right! I changed the code.

Putting this in a server action can work. you need to go through all products and use the action on its order lines. in serveractions with model product.template use something like:

def sort_seller_lines_for_all_products(self):
for product in records:
seller_ids = product.seller_ids

seller_prices = {}

for seller in seller_ids:
# seller's ID --> key and their price --> value
seller_prices[seller.id] = seller.price

# Sort the dictionary by price in ascending order
sorted_seller_ids = sorted(seller_prices, key=seller_prices.get, reverse=False)

# Update the sequence of seller_ids based on the sorted order
for sequence, seller_id in enumerate(sorted_seller_ids, start=1):
seller = seller_ids.filtered_domain([('id', '=', seller_id)])
if seller:
seller.write({'sequence': sequence})

sort_seller_lines_for_all_products(records)

You can add this as an "contextual action" so that is is available under the action wheel in the products view. (I have not tested this code btw)

Best,
Friedrich

الصورة الرمزية
Ray Carnes (ray)
أفضل إجابة

Note: Right Click the images below and select VIEW IMAGE / OPEN IMAGE IN A NEW TAB to see larger versions.

Yes.

Odoo uses the first Vendor in the list by default.

To have it choose the cheapest, the easiest way is to sort the list by price each time it is edited.  You will also have to remove the drag handle from the list to stop users re-sorting the list.

1. Create an Automated Action that makes sure the list of is always sorted after any edits (also works if you change prices from the Vendor Pricelist menu).



2. Remove the drag handle by creating your own view that inherits and overrides the default:


5
الصورة الرمزية
إهمال
Darren

is this working on Odoo 15.0? I am using Odoo Cloud by Odoo. I tried this ccode, it seem no working. I just follow the first step.

الصورة الرمزية
Sanjeev Kumar
أفضل إجابة

Is there a way to stop Odoo to pick the cheapest price? It's handy when there are several vendors for one product. However, when there is only one supplier and prices increase every year, this function does not make sense. It's really difficult to remove old prices one by one when there is a huge number of products in the system.

0
الصورة الرمزية
إهمال
Caribbean Data Challengers

Just a thought...
Did you try to work with the start and end dates of the price?
Another approach would be to add a custom boolean field "current_price". Export the whole list (updatable) and set current_price to 0. Add your new records with the current_price = 1.
Now all you need is the add this field in the sort somehow, perhaps a Python specialist can help with that.

Darren

You can try "end date" when you add the price.

الصورة الرمزية
Gargano Dok Scarl
أفضل إجابة

In odoo 13 CE is not possible sort suppliers list from product template, changes will not be saved.

It's possible sort suppliers list from product.supplierlist, changes will be saved.

Can anyone adapt code descripted in this post, for use it in template product.supplierinfo

Below original code:

if record.seller_ids:
  record['seller_ids'] = record.seller_ids.sorted(key = lambda s: s.price)

Thanks

0
الصورة الرمزية
إهمال
Ray Carnes (ray)

Make sure base_automation "Automated Action Rules" is installed and visit the Automated Actions menu.

Gargano Dok Scarl

Hi Ray, thanks for your help. I've do it some days ago, and it work. I've do step 1 only (1. Create an Automated Action) and not step 2. (2. Remove the drag handle). But if I change manually a supplier price, in product template, It not reoder automatic supplier list. Maybe I must to do step 2, for work well? Thanks

Gargano Dok Scarl

Hi, I'm using odoo 13 community, not work! I've do it, both modifies, but not sort supplier list by price.

Chris TRINGHAM

I think there may be an extra step. As well as removing the "drag handle", existing records on product.supplierinfo need to be updated so that the sequence is 1 (otherwise this overrides the sort done in the Automated Action)

Gargano Dok Scarl

Hi Chris, can you write more details to do, I'm not a developer and I don't know how do. Could you write what I must do? Thanks

Chris TRINGHAM

Here's a step-by-step guide: https://odootricks.tips/automatically-select-lowest-price-vendor/

Gargano Dok Scarl

Hi Chris, thanks for guide. I've try, and suppliers are sorted by price. But I've look that suppliers are sorted by min_qty first , and by price after. If I have some suppliers with high min_qty and more expensive, they will be sorted before others more cheap end with low min_qty. I don't know if is this correct action, but I needed sort by price first , and by min_qty secondary. Any idea?

Chris TRINGHAM

I'm not a Python programmer, but a bit of quick research reveals that you can add a second field to the sort:

if record.seller_ids:

record['seller_ids'] = record.seller_ids.sorted(key = lambda s: (s.price,s.min_qty))

Gargano Dok Scarl

Hi Chris I don't know why, but not work anyway. It is sorted by min_qty before, always. Thank you very much. If anyone have any others solution is appreciated, thanks

الصورة الرمزية
Chris Kelley
أفضل إجابة

would this work if you updated by import (i dont think it would)

0
الصورة الرمزية
إهمال
Ray Carnes (ray)

Yes. Create and Update are triggered with data imports, and I tested this particular automation.

هل أعجبك النقاش؟ لا تكن مستمعاً فقط. شاركنا!

أنشئ حساباً اليوم لتستمتع بالخصائص الحصرية، وتفاعل مع مجتمعنا الرائع!

تسجيل
المنشورات ذات الصلة الردود أدوات العرض النشاط
Link RFQs and Quotations
Purchase
الصورة الرمزية
0
سبتمبر 23
3230
Problem with tax included price تم الحل
price
الصورة الرمزية
1
يونيو 23
243
With odoo 16 what are the prices for iot box?
price
الصورة الرمزية
الصورة الرمزية
1
ديسمبر 22
4675
Bill of Entry & Date for Importing Raw Material in Purchase
Purchase
الصورة الرمزية
1
أكتوبر 22
2949
Sales Unit Price تم الحل
price
الصورة الرمزية
الصورة الرمزية
1
يناير 22
3126
المجتمع
  • دروس
  • التوثيق
  • المنتدى
مصدر مفتوح
  • تحميل
  • جيت هاب "Github"
  • المشغل الآلي رنبوت
  • الترجمات
خدماتنا
  • استضافة أودو إس إتش
  • الدعم
  • الترقية
  • التطويرات المخصصة
  • التعليم
  • اعثر على محاسب
  • اعثر على شريك
  • كنْ شريكاً
معلومات عنا
  • شركتنا
  • أصول العلامة التجارية
  • اتصلْ بنا
  • الوظائف
  • فعاليات
  • بودكاست
  • مدونة
  • عملاء
  • قانوني • الخصوصية
  • الحماية
الْعَرَبيّة 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

أودو هو عبارة عن مجموعة من تطبيقات الأعمال مفتوحة المصدر التي تغطي جميع احتياجات شركتك، مثل: إدارة علاقات العملاء والتجارة الإلكترونية والمحاسبة والمخزون ونقاط البيع وإدارة المشاريع وما إلى ذلك.

ما يجعل من أودو مميزاً هو هدفه بأن يكون سهل الاستخدام للغاية ومتكاملاً تمامًا في الوقت ذاته.

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