Generate barcodes (Order)
Event action – Abstract
Purpose: Fills barcode attributes of line items of an order object with values from a number range. Optionally, the number of barcode attributes within a line item is synchronized with the "Number of packages" of the same line item by adding or removing barcode attributes, if necessary.
See also: Generate barcodes, Generate barcodes (Shipment)
 
    
The Generate barcodes (Order) event action generates barcodes via a specific Number range type (see Number range) in order to assign these 'empty' instances of barcode attributes to relevant line items of a reference object of the Orders type as 'barcode' (barcode).
Relevant line items can alternatively be defined using one of the following methods:
- The Line items parameter allows an explicit definition of the relevant line items via a Resolvers that provides a list of Line items (e.g. Direct line items and/or Rule list resolver). 
- The Line item types parameter defines one or more Line item types by multiple selection (see Line item type). All line items that belong to a selected Line item type are considered to be relevant. 
- If no information is available for any of these parameters, all line items with the Line item type 'Default' (DEFAULT) are considered relevant. 
All relevant line items are processed according to the following schema:
- If the Sync barcodes with number of packages option is selected in the Generate barcodes (Order), the number of barcode attribute instances within the line item is matched to the 'number of packages' (numberOfPackages): - If the line item currently contains more barcode attribute instances than the Number of packages field specifies, then 'excess' instances of the barcode attribute are removed from the end of the list. It does not matter if they are already assigned barcodes. 
- If the item currently contains fewer barcode attribute instances than the Number of packages field indicates, then additional instances of the barcode attribute are added to the list at the end. 
 
- All barcode attributes contained in the item whose 'Barcode' (barcode) field is empty are assigned an automatically generated value depending on the specified Number range type. 
►NOTE◄ Which of the Number range configured for the selected Number range type are used to generate barcode values depends on the evaluation of their Association criteria according to the best-matching principle.
►IMPORTANT◄ If no number range is assigned for the Number range type for the call context or the assigned number range does not provide any more values, some or all 'Barcode' fields will not be populated. If this results in barcode duplicates for the same line item, the reference object cannot be saved in this state (see 'Barcode attributes background', above).
►NOTE◄ For background information on barcodes and an illustrative runtime example, see the page for the Common business object:
Configuration
The Generate barcodes (Order) event action expects a shipment (see Orders) as the reference object. In the context of another object type, the event action has no effect without an error occurring at runtime.
| The selection for the Number range type parameter (required field) controls which Number range are candidates for generating barcode values. The selection is made by association according to the best-matching principle (see Association criteria). The Sync barcodes with number of packages option can be selected to ensure that the number of barcode attribute instances exactly matches the 'number of packages' (numberOfPackages) of the line item for all relevant line items. Based on the given 'Number of packages' line items, 'surplus' barcode attribute instances are removed or 'missing' ones are added as required for this purpose and automatically assigned a barcode value from the applicable number range. The Sync barcodes with number of packages option is deselected by default. Then the 'Barcode' field – if empty – is only filled for barcode attribute instances that already exist in the volatile data of the reference object. | 
 | 
| The Line items parameter can be used to explicitly define, via a Resolvers, relevant line items whose barcode attributes are processed by the event action. 
 | 
 | 
| Alternatively, the Line item types parameter can be used to define relevant line items whose barcode attributes are to be processed by the event action in a blanket manner via their Line item type. 
 ►NOTE◄ Only if there is neither a configuration under Line items nor a selection under Line item types, all line items with the Line item type 'Default' (DEFAULT) are considered as relevant. | 
 | 
 
     
