Ir al contenido
Odoo Menú
  • Iniciar sesión
  • Pruébalo gratis
  • Aplicaciones
    Finanzas
    • Contabilidad
    • Facturación
    • Gastos
    • Hoja de cálculo (BI)
    • Documentos
    • Firma electrónica
    Ventas
    • CRM
    • Ventas
    • TPV para tiendas
    • TPV para restaurantes
    • Suscripciones
    • Alquiler
    Sitios web
    • Creador de sitios web
    • Comercio electrónico
    • Blog
    • Foro
    • Chat en directo
    • e-learning
    Cadena de suministro
    • Inventario
    • Fabricación
    • PLM
    • Compra
    • Mantenimiento
    • Calidad
    Recursos Humanos
    • Empleados
    • Reclutamiento
    • Ausencias
    • Evaluación
    • Referencias
    • Flota
    Marketing
    • Marketing social
    • Marketing por correo electrónico
    • Marketing por SMS
    • Eventos
    • Automatización de marketing
    • Encuestas
    Servicios
    • Proyecto
    • Partes de horas
    • Servicio de campo
    • Servicio de asistencia
    • Planificación
    • Citas
    Productividad
    • Conversaciones
    • Inteligencia artificial
    • IoT
    • VoIP
    • Información
    • WhatsApp
    Aplicaciones de terceros Studio de Odoo Plataforma de Odoo Cloud
  • Sectores
    Comercio al por menor
    • Librería
    • Tienda de ropa
    • Tienda de muebles
    • Tienda de ultramarinos
    • Ferretería
    • Juguetería
    Alimentación y hostelería
    • Bar y pub
    • Restaurante
    • Comida rápida
    • Casa de huéspedes
    • Distribuidor de bebidas
    • Hotel
    Inmueble
    • Agencia inmobiliaria
    • Estudio de arquitectura
    • Construcción
    • Gestión inmobiliaria
    • Jardinería
    • Asociación de propietarios
    Consultoría
    • Asesoría contable
    • Partner de Odoo
    • Agencia de marketing
    • Bufete de abogados
    • Adquisición de talentos
    • Auditorías y certificaciones
    Fabricación
    • Textil
    • Metal
    • Muebles
    • Alimentos
    • Cervecería
    • Regalos corporativos
    Salud y bienestar
    • Club deportivo
    • Óptica
    • Gimnasio
    • Especialistas en bienestar
    • Farmacia
    • Peluquería
    Oficios
    • Servicios de mantenimiento
    • Hardware y soporte técnico
    • Sistemas de energía solar
    • Zapatero
    • Servicios de limpieza
    • Servicios de calefacción, ventilación y aire acondicionado
    Otros
    • Organización sin ánimo de lucro
    • Agencia de protección del medio ambiente
    • Alquiler de vallas publicitarias
    • Estudio fotográfico
    • Alquiler de bicicletas
    • Distribuidor de software
    Explorar todos los sectores
  • Comunidad
    Aprender
    • Tutoriales
    • Documentación
    • Certificaciones
    • Formación
    • Blog
    • Podcast
    Potenciar la educación
    • Programa de formación
    • Scale Up! El juego empresarial
    • Visita Odoo
    Obtener el software
    • Descargar
    • Comparar ediciones
    • Versiones
    Colaborar
    • GitHub
    • Foro
    • Eventos
    • Traducciones
    • Convertirse en partner
    • Servicios para partners
    • Registrar tu asesoría contable
    • Referral Program
    Obtener servicios
    • Encontrar un partner
    • Encontrar un asesor fiscal
    • Contacta con un experto
    • Servicios de implementación
    • Referencias de clientes
    • Ayuda
    • Actualizaciones
    GitHub YouTube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Solicitar una demostración
  • Precios
  • Ayuda
Debe estar registrado para interactuar con la comunidad.
Todas las publicaciones Personas Insignias
Etiquetas (Ver todo)
odoo accounting v14 pos v15
Sobre este foro
Debe estar registrado para interactuar con la comunidad.
Todas las publicaciones Personas Insignias
Etiquetas (Ver todo)
odoo accounting v14 pos v15
Sobre este foro
Ayuda

How to prevent from adding same products in sale order line

Suscribirse

Reciba una notificación cuando haya actividad en esta publicación

Esta pregunta ha sido marcada
odooodoo12Odoo13.0
1 Responder
8116 Vistas
Avatar
Madara

