@dangl/angular-ava 1.0.0 → 1.0.1-beta0001

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/README.md +181 -181
  2. package/esm2022/lib/angular-ava.module.mjs +1 -1
  3. package/esm2022/lib/ava-tree/tree/components/ava-tree/ava-tree.component.mjs +3 -3
  4. package/esm2022/lib/ava-tree/tree/components/list-structure/list-structure.component.mjs +3 -3
  5. package/esm2022/lib/ava-tree/tree/components/table-structure/table-structure.component.mjs +3 -3
  6. package/esm2022/lib/ava-tree/tree/components/tree-item/tree-item.component.mjs +3 -3
  7. package/esm2022/lib/ava-tree/tree/components/tree-node/tree-node.component.mjs +3 -3
  8. package/esm2022/lib/ava-tree/tree/components/tree-structure/tree-structure.component.mjs +3 -3
  9. package/esm2022/lib/ava-tree/tree/constants/defaultFilters.mjs +1 -1
  10. package/esm2022/lib/ava-tree/tree/constants/defaultTextWords.mjs +1 -1
  11. package/esm2022/lib/ava-tree/tree/constants/defaults.mjs +1 -1
  12. package/esm2022/lib/ava-tree/tree/constants/index.mjs +1 -1
  13. package/esm2022/lib/ava-tree/tree/directives/save-changing-view.directive.mjs +1 -1
  14. package/esm2022/lib/ava-tree/tree/model/ava-models.mjs +1 -1
  15. package/esm2022/lib/ava-tree/tree/model/context-menu-data.model.mjs +1 -1
  16. package/esm2022/lib/ava-tree/tree/model/function-view-line.model.mjs +1 -1
  17. package/esm2022/lib/ava-tree/tree/model/index.mjs +1 -1
  18. package/esm2022/lib/ava-tree/tree/model/selecting.model.mjs +1 -1
  19. package/esm2022/lib/ava-tree/tree/model/tableColumnType.mjs +1 -1
  20. package/esm2022/lib/ava-tree/tree/model/tree-mode.model.mjs +1 -1
  21. package/esm2022/lib/ava-tree/tree/pipes/element-icon-name.pipe.mjs +1 -1
  22. package/esm2022/lib/ava-tree/tree/pipes/element-item-number.pipe.mjs +1 -1
  23. package/esm2022/lib/ava-tree/tree/pipes/element-text.pipe.mjs +1 -1
  24. package/esm2022/lib/ava-tree/tree/pipes/group-child-elements.pipe.mjs +1 -1
  25. package/esm2022/lib/ava-tree/tree/services/expand-parent-group.service.mjs +1 -1
  26. package/esm2022/lib/ava-tree/tree/services/flat-elements.service.mjs +1 -1
  27. package/esm2022/lib/ava-tree/tree/services/keyboard-operation.service.mjs +1 -1
  28. package/esm2022/lib/ava-tree/tree/services/select-element.service.mjs +1 -1
  29. package/esm2022/lib/ava-tree/tree/services/tree-node-selection.service.mjs +1 -1
  30. package/esm2022/lib/version.mjs +6 -6
  31. package/esm2022/public-api.mjs +1 -1
  32. package/fesm2022/dangl-angular-ava.mjs +17 -17
  33. package/fesm2022/dangl-angular-ava.mjs.map +1 -1
  34. package/package.json +1 -1
@@ -196,4 +196,4 @@ export var CommerceInquiryTypeDto;
196
196
  CommerceInquiryTypeDto["Immediate"] = "Immediate";
197
197
  CommerceInquiryTypeDto["Exhibition"] = "Exhibition";
