com.tectonica.jonix.onix2.Header Maven / Gradle / Ivy
Show all versions of jonix-onix2 Show documentation
/*
* Copyright (C) 2012-2024 Zach Melamed
*
* Latest version available online at https://github.com/zach-m/jonix
* Contact me at [email protected]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.tectonica.jonix.onix2;
import com.tectonica.jonix.common.JPU;
import com.tectonica.jonix.common.ListOfOnixDataCompositeWithKey;
import com.tectonica.jonix.common.OnixHeader;
import com.tectonica.jonix.common.OnixVersion;
import com.tectonica.jonix.common.codelist.Languages;
import com.tectonica.jonix.common.codelist.NameIdentifierTypes;
import com.tectonica.jonix.common.codelist.RecordSourceTypes;
import com.tectonica.jonix.common.codelist.TextCaseFlags;
import com.tectonica.jonix.common.codelist.TextFormats;
import com.tectonica.jonix.common.codelist.TransliterationSchemes;
import com.tectonica.jonix.common.struct.JonixAddresseeIdentifier;
import com.tectonica.jonix.common.struct.JonixSenderIdentifier;
import java.io.Serializable;
import java.util.function.Consumer;
/*
* NOTE: THIS IS AN AUTO-GENERATED FILE, DO NOT EDIT MANUALLY
*/
/**
* Header composite
*
* A group of data elements which together constitute a message header. The elements may alternatively be sent without
* being grouped into a composite, but the composite approach is recommended since it makes it easier to maintain a
* standard header “package” to drop into any new ONIX Product Information Message. Note that the Sender and
* Addressee Identifier composites can only be used within the Header composite, and future extensions to the Header
* will be defined only within the composite.
*
*
*
* Reference name
* <Header>
*
*
* Short tag
* <header>
*
*
*
* This tag may be included in the following composites:
*
* - <{@link ONIXMessage}>
*
* Possible placements within ONIX message:
*
* - {@link Header}
*
*/
public class Header implements OnixHeader, Serializable {
private static final long serialVersionUID = 1L;
public static final String refname = "Header";
public static final String shortname = "header";
/////////////////////////////////////////////////////////////////////////////////
// ATTRIBUTES
/////////////////////////////////////////////////////////////////////////////////
private final OnixVersion onixVersion;
private final String onixRelease;
public TextFormats textformat;
public TextCaseFlags textcase;
public Languages language;
public TransliterationSchemes transliteration;
/**
* (type: DateOrDateTime)
*/
public String datestamp;
public RecordSourceTypes sourcetype;
public String sourcename;
/////////////////////////////////////////////////////////////////////////////////
// CONSTRUCTION
/////////////////////////////////////////////////////////////////////////////////
private boolean initialized;
private final boolean exists;
private final org.w3c.dom.Element element;
/**
* This constructor is for backward compatibility. For future proofing, it's recommended to use the other
* constructor, passing onixRelease label.
*/
public Header(org.w3c.dom.Element element) {
this(element, null);
}
public Header(org.w3c.dom.Element element, String onixRelease) {
exists = true;
initialized = false;
this.element = element;
this.onixVersion = OnixVersion.ONIX2;
this.onixRelease = onixRelease;
textformat = TextFormats.byCode(JPU.getAttribute(element, "textformat"));
textcase = TextCaseFlags.byCode(JPU.getAttribute(element, "textcase"));
language = Languages.byCode(JPU.getAttribute(element, "language"));
transliteration = TransliterationSchemes.byCode(JPU.getAttribute(element, "transliteration"));
datestamp = JPU.getAttribute(element, "datestamp");
sourcetype = RecordSourceTypes.byCode(JPU.getAttribute(element, "sourcetype"));
sourcename = JPU.getAttribute(element, "sourcename");
}
@Override
public OnixVersion onixVersion() {
return onixVersion;
}
@Override
public String onixRelease() {
return onixRelease;
}
@Override
public void _initialize() {
if (initialized) {
return;
}
initialized = true;
JPU.forElementsOf(element, e -> {
final String name = e.getNodeName();
switch (name) {
case FromEANNumber.refname:
case FromEANNumber.shortname:
fromEANNumber = new FromEANNumber(e);
break;
case SentDate.refname:
case SentDate.shortname:
sentDate = new SentDate(e);
break;
case FromSAN.refname:
case FromSAN.shortname:
fromSAN = new FromSAN(e);
break;
case FromCompany.refname:
case FromCompany.shortname:
fromCompany = new FromCompany(e);
break;
case FromPerson.refname:
case FromPerson.shortname:
fromPerson = new FromPerson(e);
break;
case FromEmail.refname:
case FromEmail.shortname:
fromEmail = new FromEmail(e);
break;
case ToEANNumber.refname:
case ToEANNumber.shortname:
toEANNumber = new ToEANNumber(e);
break;
case ToSAN.refname:
case ToSAN.shortname:
toSAN = new ToSAN(e);
break;
case ToCompany.refname:
case ToCompany.shortname:
toCompany = new ToCompany(e);
break;
case ToPerson.refname:
case ToPerson.shortname:
toPerson = new ToPerson(e);
break;
case MessageNumber.refname:
case MessageNumber.shortname:
messageNumber = new MessageNumber(e);
break;
case MessageRepeat.refname:
case MessageRepeat.shortname:
messageRepeat = new MessageRepeat(e);
break;
case MessageNote.refname:
case MessageNote.shortname:
messageNote = new MessageNote(e);
break;
case DefaultLanguageOfText.refname:
case DefaultLanguageOfText.shortname:
defaultLanguageOfText = new DefaultLanguageOfText(e);
break;
case DefaultPriceTypeCode.refname:
case DefaultPriceTypeCode.shortname:
defaultPriceTypeCode = new DefaultPriceTypeCode(e);
break;
case DefaultCurrencyCode.refname:
case DefaultCurrencyCode.shortname:
defaultCurrencyCode = new DefaultCurrencyCode(e);
break;
case DefaultLinearUnit.refname:
case DefaultLinearUnit.shortname:
defaultLinearUnit = new DefaultLinearUnit(e);
break;
case DefaultWeightUnit.refname:
case DefaultWeightUnit.shortname:
defaultWeightUnit = new DefaultWeightUnit(e);
break;
case DefaultClassOfTrade.refname:
case DefaultClassOfTrade.shortname:
defaultClassOfTrade = new DefaultClassOfTrade(e);
break;
case SenderIdentifier.refname:
case SenderIdentifier.shortname:
senderIdentifiers = JPU.addToList(senderIdentifiers, new SenderIdentifier(e));
break;
case AddresseeIdentifier.refname:
case AddresseeIdentifier.shortname:
addresseeIdentifiers = JPU.addToList(addresseeIdentifiers, new AddresseeIdentifier(e));
break;
default:
break;
}
});
}
/**
* @return whether this tag (<Header> or <header>) is explicitly provided in the ONIX XML
*/
@Override
public boolean exists() {
return exists;
}
public void ifExists(Consumer action) {
if (exists) {
action.accept(this);
}
}
@Override
public org.w3c.dom.Element getXmlElement() {
return element;
}
/////////////////////////////////////////////////////////////////////////////////
// MEMBERS
/////////////////////////////////////////////////////////////////////////////////
private FromEANNumber fromEANNumber = FromEANNumber.EMPTY;
/**
*
* An EAN location number which identifies the sender of an ONIX message. Optional and non-repeating; but either the
* <FromCompany> element or a sender identifier using one or more elements from MH.1 to MH.5 must be included.
*
* JONIX adds: this field is required
*/
public FromEANNumber fromEANNumber() {
_initialize();
return fromEANNumber;
}
private SentDate sentDate = SentDate.EMPTY;
/**
*
* The date on which the message is sent. Optionally, the time may be added, using the 24-hour clock. Mandatory and
* non-repeating.
*
* JONIX adds: this field is required
*/
public SentDate sentDate() {
_initialize();
return sentDate;
}
private FromSAN fromSAN = FromSAN.EMPTY;
/**
*
* A US book trade Standard Address Number which identifies the sender of an ONIX message. Optional and
* non-repeating; but either the <FromCompany> element or a sender identifier using one or more elements from
* MH.1 to MH.5 must be included.
*
* JONIX adds: this field is optional
*/
public FromSAN fromSAN() {
_initialize();
return fromSAN;
}
private FromCompany fromCompany = FromCompany.EMPTY;
/**
*
* The name of the sender organization, which should always be stated in a standard form agreed with the addressee.
* Optional and non-repeating; but either the <FromCompany> element or a sender identifier using one or more
* elements from MH.1 to MH.5 must be included.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public FromCompany fromCompany() {
_initialize();
return fromCompany;
}
private FromPerson fromPerson = FromPerson.EMPTY;
/**
*
* Free text giving the name, department, phone number, etc for a contact person in the sender organization
* who is responsible for the content of the message. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public FromPerson fromPerson() {
_initialize();
return fromPerson;
}
private FromEmail fromEmail = FromEmail.EMPTY;
/**
*
* A text field giving the email address for a contact person in the sender organization who is responsible for the
* content of the message. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public FromEmail fromEmail() {
_initialize();
return fromEmail;
}
private ToEANNumber toEANNumber = ToEANNumber.EMPTY;
/**
*
* An EAN location number which identifies the addressee of an ONIX message. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public ToEANNumber toEANNumber() {
_initialize();
return toEANNumber;
}
private ToSAN toSAN = ToSAN.EMPTY;
/**
*
* A US book trade Standard Address Number which identifies the addressee of an ONIX message. Optional and
* non-repeating.
*
* JONIX adds: this field is optional
*/
public ToSAN toSAN() {
_initialize();
return toSAN;
}
private ToCompany toCompany = ToCompany.EMPTY;
/**
*
* The name of the addressee organization, which should always be stated in a standard form agreed with the
* addressee. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public ToCompany toCompany() {
_initialize();
return toCompany;
}
private ToPerson toPerson = ToPerson.EMPTY;
/**
*
* Free text giving the name, department etc for a contact person in the addressee organization to whom the
* message is to be directed. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public ToPerson toPerson() {
_initialize();
return toPerson;
}
private MessageNumber messageNumber = MessageNumber.EMPTY;
/**
*
* A sequence number of the messages in a series sent between trading partners, to enable the receiver to check
* against gaps and duplicates. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public MessageNumber messageNumber() {
_initialize();
return messageNumber;
}
private MessageRepeat messageRepeat = MessageRepeat.EMPTY;
/**
*
* A number which distinguishes any repeat transmissions of a message. If this element is used, the original is
* numbered 1 and repeats are numbered 2, 3 etc. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public MessageRepeat messageRepeat() {
_initialize();
return messageRepeat;
}
private MessageNote messageNote = MessageNote.EMPTY;
/**
*
* Free text giving additional information about the message. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public MessageNote messageNote() {
_initialize();
return messageNote;
}
private DefaultLanguageOfText defaultLanguageOfText = DefaultLanguageOfText.EMPTY;
/**
*
* An ISO standard code indicating the default language which is assumed for the text of products listed in the
* message, unless explicitly stated otherwise by sending a “language of text” element in the product record. This
* default will be assumed for all product records which do not specify a language in Group PR.11. Optional and
* non-repeating.
*
* JONIX adds: this field is optional
*/
public DefaultLanguageOfText defaultLanguageOfText() {
_initialize();
return defaultLanguageOfText;
}
private DefaultPriceTypeCode defaultPriceTypeCode = DefaultPriceTypeCode.EMPTY;
/**
*
* An ONIX code indicating the default price type which is assumed for prices listed in the message, unless
* explicitly stated otherwise in a <Price> composite in the product record. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public DefaultPriceTypeCode defaultPriceTypeCode() {
_initialize();
return defaultPriceTypeCode;
}
private DefaultCurrencyCode defaultCurrencyCode = DefaultCurrencyCode.EMPTY;
/**
*
* An ISO standard code indicating the currency which is assumed for prices listed in the message, unless explicitly
* stated otherwise in a <Price> composite in the product record. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public DefaultCurrencyCode defaultCurrencyCode() {
_initialize();
return defaultCurrencyCode;
}
private DefaultLinearUnit defaultLinearUnit = DefaultLinearUnit.EMPTY;
/**
*
* A code indicating the default unit which is assumed for linear measurements listed in the message, unless
* otherwise specified in the product record. This element is deprecated. For most implementations, explicit coding of measure units with each occurrence of a measurement is to be
* preferred. Optional and non-repeating.
*
* JONIX adds: this field is optional
*/
public DefaultLinearUnit defaultLinearUnit() {
_initialize();
return defaultLinearUnit;
}
private DefaultWeightUnit defaultWeightUnit = DefaultWeightUnit.EMPTY;
/**
*
* A code indicating the default unit which is assumed for weights listed in the message, unless otherwise specified
* in the product record. This element is deprecated. For most
* implementations, explicit coding of units with each occurrence of a weight is to be preferred. Optional
* and non-repeating.
*
* JONIX adds: this field is optional
*/
public DefaultWeightUnit defaultWeightUnit() {
_initialize();
return defaultWeightUnit;
}
private DefaultClassOfTrade defaultClassOfTrade = DefaultClassOfTrade.EMPTY;
/**
*
* Free text indicating the class of trade which is assumed for prices given in the message, unless explicitly
* stated otherwise specified in <j149>. For example: Institutional, General trade, Wholesale distributor,
* which may be represented by a suitable code or abbreviation agreed between trading partners. otherwise specified
* in the product record. Optional and non-repeating.
*
*
* The text is not limited to ASCII characters.
*
* JONIX adds: this field is optional
*/
public DefaultClassOfTrade defaultClassOfTrade() {
_initialize();
return defaultClassOfTrade;
}
private ListOfOnixDataCompositeWithKey senderIdentifiers = JPU.emptyListOfOnixDataCompositeWithKey(SenderIdentifier.class);
/**
*
* A group of data elements which together define the identifier of the sender within a specified namespace, used
* here to allow different party identifiers to be included without defining additional data elements. In particular
* the composite allows a proprietary identifier to be used by mutual agreement between parties to an exchange. The
* composite is optional and repeatable; but either the <FromCompany> element or a sender identifier using one
* or more elements from MH.1 to MH.5 must be included.
*
* JONIX adds: this list may be empty
*/
public ListOfOnixDataCompositeWithKey
senderIdentifiers() {
_initialize();
return senderIdentifiers;
}
private ListOfOnixDataCompositeWithKey addresseeIdentifiers = JPU.emptyListOfOnixDataCompositeWithKey(AddresseeIdentifier.class);
/**
*
* A group of data elements which together define the identifier of the addressee within a specified namespace, used
* here to allow different party identifiers to be included without defining additional data elements. In particular
* the composite allows a proprietary identifier to be used by mutual agreement between parties to an exchange. The
* composite is optional and repeatable.
*
* JONIX adds: this list may be empty
*/
public ListOfOnixDataCompositeWithKey
addresseeIdentifiers() {
_initialize();
return addresseeIdentifiers;
}
}