hi all iam a newbie to odoo , what iam trying to achieve is i want to prevent from adding duplicate products in order line , if the same exits already we should not able to add the duplicate product 


    @ api.multi

    @ api.constrains ('order_line')

    def _check_exist_product_in_line (self):

      for rec in self:

          product_id = self.env ['product.product']. search ([('default_code', '=', 'MIFFLIN')])

          for line in self.order_line:

             if line.product_id.id in product_id:

                raise ValidationError (_ ('Product already added.'))

             product_id.append (line.product_id.id)



i tried like this but it's not working its throwing operation not permitted. what am i missing here , someone help me here

0
Avatar
Descartar
Madara
Autor

TypeError: Mixing apples and oranges: product.product(28,) in sale.order.line(572,)

Avatar
Mohamed Lamine Lalmi
Mejor respuesta

Hello Mascherano,

Comparing what you want to achieve with what your code does seem like two different things to me.

I feel your code will solve your situation, you can just fix it like the following:

  1. Please do not use @api.multi & @api.constrains on the same function

  2. the result of self.env ['product.product']. search ([('default_code', '=', 'MIFFLIN')]) is product.product object set and not an integer and you are trying to compare this set of objects with an integer on if line.product_id.id in product_id (line.product_id.id is an integer value) ==> This throws the error: TypeError: Mixing apples and oranges

  3. Bellow is the fix of your code:

@api.constrains ('order_line')
def _check_exist_product_in_line(self):
product_ids = self.env['product.product'].search([('default_code', '=', 'MIFFLIN')])
for rec in self:
for line in rec.order_line:
if line.product_id in product_ids:
raise ValidationError(_('Product already added.'))
product_id.append(line.product_id.id)
    return True

Let me explain a little bit what's your code is for:

  1. Get all the products that has 'MIFFLIN' as a default code.

  2. You loop on the Sale order lines

  3. If the line's product is one of the products searched on step 1 then raise an error.

  4. So your code will always raise an error if 'MIFFLIN' product is present on sale order lines even that is not duplicated (exist only once).

Honestly, i don't believe your code will help you to achieve your explained goal, If you feel the same, please to use the bellow code:

@api.constrains ('order_line')
def _check_exist_product_in_line(self):
for order in self:
products_in_lines = order.mapped('order_line.product_id')
for product in products_in_lines:
lines_count = len(order.order_line.filtered(lambda line: line.product_id == product))
if lines_count > 1:
raise ValidationError(_('Product already added.'))
return True

Hope this will help,

Good luck.

0
Avatar
Descartar
Madara
Autor

when i try to add the product , it showing as error product_id is not defined

Cybat

product_ids = []
for line in self.order_line:
product_ids.append (line.product_id.id)
occurrences = product_ids.count (self.product_id.id)
if occurrences> 2:
raise ValidationError ('You cannot select already added product.' )

Cybat

Onchange product_id

¿Le interesa esta conversación? ¡Participe en ella!

Cree una cuenta para poder utilizar funciones exclusivas e interactuar con la comunidad.

Inscribirse
Publicaciones relacionadas Respuestas Vistas Actividad
Can I use select ="multi" with selection field in search panel tag in sale order tree view?
odoo odoo12 Odoo13.0
Avatar
Avatar
1
jun 23
6557
Odoo Installation Script Resuelto
odoo odoo12 Odoo13.0 v14
Avatar
Avatar
Avatar
Avatar
4
dic 24
21587
how to particular Sales Order delivery note states using for loop
python odoo odoo12 Odoo13.0
Avatar
0
oct 21
4231
Odoo error to 13 from 12
migration odoo odoo12 Odoo13.0
Avatar
2
ene 20
4481
psycopg2.ProgrammingError: no existe la relación «_unknown» Please HELP!!!!
odoo odoo12
Avatar
Avatar
2
nov 25
2376
Comunidad
  • Tutoriales
  • Documentación
  • Foro
Código abierto
  • Descargar
  • GitHub
  • Runbot
  • Traducciones
Servicios
  • Alojamiento Odoo.sh
  • Ayuda
  • Actualizar
  • Desarrollos personalizados
  • Educación
  • Encontrar un asesor fiscal
  • Encontrar un partner
  • Convertirse en partner
Sobre nosotros
  • Nuestra empresa
  • Activos de marca
  • Contacta con nosotros
  • Puestos de trabajo
  • Eventos
  • Podcast
  • Blog
  • Clientes
  • Información legal • Privacidad
  • Seguridad
الْعَرَبيّة 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 es un conjunto de aplicaciones empresariales de código abierto que cubre todas las necesidades de tu empresa: CRM, comercio electrónico, contabilidad, inventario, punto de venta, gestión de proyectos, etc.

La propuesta única de valor de Odoo es ser muy fácil de usar y estar totalmente integrado.

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