198
198
  })(CommerceInquiryTypeDto || (CommerceInquiryTypeDto = {}));
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ava-models.js","sourceRoot":"","sources":["../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/model/ava-models.ts"],"names":[],"mappings":"AAAA,wBAAwB;AACxB,mBAAmB;AACnB,2HAA2H;AAC3H,oBAAoB;AACpB,wBAAwB;AAExB,oBAAoB;AACpB,oBAAoB;AACpB,uCAAuC;AAEvC,6EAA6E;AAC7E,MAAM,CAAN,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC5B,yCAAiB,CAAA;IACjB,uCAAe,CAAA;IACf,2CAAmB,CAAA;AACvB,CAAC,EAJW,oBAAoB,KAApB,oBAAoB,QAI/B;AA0ID,iDAAiD;AACjD,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IACzB,wCAAmB,CAAA;IACnB,kDAA6B,CAAA;AACjC,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B;AAED,sIAAsI;AACtI,MAAM,CAAN,IAAY,2BAMX;AAND,WAAY,2BAA2B;IACnC,sDAAuB,CAAA;IACvB,8CAAe,CAAA;IACf,oDAAqB,CAAA;IACrB,8CAAe,CAAA;IACf,0CAAW,CAAA;AACf,CAAC,EANW,2BAA2B,KAA3B,2BAA2B,QAMtC;AAED,mFAAmF;AACnF,MAAM,CAAN,IAAY,qBAMX;AAND,WAAY,qBAAqB;IAC7B,4CAAmB,CAAA;IACnB,wCAAe,CAAA;IACf,gDAAuB,CAAA;IACvB,wCAAe,CAAA;IACf,wDAA+B,CAAA;AACnC,CAAC,EANW,qBAAqB,KAArB,qBAAqB,QAMhC;AAED,iNAAiN;AACjN,MAAM,CAAN,IAAY,YAYX;AAZD,WAAY,YAAY;IACpB,2CAA2B,CAAA;IAC3B,mDAAmC,CAAA;IACnC,yDAAyC,CAAA;IACzC,mHAAmG,CAAA;IACnG,iEAAiD,CAAA;IACjD,qCAAqB,CAAA;IACrB,6FAA6E,CAAA;IAC7E,6CAA6B,CAAA;IAC7B,2CAA2B,CAAA;IAC3B,6EAA6D,CAAA;IAC7D,uDAAuC,CAAA;AAC3C,CAAC,EAZW,YAAY,KAAZ,YAAY,QAYvB;AAED,iSAAiS;AACjS,MAAM,CAAN,IAAY,mBAKX;AALD,WAAY,mBAAmB;IAC3B,kDAA2B,CAAA;IAC3B,kEAA2C,CAAA;IAC3C,0DAAmC,CAAA;IACnC,sFAA+D,CAAA;AACnE,CAAC,EALW,mBAAmB,KAAnB,mBAAmB,QAK9B;AA8ID,2XAA2X;AAC3X,MAAM,CAAN,IAAY,gBASX;AATD,WAAY,gBAAgB;IACxB,uCAAmB,CAAA;IACnB,yCAAqB,CAAA;IACrB,qCAAiB,CAAA;IACjB,yCAAqB,CAAA;IACrB,iDAA6B,CAAA;IAC7B,iEAA6C,CAAA;IAC7C,+BAAW,CAAA;IACX,6CAAyB,CAAA;AAC7B,CAAC,EATW,gBAAgB,KAAhB,gBAAgB,QAS3B;AAwND,0CAA0C;AAC1C,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACvB,gCAAa,CAAA;IACb,sCAAmB,CAAA;IACnB,wCAAqB,CAAA;AACzB,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAYD,uGAAuG;AACvG,MAAM,CAAN,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAChC,+CAAmB,CAAA;IACnB,yCAAa,CAAA;IACb,yCAAa,CAAA;IACb,iDAAqB,CAAA;AACzB,CAAC,EALW,wBAAwB,KAAxB,wBAAwB,QAKnC;AA4BD,yIAAyI;AACzI,MAAM,CAAN,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC1B,6CAAuB,CAAA;IACvB,mDAA6B,CAAA;IAC7B,6CAAuB,CAAA;IACvB,yCAAmB,CAAA;AACvB,CAAC,EALW,kBAAkB,KAAlB,kBAAkB,QAK7B;AAuBD,sDAAsD;AACtD,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACvB,sCAAmB,CAAA;IACnB,wCAAqB,CAAA;IACrB,8CAA2B,CAAA;AAC/B,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAED,yDAAyD;AACzD,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,uCAAuB,CAAA;IACvB,6CAA6B,CAAA;AACjC,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AAED,4EAA4E;AAC5E,MAAM,CAAN,IAAY,cAGX;AAHD,WAAY,cAAc;IACtB,qCAAmB,CAAA;IACnB,mDAAiC,CAAA;AACrC,CAAC,EAHW,cAAc,KAAd,cAAc,QAGzB;AAgGD,6HAA6H;AAC7H,MAAM,CAAN,IAAY,mBAIX;AAJD,WAAY,mBAAmB;IAC3B,0CAAmB,CAAA;IACnB,4CAAqB,CAAA;IACrB,kEAA2C,CAAA;AAC/C,CAAC,EAJW,mBAAmB,KAAnB,mBAAmB,QAI9B;AAED,kFAAkF;AAClF,MAAM,CAAN,IAAY,iBAUX;AAVD,WAAY,iBAAiB;IACzB,wCAAmB,CAAA;IACnB,8CAAyB,CAAA;IACzB,oCAAe,CAAA;IACf,wCAAmB,CAAA;IACnB,4CAAuB,CAAA;IACvB,0CAAqB,CAAA;IACrB,4DAAuC,CAAA;IACvC,kEAA6C,CAAA;IAC7C,0CAAqB,CAAA;AACzB,CAAC,EAVW,iBAAiB,KAAjB,iBAAiB,QAU5B;AAED,gOAAgO;AAChO,MAAM,CAAN,IAAY,4BAKX;AALD,WAAY,4BAA4B;IACpC,uDAAuB,CAAA;IACvB,yFAAyD,CAAA;IACzD,6EAA6C,CAAA;IAC7C,2EAA2C,CAAA;AAC/C,CAAC,EALW,4BAA4B,KAA5B,4BAA4B,QAKvC;AAgBD,kDAAkD;AAClD,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACtB,qCAAmB,CAAA;IACnB,+BAAa,CAAA;IACb,yCAAuB,CAAA;IACvB,+BAAa,CAAA;AACjB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,2CAA2C;AAC3C,MAAM,CAAN,IAAY,sBAOX;AAPD,WAAY,sBAAsB;IAC9B,6CAAmB,CAAA;IACnB,6CAAmB,CAAA;IACnB,yCAAe,CAAA;IACf,uCAAa,CAAA;IACb,yCAAe,CAAA;IACf,2CAAiB,CAAA;AACrB,CAAC,EAPW,sBAAsB,KAAtB,sBAAsB,QAOjC;AAmKD,4FAA4F;AAC5F,MAAM,CAAN,IAAY,gBAQX;AARD,WAAY,gBAAgB;IACxB,2CAAuB,CAAA;IACvB,iCAAa,CAAA;IACb,iDAA6B,CAAA;IAC7B,iDAA6B,CAAA;IAC7B,mCAAe,CAAA;IACf,2CAAuB,CAAA;IACvB,mCAAe,CAAA;AACnB,CAAC,EARW,gBAAgB,KAAhB,gBAAgB,QAQ3B;AAED,sEAAsE;AACtE,MAAM,CAAN,IAAY,SAQX;AARD,WAAY,SAAS;IACjB,0BAAa,CAAA;IACb,8BAAiB,CAAA;IACjB,kCAAqB,CAAA;IACrB,gCAAmB,CAAA;IACnB,8BAAiB,CAAA;IACjB,wBAAW,CAAA;IACX,wBAAW,CAAA;AACf,CAAC,EARW,SAAS,KAAT,SAAS,QAQpB;AAsCD,yDAAyD;AACzD,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,oCAAiB,CAAA;IACjB,kCAAe,CAAA;AACnB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AA8BD,oDAAoD;AACpD,MAAM,CAAN,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAC9B,6CAAmB,CAAA;IACnB,6CAAmB,CAAA;IACnB,iDAAuB,CAAA;IACvB,mDAAyB,CAAA;AAC7B,CAAC,EALW,sBAAsB,KAAtB,sBAAsB,QAKjC","sourcesContent":["//----------------------\r\n// <auto-generated>\r\n//     Generated using the NSwag toolchain v14.0.0.0 (NJsonSchema v11.0.0.0 (Newtonsoft.Json v13.0.0.0)) (http://NSwag.org)\r\n// </auto-generated>\r\n//----------------------\r\n\r\n/* tslint:disable */\r\n/* eslint-disable */\r\n// ReSharper disable InconsistentNaming\r\n\r\n/** This enum configures rounding modes for price calculations in projects */\r\nexport enum PriceRoundingModeDto {\r\n    Normal = \"Normal\",\r\n    Floor = \"Floor\",\r\n    Ceiling = \"Ceiling\",\r\n}\r\n\r\n/** General information about a Project. */\r\nexport interface ProjectInformationDto {\r\n    /** Information about the buyer. */\r\n    buyer?: PartyInformationDto | undefined;\r\n    /** Description for the project. */\r\n    description?: string | undefined;\r\n    /** Short description for the project. */\r\n    descriptionShort?: string | undefined;\r\n    /** Name of the project. */\r\n    name?: string | undefined;\r\n    /** Information about the site. */\r\n    site?: PartyInformationDto | undefined;\r\n    /** The ItemNumberSchema used in the project. */\r\n    itemNumberSchema?: ItemNumberSchemaDto | undefined;\r\n    /** Short label for the currency used. */\r\n    currencyShort?: string | undefined;\r\n    /** Full label of the currency used. */\r\n    currencyLong?: string | undefined;\r\n    /** Label for the labour time part of prices used in the project. */\r\n    labourTimeLabel?: string | undefined;\r\n    /** Labels for the price components used in the project. Caution: Removal of a price component will trigger to have dependent price informations be deleted in IElements that use this property. If this property is changed or altered after the project has already been used, it is strongly advised to do operations step by step, e.g. if renaming and reordering multiple price components, this should be done one by one. Otherwise, a combination of rename and reordering will not be correctly propagated downwards to child objects in this Project. */\r\n    priceComponents?: string[] | undefined;\r\n    /** This dictionary specifies actual types used for the PriceComponents. For example, a single price component might have the name 'Material' as a string, ans this dictionary would then have a key 'Material' and a value of Materials. You can not add keys here that are not also present in the PriceComponents property, and removing price components will also remove them from this dictionary here. */\r\n    readonly priceComponentTypes?: { [key: string]: PriceComponentTypeDto; } | undefined;\r\n    /** This bool indicates if this project allows the bidder to add bidder comments. Bidder comments are a way to attach clarifying information when submitting an offer. */\r\n    bidderCommentAllowed?: boolean | undefined;\r\n    /** This property indicates if the project should allow side offers from contractors. In GAEB, a side offer would typically be in exchange phase 85. */\r\n    sideOffersAllowed?: boolean | undefined;\r\n    /** This enumeration describes the type of the award / procurement process. If this is used in a GAEB context, more information about award types can be found in the German VOB/A rules and the GAEB standard */\r\n    awardType?: AwardTypeDto | undefined;\r\n    /** This enumeration describes awards for project that are not just a regular procurement. For example, it can be used to describe recurring maintenance or an outline contract (German: Rahmenvertrag) which just specifies services and prices but may be requested on demand when necessary */\r\n    specialAwardKind?: SpecialAwardKindDto | undefined;\r\n    /** Requesters in a construction project, in German also called 'Bedarfsträger', are parties connected to the building process, e.g. architects or planners. */\r\n    requesters?: PartyInformationDto[] | undefined;\r\n    /** Notification sites are addresses that are used for delivering messages in the context of construction projects. */\r\n    notificationSites?: PartyInformationDto[] | undefined;\r\n}\r\n\r\n/** Represents information about a party (a site or an organization). */\r\nexport interface PartyInformationDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This party's name. */\r\n    name?: string | undefined;\r\n    /** This party's street. */\r\n    street?: string | undefined;\r\n    /** This party's ZipCode. */\r\n    zipCode?: string | undefined;\r\n    /** This party's City. */\r\n    city?: string | undefined;\r\n    /** This party's Country. */\r\n    country?: string | undefined;\r\n    /** This party's Identifier. */\r\n    identifier?: string | undefined;\r\n    /** Remarks for this party. */\r\n    remarks?: string | undefined;\r\n    /** An email address for this party. */\r\n    email?: string | undefined;\r\n    /** A phone number for this party. */\r\n    phone?: string | undefined;\r\n    /** The name of a contact person. */\r\n    contactPersonName?: string | undefined;\r\n    /** This is an identifier related to this PartyInformation and their internal reference of the tender (or award). This might be used to assign an identifier (German \"Vergabenummer\") for the current project. This is typically only used in Buyer and Bidder representations and should map to the concept of \"Vergabenummer\" or \"AwardNo\" in GAEB. */\r\n    awardIdentifier?: string | undefined;\r\n    /** This property indicates if the party is registered within the European Economic Area. */\r\n    isInEuropeanEconomicArea?: boolean | undefined;\r\n    /** If this is within the European Economic Area (see IsInEuropeanEconomicArea, then as a business entity it likely has an EU VAT Id. */\r\n    vatId?: string | undefined;\r\n    /** The fax number for this party. */\r\n    fax?: string | undefined;\r\n    /** The two letter ISO country code, e.g. DE for Germany. */\r\n    countryCode?: string | undefined;\r\n    /** Depending on which party this class represents, it might have either a 'creditor' or 'debtor' number. This is often used in internal accounting systems. */\r\n    creditorOrDebtorIdentifier?: string | undefined;\r\n    /** The Global Location Number (GLN) is issued by GS1 and is intended to be a unique identifier for the physical address of a party, e.g. a business office. */\r\n    globalLocationNumber?: string | undefined;\r\n    /** This list contains information about bank accounts associated with this PartyInformation. It's typically used for buyers and bidders. */\r\n    bankingInformation?: BankingInformationDto[] | undefined;\r\n    /** This can be used to specify a registration number for this party, e.g. a company registration number. It is usually used in GAEB XML commerce exchanges for bidders to supply their WEEE registration number, which is used to identify them as a registered WEEE company. */\r\n    registrationNumber?: string | undefined;\r\n}\r\n\r\n/** This is a class that represents the information about a bank connection. It is usually used within a PartyInformation. */\r\nexport interface BankingInformationDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The name of the bank. */\r\n    name?: string | undefined;\r\n    /** The international identifier for the bank account. */\r\n    iban?: string | undefined;\r\n    /** The account number. Typically no longer used since the introduction of IBAN within the SEPA area. */\r\n    accountNumber?: string | undefined;\r\n    /** The international bank identifier. */\r\n    bic?: string | undefined;\r\n    /** The routing number for the bank. Typically no longer used since the introduction of IBAN within the SEPA area. */\r\n    routingNumber?: string | undefined;\r\n}\r\n\r\n/** The schema for ItemNumber's in a Project. */\r\nexport interface ItemNumberSchemaDto {\r\n    /** The count of tiers in the ItemNumberSchema */\r\n    readonly totalLength?: number | undefined;\r\n    /** The collection of tiers for this ItemNumberSchema. */\r\n    tiers?: ItemNumberSchemaTierDto[] | undefined;\r\n    /** The separator to use for separiting the different levels in an ItemNumber. Defaults to DEFAULT_SEPARATOR, which is a point '.'. Setting this to a space or other whitespaces is discouraged, as this might not work correct in all situations and item numbers could be displayed not as intended. This can not be set to an empty or null string, trying that will default to the DEFAULT_SEPARATOR. If a value is set that has a different length than one '1', the DEFAULT_SEPARATOR will be used instead. You should also not use values for the separator that are also valid for the item numbers themselves, as that might also lead to incorrect results */\r\n    separator?: string | undefined;\r\n    /** This string is used to fill (left-pad) item numbers. For example, if a tier has a length of '4' but the given item number is '12', with a Filler of '0', then the final item number will be represented as '0'. This must be a single character string, if a value is given where the Length property does not evaluate to '1', the DEFAULT_FILLER '0' is used. A space is fine to use. You should ensure that you use a value different than Separator, as that might produce unexpected results. No attempt is done by the code to recover from such ambiguous configurations. */\r\n    filler?: string | undefined;\r\n    /** This is just a string property that can optionally be used to store additional data for this ItemNumberSchema, e.g. an identification or a type. It does not have any influence over how item numbers are generated, and is not supported in most exchange formats. However, it is used to store ÖNorm service specification structure types. */\r\n    identifier?: string | undefined;\r\n    /** This property indicates if ItemNumbers using this ItemNumberSchema should skip empty group levels. This is commonly only used in GAEB files, where there might be gaps in the hierarchy of elements and position identifiers should be placed at the end of the string representation. */\r\n    skipNonExistingLevelsInPositionItemNumbers?: boolean | undefined;\r\n    /** This string is used only when the property SkipNonExistingLevelsInPositionItemNumbers in this ItemNumberSchema is also set to true. It defaults to DEFAULT_SKIPPED_TIERS_FILLER, but can be set to any string with a lenght of one. Null values or values with a longer length will lead to this property reverting back to the default value. This is used to fill skipped tiers in item numbers where a position is placed in a higher hierarchy level than what would be defined in the Tiers. For example, it could produce an item number like '01.__.02', which would indicate a skipped second level. This should be using different values than Filler and Separator, since that could cause ambiguities in the code that generates the actual item numbers. No attempt is done by the code to recover from such ambiguous configurations. */\r\n    skippedTiersFiller?: string | undefined;\r\n    /** This is a read-only property that indicates if this schema has a valid structure. It internally just returns the result from IsCorrectlyDefined. This will return if the ItemNumberSchema is correctly defined. For it to be correctly defined, the following conditions must be true: There may only be one lot group, if there is one, it must be at the top. Following lot levels, there may be at least one group level. After the group levels, there must be one position level. After the position level, there may be one index level. If no tiers are defined at all, this will also return false. */\r\n    readonly schemaIsCorrectlyDefined?: boolean | undefined;\r\n    /** Defaults to false. If this is disabled, all letters in the ItemNumber string representations will be transformed to their lowercase representation. */\r\n    allowUpperCaseLettering?: boolean | undefined;\r\n}\r\n\r\n/** Represents information about a single Tier in an ItemNumber. */\r\nexport interface ItemNumberSchemaTierDto {\r\n    /** The (maximum) length for this tier. Will not accept a length less than 1. Defaults to 1 if length less than one is specified. */\r\n    length?: number | undefined;\r\n    /** This ItemNumberSchemaTier's type. */\r\n    type?: ItemNumberTypeDto | undefined;\r\n    /** This specifies which ItemNumberSchemaTierType this tier represents. This can be, for example, a group tier / level, a position level or a lot level. */\r\n    tierType?: ItemNumberSchemaTierTypeDto | undefined;\r\n    /** Indicates if this tier represents a lot. See the documentation for more information about lots. */\r\n    readonly isLot?: boolean | undefined;\r\n    /** This value is the increment, or step size, that should be used for new item numbers. It defaults to DEFAULT_INCREMENT, but can be changed to any other positive number greater than zero. Invalid values make this be set to one '1' */\r\n    increment?: number | undefined;\r\n    /** This is an optional name for the given tier */\r\n    tierName?: string | undefined;\r\n}\r\n\r\n/** Determines the type of an ItemNumberSchema */\r\nexport enum ItemNumberTypeDto {\r\n    Numeric = \"Numeric\",\r\n    Alphanumeric = \"Alphanumeric\",\r\n}\r\n\r\n/** Specifies the type an ItemNumberSchemaTier represents. For example, a tier may indicate to be used for positions or for groups. */\r\nexport enum ItemNumberSchemaTierTypeDto {\r\n    Undefined = \"Undefined\",\r\n    Index = \"Index\",\r\n    Position = \"Position\",\r\n    Group = \"Group\",\r\n    Lot = \"Lot\",\r\n}\r\n\r\n/** This enumeration models types of price components for better classification. */\r\nexport enum PriceComponentTypeDto {\r\n    Unknown = \"Unknown\",\r\n    Wages = \"Wages\",\r\n    Materials = \"Materials\",\r\n    Plant = \"Plant\",\r\n    Miscellaneous = \"Miscellaneous\",\r\n}\r\n\r\n/** This enumeration describes the type of the award / procurement process. If this is used in a GAEB context, more information about award types can be found in the German VOB/A rules and the GAEB standard */\r\nexport enum AwardTypeDto {\r\n    Unspecified = \"Unspecified\",\r\n    OpenProcurement = \"OpenProcurement\",\r\n    ClosedProducrement = \"ClosedProducrement\",\r\n    NegotiationProcurementWithoutPublicAnnouncement = \"NegotiationProcurementWithoutPublicAnnouncement\",\r\n    NegotiationProcurement = \"NegotiationProcurement\",\r\n    OpenCall = \"OpenCall\",\r\n    SelectedCallWithoutPublicCompetition = \"SelectedCallWithoutPublicCompetition\",\r\n    SelectedCall = \"SelectedCall\",\r\n    DirectAward = \"DirectAward\",\r\n    InternationalNATOProcurement = \"InternationalNATOProcurement\",\r\n    CompetitiveDialog = \"CompetitiveDialog\",\r\n}\r\n\r\n/** This enumeration describes awards for project that are not just a regular procurement. For example, it can be used to describe recurring maintenance or an outline contract (German: Rahmenvertrag) which just specifies services and prices but may be requested on demand when necessary */\r\nexport enum SpecialAwardKindDto {\r\n    Unspecified = \"Unspecified\",\r\n    MaintenanceContract = \"MaintenanceContract\",\r\n    OutlineContract = \"OutlineContract\",\r\n    OutlineForMaintenanceContract = \"OutlineForMaintenanceContract\",\r\n}\r\n\r\n/** This is the base class that holds information about a whole service specification. */\r\nexport interface ServiceSpecificationDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The hourly wage that is used within this ElementContainerBase. Will be propagated to child elements. */\r\n    readonly projectHourlyWage?: number | undefined;\r\n    /** The tax rate that is used within this ElementContainerBase. Will be propagated to child elements. */\r\n    projectTaxRate?: number | undefined;\r\n    /** The price components that are used within this project. They are ignored during Json deserialization because they will be set from the parent project. */\r\n    projectPriceComponents?: string[] | undefined;\r\n    /** The ItemNumberSchema that is used within this project. */\r\n    projectItemNumberSchema?: ItemNumberSchemaDto | undefined;\r\n    /** The IElements within this ElementContainerBase. */\r\n    elements?: IElementDto[] | undefined;\r\n    /** The label used in the parent Project to mark labour time, e.g. \"Hours\" or \"Stunden\". */\r\n    readonly projectLabourTimeLabel?: string | undefined;\r\n    /** Indicates if there are child IElements that have conflicting, duplicated ItemNumbers or if any child ElementContainerBase elements themselves contain duplicate ItemNumber s. Will always indicate false when told to ignore duplicate item numbers. */\r\n    readonly containsDuplicateItemNumbers?: boolean | undefined;\r\n    /** Indicates if there are child IElements that have conflicting, duplicated Ids or if any child ElementContainerBase elements themselves contain duplicate Id s. Will always indicate false when told to ignore duplicate item numbers. */\r\n    readonly containsDuplicateElementIds?: boolean | undefined;\r\n    /** Indicate if duplicated ItemNumbers within child elements are to be ignored. Will not perform checks for duplicates if yes. */\r\n    ignoreDuplicateItemNumbers?: boolean | undefined;\r\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties */\r\n    ignoreProjectCataloguePropagation?: boolean | undefined;\r\n    /** Indicate if duplicated Ids within child elements are to be ignored. Will not perform checks for duplicates if yes. */\r\n    ignoreDuplicateElementIds?: boolean | undefined;\r\n    /** Price composition by tax rate. */\r\n    totalPriceGrossByTaxRate?: GrossPriceComponentDto[] | undefined;\r\n    /** Internally used to indicate that a propagation is currently done, this is done to not recalculate every single result from a lot of changes when it is sufficient to calculate the total price at once. */\r\n    ignoreChildPriceUpdates?: boolean | undefined;\r\n    /** Net price after applied deductions. */\r\n    readonly deductedPrice?: number | undefined;\r\n    /** Factor of applied deductions to the total price. For example, \"0.03\" means that a 3% deduction is to be applied. */\r\n    deductionFactor?: number | undefined;\r\n    /** The exact amount of the discount as an absolute value. For backwards compatibility reasons, setting this value will also set a calculated value to DeductionFactor, which will also be updated in case the total price is changed to reflect a relative value of the absolute discount sum. */\r\n    absoluteDeduction?: number | undefined;\r\n    /** Will return this ElementContainerBase's total price. */\r\n    readonly totalPrice?: number | undefined;\r\n    /** The total gross price for this ElementContainerBase including all child elements. */\r\n    readonly totalPriceGross?: number | undefined;\r\n    /** Total gross price after applied deductions. */\r\n    readonly totalPriceGrossDeducted?: number | undefined;\r\n    /** Indicates the PriceType of this ElementContainerBase, whether it should factor into total costs or not. */\r\n    priceType?: PriceTypeDto | undefined;\r\n    /** Information about the bidder. */\r\n    bidder?: PartyInformationDto | undefined;\r\n    /** This discriminator is used to identify different bidders in a project. It is different from the Identifier property in the Bidder in that the BidderDiscriminator is intended to be a numerical identifier within a project, while the Identifier does uniquely identify a bidder in the system independent of a specific project. This property should map to \"Bieternummer\" or \"BidderNo\" in GAEB. */\r\n    bidderDiscriminator?: string | undefined;\r\n    /** This is used to store the GAEB XML Id within this ServiceSpecification. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\r\n    gaebXmlId?: string | undefined;\r\n    /** The ProjectInformation used within the Project in which this ElementContainerBase is contained. This is reference equal to the ProjectInformation used in the parent project. */\r\n    readonly projectInformation?: ProjectInformationDto | undefined;\r\n    /** This service specifications exchange phase, i.e. the current status in the project it is intended to be used (such as request for offer, offer, awarding...). */\r\n    exchangePhase?: ExchangePhaseDto | undefined;\r\n    /** This indicates where the service specification originates, i.e. from an exchange file format or self created. If applicable, additional information is present in the OriginDetail property. */\r\n    origin?: OriginDto | undefined;\r\n    /** This property complements the Origin property. Some formats, e.g. GaebXml might have additional information attached, e.g. GAEB XML V3.2 oder GAEB XML V3.1. This string property is used to hold such data. The Dangl.AVA module does not have a list of possible values, since this is defined in the native format assemblies, e.g. Dangl.GAEB or Dangl.Oenorm. */\r\n    originDetail?: string | undefined;\r\n    /** Creation date of this ServiceSpecification. */\r\n    creationDate?: Date | undefined;\r\n    /** Date indicating until when an offer has to be submitted. In German, this is often called the \"Eröffnungstermin\" */\r\n    offerByDate?: Date | undefined;\r\n    /** Date indicating by when the buyer will select a contractor. */\r\n    decisionDate?: Date | undefined;\r\n    /** Date of when the offer / bid was created */\r\n    bidDate?: Date | undefined;\r\n    /** If a construction project requires a warranty bond, this property indicates the amount as a percentage, e.g. '0.15m' means 15% of the construction total amount as a warranty bond. */\r\n    warrantyBondPercentage?: number | undefined;\r\n    /** If a construction project requires an execution guarantty, this property indicates the amount as a percentage, e.g. '0.15m' means 15% of the construction total amount as an execution guarantee. In practice, this percentage is usually deducted from intermediate invoices and only billed in the final invoice. */\r\n    executionGuaranteePercentage?: number | undefined;\r\n    /** String indicating where the physical submission of the offer is taking place. */\r\n    submissionLocation?: string | undefined;\r\n    /** Description of this ServiceSpecification. */\r\n    description?: string | undefined;\r\n    /** The name of this ServiceSpecification. */\r\n    name?: string | undefined;\r\n    /** This PriceInformation contains global data for the ServiceSpecification. When inside a Project, do not set this property manually. */\r\n    priceInformation?: PriceInformationDto | undefined;\r\n    /** These are Catalogue that are used within this ElementContainerBase. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    /** Referenced catalogues for this ElementContainerBase. */\r\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\r\n    /** The date when the execution of the services is scheduled to start */\r\n    plannedExecutionStart?: Date | undefined;\r\n    /** The date then the execution of the services is scheduled to be finished */\r\n    plannedExecutionEnd?: Date | undefined;\r\n    /** The date on which the contract has been awarded. This matches \"Auftragsdatum\" in GAEB */\r\n    contractDate?: Date | undefined;\r\n    /** This value can be used to indicate the number or identifier of the contract. It matches \"Auftragsnummer\" in GAEB */\r\n    contractIdentifier?: string | undefined;\r\n    /** This indicates how long the warranty period is for this ServiceSpecification */\r\n    warrantyDuration?: WarrantyDurationDto | undefined;\r\n    /** The date on which the warranty period ends */\r\n    warrantyEnd?: Date | undefined;\r\n    /** The date on which the services rendered by the bidder are scheduled to be approved by the buyer */\r\n    approvalDate?: Date | undefined;\r\n    /** This should specify how the approval is performed by the buyer. This matches \"AcceptType\" in GAEB */\r\n    typeOfApproval?: string | undefined;\r\n    /** This optional string property is shared by all IElements, and indicates if the element is part of an addendum, a 'Nachtrag' in German. */\r\n    addendumNumber?: string | undefined;\r\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\r\n    addendumStatus?: AddendumStatusDto | undefined;\r\n    /** This property holds additional information that's only valid in commerce exchange phases. */\r\n    commerceProperties?: ServiceSpecificationCommercePropertiesDto | undefined;\r\n    /** This is internally used during mapping operations to temporarily hold information about removed ItemNumberSchemas. Those schemas are set to null during the mapping process to ensure that schemas in elements higher up in the hierarchy are correctly passed down to child elements. */\r\n    itemNumberSchemaMappingOperation?: ItemNumberSchemaMappingOperation | undefined;\r\n    /** This is internally used during mapping operations to temporarily hold information about complementing positions */\r\n    complementingPositionData?: ComplementingPositionData | undefined;\r\n}\r\n\r\n/** Base interface definition for elements within an ElementContainerBase. */\r\nexport interface IElementDto {\r\n    elementType?: string | undefined;\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This is used to store the GAEB XML Id within this IElement. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\r\n    gaebXmlId?: string | undefined;\r\n    /** This optional string property is shared by all IElements, and indicates if the element is part of an addendum, a 'Nachtrag' in German. */\r\n    addendumNumber?: string | undefined;\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\r\n    elementTypeDiscriminator: string;\r\n}\r\n\r\n/** This class describes an external catalogue. Catalogues, or collections, hold information to categorize and describe items. For example, the German DIN 276 cost group standards describe different types of costs for building projects. When referencing the DIN 276 catalogue and providing an item key or identifier, it is possible to reference data in this catalogue. */\r\nexport interface CatalogueDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This is used to store the GAEB XML Id within this Catalogue. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\r\n    gaebXmlId?: string | undefined;\r\n    /** The name that is given for this catalogue. */\r\n    name?: string | undefined;\r\n    /** Additional information about this catalogue. */\r\n    description?: string | undefined;\r\n    /** If given, this gives a classification for the contents of the catalogue */\r\n    catalogueType?: CatalogueTypeDto | undefined;\r\n    /** This property may hold additional information about the catalogue type. It is currently only used in GAEB XML exchange to carry detailed information about a catalogue type, but it's otherwise just a free text field. */\r\n    catalogueTypeDetail?: string | undefined;\r\n}\r\n\r\n/** This enumeration describes the type of a catalogue. Catalogues, or collections, hold information to categorize and describe items. For example, the German DIN 276 cost group standards describe different types of costs for building projects. When referencing the DIN 276 catalogue and providing an item key or identifier, it is possible to reference data in this catalogue. */\r\nexport enum CatalogueTypeDto {\r\n    Unknown = \"Unknown\",\r\n    Location = \"Location\",\r\n    DIN276 = \"DIN276\",\r\n    CostUnit = \"CostUnit\",\r\n    WorkCategory = \"WorkCategory\",\r\n    OenormB1801CostGroup = \"OenormB1801CostGroup\",\r\n    BIM = \"BIM\",\r\n    Attachment = \"Attachment\",\r\n}\r\n\r\n/** This class is used to link data between catalogues and objects. */\r\nexport interface CatalogueReferenceDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This points to the item in the catalogue itself. This means that, for example when this quantity assignment references a \"DIN 276\" catalogue, this property indicates the number / identifier / key in DIN 276 that is referenced. */\r\n    catalogueReferenceKey?: string | undefined;\r\n    /** The Id of the CatalogueReference that is targeted by this item. Set this property to set the referenced catalogue. */\r\n    catalogueReferenceId?: string | undefined;\r\n    /** These are CatalogueReference that are used within this ServiceSpecification. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    /** This returns the referenced catalogue. Will return null if there is no reference or the catalogue is not present in the ProjectCatalogues. */\r\n    readonly catalogue?: CatalogueDto | undefined;\r\n}\r\n\r\n/** A Position is the main item type in a ServiceSpecification, holding information about tasks to be done, their prices, description, amounts etc. */\r\nexport interface PositionDto extends IElementDto {\r\n    /** Will return the price per unit, rounded according to the project settings or the default value of three decimal places */\r\n    readonly unitPrice?: number | undefined;\r\n    /** You can use this property to directly set the unit price for this position. This will override any given PriceComponents */\r\n    unitPriceOverride?: number | undefined;\r\n    /** Will return this Position's total quantity, rounded to three decimal places. */\r\n    readonly quantity?: number | undefined;\r\n    /** You can use this property to directly set the quantity for this position. This will override any given QuantityComponents */\r\n    quantityOverride?: number | undefined;\r\n    /** This indicates true if this specific position is specified as a complementing position for any base position. */\r\n    isComplementingPosition?: boolean | undefined;\r\n    /** If IsComplementingPosition is set to true, this will indicate which base positions are targeted by this complementing position. */\r\n    complementsPositions?: string[] | undefined;\r\n    /** You can use this property to directly specify the total price of this position as a percentage of the sum of the total prices of base positions that this position complements. It will essentially set the total price for this position to the sum of all total prices of the positions specified in ComplementsPositions multiplied by the percentage here. If present, this has precedence over UnitPriceOverride as well as QuantityOverride. */\r\n    complementingPricePercentageOverride?: number | undefined;\r\n    /** This is a read only property showing the total price of this positions as a percentage of the sum of the total prices of all base positions, in case this position is a complementing positions. If this position is not a complementing position, this will be null. Also, if no prices are present, this will also be null. */\r\n    complementingPricePercentage?: number | undefined;\r\n    /** The tag of the unit used for this positions quantity. */\r\n    unitTag?: string | undefined;\r\n    /** The components for labour time in this Position. */\r\n    labourComponents?: LabourPriceComponentDto | undefined;\r\n    /** The single price components in this Position. Price components should not be handled directly on a per-position basis but set globally in the parent Projects ProjectInformation. */\r\n    priceComponents?: PriceComponentDto[] | undefined;\r\n    /** The quantity components of this Position. */\r\n    quantityComponents?: CalculationDto[] | undefined;\r\n    /** Further structuring of this Position. */\r\n    subDescriptions?: SubDescriptionDto[] | undefined;\r\n    /** Indicates the status of this Position's comission. */\r\n    comissionStatus?: ComissionStatusDto | undefined;\r\n    /** A list of positions that complement this Position. The positions are referenced by their GUIDs. It might be used together with ComplementedByQuantities in case that only a given quantity is complemented by positions. */\r\n    complementedBy?: string[] | undefined;\r\n    /** Will indicate if this Position is complemented in this ServiceSpecification by other Positions. It can not be set to false when there are entries in the ComplementedBy property. */\r\n    complemented?: boolean | undefined;\r\n    /** Indicates that the amount for this Position is to be set by the bidder. */\r\n    amountToBeEnteredByBidder?: boolean | undefined;\r\n    /** Indicates if the bidder demands for prices to be broken up into their price components. */\r\n    priceCompositionRequired?: boolean | undefined;\r\n    /** Indicates if this Position should use a different TaxRate than what is the default for the Project. */\r\n    useDifferentTaxRate?: boolean | undefined;\r\n    /** Will return either the parent ServiceSpecification's TaxRate or it's own if it has a different value. (For example, in Germany Water has a different TaxRate than regular Positions) */\r\n    taxRate?: number | undefined;\r\n    /** The ItemNumber for this Position. */\r\n    itemNumber?: ItemNumberDto | undefined;\r\n    /** The rate of deductions, i.e. 0.12m means 12% price deduction. */\r\n    deductionFactor?: number | undefined;\r\n    /** Returns the product of UnitPrice times Quantity. */\r\n    readonly totalPrice?: number | undefined;\r\n    /** The total gross price for this Position. */\r\n    readonly totalPriceGross?: number | undefined;\r\n    /** Total gross price after applied deductions. */\r\n    readonly totalPriceGrossDeducted?: number | undefined;\r\n    /** Net price after applied deductions. Please be aware that this is the total price, from TotalPrice, not the unit price of the position. */\r\n    readonly deductedPrice?: number | undefined;\r\n    /** This indicates the type of a position. If this is an alternative position, its AlternativeTo property should be set to the id of the position it can replace. */\r\n    positionType?: PositionTypeDto | undefined;\r\n    /** Indicates the PriceType of this Position. */\r\n    priceType?: PriceTypeDto | undefined;\r\n    /** This indicates if this position is regular or describing a labour / hourly paid work service */\r\n    serviceType?: ServiceTypeDto | undefined;\r\n    /** This property describes additional information about a product being used within this Position. For example, a pipe position, per length unit, could be composed of different pipe segments, fitting and other accessory articles. */\r\n    productData?: ProductDataDto | undefined;\r\n    /** Short description for this DescriptionBase element. */\r\n    shortText?: string | undefined;\r\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\r\n    longText?: string | undefined;\r\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\r\n    htmlLongText?: string | undefined;\r\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\r\n    additionType?: AdditionTypeDto | undefined;\r\n    elementType?: string | undefined;\r\n    /** Quantity assignments are, in contrast to SubDescriptions, used to categorize parts of this Position. For example, it could be categorized by cost group - e.g. a Position describing concrete walls could follow the German DIN 276 Cost Groups Standard and specify that of the total 1.000m² wall, 500m² are classified as exterior walls and 500m² are classified as interior walls. They would then have different cost groups associated, e.g. for accounting purposes. */\r\n    quantityAssignments?: QuantityAssignmentDto[] | undefined;\r\n    /** The CommerceProperties support specialized information that is only useful in GAEB XML 9x data exchange phases. It is intended to provide article information. */\r\n    commerceProperties?: CommercePropertiesDto | undefined;\r\n    /** If this position is an Alternative, then this property should point to the id of the position in this service specification that it can replace. If this is set to a value, you can optionally also specify an identifier via AlternativeIdentifier to specifiy multiple positions that must be used together to be an alternative to a single base position. */\r\n    alternativeTo?: string | undefined;\r\n    /** This is an optional property that can be used together with AlternativeTo. If this is set, you can indicate which alternative group a specific position is assigned to. That way, if you specifiy multiple alternative Positions with the same AlternativeIdentifier, you can indicate that to replace a single base Position, multiple alternative Positions should be used. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base position via AlternativeTo. */\r\n    alternativeIdentifier?: number | undefined;\r\n    /** This is an optional property that can be used together with AlternativeTo and AlternativeGroupIdentifier. If this is set, you can indicate which alternative group a specific position is assigned to. That way, you can specify the id (in integer format) for the alternative group this position belongs to. It's different to AlternativeIdentifier in that the other property describes the id of the group, while this property here describes the group itself. If a position only has set AlternativeGroupIdentifier but not AlternativeIdentifier, then it likely is a base position for a specific group. This was introduced in version v2.9.0 to be able to model both position and group ids for alternative group combinations. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base position via AlternativeTo. */\r\n    alternativeGroupIdentifier?: number | undefined;\r\n    /** If this is true, it indicates that the position is intended to be a lump sum, \"Pauschal\" in German. This means the position total price that is being invoiced should not depend on the actual quantity. In practice, partial invoices are still often used for partial services rendered. This property does not affect the price calculation for this position. Typically, the Quantity should be set to 1.0 when this flag is used. */\r\n    isLumpSum?: boolean | undefined;\r\n    /** This identifier can be used to point to the Id of a position in the same ServiceSpecification that acts as a base position. It matches \"Bezugsposition\" in GAEB. This can be used for positions that repeat partially or are linked together */\r\n    repetitionTo?: string | undefined;\r\n    v1CompatibilityPriceType?: string | undefined;\r\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\r\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\r\n    /** This list contains references to positions that complement this one, additionally also specifying a quantity for which the addition is intended. This does not replace the ComplementedBy property and there are no automatic checks being done between these two properties, so it's up to the user code to ensure deletions (and additions, if desired) are performed for both properties. When copying withing keeping Ids, this list will not be part of the copy process, since it would only contain quantities without actual position references. Containers, however, will rebuild the list with updated position references when copying positions that contain entries here. */\r\n    complementedByQuantities?: ComplementedByQuantityDto[] | undefined;\r\n    /** This identifier can be used to point to the Id of an ExecutionDescription in the same ServiceSpecification. ExecutionDescriptions act as a way to centrally describe how positions should be executed in practice. Often, the position itself still has text of its own to highlight deviations from that or add more details. */\r\n    executionDescriptionReference?: string | undefined;\r\n    /** This indicates if a position has not been offered. This is typically only expected to be true when the exchange phase of the parent ServiceSpecification is Offer, and it means that the position has not been offered at all. */\r\n    notOffered?: boolean | undefined;\r\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for Positions and extends the OenormProperties base class. */\r\n    oenormPositionProperties?: OenormPositionPropertiesDto | undefined;\r\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\r\n    descriptionId?: string | undefined;\r\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\r\n    hierarchyLevel?: number | undefined;\r\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\r\n    addendumStatus?: AddendumStatusDto | undefined;\r\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\r\n    /** This property can optionally be used in GAEB exchange scenarios. It is only meaningful if this position itself is a complementing position, meaning if this position is marked in other positions in their ComplementedBy list. Then, it specifies how the complementing should be expressed in GAEB. By default, positions are always explicitly referenced, but other options are possible. Please also note that the Dangl.AVA.Converter package, which is used for GAEB exports, will check if the given type is valid in the current project configuration. If not, directly referenced positions will be used as fallback. */\r\n    gaebComplementingType?: PositionComplementingTypeDto | undefined;\r\n    /** HoldOut properties describe services that are to be provided and maintained for a specific time, e.g. fences on a construction site. */\r\n    holdOutProperties?: PositionHoldOutPropertiesDto | undefined;\r\n    /** This is an informational property, which directly holds a numerical value for an estimated quantity. It is not used for any price calculations. */\r\n    estimatedQuantity?: number | undefined;\r\n    /** This is an optional property that holds price catalogue data. These are prices that may represent an estimate, and they typically come from a price catalogue. */\r\n    priceCatalogueData?: PriceCatalogueDataDto | undefined;\r\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties. */\r\n    ignoreProjectCataloguePropagation?: boolean | undefined;\r\n}\r\n\r\n/** Based on the PriceComponent, this class is responsible for labour time components. */\r\nexport interface LabourPriceComponentDto {\r\n    /** The label associated with this price component. Will be taken from the parent Projects ProjectInformation. */\r\n    label?: string | undefined;\r\n    /** The total, calculated price of this component. Will multiply the calculated amount of hours with the ServiceSpecifications hourly wage rate. */\r\n    readonly price?: number | undefined;\r\n    /** The cost per hour of manual labor. */\r\n    hourlyWage?: number | undefined;\r\n    /** The single Calculation elements this price component is composed of. */\r\n    values?: CalculationDto[] | undefined;\r\n    /** Indicates if the ServiceSpecification's standard HourlyWage is to be used or a custom value. */\r\n    useOwnHourlyWage?: boolean | undefined;\r\n    /** The total, calculated time of this component. Will return the result rounded to three decimal places. */\r\n    readonly totalTime?: number | undefined;\r\n    /** These are Catalogues that are used within this PriceComponent. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n}\r\n\r\n/** This class holds means to calculate mathematical expressions from given strings. */\r\nexport interface CalculationDto {\r\n    /** Descriptive text for this calculation. */\r\n    description?: string | undefined;\r\n    /** This Calculation's mathematical expression. Please note that thousands separators are not supported. Both comma and point will be treated as decimal separators. */\r\n    formula?: string | undefined;\r\n    /** The calculated result from the formula, 0 if invalid. */\r\n    readonly result?: number | undefined;\r\n    /** Whether the Formula is a valid expression. */\r\n    readonly valid?: boolean | undefined;\r\n    /** Will be -1 if the Formula is correct, else it will show the position in the formula where an error was encountered. This is a zero based index. */\r\n    readonly errorPositionInLine?: number | undefined;\r\n    /** These are Catalogues that are used within this Calculation. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    /** Referenced catalogues for this Calculation. */\r\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\r\n}\r\n\r\n/** This class provides means to store information about a price and it's composition. Note that this is referencing to a single price component, so for example a Position would have a list of PriceComponents, one for Material, one for Labour etc. */\r\nexport interface PriceComponentDto {\r\n    /** The total, calculated price of this component. */\r\n    readonly price?: number | undefined;\r\n    /** The label associated with this price component. Will be taken from the parent Projects ProjectInformation. */\r\n    label?: string | undefined;\r\n    /** The single Calculation elements this price component is composed of. */\r\n    values?: CalculationDto[] | undefined;\r\n    /** These are Catalogues that are used within this PriceComponent. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n}\r\n\r\n/** This is appended to a Position and is used to separate the complete Position into smaller amounts to be described separately, for example concrete walls could be attached to different building storeys. */\r\nexport interface SubDescriptionDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** Returns the total calculated sum of all quantity assignments. Will return the result rounded to three decimal places. */\r\n    readonly quantity?: number | undefined;\r\n    /** You can use this property to directly set the quantity for this sub description. This will override any given QuantityComponents */\r\n    quantityOverride?: number | undefined;\r\n    /** Holds quantity information for this sub description. Quantity is listening to changes here and is reporting the total sum of all quantity components. */\r\n    quantityComponents?: CalculationDto[] | undefined;\r\n    /** Indicates if the bidder is asked to specify an amount. */\r\n    amountToBeEnteredByBidder?: boolean | undefined;\r\n    /** Identifier for this SubDescription. */\r\n    identifier?: string | undefined;\r\n    /** Short description for this DescriptionBase element. */\r\n    shortText?: string | undefined;\r\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\r\n    longText?: string | undefined;\r\n    /** If this is given, then the sub description has a different unit tag than the parent position. */\r\n    unitTag?: string | undefined;\r\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\r\n    htmlLongText?: string | undefined;\r\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\r\n    additionType?: AdditionTypeDto | undefined;\r\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\r\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\r\n    /** This identifier can be used to point to the Id of an ExecutionDescription in the same ServiceSpecification. ExecutionDescriptions act as a way to centrally describe how positions (or sub descriptions) should be executed in practice. Often, the position (or sub description) itself still has text of its own to highlight deviations from that or add more details. When working with import and export features, this property is only supported in GAEB 90 data exchange. */\r\n    executionDescriptionReference?: string | undefined;\r\n    /** These are Catalogues that are used within this Calculation. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\r\n    descriptionId?: string | undefined;\r\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\r\n    elementType?: string | undefined;\r\n    elementTypeDiscriminator?: string | undefined;\r\n}\r\n\r\n/** Indicates the origin of an element. */\r\nexport enum AdditionTypeDto {\r\n    None = \"None\",\r\n    ByBuyer = \"ByBuyer\",\r\n    ByBidder = \"ByBidder\",\r\n}\r\n\r\n/** This class represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\r\nexport interface StandardizedDescriptionDto {\r\n    /** This enumeration identifies a pre-known standard used for referencing standardized descriptions. */\r\n    standardReferenceType?: StandardReferenceTypeDto | undefined;\r\n    /** This string property is the identifier to map to the references standard. Its type is given in the StandardReferenceType */\r\n    standardReference?: string | undefined;\r\n    /** This is a special reference to the German STLB \"Standardleistungsbuch Bau\" reference. If this is used, the StandardReference property should not be set. */\r\n    stlbReference?: STLBReferenceDto | undefined;\r\n}\r\n\r\n/** This enumeration identifies a pre-known standard used for referencing standardized descriptions. */\r\nexport enum StandardReferenceTypeDto {\r\n    Unknown = \"Unknown\",\r\n    StLB = \"StLB\",\r\n    StLK = \"StLK\",\r\n    STLBBauZ = \"STLBBauZ\",\r\n}\r\n\r\n/** This class represents a specialized reference to the German STLB \"Standardleistungsbuch Bau\". The STLB is a commercial offering and describes common services in the construction sector. When this is used, this describes the exact type of a service via a reference to this standard */\r\nexport interface STLBReferenceDto {\r\n    /** The date of the STLB version. Typically, only the Year and Month are used */\r\n    versionDate?: Date | undefined;\r\n    /** The name of the catalogue within the STLB */\r\n    catalogueName?: string | undefined;\r\n    /** The name of the group in STLB */\r\n    group?: string | undefined;\r\n    /** The cost group this service is associated with */\r\n    costGroup?: string | undefined;\r\n    /** The service area (or type) in the STLB */\r\n    serviceArea?: string | undefined;\r\n    /** These keys may optionally be used to further reference multiple, specific items within the STLB */\r\n    keys?: STLBKeyDto[] | undefined;\r\n}\r\n\r\n/** This class represents a single key reference within the German STLB \"Standardleistungsbuch Bau\" */\r\nexport interface STLBKeyDto {\r\n    /** This identifier is required and uniquely describes a single reference within the STLB standard. It maps to \"ArtChrIdent\" in GAEB XML */\r\n    artIdentifier?: number | undefined;\r\n    /** This optional index property further categorizes a single reference within the STLB standard. It maps to \"ArtChIdx\" in GAEB XML */\r\n    artIndex?: number | undefined;\r\n    /** This optional identifier further specifies the execution kind of the reference in the STLB standard. It maps to \"ChVIdent\" in GAEB XML */\r\n    kindIdentifier?: number | undefined;\r\n}\r\n\r\n/** Indicates if this service specification item is commissioned (and therefore should be executed), postponed for later or undefined. */\r\nexport enum ComissionStatusDto {\r\n    Undefined = \"Undefined\",\r\n    Commissioned = \"Commissioned\",\r\n    Postponed = \"Postponed\",\r\n    Removed = \"Removed\",\r\n}\r\n\r\n/** This class represents as identifier of a certain service specification's element and is uniquely within the service specification. */\r\nexport interface ItemNumberDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** Will return this ItemNumber as point delimited string. Will not distinguish between upper- and lowercase and return an all-lowercase representation. Will consider first numbers, then characters, e.g. 1a is considered preceding aa. Transformation to all lowercase can be configured in the ItemNumberSchema property. */\r\n    stringRepresentation?: string | undefined;\r\n    /** Indicates if the characters and the length of the Identifiers match the current ItemNumberSchema. */\r\n    readonly isSchemaCompliant?: boolean | undefined;\r\n    /** Used for representing and validating this ItemNumber. */\r\n    itemNumberSchema?: ItemNumberSchemaDto | undefined;\r\n    /** Collection of the single identifiers in this ItemNumber. P.e., \"02.03.004\" will have three elements \"02\", \"03\", and \"004\". Since ReadOnlyObservableCollection`1 does have the event set to protected, it can be accessed like this: (itemNumber.Identifiers as INotifyCollectionChanged).CollectionChanged */\r\n    identifiers?: string[] | undefined;\r\n    /** This indicates if this item number is at the lot level. Find out more about lots in the documentation. */\r\n    readonly isLot?: boolean | undefined;\r\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\r\n    hierarchyLevel?: number | undefined;\r\n    /** This property indicates if this ItemNumber is attached to an object of the Position type. */\r\n    readonly isAttachedToPosition?: boolean | undefined;\r\n    itemNumberSchemaBeforeMapping?: ItemNumberSchemaDto | undefined;\r\n}\r\n\r\n/** This is a classification for Position elements. */\r\nexport enum PositionTypeDto {\r\n    Regular = \"Regular\",\r\n    Optional = \"Optional\",\r\n    Alternative = \"Alternative\",\r\n}\r\n\r\n/** This indicates the price type of a IPricedElement. */\r\nexport enum PriceTypeDto {\r\n    WithTotal = \"WithTotal\",\r\n    WithoutTotal = \"WithoutTotal\",\r\n}\r\n\r\n/** The service type describes the type of service a Position represents. */\r\nexport enum ServiceTypeDto {\r\n    Regular = \"Regular\",\r\n    HourlyPaidWork = \"HourlyPaidWork\",\r\n}\r\n\r\n/** This class represents data about products and their vendor */\r\nexport interface ProductDataDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This PartyInformation is used to describe details about the vendor of this ProductData. */\r\n    vendor?: PartyInformationDto | undefined;\r\n    /** The collection of ArticleData that describe this product, e.g. a pipe product could be composed out of multiple pipe segments and fittings. */\r\n    articles?: ArticleDataDto[] | undefined;\r\n    /** Short description for this ITextElement element. */\r\n    shortText?: string | undefined;\r\n    /** Detailed description for this ITextElement element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\r\n    longText?: string | undefined;\r\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\r\n    htmlLongText?: string | undefined;\r\n}\r\n\r\n/** This class represents a single article, usually used within ProductData */\r\nexport interface ArticleDataDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The name (or brand name) for this article, usually given by the supplier or vendor. */\r\n    name?: string | undefined;\r\n    /** An article number that describes it, useful when integrating other systems. */\r\n    articleNumber?: string | undefined;\r\n    /** Quantity for this article. If this is used within a Position, the quantity here should be the quantity required for the full quantity of the position, not for a single unit. */\r\n    quantity?: number | undefined;\r\n    /** The unit tag for this single ArticleData. */\r\n    unitTag?: string | undefined;\r\n    /** This is an optional text element that can be used to further describe the ArticleData. */\r\n    description?: string | undefined;\r\n    /** Short description for this ITextElement element. */\r\n    shortText?: string | undefined;\r\n    /** Detailed description for this ITextElement element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\r\n    longText?: string | undefined;\r\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\r\n    htmlLongText?: string | undefined;\r\n}\r\n\r\n/** Quantity assignments are, in contrast to SubDescriptions, used to categorize parts of their parent Position. For example, it could be categorized by cost group - e.g. a Position describing concrete walls could follow the German DIN 276 Cost Groups Standard and specify that of the total 1.000m² wall, 500m² are classified as exterior walls and 500m² are classified as interior walls. They would then have different cost groups associated, e.g. for accounting purposes. */\r\nexport interface QuantityAssignmentDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The total quantity in this quantity assignment */\r\n    quantity?: number | undefined;\r\n    /** These are Catalogue that are used within this ServiceSpecification. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\r\n    projectCatalogues?: CatalogueDto[] | undefined;\r\n    /** Referenced catalogues for this QuantityAssignment. */\r\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\r\n}\r\n\r\n/** This class holds specialized information that is relevant to trade or commerce based data exchange scenarios, e.g. between customers, vendors, suppliers and distributors. It is used when exporting to GAEB XML 9x exchange phases. */\r\nexport interface CommercePropertiesDto {\r\n    /** This maps to ArtNo in GAEB XML and represents an article number given by the supplier. */\r\n    articleNumber?: string | undefined;\r\n    /** This maps to EAN in GAEB XML and represents an GTIN (formerly EAN) article number. */\r\n    eanGtinArticleNumber?: string | undefined;\r\n    /** This maps to ArtNoID in GAEB XML and represents an ILN article number. */\r\n    ilnArticleNumber?: string | undefined;\r\n    /** This maps to CatalogNo in GAEB XML and represents an identifier of a specific catalogue. The referenced catalogue is usually a customer specific one, not related to CatalogueReferences. */\r\n    catalogueNumber?: string | undefined;\r\n    /** This maps to CatalogArtNo in GAEB XML and represents a key that maps to an entry in a specific catalogue. The referenced catalogue is usually a customer specific one, not related to CatalogueReferences. */\r\n    catalogueArticleNumber?: string | undefined;\r\n    /** This optional property can be used to indicate the basis for prices for a single position. Price basis means that the price is given per unit of the basis, e.g. per a pack of five when this property is set to '5'. */\r\n    priceBasis?: number | undefined;\r\n    /** This optional property can be used to indicate a sub position identifier specific for the commerce exchange */\r\n    subPositionIdentifier?: string | undefined;\r\n    /** In a commerce exchange, this property is usually used to reference the base item number of an underlying phase 83 exchange file */\r\n    customerBaseItemNumber?: string | undefined;\r\n}\r\n\r\n/** This class represents the linking to a complementary position with a specific quantity set. For example, Position 'A' could be complementing Position 'B' with a total quantity of 20 units */\r\nexport interface ComplementedByQuantityDto {\r\n    /** The quantity that is complemented. E.g., if the base position has a quantity of 100 m² of a brick wall, a complementing position might be for 'walls that exceed 3 m height' and for a total quantity of 10 m². */\r\n    quantity?: number | undefined;\r\n    /** This is the reference to the Id of the Position that is complementing. This means it does NOT reference the base position but the one that contains the actual addition. */\r\n    complementingPositionId?: string | undefined;\r\n}\r\n\r\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for Positions and extends the OenormProperties base class. */\r\nexport interface OenormPositionPropertiesDto {\r\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\r\n    originCode?: OenormOriginCodeDto | undefined;\r\n    /** This marks if the opening texts within this element are considered free text. It corresponds to 'vorbemerkungskennzeichen' in ÖNorm. */\r\n    openingTextIsFreeText?: boolean | undefined;\r\n    /** This indicates if the ÖNorm 'wesentliche position' mark is set */\r\n    isMainPosition?: boolean | undefined;\r\n    /** This indicates if the ÖNorm position was a 'ungeteilteposition' (undivided position). This will only be taken into account when the position is also the sole element inside it's parent group */\r\n    isUndividedPosition?: boolean | undefined;\r\n    /** In some ÖNorm formats, the short text can have it's own addition, so the text is split up in OenormShortText and OenormShortTextAddition To serialize this, either the ShortText property of the parent position needs to be null, or OenormShortText ' ' OenormShortTextAddition needs to match the ShortText. */\r\n    oenormShortText?: string | undefined;\r\n    /** In some ÖNorm formats, the short text can have it's own addition, so the text is split up in OenormShortText and OenormShortTextAddition To serialize this, either the ShortText property of the parent position needs to be null, or OenormShortText ' ' OenormShortTextAddition needs to match the ShortText. */\r\n    oenormShortTextAddition?: string | undefined;\r\n}\r\n\r\n/** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\r\nexport enum OenormOriginCodeDto {\r\n    Unknown = \"Unknown\",\r\n    FreeText = \"FreeText\",\r\n    AdditionDescription = \"AdditionDescription\",\r\n}\r\n\r\n/** This enumeration represents the status of an addendum, 'Nachtrag' in German */\r\nexport enum AddendumStatusDto {\r\n    Unknown = \"Unknown\",\r\n    Recognized = \"Recognized\",\r\n    Filed = \"Filed\",\r\n    Offered = \"Offered\",\r\n    Withdrawn = \"Withdrawn\",\r\n    Rejected = \"Rejected\",\r\n    RejectionObjected = \"RejectionObjected\",\r\n    FormallyAcknowledged = \"FormallyAcknowledged\",\r\n    Approved = \"Approved\",\r\n}\r\n\r\n/** This enum represents the different ways in which a complementing position type can be specified. It is typically only used in GAEB exports, since in Dangl.AVA, complementing positions are always explicitly referenced. */\r\nexport enum PositionComplementingTypeDto {\r\n    Undefined = \"Undefined\",\r\n    AllPreviousMarkedPositions = \"AllPreviousMarkedPositions\",\r\n    AllPreviousPositions = \"AllPreviousPositions\",\r\n    ReferencedPositions = \"ReferencedPositions\",\r\n}\r\n\r\n/** This class holds properties that describe retention types in position. Retention / hold out usually means that a service is provided and kept available for a specific amount of time, e.g. fences on a construction site */\r\nexport interface PositionHoldOutPropertiesDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The actual type */\r\n    holdOutType?: HoldOutTypeDto | undefined;\r\n    /** The duration of the period */\r\n    holdOutDuration?: number | undefined;\r\n    /** The time unit of the period */\r\n    holdOutDurationUnit?: HoldOutDurationUnitDto | undefined;\r\n    /** References to base positions */\r\n    basePositionReferences?: string[] | undefined;\r\n}\r\n\r\n/** Types of retentions to be used in positions */\r\nexport enum HoldOutTypeDto {\r\n    Unknown = \"Unknown\",\r\n    Base = \"Base\",\r\n    Extension = \"Extension\",\r\n    Rent = \"Rent\",\r\n}\r\n\r\n/** Duration used in retention positions */\r\nexport enum HoldOutDurationUnitDto {\r\n    Unknown = \"Unknown\",\r\n    Minutes = \"Minutes\",\r\n    Hours = \"Hours\",\r\n    Days = \"Days\",\r\n    Weeks = \"Weeks\",\r\n    Months = \"Months\",\r\n}\r\n\r\n/** Price catalogue data represents assumed or estimated prices from a catalogue source */\r\nexport interface PriceCatalogueDataDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The lower bound of the unit price */\r\n    unitPriceFrom?: number | undefined;\r\n    /** The upper bound of the unit price */\r\n    unitPriceTo?: number | undefined;\r\n    /** The average unit price */\r\n    unitPriceAverage?: number | undefined;\r\n    /** The lower bound of the wage price */\r\n    wagePriceFrom?: number | undefined;\r\n    /** The upper bound of the wage price */\r\n    wagePriceTo?: number | undefined;\r\n    /** The average wage price */\r\n    wagePriceAverage?: number | undefined;\r\n}\r\n\r\n/** An ExecutionDescription is used to give more details for certain items, especially on how they are meant to be executed. */\r\nexport interface ExecutionDescriptionDto extends IElementDto {\r\n    /** Blocks within an ExecutionDescription contain the actual information. */\r\n    blocks?: NoteTextDto[] | undefined;\r\n    /** Labels this ExecutionDescription. */\r\n    label?: string | undefined;\r\n    /** Uniquely identifies this ExecutionDescription. */\r\n    identifier?: string | undefined;\r\n    elementType?: string | undefined;\r\n}\r\n\r\n/** Represents an element that holds text information. */\r\nexport interface NoteTextDto extends IElementDto {\r\n    /** If this is set to true, this text is meant to not be seen as part of the regular elements hierarchy but as a special opening text at the beginning of the project. For example, in GAEB XML, this would map to the GAEB.Award.AddText. Typically, such texts describe project-wide contractual definitions. If this is set to true, this NoteText should be placed at the top of the elements hierarchy directly in the ServiceSpecification.Elements group, otherwise it will likely not be treated correctly when exporting to GAEB. You can only set IsOpeningText or IsClosingText to true. */\r\n    isOpeningText?: boolean | undefined;\r\n    /** If this is set to true, this text is meant to not be seen as part of the regular elements hierarchy but as a special closing text at the end of the project. For Example, in GAEB XML, this would map to the GAEB.AddText. Typically, such texts are used to describe project wide finishing descriptions. If this is set to true, this NoteText should be placed at the top of the elements hierarchy directly in the ServiceSpecification.Elements group, otherwise it will likely not be treated correctly when exporting to GAEB. You can only set IsOpeningText or IsClosingText to true. */\r\n    isClosingText?: boolean | undefined;\r\n    /** Short description for this DescriptionBase element. */\r\n    shortText?: string | undefined;\r\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\r\n    additionType?: AdditionTypeDto | undefined;\r\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\r\n    longText?: string | undefined;\r\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\r\n    htmlLongText?: string | undefined;\r\n    /** This is an optional internal identifier that may be used to add additional information to this NoteText. It is not supported in GAEB import or export. */\r\n    identifier?: string | undefined;\r\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\r\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\r\n    elementType?: string | undefined;\r\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\r\n    descriptionId?: string | undefined;\r\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for NoteTexts. */\r\n    oenormNoteTextProperties?: OenormNoteTextPropertiesDto | undefined;\r\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\r\n}\r\n\r\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for NoteTexts. */\r\nexport interface OenormNoteTextPropertiesDto {\r\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\r\n    originCode?: OenormOriginCodeDto | undefined;\r\n}\r\n\r\n/** This is a grouping IElement that holds other IElements within. */\r\nexport interface ServiceSpecificationGroupDto extends IElementDto {\r\n    /** The hourly wage that is used within this ElementContainerBase. Will be propagated to child elements. */\r\n    readonly projectHourlyWage?: number | undefined;\r\n    /** The tax rate that is used within this ElementContainerBase. Will be propagated to child elements. */\r\n    projectTaxRate?: number | undefined;\r\n    /** The price components that are used within this project. They are ignored during Json deserialization because they will be set from the parent project. */\r\n    projectPriceComponents?: string[] | undefined;\r\n    /** The ItemNumberSchema that is used within this project. */\r\n    projectItemNumberSchema?: ItemNumberSchemaDto | undefined;\r\n    /** The IElements within this ElementContainerBase. */\r\n    elements?: IElementDto[] | undefined;\r\n    /** The label used in the parent Project to mark labour time, e.g. \"Hours\" or \"Stunden\". */\r\n    readonly projectLabourTimeLabel?: string | undefined;\r\n    /** Indicates if there are child IElements that have conflicting, duplicated ItemNumbers or if any child ElementContainerBase elements themselves contain duplicate ItemNumber s. Will always indicate false when told to ignore duplicate item numbers. */\r\n    readonly containsDuplicateItemNumbers?: boolean | undefined;\r\n    /** Indicates if there are child IElements that have conflicting, duplicated Ids or if any child ElementContainerBase elements themselves contain duplicate Id s. Will always indicate false when told to ignore duplicate item numbers. */\r\n    readonly containsDuplicateElementIds?: boolean | undefined;\r\n    /** Indicate if duplicated ItemNumbers within child elements are to be ignored. Will not perform checks for duplicates if yes. */\r\n    ignoreDuplicateItemNumbers?: boolean | undefined;\r\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties */\r\n    ignoreProjectCataloguePropagation?: boolean | undefined;\r\n    /** Indicate if duplicated Ids within child elements are to be ignored. Will not perform checks for duplicates if yes. */\r\n    ignoreDuplicateElementIds?: boolean | undefined;\r\n    /** Price composition by tax rate. */\r\n    totalPriceGrossByTaxRate?: GrossPriceComponentDto[] | undefined;\r\n    /** Internally used to indicate that a propagation is currently done, this is done to not recalculate every single result from a lot of changes when it is sufficient to calculate the total price at once. */\r\n    ignoreChildPriceUpdates?: boolean | undefined;\r\n    /** Net price after applied deductions. */\r\n    readonly deductedPrice?: number | undefined;\r\n    /** Factor of applied deductions to the total price. For example, \"0.03\" means that a 3% deduction is to be applied. */\r\n    deductionFactor?: number | undefined;\r\n    /** The exact amount of the discount as an absolute value. For backwards compatibility reasons, setting this value will also set a calculated value to DeductionFactor, which will also be updated in case the total price is changed to reflect a relative value of the absolute discount sum. */\r\n    absoluteDeduction?: number | undefined;\r\n    /** Will return this ElementContainerBase's total price. */\r\n    readonly totalPrice?: number | undefined;\r\n    /** The total gross price for this ElementContainerBase including all child elements. */\r\n    readonly totalPriceGross?: number | undefined;\r\n    /** Total gross price after applied deductions. */\r\n    readonly totalPriceGrossDeducted?: number | undefined;\r\n    /** Indicates the PriceType of this ElementContainerBase, whether it should factor into total costs or not. */\r\n    priceType?: PriceTypeDto | undefined;\r\n    /** Description for this ServiceSpecificationGroup. */\r\n    shortText?: string | undefined;\r\n    /** Indicates if this service specification group is commissioned (and therefore should be executed), postponed for later or undefined. */\r\n    comissionStatus?: ComissionStatusDto | undefined;\r\n    /** The ItemNumber for this INumberedElement interface. */\r\n    itemNumber?: ItemNumberDto | undefined;\r\n    elementType?: string | undefined;\r\n    /** This indicates if this group is the parent of a lot. See the documentation for more information about working with lots. */\r\n    readonly isLot?: boolean | undefined;\r\n    /** If this group is an alternative for a base group, then this property should point to the id of the group in this service specification that it can replace. If this is an alternative group to a base group, the PriceType should typically be set to \"WithoutTotal\" so this group does not factor into total costs. The PriceType is not changed when this property is set */\r\n    alternativeTo?: string | undefined;\r\n    v1CompatibilityPriceType?: string | undefined;\r\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. */\r\n    oenormProperties?: OenormPropertiesDto | undefined;\r\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\r\n    hierarchyLevel?: number | undefined;\r\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\r\n    addendumStatus?: AddendumStatusDto | undefined;\r\n    /** This is internally used during mapping operations to temporarily hold information about removed ItemNumberSchemas. Those schemas are set to null during the mapping process to ensure that schemas in elements higher up in the hierarchy are correctly passed down to child elements. */\r\n    itemNumberSchemaMappingOperation?: ItemNumberSchemaMappingOperation | undefined;\r\n    /** This is an optional property that can be used together with AlternativeTo. If this is set, you can indicate which alternative group a specific group is assigned to. That way, if you specifiy multiple alternative ServiceSpecificationGroups with the same AlternativeIdentifier, you can indicate that to replace a single base ServiceSpecificationGroup, multiple alternative ServiceSpecificationGroups should be used. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base group via AlternativeTo. */\r\n    alternativeIdentifier?: number | undefined;\r\n    /** This is an optional property that can be used together with AlternativeTo and AlternativeGroupIdentifier. If this is set, you can indicate which alternative group a specific group is assigned to. That way, you can specify the id (in integer format) for the alternative group this group belongs to. It's different to AlternativeIdentifier in that the other property describes the id of the group, while this property here describes the group itself. If a group only has set AlternativeGroupIdentifier but not AlternativeIdentifier, then it likely is a base group for a specific group. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base group via AlternativeTo. */\r\n    alternativeGroupIdentifier?: number | undefined;\r\n}\r\n\r\n/** This is used in an ElementContainerBase to hold the price composition. */\r\nexport interface GrossPriceComponentDto {\r\n    /** This components tax rate. */\r\n    taxRate?: number | undefined;\r\n    /** This is the factor of applied deductions for this component */\r\n    deductionFactor?: number | undefined;\r\n    /** The total net price for all components of a given tax rate. */\r\n    totalNet?: number | undefined;\r\n    /** The resulting price component after applied deductions */\r\n    readonly totalDeducted?: number | undefined;\r\n    /** The total tax amount for all components of a given tax rate. */\r\n    readonly totalTax?: number | undefined;\r\n    /** The total gross price for all components of a given tax rate. */\r\n    readonly totalGross?: number | undefined;\r\n    /** The total gross price for all components of a given tax rate, after applied deductions. */\r\n    readonly totalGrossDeducted?: number | undefined;\r\n    /** The total tax amount for all components of a given tax rate, after applied deductions. */\r\n    readonly totalTaxDeducted?: number | undefined;\r\n}\r\n\r\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. */\r\nexport interface OenormPropertiesDto {\r\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\r\n    originCode?: OenormOriginCodeDto | undefined;\r\n    /** This marks if the opening texts within this element are considered free text. It corresponds to 'vorbemerkungskennzeichen' in ÖNorm. */\r\n    openingTextIsFreeText?: boolean | undefined;\r\n}\r\n\r\n/** This abstract class is used internally to hold results about an item number schema removal operation. Item number schemas are removed during the mapping process to allow top-down propagation after conversion, but are then added back to the DTOs to preserve the original source. */\r\nexport interface ItemNumberSchemaMappingOperation {\r\n}\r\n\r\n/** Indicates a ServiceSpecification's exchange phase, based on the GAEB exchange phases. */\r\nexport enum ExchangePhaseDto {\r\n    Undefined = \"Undefined\",\r\n    Base = \"Base\",\r\n    CostEstimate = \"CostEstimate\",\r\n    OfferRequest = \"OfferRequest\",\r\n    Offer = \"Offer\",\r\n    SideOffer = \"SideOffer\",\r\n    Grant = \"Grant\",\r\n}\r\n\r\n/** Indicates where a service specification was originally created. */\r\nexport enum OriginDto {\r\n    Self = \"Self\",\r\n    Gaeb90 = \"Gaeb90\",\r\n    Gaeb2000 = \"Gaeb2000\",\r\n    GaebXml = \"GaebXml\",\r\n    Oenorm = \"Oenorm\",\r\n    Reb = \"Reb\",\r\n    Sia = \"Sia\",\r\n}\r\n\r\n/** Holds global price information for a ServiceSpecification */\r\nexport interface PriceInformationDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The amount of currency per one hour of manual labour work in this project. */\r\n    hourlyWage?: number | undefined;\r\n    /** The final, total price will be deducted by this rate. */\r\n    deductionFactor?: number | undefined;\r\n    /** This is given when there is only one flat price for the whole service specification. */\r\n    flatSum?: number | undefined;\r\n    /** Global tax rate for the project. Note that certain elements may have a different, specific tax rate. */\r\n    taxRate?: number | undefined;\r\n    /** This property indicates if the TaxRate property is actually zero (0) or if it's just unset. The TaxRate is a non-nullable property, so it can't be null and therefore a distinction between unset and zero relies on this additional property. When exporting to GAEB, this can be used e.g. to decide whether or not the tax rate should be serialized. This property is automtically set to false when the TaxRate is set to any value, even zero. If the TaxRate is not set to zero, this property will always return false and can not be set to true. */\r\n    hasUnsetTaxRate?: boolean | undefined;\r\n    /** Trade discounts for offered in this ServiceSpecification. */\r\n    tradeDiscounts?: TradeDiscountDto[] | undefined;\r\n}\r\n\r\n/** This class holds information about offered trade discounts (Skonto in German) */\r\nexport interface TradeDiscountDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** The amount of days for how long a declared trade discount applies. Must be a positive number, negative values will be ignored and not set. */\r\n    deadline?: number | undefined;\r\n    /** The rate of the trade discount. */\r\n    rate?: number | undefined;\r\n}\r\n\r\n/** This class does not represent a typical `TimeSpan` but has a scalar value int Duration and a DurationUnit Unit to represent durations as typically used in contracts, e.g. 5 Months */\r\nexport interface WarrantyDurationDto {\r\n    /** The scalar value of the duration. This value must be equal to or bigger than zero (>= 0). Negative values can not be set and will be ignored. */\r\n    duration?: number | undefined;\r\n    /** The unit of the duration */\r\n    unit?: DurationUnitDto | undefined;\r\n}\r\n\r\n/** This enumeration represents the unit of a duration */\r\nexport enum DurationUnitDto {\r\n    Months = \"Months\",\r\n    Years = \"Years\",\r\n}\r\n\r\n/** This class represents properties used in commerce exchange scenarios */\r\nexport interface ServiceSpecificationCommercePropertiesDto {\r\n    /** The date until the price is valid or fixed. */\r\n    fixedPriceDate?: Date | undefined;\r\n    /** The date of the delivery voucher note. */\r\n    deliveryVoucherDate?: Date | undefined;\r\n    /** The actual date of delivery. */\r\n    deliveryDate?: Date | undefined;\r\n    /** The number of the inquiry, usually in a context of offer requests. */\r\n    inquiryNumber?: string | undefined;\r\n    /** The number of the offer, usually in a context of an offer. */\r\n    offerNumber?: string | undefined;\r\n    /** The order number, usually in the context of a grant or contract. */\r\n    orderNumber?: string | undefined;\r\n    /** The order confirmation number */\r\n    orderConfirmationNumber?: string | undefined;\r\n    /** The number of the delivery, e.g. on the delivery note voucher. */\r\n    deliveryNumber?: string | undefined;\r\n    /** The reference number of the customer / buyer. */\r\n    customerReferenceNumber?: string | undefined;\r\n    /** The reference number of the supplier / bidder. */\r\n    supplierReferenceNumber?: string | undefined;\r\n    /** The type of shippment. */\r\n    shippingType?: string | undefined;\r\n    /** The type of the price inquiry. */\r\n    inquiryType?: CommerceInquiryTypeDto | undefined;\r\n}\r\n\r\n/** This enum represents types of price inquiries */\r\nexport enum CommerceInquiryTypeDto {\r\n    Unknown = \"Unknown\",\r\n    Project = \"Project\",\r\n    Immediate = \"Immediate\",\r\n    Exhibition = \"Exhibition\",\r\n}\r\n\r\nexport interface ComplementingPositionData {\r\n    positionsById?: { [key: string]: PositionDto; } | undefined;\r\n    basePositions?: { [key: string]: PositionDto; } | undefined;\r\n    complementingPositionIds?: string[] | undefined;\r\n}\r\n\r\n/** A Project contains all relevant information for a construction project. */\r\nexport interface ProjectDto {\r\n    /** Elements GUID identifier. */\r\n    id: string;\r\n    /** This property controls the accuracy of all price properties, meaning how many decimal places are preserved in calculations. It defaults to DEFAULT_PRICE_ACCURACY. Please see the Dangl.AVA documentation for further information about decimal precision. If UnitPriceAccuracy is set, then this property is ignored for unit prices. */\r\n    priceAccuracy?: number | undefined;\r\n    /** This property controls the accuracy of position unit price properties, meaning how many decimal places are preserved in calculations. Please see the Dangl.AVA documentation for further information about decimal precision. This can be separately set from PriceAccuracy, and it only controls the accuracy of the unit price of positions, not the total price. It defaults to null, which means the standard PriceAccuracy is used for unit prices. */\r\n    unitPriceAccuracy?: number | undefined;\r\n    /** This forces total prices to be the strict product of quantities times unit price in positions. It is enabled by default. If this is disabled, both the unit price and the total price of positions is calculated from the non-rounded values. Please see the documentation for a more detailed explanation of this setting. */\r\n    forceStrictTotals?: boolean | undefined;\r\n    /** This property controls the rounding mode of all price properties, meaning how rounding of decimal places is performed in price calculations. It defaults to DEFAULT_ROUNDING_MODE. Please see the Dangl.AVA documentation for further information about decimal precision. */\r\n    priceRoundingMode?: PriceRoundingModeDto | undefined;\r\n    /** The ProjectInformation contains information that describes the project and its structure. */\r\n    projectInformation?: ProjectInformationDto | undefined;\r\n    /** The ServiceSpecifications in this Project. */\r\n    serviceSpecifications?: ServiceSpecificationDto[] | undefined;\r\n    /** This is used to store the GAEB XML Id within this Project. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\r\n    gaebXmlId?: string | undefined;\r\n}\r\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ava-models.js","sourceRoot":"","sources":["../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/model/ava-models.ts"],"names":[],"mappings":"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","sourcesContent":["//----------------------\n// <auto-generated>\n//     Generated using the NSwag toolchain v14.0.0.0 (NJsonSchema v11.0.0.0 (Newtonsoft.Json v13.0.0.0)) (http://NSwag.org)\n// </auto-generated>\n//----------------------\n\n/* tslint:disable */\n/* eslint-disable */\n// ReSharper disable InconsistentNaming\n\n/** This enum configures rounding modes for price calculations in projects */\nexport enum PriceRoundingModeDto {\n    Normal = \"Normal\",\n    Floor = \"Floor\",\n    Ceiling = \"Ceiling\",\n}\n\n/** General information about a Project. */\nexport interface ProjectInformationDto {\n    /** Information about the buyer. */\n    buyer?: PartyInformationDto | undefined;\n    /** Description for the project. */\n    description?: string | undefined;\n    /** Short description for the project. */\n    descriptionShort?: string | undefined;\n    /** Name of the project. */\n    name?: string | undefined;\n    /** Information about the site. */\n    site?: PartyInformationDto | undefined;\n    /** The ItemNumberSchema used in the project. */\n    itemNumberSchema?: ItemNumberSchemaDto | undefined;\n    /** Short label for the currency used. */\n    currencyShort?: string | undefined;\n    /** Full label of the currency used. */\n    currencyLong?: string | undefined;\n    /** Label for the labour time part of prices used in the project. */\n    labourTimeLabel?: string | undefined;\n    /** Labels for the price components used in the project. Caution: Removal of a price component will trigger to have dependent price informations be deleted in IElements that use this property. If this property is changed or altered after the project has already been used, it is strongly advised to do operations step by step, e.g. if renaming and reordering multiple price components, this should be done one by one. Otherwise, a combination of rename and reordering will not be correctly propagated downwards to child objects in this Project. */\n    priceComponents?: string[] | undefined;\n    /** This dictionary specifies actual types used for the PriceComponents. For example, a single price component might have the name 'Material' as a string, ans this dictionary would then have a key 'Material' and a value of Materials. You can not add keys here that are not also present in the PriceComponents property, and removing price components will also remove them from this dictionary here. */\n    readonly priceComponentTypes?: { [key: string]: PriceComponentTypeDto; } | undefined;\n    /** This bool indicates if this project allows the bidder to add bidder comments. Bidder comments are a way to attach clarifying information when submitting an offer. */\n    bidderCommentAllowed?: boolean | undefined;\n    /** This property indicates if the project should allow side offers from contractors. In GAEB, a side offer would typically be in exchange phase 85. */\n    sideOffersAllowed?: boolean | undefined;\n    /** This enumeration describes the type of the award / procurement process. If this is used in a GAEB context, more information about award types can be found in the German VOB/A rules and the GAEB standard */\n    awardType?: AwardTypeDto | undefined;\n    /** This enumeration describes awards for project that are not just a regular procurement. For example, it can be used to describe recurring maintenance or an outline contract (German: Rahmenvertrag) which just specifies services and prices but may be requested on demand when necessary */\n    specialAwardKind?: SpecialAwardKindDto | undefined;\n    /** Requesters in a construction project, in German also called 'Bedarfsträger', are parties connected to the building process, e.g. architects or planners. */\n    requesters?: PartyInformationDto[] | undefined;\n    /** Notification sites are addresses that are used for delivering messages in the context of construction projects. */\n    notificationSites?: PartyInformationDto[] | undefined;\n}\n\n/** Represents information about a party (a site or an organization). */\nexport interface PartyInformationDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** This party's name. */\n    name?: string | undefined;\n    /** This party's street. */\n    street?: string | undefined;\n    /** This party's ZipCode. */\n    zipCode?: string | undefined;\n    /** This party's City. */\n    city?: string | undefined;\n    /** This party's Country. */\n    country?: string | undefined;\n    /** This party's Identifier. */\n    identifier?: string | undefined;\n    /** Remarks for this party. */\n    remarks?: string | undefined;\n    /** An email address for this party. */\n    email?: string | undefined;\n    /** A phone number for this party. */\n    phone?: string | undefined;\n    /** The name of a contact person. */\n    contactPersonName?: string | undefined;\n    /** This is an identifier related to this PartyInformation and their internal reference of the tender (or award). This might be used to assign an identifier (German \"Vergabenummer\") for the current project. This is typically only used in Buyer and Bidder representations and should map to the concept of \"Vergabenummer\" or \"AwardNo\" in GAEB. */\n    awardIdentifier?: string | undefined;\n    /** This property indicates if the party is registered within the European Economic Area. */\n    isInEuropeanEconomicArea?: boolean | undefined;\n    /** If this is within the European Economic Area (see IsInEuropeanEconomicArea, then as a business entity it likely has an EU VAT Id. */\n    vatId?: string | undefined;\n    /** The fax number for this party. */\n    fax?: string | undefined;\n    /** The two letter ISO country code, e.g. DE for Germany. */\n    countryCode?: string | undefined;\n    /** Depending on which party this class represents, it might have either a 'creditor' or 'debtor' number. This is often used in internal accounting systems. */\n    creditorOrDebtorIdentifier?: string | undefined;\n    /** The Global Location Number (GLN) is issued by GS1 and is intended to be a unique identifier for the physical address of a party, e.g. a business office. */\n    globalLocationNumber?: string | undefined;\n    /** This list contains information about bank accounts associated with this PartyInformation. It's typically used for buyers and bidders. */\n    bankingInformation?: BankingInformationDto[] | undefined;\n    /** This can be used to specify a registration number for this party, e.g. a company registration number. It is usually used in GAEB XML commerce exchanges for bidders to supply their WEEE registration number, which is used to identify them as a registered WEEE company. */\n    registrationNumber?: string | undefined;\n}\n\n/** This is a class that represents the information about a bank connection. It is usually used within a PartyInformation. */\nexport interface BankingInformationDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The name of the bank. */\n    name?: string | undefined;\n    /** The international identifier for the bank account. */\n    iban?: string | undefined;\n    /** The account number. Typically no longer used since the introduction of IBAN within the SEPA area. */\n    accountNumber?: string | undefined;\n    /** The international bank identifier. */\n    bic?: string | undefined;\n    /** The routing number for the bank. Typically no longer used since the introduction of IBAN within the SEPA area. */\n    routingNumber?: string | undefined;\n}\n\n/** The schema for ItemNumber's in a Project. */\nexport interface ItemNumberSchemaDto {\n    /** The count of tiers in the ItemNumberSchema */\n    readonly totalLength?: number | undefined;\n    /** The collection of tiers for this ItemNumberSchema. */\n    tiers?: ItemNumberSchemaTierDto[] | undefined;\n    /** The separator to use for separiting the different levels in an ItemNumber. Defaults to DEFAULT_SEPARATOR, which is a point '.'. Setting this to a space or other whitespaces is discouraged, as this might not work correct in all situations and item numbers could be displayed not as intended. This can not be set to an empty or null string, trying that will default to the DEFAULT_SEPARATOR. If a value is set that has a different length than one '1', the DEFAULT_SEPARATOR will be used instead. You should also not use values for the separator that are also valid for the item numbers themselves, as that might also lead to incorrect results */\n    separator?: string | undefined;\n    /** This string is used to fill (left-pad) item numbers. For example, if a tier has a length of '4' but the given item number is '12', with a Filler of '0', then the final item number will be represented as '0'. This must be a single character string, if a value is given where the Length property does not evaluate to '1', the DEFAULT_FILLER '0' is used. A space is fine to use. You should ensure that you use a value different than Separator, as that might produce unexpected results. No attempt is done by the code to recover from such ambiguous configurations. */\n    filler?: string | undefined;\n    /** This is just a string property that can optionally be used to store additional data for this ItemNumberSchema, e.g. an identification or a type. It does not have any influence over how item numbers are generated, and is not supported in most exchange formats. However, it is used to store ÖNorm service specification structure types. */\n    identifier?: string | undefined;\n    /** This property indicates if ItemNumbers using this ItemNumberSchema should skip empty group levels. This is commonly only used in GAEB files, where there might be gaps in the hierarchy of elements and position identifiers should be placed at the end of the string representation. */\n    skipNonExistingLevelsInPositionItemNumbers?: boolean | undefined;\n    /** This string is used only when the property SkipNonExistingLevelsInPositionItemNumbers in this ItemNumberSchema is also set to true. It defaults to DEFAULT_SKIPPED_TIERS_FILLER, but can be set to any string with a lenght of one. Null values or values with a longer length will lead to this property reverting back to the default value. This is used to fill skipped tiers in item numbers where a position is placed in a higher hierarchy level than what would be defined in the Tiers. For example, it could produce an item number like '01.__.02', which would indicate a skipped second level. This should be using different values than Filler and Separator, since that could cause ambiguities in the code that generates the actual item numbers. No attempt is done by the code to recover from such ambiguous configurations. */\n    skippedTiersFiller?: string | undefined;\n    /** This is a read-only property that indicates if this schema has a valid structure. It internally just returns the result from IsCorrectlyDefined. This will return if the ItemNumberSchema is correctly defined. For it to be correctly defined, the following conditions must be true: There may only be one lot group, if there is one, it must be at the top. Following lot levels, there may be at least one group level. After the group levels, there must be one position level. After the position level, there may be one index level. If no tiers are defined at all, this will also return false. */\n    readonly schemaIsCorrectlyDefined?: boolean | undefined;\n    /** Defaults to false. If this is disabled, all letters in the ItemNumber string representations will be transformed to their lowercase representation. */\n    allowUpperCaseLettering?: boolean | undefined;\n}\n\n/** Represents information about a single Tier in an ItemNumber. */\nexport interface ItemNumberSchemaTierDto {\n    /** The (maximum) length for this tier. Will not accept a length less than 1. Defaults to 1 if length less than one is specified. */\n    length?: number | undefined;\n    /** This ItemNumberSchemaTier's type. */\n    type?: ItemNumberTypeDto | undefined;\n    /** This specifies which ItemNumberSchemaTierType this tier represents. This can be, for example, a group tier / level, a position level or a lot level. */\n    tierType?: ItemNumberSchemaTierTypeDto | undefined;\n    /** Indicates if this tier represents a lot. See the documentation for more information about lots. */\n    readonly isLot?: boolean | undefined;\n    /** This value is the increment, or step size, that should be used for new item numbers. It defaults to DEFAULT_INCREMENT, but can be changed to any other positive number greater than zero. Invalid values make this be set to one '1' */\n    increment?: number | undefined;\n    /** This is an optional name for the given tier */\n    tierName?: string | undefined;\n}\n\n/** Determines the type of an ItemNumberSchema */\nexport enum ItemNumberTypeDto {\n    Numeric = \"Numeric\",\n    Alphanumeric = \"Alphanumeric\",\n}\n\n/** Specifies the type an ItemNumberSchemaTier represents. For example, a tier may indicate to be used for positions or for groups. */\nexport enum ItemNumberSchemaTierTypeDto {\n    Undefined = \"Undefined\",\n    Index = \"Index\",\n    Position = \"Position\",\n    Group = \"Group\",\n    Lot = \"Lot\",\n}\n\n/** This enumeration models types of price components for better classification. */\nexport enum PriceComponentTypeDto {\n    Unknown = \"Unknown\",\n    Wages = \"Wages\",\n    Materials = \"Materials\",\n    Plant = \"Plant\",\n    Miscellaneous = \"Miscellaneous\",\n}\n\n/** This enumeration describes the type of the award / procurement process. If this is used in a GAEB context, more information about award types can be found in the German VOB/A rules and the GAEB standard */\nexport enum AwardTypeDto {\n    Unspecified = \"Unspecified\",\n    OpenProcurement = \"OpenProcurement\",\n    ClosedProducrement = \"ClosedProducrement\",\n    NegotiationProcurementWithoutPublicAnnouncement = \"NegotiationProcurementWithoutPublicAnnouncement\",\n    NegotiationProcurement = \"NegotiationProcurement\",\n    OpenCall = \"OpenCall\",\n    SelectedCallWithoutPublicCompetition = \"SelectedCallWithoutPublicCompetition\",\n    SelectedCall = \"SelectedCall\",\n    DirectAward = \"DirectAward\",\n    InternationalNATOProcurement = \"InternationalNATOProcurement\",\n    CompetitiveDialog = \"CompetitiveDialog\",\n}\n\n/** This enumeration describes awards for project that are not just a regular procurement. For example, it can be used to describe recurring maintenance or an outline contract (German: Rahmenvertrag) which just specifies services and prices but may be requested on demand when necessary */\nexport enum SpecialAwardKindDto {\n    Unspecified = \"Unspecified\",\n    MaintenanceContract = \"MaintenanceContract\",\n    OutlineContract = \"OutlineContract\",\n    OutlineForMaintenanceContract = \"OutlineForMaintenanceContract\",\n}\n\n/** This is the base class that holds information about a whole service specification. */\nexport interface ServiceSpecificationDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The hourly wage that is used within this ElementContainerBase. Will be propagated to child elements. */\n    readonly projectHourlyWage?: number | undefined;\n    /** The tax rate that is used within this ElementContainerBase. Will be propagated to child elements. */\n    projectTaxRate?: number | undefined;\n    /** The price components that are used within this project. They are ignored during Json deserialization because they will be set from the parent project. */\n    projectPriceComponents?: string[] | undefined;\n    /** The ItemNumberSchema that is used within this project. */\n    projectItemNumberSchema?: ItemNumberSchemaDto | undefined;\n    /** The IElements within this ElementContainerBase. */\n    elements?: IElementDto[] | undefined;\n    /** The label used in the parent Project to mark labour time, e.g. \"Hours\" or \"Stunden\". */\n    readonly projectLabourTimeLabel?: string | undefined;\n    /** Indicates if there are child IElements that have conflicting, duplicated ItemNumbers or if any child ElementContainerBase elements themselves contain duplicate ItemNumber s. Will always indicate false when told to ignore duplicate item numbers. */\n    readonly containsDuplicateItemNumbers?: boolean | undefined;\n    /** Indicates if there are child IElements that have conflicting, duplicated Ids or if any child ElementContainerBase elements themselves contain duplicate Id s. Will always indicate false when told to ignore duplicate item numbers. */\n    readonly containsDuplicateElementIds?: boolean | undefined;\n    /** Indicate if duplicated ItemNumbers within child elements are to be ignored. Will not perform checks for duplicates if yes. */\n    ignoreDuplicateItemNumbers?: boolean | undefined;\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties */\n    ignoreProjectCataloguePropagation?: boolean | undefined;\n    /** Indicate if duplicated Ids within child elements are to be ignored. Will not perform checks for duplicates if yes. */\n    ignoreDuplicateElementIds?: boolean | undefined;\n    /** Price composition by tax rate. */\n    totalPriceGrossByTaxRate?: GrossPriceComponentDto[] | undefined;\n    /** Internally used to indicate that a propagation is currently done, this is done to not recalculate every single result from a lot of changes when it is sufficient to calculate the total price at once. */\n    ignoreChildPriceUpdates?: boolean | undefined;\n    /** Net price after applied deductions. */\n    readonly deductedPrice?: number | undefined;\n    /** Factor of applied deductions to the total price. For example, \"0.03\" means that a 3% deduction is to be applied. */\n    deductionFactor?: number | undefined;\n    /** The exact amount of the discount as an absolute value. For backwards compatibility reasons, setting this value will also set a calculated value to DeductionFactor, which will also be updated in case the total price is changed to reflect a relative value of the absolute discount sum. */\n    absoluteDeduction?: number | undefined;\n    /** Will return this ElementContainerBase's total price. */\n    readonly totalPrice?: number | undefined;\n    /** The total gross price for this ElementContainerBase including all child elements. */\n    readonly totalPriceGross?: number | undefined;\n    /** Total gross price after applied deductions. */\n    readonly totalPriceGrossDeducted?: number | undefined;\n    /** Indicates the PriceType of this ElementContainerBase, whether it should factor into total costs or not. */\n    priceType?: PriceTypeDto | undefined;\n    /** Information about the bidder. */\n    bidder?: PartyInformationDto | undefined;\n    /** This discriminator is used to identify different bidders in a project. It is different from the Identifier property in the Bidder in that the BidderDiscriminator is intended to be a numerical identifier within a project, while the Identifier does uniquely identify a bidder in the system independent of a specific project. This property should map to \"Bieternummer\" or \"BidderNo\" in GAEB. */\n    bidderDiscriminator?: string | undefined;\n    /** This is used to store the GAEB XML Id within this ServiceSpecification. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\n    gaebXmlId?: string | undefined;\n    /** The ProjectInformation used within the Project in which this ElementContainerBase is contained. This is reference equal to the ProjectInformation used in the parent project. */\n    readonly projectInformation?: ProjectInformationDto | undefined;\n    /** This service specifications exchange phase, i.e. the current status in the project it is intended to be used (such as request for offer, offer, awarding...). */\n    exchangePhase?: ExchangePhaseDto | undefined;\n    /** This indicates where the service specification originates, i.e. from an exchange file format or self created. If applicable, additional information is present in the OriginDetail property. */\n    origin?: OriginDto | undefined;\n    /** This property complements the Origin property. Some formats, e.g. GaebXml might have additional information attached, e.g. GAEB XML V3.2 oder GAEB XML V3.1. This string property is used to hold such data. The Dangl.AVA module does not have a list of possible values, since this is defined in the native format assemblies, e.g. Dangl.GAEB or Dangl.Oenorm. */\n    originDetail?: string | undefined;\n    /** Creation date of this ServiceSpecification. */\n    creationDate?: Date | undefined;\n    /** Date indicating until when an offer has to be submitted. In German, this is often called the \"Eröffnungstermin\" */\n    offerByDate?: Date | undefined;\n    /** Date indicating by when the buyer will select a contractor. */\n    decisionDate?: Date | undefined;\n    /** Date of when the offer / bid was created */\n    bidDate?: Date | undefined;\n    /** If a construction project requires a warranty bond, this property indicates the amount as a percentage, e.g. '0.15m' means 15% of the construction total amount as a warranty bond. */\n    warrantyBondPercentage?: number | undefined;\n    /** If a construction project requires an execution guarantty, this property indicates the amount as a percentage, e.g. '0.15m' means 15% of the construction total amount as an execution guarantee. In practice, this percentage is usually deducted from intermediate invoices and only billed in the final invoice. */\n    executionGuaranteePercentage?: number | undefined;\n    /** String indicating where the physical submission of the offer is taking place. */\n    submissionLocation?: string | undefined;\n    /** Description of this ServiceSpecification. */\n    description?: string | undefined;\n    /** The name of this ServiceSpecification. */\n    name?: string | undefined;\n    /** This PriceInformation contains global data for the ServiceSpecification. When inside a Project, do not set this property manually. */\n    priceInformation?: PriceInformationDto | undefined;\n    /** These are Catalogue that are used within this ElementContainerBase. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n    /** Referenced catalogues for this ElementContainerBase. */\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\n    /** The date when the execution of the services is scheduled to start */\n    plannedExecutionStart?: Date | undefined;\n    /** The date then the execution of the services is scheduled to be finished */\n    plannedExecutionEnd?: Date | undefined;\n    /** The date on which the contract has been awarded. This matches \"Auftragsdatum\" in GAEB */\n    contractDate?: Date | undefined;\n    /** This value can be used to indicate the number or identifier of the contract. It matches \"Auftragsnummer\" in GAEB */\n    contractIdentifier?: string | undefined;\n    /** This indicates how long the warranty period is for this ServiceSpecification */\n    warrantyDuration?: WarrantyDurationDto | undefined;\n    /** The date on which the warranty period ends */\n    warrantyEnd?: Date | undefined;\n    /** The date on which the services rendered by the bidder are scheduled to be approved by the buyer */\n    approvalDate?: Date | undefined;\n    /** This should specify how the approval is performed by the buyer. This matches \"AcceptType\" in GAEB */\n    typeOfApproval?: string | undefined;\n    /** This optional string property is shared by all IElements, and indicates if the element is part of an addendum, a 'Nachtrag' in German. */\n    addendumNumber?: string | undefined;\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\n    addendumStatus?: AddendumStatusDto | undefined;\n    /** This property holds additional information that's only valid in commerce exchange phases. */\n    commerceProperties?: ServiceSpecificationCommercePropertiesDto | undefined;\n    /** This is internally used during mapping operations to temporarily hold information about removed ItemNumberSchemas. Those schemas are set to null during the mapping process to ensure that schemas in elements higher up in the hierarchy are correctly passed down to child elements. */\n    itemNumberSchemaMappingOperation?: ItemNumberSchemaMappingOperation | undefined;\n    /** This is internally used during mapping operations to temporarily hold information about complementing positions */\n    complementingPositionData?: ComplementingPositionData | undefined;\n}\n\n/** Base interface definition for elements within an ElementContainerBase. */\nexport interface IElementDto {\n    elementType?: string | undefined;\n    /** Elements GUID identifier. */\n    id: string;\n    /** This is used to store the GAEB XML Id within this IElement. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\n    gaebXmlId?: string | undefined;\n    /** This optional string property is shared by all IElements, and indicates if the element is part of an addendum, a 'Nachtrag' in German. */\n    addendumNumber?: string | undefined;\n    projectCatalogues?: CatalogueDto[] | undefined;\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\n    elementTypeDiscriminator: string;\n}\n\n/** This class describes an external catalogue. Catalogues, or collections, hold information to categorize and describe items. For example, the German DIN 276 cost group standards describe different types of costs for building projects. When referencing the DIN 276 catalogue and providing an item key or identifier, it is possible to reference data in this catalogue. */\nexport interface CatalogueDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** This is used to store the GAEB XML Id within this Catalogue. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\n    gaebXmlId?: string | undefined;\n    /** The name that is given for this catalogue. */\n    name?: string | undefined;\n    /** Additional information about this catalogue. */\n    description?: string | undefined;\n    /** If given, this gives a classification for the contents of the catalogue */\n    catalogueType?: CatalogueTypeDto | undefined;\n    /** This property may hold additional information about the catalogue type. It is currently only used in GAEB XML exchange to carry detailed information about a catalogue type, but it's otherwise just a free text field. */\n    catalogueTypeDetail?: string | undefined;\n}\n\n/** This enumeration describes the type of a catalogue. Catalogues, or collections, hold information to categorize and describe items. For example, the German DIN 276 cost group standards describe different types of costs for building projects. When referencing the DIN 276 catalogue and providing an item key or identifier, it is possible to reference data in this catalogue. */\nexport enum CatalogueTypeDto {\n    Unknown = \"Unknown\",\n    Location = \"Location\",\n    DIN276 = \"DIN276\",\n    CostUnit = \"CostUnit\",\n    WorkCategory = \"WorkCategory\",\n    OenormB1801CostGroup = \"OenormB1801CostGroup\",\n    BIM = \"BIM\",\n    Attachment = \"Attachment\",\n}\n\n/** This class is used to link data between catalogues and objects. */\nexport interface CatalogueReferenceDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** This points to the item in the catalogue itself. This means that, for example when this quantity assignment references a \"DIN 276\" catalogue, this property indicates the number / identifier / key in DIN 276 that is referenced. */\n    catalogueReferenceKey?: string | undefined;\n    /** The Id of the CatalogueReference that is targeted by this item. Set this property to set the referenced catalogue. */\n    catalogueReferenceId?: string | undefined;\n    /** These are CatalogueReference that are used within this ServiceSpecification. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n    /** This returns the referenced catalogue. Will return null if there is no reference or the catalogue is not present in the ProjectCatalogues. */\n    readonly catalogue?: CatalogueDto | undefined;\n}\n\n/** A Position is the main item type in a ServiceSpecification, holding information about tasks to be done, their prices, description, amounts etc. */\nexport interface PositionDto extends IElementDto {\n    /** Will return the price per unit, rounded according to the project settings or the default value of three decimal places */\n    readonly unitPrice?: number | undefined;\n    /** You can use this property to directly set the unit price for this position. This will override any given PriceComponents */\n    unitPriceOverride?: number | undefined;\n    /** Will return this Position's total quantity, rounded to three decimal places. */\n    readonly quantity?: number | undefined;\n    /** You can use this property to directly set the quantity for this position. This will override any given QuantityComponents */\n    quantityOverride?: number | undefined;\n    /** This indicates true if this specific position is specified as a complementing position for any base position. */\n    isComplementingPosition?: boolean | undefined;\n    /** If IsComplementingPosition is set to true, this will indicate which base positions are targeted by this complementing position. */\n    complementsPositions?: string[] | undefined;\n    /** You can use this property to directly specify the total price of this position as a percentage of the sum of the total prices of base positions that this position complements. It will essentially set the total price for this position to the sum of all total prices of the positions specified in ComplementsPositions multiplied by the percentage here. If present, this has precedence over UnitPriceOverride as well as QuantityOverride. */\n    complementingPricePercentageOverride?: number | undefined;\n    /** This is a read only property showing the total price of this positions as a percentage of the sum of the total prices of all base positions, in case this position is a complementing positions. If this position is not a complementing position, this will be null. Also, if no prices are present, this will also be null. */\n    complementingPricePercentage?: number | undefined;\n    /** The tag of the unit used for this positions quantity. */\n    unitTag?: string | undefined;\n    /** The components for labour time in this Position. */\n    labourComponents?: LabourPriceComponentDto | undefined;\n    /** The single price components in this Position. Price components should not be handled directly on a per-position basis but set globally in the parent Projects ProjectInformation. */\n    priceComponents?: PriceComponentDto[] | undefined;\n    /** The quantity components of this Position. */\n    quantityComponents?: CalculationDto[] | undefined;\n    /** Further structuring of this Position. */\n    subDescriptions?: SubDescriptionDto[] | undefined;\n    /** Indicates the status of this Position's comission. */\n    comissionStatus?: ComissionStatusDto | undefined;\n    /** A list of positions that complement this Position. The positions are referenced by their GUIDs. It might be used together with ComplementedByQuantities in case that only a given quantity is complemented by positions. */\n    complementedBy?: string[] | undefined;\n    /** Will indicate if this Position is complemented in this ServiceSpecification by other Positions. It can not be set to false when there are entries in the ComplementedBy property. */\n    complemented?: boolean | undefined;\n    /** Indicates that the amount for this Position is to be set by the bidder. */\n    amountToBeEnteredByBidder?: boolean | undefined;\n    /** Indicates if the bidder demands for prices to be broken up into their price components. */\n    priceCompositionRequired?: boolean | undefined;\n    /** Indicates if this Position should use a different TaxRate than what is the default for the Project. */\n    useDifferentTaxRate?: boolean | undefined;\n    /** Will return either the parent ServiceSpecification's TaxRate or it's own if it has a different value. (For example, in Germany Water has a different TaxRate than regular Positions) */\n    taxRate?: number | undefined;\n    /** The ItemNumber for this Position. */\n    itemNumber?: ItemNumberDto | undefined;\n    /** The rate of deductions, i.e. 0.12m means 12% price deduction. */\n    deductionFactor?: number | undefined;\n    /** Returns the product of UnitPrice times Quantity. */\n    readonly totalPrice?: number | undefined;\n    /** The total gross price for this Position. */\n    readonly totalPriceGross?: number | undefined;\n    /** Total gross price after applied deductions. */\n    readonly totalPriceGrossDeducted?: number | undefined;\n    /** Net price after applied deductions. Please be aware that this is the total price, from TotalPrice, not the unit price of the position. */\n    readonly deductedPrice?: number | undefined;\n    /** This indicates the type of a position. If this is an alternative position, its AlternativeTo property should be set to the id of the position it can replace. */\n    positionType?: PositionTypeDto | undefined;\n    /** Indicates the PriceType of this Position. */\n    priceType?: PriceTypeDto | undefined;\n    /** This indicates if this position is regular or describing a labour / hourly paid work service */\n    serviceType?: ServiceTypeDto | undefined;\n    /** This property describes additional information about a product being used within this Position. For example, a pipe position, per length unit, could be composed of different pipe segments, fitting and other accessory articles. */\n    productData?: ProductDataDto | undefined;\n    /** Short description for this DescriptionBase element. */\n    shortText?: string | undefined;\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\n    longText?: string | undefined;\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\n    htmlLongText?: string | undefined;\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\n    additionType?: AdditionTypeDto | undefined;\n    elementType?: string | undefined;\n    /** Quantity assignments are, in contrast to SubDescriptions, used to categorize parts of this Position. For example, it could be categorized by cost group - e.g. a Position describing concrete walls could follow the German DIN 276 Cost Groups Standard and specify that of the total 1.000m² wall, 500m² are classified as exterior walls and 500m² are classified as interior walls. They would then have different cost groups associated, e.g. for accounting purposes. */\n    quantityAssignments?: QuantityAssignmentDto[] | undefined;\n    /** The CommerceProperties support specialized information that is only useful in GAEB XML 9x data exchange phases. It is intended to provide article information. */\n    commerceProperties?: CommercePropertiesDto | undefined;\n    /** If this position is an Alternative, then this property should point to the id of the position in this service specification that it can replace. If this is set to a value, you can optionally also specify an identifier via AlternativeIdentifier to specifiy multiple positions that must be used together to be an alternative to a single base position. */\n    alternativeTo?: string | undefined;\n    /** This is an optional property that can be used together with AlternativeTo. If this is set, you can indicate which alternative group a specific position is assigned to. That way, if you specifiy multiple alternative Positions with the same AlternativeIdentifier, you can indicate that to replace a single base Position, multiple alternative Positions should be used. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base position via AlternativeTo. */\n    alternativeIdentifier?: number | undefined;\n    /** This is an optional property that can be used together with AlternativeTo and AlternativeGroupIdentifier. If this is set, you can indicate which alternative group a specific position is assigned to. That way, you can specify the id (in integer format) for the alternative group this position belongs to. It's different to AlternativeIdentifier in that the other property describes the id of the group, while this property here describes the group itself. If a position only has set AlternativeGroupIdentifier but not AlternativeIdentifier, then it likely is a base position for a specific group. This was introduced in version v2.9.0 to be able to model both position and group ids for alternative group combinations. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base position via AlternativeTo. */\n    alternativeGroupIdentifier?: number | undefined;\n    /** If this is true, it indicates that the position is intended to be a lump sum, \"Pauschal\" in German. This means the position total price that is being invoiced should not depend on the actual quantity. In practice, partial invoices are still often used for partial services rendered. This property does not affect the price calculation for this position. Typically, the Quantity should be set to 1.0 when this flag is used. */\n    isLumpSum?: boolean | undefined;\n    /** This identifier can be used to point to the Id of a position in the same ServiceSpecification that acts as a base position. It matches \"Bezugsposition\" in GAEB. This can be used for positions that repeat partially or are linked together */\n    repetitionTo?: string | undefined;\n    v1CompatibilityPriceType?: string | undefined;\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\n    /** This list contains references to positions that complement this one, additionally also specifying a quantity for which the addition is intended. This does not replace the ComplementedBy property and there are no automatic checks being done between these two properties, so it's up to the user code to ensure deletions (and additions, if desired) are performed for both properties. When copying withing keeping Ids, this list will not be part of the copy process, since it would only contain quantities without actual position references. Containers, however, will rebuild the list with updated position references when copying positions that contain entries here. */\n    complementedByQuantities?: ComplementedByQuantityDto[] | undefined;\n    /** This identifier can be used to point to the Id of an ExecutionDescription in the same ServiceSpecification. ExecutionDescriptions act as a way to centrally describe how positions should be executed in practice. Often, the position itself still has text of its own to highlight deviations from that or add more details. */\n    executionDescriptionReference?: string | undefined;\n    /** This indicates if a position has not been offered. This is typically only expected to be true when the exchange phase of the parent ServiceSpecification is Offer, and it means that the position has not been offered at all. */\n    notOffered?: boolean | undefined;\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for Positions and extends the OenormProperties base class. */\n    oenormPositionProperties?: OenormPositionPropertiesDto | undefined;\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\n    descriptionId?: string | undefined;\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\n    hierarchyLevel?: number | undefined;\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\n    addendumStatus?: AddendumStatusDto | undefined;\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\n    /** This property can optionally be used in GAEB exchange scenarios. It is only meaningful if this position itself is a complementing position, meaning if this position is marked in other positions in their ComplementedBy list. Then, it specifies how the complementing should be expressed in GAEB. By default, positions are always explicitly referenced, but other options are possible. Please also note that the Dangl.AVA.Converter package, which is used for GAEB exports, will check if the given type is valid in the current project configuration. If not, directly referenced positions will be used as fallback. */\n    gaebComplementingType?: PositionComplementingTypeDto | undefined;\n    /** HoldOut properties describe services that are to be provided and maintained for a specific time, e.g. fences on a construction site. */\n    holdOutProperties?: PositionHoldOutPropertiesDto | undefined;\n    /** This is an informational property, which directly holds a numerical value for an estimated quantity. It is not used for any price calculations. */\n    estimatedQuantity?: number | undefined;\n    /** This is an optional property that holds price catalogue data. These are prices that may represent an estimate, and they typically come from a price catalogue. */\n    priceCatalogueData?: PriceCatalogueDataDto | undefined;\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties. */\n    ignoreProjectCataloguePropagation?: boolean | undefined;\n}\n\n/** Based on the PriceComponent, this class is responsible for labour time components. */\nexport interface LabourPriceComponentDto {\n    /** The label associated with this price component. Will be taken from the parent Projects ProjectInformation. */\n    label?: string | undefined;\n    /** The total, calculated price of this component. Will multiply the calculated amount of hours with the ServiceSpecifications hourly wage rate. */\n    readonly price?: number | undefined;\n    /** The cost per hour of manual labor. */\n    hourlyWage?: number | undefined;\n    /** The single Calculation elements this price component is composed of. */\n    values?: CalculationDto[] | undefined;\n    /** Indicates if the ServiceSpecification's standard HourlyWage is to be used or a custom value. */\n    useOwnHourlyWage?: boolean | undefined;\n    /** The total, calculated time of this component. Will return the result rounded to three decimal places. */\n    readonly totalTime?: number | undefined;\n    /** These are Catalogues that are used within this PriceComponent. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n}\n\n/** This class holds means to calculate mathematical expressions from given strings. */\nexport interface CalculationDto {\n    /** Descriptive text for this calculation. */\n    description?: string | undefined;\n    /** This Calculation's mathematical expression. Please note that thousands separators are not supported. Both comma and point will be treated as decimal separators. */\n    formula?: string | undefined;\n    /** The calculated result from the formula, 0 if invalid. */\n    readonly result?: number | undefined;\n    /** Whether the Formula is a valid expression. */\n    readonly valid?: boolean | undefined;\n    /** Will be -1 if the Formula is correct, else it will show the position in the formula where an error was encountered. This is a zero based index. */\n    readonly errorPositionInLine?: number | undefined;\n    /** These are Catalogues that are used within this Calculation. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n    /** Referenced catalogues for this Calculation. */\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\n}\n\n/** This class provides means to store information about a price and it's composition. Note that this is referencing to a single price component, so for example a Position would have a list of PriceComponents, one for Material, one for Labour etc. */\nexport interface PriceComponentDto {\n    /** The total, calculated price of this component. */\n    readonly price?: number | undefined;\n    /** The label associated with this price component. Will be taken from the parent Projects ProjectInformation. */\n    label?: string | undefined;\n    /** The single Calculation elements this price component is composed of. */\n    values?: CalculationDto[] | undefined;\n    /** These are Catalogues that are used within this PriceComponent. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n}\n\n/** This is appended to a Position and is used to separate the complete Position into smaller amounts to be described separately, for example concrete walls could be attached to different building storeys. */\nexport interface SubDescriptionDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** Returns the total calculated sum of all quantity assignments. Will return the result rounded to three decimal places. */\n    readonly quantity?: number | undefined;\n    /** You can use this property to directly set the quantity for this sub description. This will override any given QuantityComponents */\n    quantityOverride?: number | undefined;\n    /** Holds quantity information for this sub description. Quantity is listening to changes here and is reporting the total sum of all quantity components. */\n    quantityComponents?: CalculationDto[] | undefined;\n    /** Indicates if the bidder is asked to specify an amount. */\n    amountToBeEnteredByBidder?: boolean | undefined;\n    /** Identifier for this SubDescription. */\n    identifier?: string | undefined;\n    /** Short description for this DescriptionBase element. */\n    shortText?: string | undefined;\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\n    longText?: string | undefined;\n    /** If this is given, then the sub description has a different unit tag than the parent position. */\n    unitTag?: string | undefined;\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\n    htmlLongText?: string | undefined;\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\n    additionType?: AdditionTypeDto | undefined;\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\n    /** This identifier can be used to point to the Id of an ExecutionDescription in the same ServiceSpecification. ExecutionDescriptions act as a way to centrally describe how positions (or sub descriptions) should be executed in practice. Often, the position (or sub description) itself still has text of its own to highlight deviations from that or add more details. When working with import and export features, this property is only supported in GAEB 90 data exchange. */\n    executionDescriptionReference?: string | undefined;\n    /** These are Catalogues that are used within this Calculation. Catalogues are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. They are propagate to all child elements, e.g. other containers and QuantityAssignments. In the context of a ServiceSpecification, all elements share the same instance of the collection. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\n    descriptionId?: string | undefined;\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\n    elementType?: string | undefined;\n    elementTypeDiscriminator?: string | undefined;\n}\n\n/** Indicates the origin of an element. */\nexport enum AdditionTypeDto {\n    None = \"None\",\n    ByBuyer = \"ByBuyer\",\n    ByBidder = \"ByBidder\",\n}\n\n/** This class represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\nexport interface StandardizedDescriptionDto {\n    /** This enumeration identifies a pre-known standard used for referencing standardized descriptions. */\n    standardReferenceType?: StandardReferenceTypeDto | undefined;\n    /** This string property is the identifier to map to the references standard. Its type is given in the StandardReferenceType */\n    standardReference?: string | undefined;\n    /** This is a special reference to the German STLB \"Standardleistungsbuch Bau\" reference. If this is used, the StandardReference property should not be set. */\n    stlbReference?: STLBReferenceDto | undefined;\n}\n\n/** This enumeration identifies a pre-known standard used for referencing standardized descriptions. */\nexport enum StandardReferenceTypeDto {\n    Unknown = \"Unknown\",\n    StLB = \"StLB\",\n    StLK = \"StLK\",\n    STLBBauZ = \"STLBBauZ\",\n}\n\n/** This class represents a specialized reference to the German STLB \"Standardleistungsbuch Bau\". The STLB is a commercial offering and describes common services in the construction sector. When this is used, this describes the exact type of a service via a reference to this standard */\nexport interface STLBReferenceDto {\n    /** The date of the STLB version. Typically, only the Year and Month are used */\n    versionDate?: Date | undefined;\n    /** The name of the catalogue within the STLB */\n    catalogueName?: string | undefined;\n    /** The name of the group in STLB */\n    group?: string | undefined;\n    /** The cost group this service is associated with */\n    costGroup?: string | undefined;\n    /** The service area (or type) in the STLB */\n    serviceArea?: string | undefined;\n    /** These keys may optionally be used to further reference multiple, specific items within the STLB */\n    keys?: STLBKeyDto[] | undefined;\n}\n\n/** This class represents a single key reference within the German STLB \"Standardleistungsbuch Bau\" */\nexport interface STLBKeyDto {\n    /** This identifier is required and uniquely describes a single reference within the STLB standard. It maps to \"ArtChrIdent\" in GAEB XML */\n    artIdentifier?: number | undefined;\n    /** This optional index property further categorizes a single reference within the STLB standard. It maps to \"ArtChIdx\" in GAEB XML */\n    artIndex?: number | undefined;\n    /** This optional identifier further specifies the execution kind of the reference in the STLB standard. It maps to \"ChVIdent\" in GAEB XML */\n    kindIdentifier?: number | undefined;\n}\n\n/** Indicates if this service specification item is commissioned (and therefore should be executed), postponed for later or undefined. */\nexport enum ComissionStatusDto {\n    Undefined = \"Undefined\",\n    Commissioned = \"Commissioned\",\n    Postponed = \"Postponed\",\n    Removed = \"Removed\",\n}\n\n/** This class represents as identifier of a certain service specification's element and is uniquely within the service specification. */\nexport interface ItemNumberDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** Will return this ItemNumber as point delimited string. Will not distinguish between upper- and lowercase and return an all-lowercase representation. Will consider first numbers, then characters, e.g. 1a is considered preceding aa. Transformation to all lowercase can be configured in the ItemNumberSchema property. */\n    stringRepresentation?: string | undefined;\n    /** Indicates if the characters and the length of the Identifiers match the current ItemNumberSchema. */\n    readonly isSchemaCompliant?: boolean | undefined;\n    /** Used for representing and validating this ItemNumber. */\n    itemNumberSchema?: ItemNumberSchemaDto | undefined;\n    /** Collection of the single identifiers in this ItemNumber. P.e., \"02.03.004\" will have three elements \"02\", \"03\", and \"004\". Since ReadOnlyObservableCollection`1 does have the event set to protected, it can be accessed like this: (itemNumber.Identifiers as INotifyCollectionChanged).CollectionChanged */\n    identifiers?: string[] | undefined;\n    /** This indicates if this item number is at the lot level. Find out more about lots in the documentation. */\n    readonly isLot?: boolean | undefined;\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\n    hierarchyLevel?: number | undefined;\n    /** This property indicates if this ItemNumber is attached to an object of the Position type. */\n    readonly isAttachedToPosition?: boolean | undefined;\n    itemNumberSchemaBeforeMapping?: ItemNumberSchemaDto | undefined;\n}\n\n/** This is a classification for Position elements. */\nexport enum PositionTypeDto {\n    Regular = \"Regular\",\n    Optional = \"Optional\",\n    Alternative = \"Alternative\",\n}\n\n/** This indicates the price type of a IPricedElement. */\nexport enum PriceTypeDto {\n    WithTotal = \"WithTotal\",\n    WithoutTotal = \"WithoutTotal\",\n}\n\n/** The service type describes the type of service a Position represents. */\nexport enum ServiceTypeDto {\n    Regular = \"Regular\",\n    HourlyPaidWork = \"HourlyPaidWork\",\n}\n\n/** This class represents data about products and their vendor */\nexport interface ProductDataDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** This PartyInformation is used to describe details about the vendor of this ProductData. */\n    vendor?: PartyInformationDto | undefined;\n    /** The collection of ArticleData that describe this product, e.g. a pipe product could be composed out of multiple pipe segments and fittings. */\n    articles?: ArticleDataDto[] | undefined;\n    /** Short description for this ITextElement element. */\n    shortText?: string | undefined;\n    /** Detailed description for this ITextElement element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\n    longText?: string | undefined;\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\n    htmlLongText?: string | undefined;\n}\n\n/** This class represents a single article, usually used within ProductData */\nexport interface ArticleDataDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The name (or brand name) for this article, usually given by the supplier or vendor. */\n    name?: string | undefined;\n    /** An article number that describes it, useful when integrating other systems. */\n    articleNumber?: string | undefined;\n    /** Quantity for this article. If this is used within a Position, the quantity here should be the quantity required for the full quantity of the position, not for a single unit. */\n    quantity?: number | undefined;\n    /** The unit tag for this single ArticleData. */\n    unitTag?: string | undefined;\n    /** This is an optional text element that can be used to further describe the ArticleData. */\n    description?: string | undefined;\n    /** Short description for this ITextElement element. */\n    shortText?: string | undefined;\n    /** Detailed description for this ITextElement element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\n    longText?: string | undefined;\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\n    htmlLongText?: string | undefined;\n}\n\n/** Quantity assignments are, in contrast to SubDescriptions, used to categorize parts of their parent Position. For example, it could be categorized by cost group - e.g. a Position describing concrete walls could follow the German DIN 276 Cost Groups Standard and specify that of the total 1.000m² wall, 500m² are classified as exterior walls and 500m² are classified as interior walls. They would then have different cost groups associated, e.g. for accounting purposes. */\nexport interface QuantityAssignmentDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The total quantity in this quantity assignment */\n    quantity?: number | undefined;\n    /** These are Catalogue that are used within this ServiceSpecification. Catalogue references are used to describe catalogues, or collections, that can be used to describe elements with commonly known properties. For example, QuantityAssignments use these to categorize themselves. */\n    projectCatalogues?: CatalogueDto[] | undefined;\n    /** Referenced catalogues for this QuantityAssignment. */\n    catalogueReferences?: CatalogueReferenceDto[] | undefined;\n}\n\n/** This class holds specialized information that is relevant to trade or commerce based data exchange scenarios, e.g. between customers, vendors, suppliers and distributors. It is used when exporting to GAEB XML 9x exchange phases. */\nexport interface CommercePropertiesDto {\n    /** This maps to ArtNo in GAEB XML and represents an article number given by the supplier. */\n    articleNumber?: string | undefined;\n    /** This maps to EAN in GAEB XML and represents an GTIN (formerly EAN) article number. */\n    eanGtinArticleNumber?: string | undefined;\n    /** This maps to ArtNoID in GAEB XML and represents an ILN article number. */\n    ilnArticleNumber?: string | undefined;\n    /** This maps to CatalogNo in GAEB XML and represents an identifier of a specific catalogue. The referenced catalogue is usually a customer specific one, not related to CatalogueReferences. */\n    catalogueNumber?: string | undefined;\n    /** This maps to CatalogArtNo in GAEB XML and represents a key that maps to an entry in a specific catalogue. The referenced catalogue is usually a customer specific one, not related to CatalogueReferences. */\n    catalogueArticleNumber?: string | undefined;\n    /** This optional property can be used to indicate the basis for prices for a single position. Price basis means that the price is given per unit of the basis, e.g. per a pack of five when this property is set to '5'. */\n    priceBasis?: number | undefined;\n    /** This optional property can be used to indicate a sub position identifier specific for the commerce exchange */\n    subPositionIdentifier?: string | undefined;\n    /** In a commerce exchange, this property is usually used to reference the base item number of an underlying phase 83 exchange file */\n    customerBaseItemNumber?: string | undefined;\n}\n\n/** This class represents the linking to a complementary position with a specific quantity set. For example, Position 'A' could be complementing Position 'B' with a total quantity of 20 units */\nexport interface ComplementedByQuantityDto {\n    /** The quantity that is complemented. E.g., if the base position has a quantity of 100 m² of a brick wall, a complementing position might be for 'walls that exceed 3 m height' and for a total quantity of 10 m². */\n    quantity?: number | undefined;\n    /** This is the reference to the Id of the Position that is complementing. This means it does NOT reference the base position but the one that contains the actual addition. */\n    complementingPositionId?: string | undefined;\n}\n\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for Positions and extends the OenormProperties base class. */\nexport interface OenormPositionPropertiesDto {\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\n    originCode?: OenormOriginCodeDto | undefined;\n    /** This marks if the opening texts within this element are considered free text. It corresponds to 'vorbemerkungskennzeichen' in ÖNorm. */\n    openingTextIsFreeText?: boolean | undefined;\n    /** This indicates if the ÖNorm 'wesentliche position' mark is set */\n    isMainPosition?: boolean | undefined;\n    /** This indicates if the ÖNorm position was a 'ungeteilteposition' (undivided position). This will only be taken into account when the position is also the sole element inside it's parent group */\n    isUndividedPosition?: boolean | undefined;\n    /** In some ÖNorm formats, the short text can have it's own addition, so the text is split up in OenormShortText and OenormShortTextAddition To serialize this, either the ShortText property of the parent position needs to be null, or OenormShortText ' ' OenormShortTextAddition needs to match the ShortText. */\n    oenormShortText?: string | undefined;\n    /** In some ÖNorm formats, the short text can have it's own addition, so the text is split up in OenormShortText and OenormShortTextAddition To serialize this, either the ShortText property of the parent position needs to be null, or OenormShortText ' ' OenormShortTextAddition needs to match the ShortText. */\n    oenormShortTextAddition?: string | undefined;\n}\n\n/** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\nexport enum OenormOriginCodeDto {\n    Unknown = \"Unknown\",\n    FreeText = \"FreeText\",\n    AdditionDescription = \"AdditionDescription\",\n}\n\n/** This enumeration represents the status of an addendum, 'Nachtrag' in German */\nexport enum AddendumStatusDto {\n    Unknown = \"Unknown\",\n    Recognized = \"Recognized\",\n    Filed = \"Filed\",\n    Offered = \"Offered\",\n    Withdrawn = \"Withdrawn\",\n    Rejected = \"Rejected\",\n    RejectionObjected = \"RejectionObjected\",\n    FormallyAcknowledged = \"FormallyAcknowledged\",\n    Approved = \"Approved\",\n}\n\n/** This enum represents the different ways in which a complementing position type can be specified. It is typically only used in GAEB exports, since in Dangl.AVA, complementing positions are always explicitly referenced. */\nexport enum PositionComplementingTypeDto {\n    Undefined = \"Undefined\",\n    AllPreviousMarkedPositions = \"AllPreviousMarkedPositions\",\n    AllPreviousPositions = \"AllPreviousPositions\",\n    ReferencedPositions = \"ReferencedPositions\",\n}\n\n/** This class holds properties that describe retention types in position. Retention / hold out usually means that a service is provided and kept available for a specific amount of time, e.g. fences on a construction site */\nexport interface PositionHoldOutPropertiesDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The actual type */\n    holdOutType?: HoldOutTypeDto | undefined;\n    /** The duration of the period */\n    holdOutDuration?: number | undefined;\n    /** The time unit of the period */\n    holdOutDurationUnit?: HoldOutDurationUnitDto | undefined;\n    /** References to base positions */\n    basePositionReferences?: string[] | undefined;\n}\n\n/** Types of retentions to be used in positions */\nexport enum HoldOutTypeDto {\n    Unknown = \"Unknown\",\n    Base = \"Base\",\n    Extension = \"Extension\",\n    Rent = \"Rent\",\n}\n\n/** Duration used in retention positions */\nexport enum HoldOutDurationUnitDto {\n    Unknown = \"Unknown\",\n    Minutes = \"Minutes\",\n    Hours = \"Hours\",\n    Days = \"Days\",\n    Weeks = \"Weeks\",\n    Months = \"Months\",\n}\n\n/** Price catalogue data represents assumed or estimated prices from a catalogue source */\nexport interface PriceCatalogueDataDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The lower bound of the unit price */\n    unitPriceFrom?: number | undefined;\n    /** The upper bound of the unit price */\n    unitPriceTo?: number | undefined;\n    /** The average unit price */\n    unitPriceAverage?: number | undefined;\n    /** The lower bound of the wage price */\n    wagePriceFrom?: number | undefined;\n    /** The upper bound of the wage price */\n    wagePriceTo?: number | undefined;\n    /** The average wage price */\n    wagePriceAverage?: number | undefined;\n}\n\n/** An ExecutionDescription is used to give more details for certain items, especially on how they are meant to be executed. */\nexport interface ExecutionDescriptionDto extends IElementDto {\n    /** Blocks within an ExecutionDescription contain the actual information. */\n    blocks?: NoteTextDto[] | undefined;\n    /** Labels this ExecutionDescription. */\n    label?: string | undefined;\n    /** Uniquely identifies this ExecutionDescription. */\n    identifier?: string | undefined;\n    elementType?: string | undefined;\n}\n\n/** Represents an element that holds text information. */\nexport interface NoteTextDto extends IElementDto {\n    /** If this is set to true, this text is meant to not be seen as part of the regular elements hierarchy but as a special opening text at the beginning of the project. For example, in GAEB XML, this would map to the GAEB.Award.AddText. Typically, such texts describe project-wide contractual definitions. If this is set to true, this NoteText should be placed at the top of the elements hierarchy directly in the ServiceSpecification.Elements group, otherwise it will likely not be treated correctly when exporting to GAEB. You can only set IsOpeningText or IsClosingText to true. */\n    isOpeningText?: boolean | undefined;\n    /** If this is set to true, this text is meant to not be seen as part of the regular elements hierarchy but as a special closing text at the end of the project. For Example, in GAEB XML, this would map to the GAEB.AddText. Typically, such texts are used to describe project wide finishing descriptions. If this is set to true, this NoteText should be placed at the top of the elements hierarchy directly in the ServiceSpecification.Elements group, otherwise it will likely not be treated correctly when exporting to GAEB. You can only set IsOpeningText or IsClosingText to true. */\n    isClosingText?: boolean | undefined;\n    /** Short description for this DescriptionBase element. */\n    shortText?: string | undefined;\n    /** Indicates if this DescriptionBase element contains Buyer or Bidder additions to the text. */\n    additionType?: AdditionTypeDto | undefined;\n    /** Detailed description for this DescriptionBase element. When the HtmlLongText is set, this is automatically overwritten and filled with the appropriate plain text representation of the Html text. Vice versa, setting this property overrides the HtmlLongText. */\n    longText?: string | undefined;\n    /** This contains the Html representation of the Longtext. When the LongText is set, this is automatically overwritten and filled with the appropriate Html representation of the plaintext. Vice versa, setting this property overrides the LongText. GAEB 90 and GAEB 2000 exports do not support any image functionality. In GAEB XML, only images that use an embedded Base64 data uri are exported, regular url references are cleared before written out. */\n    htmlLongText?: string | undefined;\n    /** This is an optional internal identifier that may be used to add additional information to this NoteText. It is not supported in GAEB import or export. */\n    identifier?: string | undefined;\n    /** This represents a standardized description. This means that instead of solely relying on texts to describe a service, external standards and definitions are referenced for a common understanding. */\n    standardizedDescription?: StandardizedDescriptionDto | undefined;\n    elementType?: string | undefined;\n    /** This is an identifier specific for this description. Some exchange formats, like GAEB XML, use it to identify descriptions. It's different to an elements identifier in that it should only apply to the description component, meaning the text itself. */\n    descriptionId?: string | undefined;\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for NoteTexts. */\n    oenormNoteTextProperties?: OenormNoteTextPropertiesDto | undefined;\n    readonly hasBidderCommentInHtmlLongText?: boolean | undefined;\n}\n\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. It is special for NoteTexts. */\nexport interface OenormNoteTextPropertiesDto {\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\n    originCode?: OenormOriginCodeDto | undefined;\n}\n\n/** This is a grouping IElement that holds other IElements within. */\nexport interface ServiceSpecificationGroupDto extends IElementDto {\n    /** The hourly wage that is used within this ElementContainerBase. Will be propagated to child elements. */\n    readonly projectHourlyWage?: number | undefined;\n    /** The tax rate that is used within this ElementContainerBase. Will be propagated to child elements. */\n    projectTaxRate?: number | undefined;\n    /** The price components that are used within this project. They are ignored during Json deserialization because they will be set from the parent project. */\n    projectPriceComponents?: string[] | undefined;\n    /** The ItemNumberSchema that is used within this project. */\n    projectItemNumberSchema?: ItemNumberSchemaDto | undefined;\n    /** The IElements within this ElementContainerBase. */\n    elements?: IElementDto[] | undefined;\n    /** The label used in the parent Project to mark labour time, e.g. \"Hours\" or \"Stunden\". */\n    readonly projectLabourTimeLabel?: string | undefined;\n    /** Indicates if there are child IElements that have conflicting, duplicated ItemNumbers or if any child ElementContainerBase elements themselves contain duplicate ItemNumber s. Will always indicate false when told to ignore duplicate item numbers. */\n    readonly containsDuplicateItemNumbers?: boolean | undefined;\n    /** Indicates if there are child IElements that have conflicting, duplicated Ids or if any child ElementContainerBase elements themselves contain duplicate Id s. Will always indicate false when told to ignore duplicate item numbers. */\n    readonly containsDuplicateElementIds?: boolean | undefined;\n    /** Indicate if duplicated ItemNumbers within child elements are to be ignored. Will not perform checks for duplicates if yes. */\n    ignoreDuplicateItemNumbers?: boolean | undefined;\n    /** If this is set to true, the ProjectCatalogues property will not be propagated to child elements. This is useful in mapping scenarios, where you want to disable propagation for multiple changes, and only enable it once you have mapped all properties */\n    ignoreProjectCataloguePropagation?: boolean | undefined;\n    /** Indicate if duplicated Ids within child elements are to be ignored. Will not perform checks for duplicates if yes. */\n    ignoreDuplicateElementIds?: boolean | undefined;\n    /** Price composition by tax rate. */\n    totalPriceGrossByTaxRate?: GrossPriceComponentDto[] | undefined;\n    /** Internally used to indicate that a propagation is currently done, this is done to not recalculate every single result from a lot of changes when it is sufficient to calculate the total price at once. */\n    ignoreChildPriceUpdates?: boolean | undefined;\n    /** Net price after applied deductions. */\n    readonly deductedPrice?: number | undefined;\n    /** Factor of applied deductions to the total price. For example, \"0.03\" means that a 3% deduction is to be applied. */\n    deductionFactor?: number | undefined;\n    /** The exact amount of the discount as an absolute value. For backwards compatibility reasons, setting this value will also set a calculated value to DeductionFactor, which will also be updated in case the total price is changed to reflect a relative value of the absolute discount sum. */\n    absoluteDeduction?: number | undefined;\n    /** Will return this ElementContainerBase's total price. */\n    readonly totalPrice?: number | undefined;\n    /** The total gross price for this ElementContainerBase including all child elements. */\n    readonly totalPriceGross?: number | undefined;\n    /** Total gross price after applied deductions. */\n    readonly totalPriceGrossDeducted?: number | undefined;\n    /** Indicates the PriceType of this ElementContainerBase, whether it should factor into total costs or not. */\n    priceType?: PriceTypeDto | undefined;\n    /** Description for this ServiceSpecificationGroup. */\n    shortText?: string | undefined;\n    /** Indicates if this service specification group is commissioned (and therefore should be executed), postponed for later or undefined. */\n    comissionStatus?: ComissionStatusDto | undefined;\n    /** The ItemNumber for this INumberedElement interface. */\n    itemNumber?: ItemNumberDto | undefined;\n    elementType?: string | undefined;\n    /** This indicates if this group is the parent of a lot. See the documentation for more information about working with lots. */\n    readonly isLot?: boolean | undefined;\n    /** If this group is an alternative for a base group, then this property should point to the id of the group in this service specification that it can replace. If this is an alternative group to a base group, the PriceType should typically be set to \"WithoutTotal\" so this group does not factor into total costs. The PriceType is not changed when this property is set */\n    alternativeTo?: string | undefined;\n    v1CompatibilityPriceType?: string | undefined;\n    /** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. */\n    oenormProperties?: OenormPropertiesDto | undefined;\n    /** This is a zero based hierarchy level. It's set automatically when used in the context of a Project, and can be used to identify the hierarchy level of the current element. */\n    hierarchyLevel?: number | undefined;\n    /** This indicates, if this element is part of an addendum an, if yes, with what status. */\n    addendumStatus?: AddendumStatusDto | undefined;\n    /** This is internally used during mapping operations to temporarily hold information about removed ItemNumberSchemas. Those schemas are set to null during the mapping process to ensure that schemas in elements higher up in the hierarchy are correctly passed down to child elements. */\n    itemNumberSchemaMappingOperation?: ItemNumberSchemaMappingOperation | undefined;\n    /** This is an optional property that can be used together with AlternativeTo. If this is set, you can indicate which alternative group a specific group is assigned to. That way, if you specifiy multiple alternative ServiceSpecificationGroups with the same AlternativeIdentifier, you can indicate that to replace a single base ServiceSpecificationGroup, multiple alternative ServiceSpecificationGroups should be used. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base group via AlternativeTo. */\n    alternativeIdentifier?: number | undefined;\n    /** This is an optional property that can be used together with AlternativeTo and AlternativeGroupIdentifier. If this is set, you can indicate which alternative group a specific group is assigned to. That way, you can specify the id (in integer format) for the alternative group this group belongs to. It's different to AlternativeIdentifier in that the other property describes the id of the group, while this property here describes the group itself. If a group only has set AlternativeGroupIdentifier but not AlternativeIdentifier, then it likely is a base group for a specific group. This property is not checked or managed automatically, so it is possible for this property to become invalid, by for example setting this property but not setting a base group via AlternativeTo. */\n    alternativeGroupIdentifier?: number | undefined;\n}\n\n/** This is used in an ElementContainerBase to hold the price composition. */\nexport interface GrossPriceComponentDto {\n    /** This components tax rate. */\n    taxRate?: number | undefined;\n    /** This is the factor of applied deductions for this component */\n    deductionFactor?: number | undefined;\n    /** The total net price for all components of a given tax rate. */\n    totalNet?: number | undefined;\n    /** The resulting price component after applied deductions */\n    readonly totalDeducted?: number | undefined;\n    /** The total tax amount for all components of a given tax rate. */\n    readonly totalTax?: number | undefined;\n    /** The total gross price for all components of a given tax rate. */\n    readonly totalGross?: number | undefined;\n    /** The total gross price for all components of a given tax rate, after applied deductions. */\n    readonly totalGrossDeducted?: number | undefined;\n    /** The total tax amount for all components of a given tax rate, after applied deductions. */\n    readonly totalTaxDeducted?: number | undefined;\n}\n\n/** This class models special properties that only apply to some exchange scenarios where ÖNorm is used. */\nexport interface OenormPropertiesDto {\n    /** This indicates where the content of this element originates, if set. It corresponds to 'herkunftskennzeichen' in ÖNorm */\n    originCode?: OenormOriginCodeDto | undefined;\n    /** This marks if the opening texts within this element are considered free text. It corresponds to 'vorbemerkungskennzeichen' in ÖNorm. */\n    openingTextIsFreeText?: boolean | undefined;\n}\n\n/** This abstract class is used internally to hold results about an item number schema removal operation. Item number schemas are removed during the mapping process to allow top-down propagation after conversion, but are then added back to the DTOs to preserve the original source. */\nexport interface ItemNumberSchemaMappingOperation {\n}\n\n/** Indicates a ServiceSpecification's exchange phase, based on the GAEB exchange phases. */\nexport enum ExchangePhaseDto {\n    Undefined = \"Undefined\",\n    Base = \"Base\",\n    CostEstimate = \"CostEstimate\",\n    OfferRequest = \"OfferRequest\",\n    Offer = \"Offer\",\n    SideOffer = \"SideOffer\",\n    Grant = \"Grant\",\n}\n\n/** Indicates where a service specification was originally created. */\nexport enum OriginDto {\n    Self = \"Self\",\n    Gaeb90 = \"Gaeb90\",\n    Gaeb2000 = \"Gaeb2000\",\n    GaebXml = \"GaebXml\",\n    Oenorm = \"Oenorm\",\n    Reb = \"Reb\",\n    Sia = \"Sia\",\n}\n\n/** Holds global price information for a ServiceSpecification */\nexport interface PriceInformationDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The amount of currency per one hour of manual labour work in this project. */\n    hourlyWage?: number | undefined;\n    /** The final, total price will be deducted by this rate. */\n    deductionFactor?: number | undefined;\n    /** This is given when there is only one flat price for the whole service specification. */\n    flatSum?: number | undefined;\n    /** Global tax rate for the project. Note that certain elements may have a different, specific tax rate. */\n    taxRate?: number | undefined;\n    /** This property indicates if the TaxRate property is actually zero (0) or if it's just unset. The TaxRate is a non-nullable property, so it can't be null and therefore a distinction between unset and zero relies on this additional property. When exporting to GAEB, this can be used e.g. to decide whether or not the tax rate should be serialized. This property is automtically set to false when the TaxRate is set to any value, even zero. If the TaxRate is not set to zero, this property will always return false and can not be set to true. */\n    hasUnsetTaxRate?: boolean | undefined;\n    /** Trade discounts for offered in this ServiceSpecification. */\n    tradeDiscounts?: TradeDiscountDto[] | undefined;\n}\n\n/** This class holds information about offered trade discounts (Skonto in German) */\nexport interface TradeDiscountDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** The amount of days for how long a declared trade discount applies. Must be a positive number, negative values will be ignored and not set. */\n    deadline?: number | undefined;\n    /** The rate of the trade discount. */\n    rate?: number | undefined;\n}\n\n/** This class does not represent a typical `TimeSpan` but has a scalar value int Duration and a DurationUnit Unit to represent durations as typically used in contracts, e.g. 5 Months */\nexport interface WarrantyDurationDto {\n    /** The scalar value of the duration. This value must be equal to or bigger than zero (>= 0). Negative values can not be set and will be ignored. */\n    duration?: number | undefined;\n    /** The unit of the duration */\n    unit?: DurationUnitDto | undefined;\n}\n\n/** This enumeration represents the unit of a duration */\nexport enum DurationUnitDto {\n    Months = \"Months\",\n    Years = \"Years\",\n}\n\n/** This class represents properties used in commerce exchange scenarios */\nexport interface ServiceSpecificationCommercePropertiesDto {\n    /** The date until the price is valid or fixed. */\n    fixedPriceDate?: Date | undefined;\n    /** The date of the delivery voucher note. */\n    deliveryVoucherDate?: Date | undefined;\n    /** The actual date of delivery. */\n    deliveryDate?: Date | undefined;\n    /** The number of the inquiry, usually in a context of offer requests. */\n    inquiryNumber?: string | undefined;\n    /** The number of the offer, usually in a context of an offer. */\n    offerNumber?: string | undefined;\n    /** The order number, usually in the context of a grant or contract. */\n    orderNumber?: string | undefined;\n    /** The order confirmation number */\n    orderConfirmationNumber?: string | undefined;\n    /** The number of the delivery, e.g. on the delivery note voucher. */\n    deliveryNumber?: string | undefined;\n    /** The reference number of the customer / buyer. */\n    customerReferenceNumber?: string | undefined;\n    /** The reference number of the supplier / bidder. */\n    supplierReferenceNumber?: string | undefined;\n    /** The type of shippment. */\n    shippingType?: string | undefined;\n    /** The type of the price inquiry. */\n    inquiryType?: CommerceInquiryTypeDto | undefined;\n}\n\n/** This enum represents types of price inquiries */\nexport enum CommerceInquiryTypeDto {\n    Unknown = \"Unknown\",\n    Project = \"Project\",\n    Immediate = \"Immediate\",\n    Exhibition = \"Exhibition\",\n}\n\nexport interface ComplementingPositionData {\n    positionsById?: { [key: string]: PositionDto; } | undefined;\n    basePositions?: { [key: string]: PositionDto; } | undefined;\n    complementingPositionIds?: string[] | undefined;\n}\n\n/** A Project contains all relevant information for a construction project. */\nexport interface ProjectDto {\n    /** Elements GUID identifier. */\n    id: string;\n    /** This property controls the accuracy of all price properties, meaning how many decimal places are preserved in calculations. It defaults to DEFAULT_PRICE_ACCURACY. Please see the Dangl.AVA documentation for further information about decimal precision. If UnitPriceAccuracy is set, then this property is ignored for unit prices. */\n    priceAccuracy?: number | undefined;\n    /** This property controls the accuracy of position unit price properties, meaning how many decimal places are preserved in calculations. Please see the Dangl.AVA documentation for further information about decimal precision. This can be separately set from PriceAccuracy, and it only controls the accuracy of the unit price of positions, not the total price. It defaults to null, which means the standard PriceAccuracy is used for unit prices. */\n    unitPriceAccuracy?: number | undefined;\n    /** This forces total prices to be the strict product of quantities times unit price in positions. It is enabled by default. If this is disabled, both the unit price and the total price of positions is calculated from the non-rounded values. Please see the documentation for a more detailed explanation of this setting. */\n    forceStrictTotals?: boolean | undefined;\n    /** This property controls the rounding mode of all price properties, meaning how rounding of decimal places is performed in price calculations. It defaults to DEFAULT_ROUNDING_MODE. Please see the Dangl.AVA documentation for further information about decimal precision. */\n    priceRoundingMode?: PriceRoundingModeDto | undefined;\n    /** The ProjectInformation contains information that describes the project and its structure. */\n    projectInformation?: ProjectInformationDto | undefined;\n    /** The ServiceSpecifications in this Project. */\n    serviceSpecifications?: ServiceSpecificationDto[] | undefined;\n    /** This is used to store the GAEB XML Id within this Project. This data is not used for any calculations or evaluations but only for GAEB serialization and deserialization. */\n    gaebXmlId?: string | undefined;\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51LWRhdGEubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWF2YS9zcmMvbGliL2F2YS10cmVlL3RyZWUvbW9kZWwvY29udGV4dC1tZW51LWRhdGEubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElFbGVtZW50RHRvIH0gZnJvbSAnLi9hdmEtbW9kZWxzJztcclxuXHJcbmV4cG9ydCB0eXBlIENvbnRleHRNZW51RGF0YVR5cGUgPSB7XHJcbiAgcG9zaXRpb246IHsgeDogc3RyaW5nOyB5OiBzdHJpbmcgfTtcclxuICBub2RlOiBJRWxlbWVudER0bztcclxufTtcclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51LWRhdGEubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWF2YS9zcmMvbGliL2F2YS10cmVlL3RyZWUvbW9kZWwvY29udGV4dC1tZW51LWRhdGEubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElFbGVtZW50RHRvIH0gZnJvbSAnLi9hdmEtbW9kZWxzJztcblxuZXhwb3J0IHR5cGUgQ29udGV4dE1lbnVEYXRhVHlwZSA9IHtcbiAgcG9zaXRpb246IHsgeDogc3RyaW5nOyB5OiBzdHJpbmcgfTtcbiAgbm9kZTogSUVsZW1lbnREdG87XG59O1xuIl19