Generate Barcodes (Abstract)

by , , ,
Odoo          
v 12.0 Third Party 1003
Download for 12.0 series Deploy on Odoo.sh
You bought this module and need support ? Click here !
Technical name barcodes_generator_abstract
LicenseAGPL-3
Websitehttps://www.odoo-community.org
Read description for v 10.0 v 9.0
License: AGPL-3

Generate Barcodes for any Models (Abstract)

This module expends Odoo functionality, allowing user to generate barcode depending on a given barcode rule for any Model.

For example, a typical pattern for products is "20.....{NNNDD}" that means that: * the EAN13 code will begin by '20' * followed by 5 digits (named Barcode Base in this module) * and after 5 others digits to define the variable price * a 13 digit control

With this module, it is possible to:

  • Affect a pattern (barcode.rule) to a model

  • Define a Barcode base:
    • manually, if the base of the barcode must be set by a user. (typically an internal code defined in your company)
    • automaticaly by a sequence, if you want to let Odoo to increment a sequence. (typical case of a customer number incrementation)
  • Generate a barcode, based on the defined pattern and the barcode base

Installation

This module use an extra python library named 'python-barcode' you should install to make barcode generation works properly.

sudo pip install python-barcode

Configuration

To configure this module, you need to:

  • Go to Settings / Technical / Sequences & Identifiers / Barcode Nomenclatures
  • Select a Nomenclature
  • Create or select a rule
/barcodes_generator_abstract/static/description/barcode_rule_tree.png
  • For manual generation, set:
    • 'Base set Manually' in 'Generate Type'
    • Set the model
/barcodes_generator_abstract/static/description/barcode_rule_form_manual.png
  • For automatic generation, set:
    • 'Base managed by Sequence' in 'Generate Type'
    • Set the model
    • Generate a new sequence by button, or affect a existing one
/barcodes_generator_abstract/static/description/barcode_rule_form_sequence.png

In all cases, padding will be computed automaticaly, based on the number of '.' in the Barcode Pattern field.

Usage

This module is an abstract module. You can configure Barcode Rule, but to enable this feature, you need to install an extra module for a given model. This repository provide 'barcodes_generator_product' and 'barcodes_generator_partner' module to generate barcode for product or partner model.

Alternatively, you can develop a custom module for a custom model. See 'Inheritance' parts.

Try this module on Runbot

Try me on Runbot

Inheritance

If you want to generate barcode for another model, you can create a custom module that inherits on 'barcodes_generator_abstract' and inherit your model like that:

class MyModel(models.Model):
_name = 'my.model' _inherit = ['my.model', 'barcode.generate.mixin']
class barcode_rule(models.Model):

_inherit = 'barcode.rule'

generate_model = fields.Selection(selection_add=[('my.model', 'My Model')])

Finally, you should inherit your model view adding buttons and fields.

Note

Your model should have a field 'barcode' defined.

Known issues / Roadmap

  • On barcode.rule model, constraint and domain system could be set between 'type' and 'generate_model' fields.
  • Cache is being cleared in a constraint in barcode.rule. Mutating in a constraint is bad practice & should be moved somewhere.

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us smashing it by providing a detailed and welcomed feedback.

Credits

Images

Contributors

Maintainer

Odoo Community Association

This module is maintained by the OCA.

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

To contribute to this module, please visit https://odoo-community.org.

Please log in to comment on this module

  • The author can leave a single reply to each comment.
  • This section is meant to ask simple questions or leave a rating. Every report of a problem experienced while using the module should be addressed to the author directly (refer to the following point).
  • If you want to start a discussion with the author, please use the developer contact information. They can usually be found in the description.
Please choose a rating from 1 to 5 for this module.