Crm.Pricing.BonusPrograms Entity
Namespace: Crm.Pricing
Bonus programs allow automatic adding of new line with bonus product or automatic application of discount in a sales document. Entity: Crm_Bonus_Programs
Renames
Old name: Crm.Marketing.BonusPrograms
New name: Crm.Pricing.BonusPrograms
Version: 25.1.1.36
Case: 37717
Default Visualization
Default Display Text Format:
{Name:T}
Default Search Members:
Name
Name Data Member:
Name
Category: Definitions
Show in UI: ShownByDefault
Track Changes
Min level: 0 - Do not track changes
Max level: 4 - Track object attribute and blob changes
Aggregate
An aggregate is a cluster of domain objects that can be treated as a single unit.
Aggregate Tree
Attributes
Name | Type | Description |
---|---|---|
Active | boolean nullable | General condition if the bonus is active. The other conditions are verified only for active bonus programs. Default(true) Filter(eq) |
BonusAction | BonusAction | If the bonus is a product, then Bonus Product, Bonus Product Quantity and Bonus Product Quantity Unit fields should be filled in. If the bonus is a discount, the Bonus Line Discount Percent should be filled in. Product - add product to the order, Discount – replace the standard discount, Cascade discount - apply after the standard discount. Required Default("D") Filter(multi eq) |
BonusDocumentAmountPercent | decimal (7, 6) nullable | The percent of the document amount that is rewarded. Should be null if and only if the bonus document amount is null. |
BonusLineDiscountPercent | decimal (7, 6) | The percent discount to be applied to bonus lines. Used only for bonus programs with Action = D (Discount) and Action = C (Cascade discount). Required Default(0) |
BonusProductQuantity | Quantity (12, 3) nullable | The quantity rewarded of the bonus product. Should be not null if and only when the bonus product is not null. Unit: BonusProductQuantityUnit |
BonusProductQuantity MultiplierForEach LotSize |
Quantity (12, 3) nullable | When not null, specifies that the bonus quantity should be multiplied for each of the specified lot size. Can be non-null only when condition product is specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit |
ConditionCustomerFilterXML | dataaccessfilter nullable | When not null, specifies that the bonus should be applied only to customers who meet the specified criteria. The criteria could include custom properties. Unit: CustomersRepository.TableName |
ConditionDistribution ChannelFilterX ML |
dataaccessfilter nullable | When not null, specifies that the bonus should be applied only when the distribution channel of the sales order has the specified characteristics. Unit: Marketing.DistributionChannels<br />Repository.TableName |
ConditionFromDate | datetime nullable | Starting date of the bonus. null means that there is no starting date restriction. Filter(eq;ge;le) |
ConditionMaxAmount | Amount (12, 2) nullable | If not null specifies the maximal amount for which the bonus is valid. null means that there is no maximal amount condition for the bonus. Currency: ConditionDocumentCurrency Filter(eq;ge;le) |
ConditionMaxQuantity | Quantity (12, 3) nullable | When not null, specifies condition for the bonus - maximal quantity of the condition product. If the condition product is null, this cannot be specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit Filter(eq;ge;le) |
ConditionMinAmount | Amount (12, 2) nullable | If not null specifies the minimal amount for which the bonus is valid. null means that there is no minimal amount condition for the bonus. Currency: ConditionDocumentCurrency Filter(eq;ge;le) |
ConditionMinQuantity | Quantity (12, 3) nullable | When not null, specifies condition for the bonus - minimal quantity of the condition product. If the condition product is null, this cannot be specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit Filter(eq;ge;le) |
ConditionShipTo CustomerFilter XML |
dataaccessfilter nullable | When not null, specifies that the bonus should be applied only when shipping to customer with the specified characteristics. Unit: CustomersRepository.TableName |
ConditionToDate | datetime nullable | Ending date (inclusive) of the bonus. null means that there is no ending date restriction. Filter(eq;ge;le) |
DisplayText | string | Uses the repository DisplayTextFormat to build the display text from the attributes and references of current object. |
Id | guid | |
Name | MultilanguageString (254) | The name of the bonus program. Required Filter(eq;like) |
ObjectVersion | int32 | The latest version of the extensible data object for the aggregate root for the time the object is loaded from the database. Can be used for optimistic locking. |
Priority | Priority | Priority (1-5) of the bonus program comparative to the other bonus programs. 1 is the lowest priority. Required Default(2) Filter(multi eq) |
References
Name | Type | Description |
---|---|---|
BonusDocumentAmountType | DocumentAmountTypes (nullable) | When not null specifies that a document amount should be added to the order when the bonus conditions are met. null means that the bonus reward is not a document amount. Filter(multi eq) |
BonusProduct | Products (nullable) | The product that is rewarded if the bonus conditions are met. null means that the bonus reward is not product. Filter(multi eq) |
BonusProductQuantityUnit | MeasurementUnits (nullable) | The measurement unit of the quantity rewarded of the bonus product. Should be not null if and only when the bonus product is not null. Filter(multi eq) |
Campaign | Campaigns (nullable) | Тhe marketing campaign to which the current definition belongs. Filter(multi eq) Introduced in version 22.1.4.67 |
CompanyLocation | CompanyLocations (nullable) | When set, specifies that the sales document must be of the specified enterprise company location. Filter(multi eq) |
ConditionCustomer | Customers (nullable) | When not null, specifies that the bonus should be applied only to the specified customer. Filter(multi eq) |
ConditionDistribution Channel |
DistributionChannels (nullable) | When not null, specifies that the bonus should be applied only when the specified channel is used. Filter(multi eq) |
ConditionDocumentCurrency | Currencies (nullable) | Condition for the document amount. Should be not null if any of the amount conditions are not null. Filter(multi eq) |
ConditionPriceList | PriceLists (nullable) | When not null, specifies that the bonus should be applied only when the sales order is based on the speicfied price list. Filter(multi eq) |
ConditionProduct | Products (nullable) | When not null, specifies a conditional product, which is required to exist in the sales document in order for the bonus program to be applied. If a condition with multiple products is required, additional products can be added to Bonus Program Products. If null the other conditions should be evaluated against the whole order. Filter(multi eq) |
ConditionProductGroup | ProductGroups (nullable) | When not null, specifies that the bonus should be applied only to products from the specified product group or its subgroups. Filter(multi eq) |
ConditionShipToCustomer | Customers (nullable) | When not null, specifies that the bonus should be applied only when shipping to the specified customer. Filter(multi eq) |
ConditionTargetGroup | TargetGroups (nullable) | When not null, specifies that the bonus should be applied only to the specified target customer group. Filter(multi eq) |
DocumentAmountType | DocumentAmountTypes (nullable) | The document amount type that is used as а category. When specified, triggers the recording of the applied discount amount that comes from the bonus program in the Document Distributed Amounts panel in sales orders. Filter(multi eq) Introduced in version 25.1.1.66 |
EnterpriseCompany | EnterpriseCompanies (nullable) | When set, specifies that the sales document must be of the specified enterprise company. Filter(multi eq) |
Child Collections
Name | Type | Description |
---|---|---|
Products | BonusProgramProducts | List of BonusProgramProduct (Crm.Pricing.BonusProgramProducts.md) child objects, based on the Crm.Pricing.BonusProgramProduct.BonusProgram (Crm.Pricing.BonusProgramProducts.md#bonusprogram) back reference |
Attribute Details
Active
General condition if the bonus is active. The other conditions are verified only for active bonus programs. Default(true)
Filter(eq)
Type: boolean nullable
Category: System
Supported Filters: Equals
Supports Order By: False
Default Value: True
Show in UI: ShownByDefault
BonusAction
If the bonus is a product, then Bonus Product, Bonus Product Quantity and Bonus Product Quantity Unit fields should be filled in. If the bonus is a discount, the Bonus Line Discount Percent should be filled in. Product - add product to the order, Discount – replace the standard discount, Cascade discount - apply after the standard discount. Required
Default("D")
Filter(multi eq)
Type: BonusAction
Category: System
Allowed values for the BonusAction
(Crm.Pricing.BonusPrograms.md#bonusaction) data attribute
Allowed Values (Crm.Pricing.BonusProgramsRepository.BonusAction Enum Members)
Value | Description |
---|---|
Product | Product value. Stored as 'P'. Database Value: 'P' Model Value: 0 Domain API Value: 'Product' |
Discount | Discount value. Stored as 'D'. Database Value: 'D' Model Value: 1 Domain API Value: 'Discount' |
CascadeDiscount | CascadeDiscount value. Stored as 'C'. Database Value: 'C' Model Value: 2 Domain API Value: 'CascadeDiscount' |
Supported Filters: Equals, EqualsIn
Supports Order By: False
Default Value: Discount
Show in UI: ShownByDefault
BonusDocumentAmountPercent
The percent of the document amount that is rewarded. Should be null if and only if the bonus document amount is null.
Type: decimal (7, 6) nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: CannotBeShown
BonusLineDiscountPercent
The percent discount to be applied to bonus lines. Used only for bonus programs with Action = D (Discount) and Action = C (Cascade discount). Required
Default(0)
Type: decimal (7, 6)
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Default Value: 0
Show in UI: ShownByDefault
BonusProductQuantity
The quantity rewarded of the bonus product. Should be not null if and only when the bonus product is not null. Unit: BonusProductQuantityUnit
Type: Quantity (12, 3) nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: ShownByDefault
BonusProductQuantityMultiplierForEachLotSize
When not null, specifies that the bonus quantity should be multiplied for each of the specified lot size. Can be non-null only when condition product is specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit
Type: Quantity (12, 3) nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: ShownByDefault
ConditionCustomerFilterXML
When not null, specifies that the bonus should be applied only to customers who meet the specified criteria. The criteria could include custom properties. Unit: CustomersRepository.TableName
Type: dataaccessfilter nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: ShownByDefault
ConditionDistributionChannelFilterXML
When not null, specifies that the bonus should be applied only when the distribution channel of the sales order has the specified characteristics. Unit: Marketing.DistributionChannelsRepository.TableName
Type: dataaccessfilter nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: ShownByDefault
ConditionFromDate
Starting date of the bonus. null means that there is no starting date restriction. Filter(eq;ge;le)
Type: datetime nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
ConditionMaxAmount
If not null specifies the maximal amount for which the bonus is valid. null means that there is no maximal amount condition for the bonus. Currency: ConditionDocumentCurrency
Filter(eq;ge;le)
Type: Amount (12, 2) nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
ConditionMaxQuantity
When not null, specifies condition for the bonus - maximal quantity of the condition product. If the condition product is null, this cannot be specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit
Filter(eq;ge;le)
Type: Quantity (12, 3) nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
ConditionMinAmount
If not null specifies the minimal amount for which the bonus is valid. null means that there is no minimal amount condition for the bonus. Currency: ConditionDocumentCurrency
Filter(eq;ge;le)
Type: Amount (12, 2) nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
ConditionMinQuantity
When not null, specifies condition for the bonus - minimal quantity of the condition product. If the condition product is null, this cannot be specified. Unit: ConditionProduct.BaseMeasurementCategory.BaseUnit
Filter(eq;ge;le)
Type: Quantity (12, 3) nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
ConditionShipToCustomerFilterXML
When not null, specifies that the bonus should be applied only when shipping to customer with the specified characteristics. Unit: CustomersRepository.TableName
Type: dataaccessfilter nullable
Category: System
Supported Filters: NotFilterable
Supports Order By: False
Show in UI: ShownByDefault
ConditionToDate
Ending date (inclusive) of the bonus. null means that there is no ending date restriction. Filter(eq;ge;le)
Type: datetime nullable
Category: System
Supported Filters: Equals, GreaterThanOrLessThan
Supports Order By: False
Show in UI: ShownByDefault
DisplayText
Uses the repository DisplayTextFormat to build the display text from the attributes and references of current object.
Type: string
Category: Calculated Attributes
Supported Filters: NotFilterable
Supports Order By: ****
Show in UI: HiddenByDefault
Id
Type: guid
Indexed: True
Category: System
Supported Filters: Equals, EqualsIn
Default Value: NewGuid
Show in UI: CannotBeShown
Name
The name of the bonus program. Required
Filter(eq;like)
Type: MultilanguageString (254)
Category: System
Supported Filters: Equals, Like
Supports Order By: False
Show in UI: ShownByDefault
ObjectVersion
The latest version of the extensible data object for the aggregate root for the time the object is loaded from the database. Can be used for optimistic locking.
Type: int32
Category: Extensible Data Object
Supported Filters: NotFilterable
Supports Order By: ****
Show in UI: HiddenByDefault
Priority
Priority (1-5) of the bonus program comparative to the other bonus programs. 1 is the lowest priority. Required
Default(2)
Filter(multi eq)
Type: Priority
Category: System
Allowed values for the Priority
(Crm.Pricing.BonusPrograms.md#priority) data attribute
Allowed Values (Crm.Pricing.BonusProgramsRepository.Priority Enum Members)
Value | Description |
---|---|
v_1Lowest | v_1Lowest value. Stored as 0. Database Value: 0 Model Value: 0 Domain API Value: 'v_1Lowest' |
Two | Two value. Stored as 1. Database Value: 1 Model Value: 1 Domain API Value: 'Two' |
Three | Three value. Stored as 2. Database Value: 2 Model Value: 2 Domain API Value: 'Three' |
Four | Four value. Stored as 3. Database Value: 3 Model Value: 3 Domain API Value: 'Four' |
v_5Highest | v_5Highest value. Stored as 4. Database Value: 4 Model Value: 4 Domain API Value: 'v_5Highest' |
Supported Filters: Equals, EqualsIn
Supports Order By: False
Default Value: 2
Show in UI: ShownByDefault
Reference Details
BonusDocumentAmountType
When not null specifies that a document amount should be added to the order when the bonus conditions are met. null means that the bonus reward is not a document amount. Filter(multi eq)
Type: DocumentAmountTypes (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: CannotBeShown
BonusProduct
The product that is rewarded if the bonus conditions are met. null means that the bonus reward is not product. Filter(multi eq)
Type: Products (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
BonusProductQuantityUnit
The measurement unit of the quantity rewarded of the bonus product. Should be not null if and only when the bonus product is not null. Filter(multi eq)
Type: MeasurementUnits (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
Campaign
Тhe marketing campaign to which the current definition belongs. Filter(multi eq)
Introduced in version 22.1.4.67
Type: Campaigns (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
CompanyLocation
When set, specifies that the sales document must be of the specified enterprise company location. Filter(multi eq)
Type: CompanyLocations (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionCustomer
When not null, specifies that the bonus should be applied only to the specified customer. Filter(multi eq)
Type: Customers (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionDistributionChannel
When not null, specifies that the bonus should be applied only when the specified channel is used. Filter(multi eq)
Type: DistributionChannels (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionDocumentCurrency
Condition for the document amount. Should be not null if any of the amount conditions are not null. Filter(multi eq)
Type: Currencies (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionPriceList
When not null, specifies that the bonus should be applied only when the sales order is based on the speicfied price list. Filter(multi eq)
Type: PriceLists (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionProduct
When not null, specifies a conditional product, which is required to exist in the sales document in order for the bonus program to be applied. If a condition with multiple products is required, additional products can be added to Bonus Program Products. If null the other conditions should be evaluated against the whole order. Filter(multi eq)
Type: Products (nullable)
Indexed: True
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionProductGroup
When not null, specifies that the bonus should be applied only to products from the specified product group or its subgroups. Filter(multi eq)
Type: ProductGroups (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionShipToCustomer
When not null, specifies that the bonus should be applied only when shipping to the specified customer. Filter(multi eq)
Type: Customers (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
ConditionTargetGroup
When not null, specifies that the bonus should be applied only to the specified target customer group. Filter(multi eq)
Type: TargetGroups (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
DocumentAmountType
The document amount type that is used as а category. When specified, triggers the recording of the applied discount amount that comes from the bonus program in the Document Distributed Amounts panel in sales orders. Filter(multi eq)
Introduced in version 25.1.1.66
Type: DocumentAmountTypes (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
EnterpriseCompany
When set, specifies that the sales document must be of the specified enterprise company. Filter(multi eq)
Type: EnterpriseCompanies (nullable)
Category: System
Supported Filters: Equals, EqualsIn
Show in UI: ShownByDefault
API Methods
Methods that can be invoked in public APIs.
GetAllowedCustomPropertyValues
Gets the allowed values for the specified custom property for this entity object. If supported the result is ordered by property value. Some property value sources do not support ordering - in that case the result is not ordered.
Return Type: Collection Of CustomPropertyValue
Declaring Type: EntityObject
Domain API Request: GET
Parameters
customPropertyCode
The code of the custom property
Type: stringsearch
The search text - searches by value or description. Can contain wildcard character %.
Type: string
Optional: True
Default Value: nullexactMatch
If true the search text should be equal to the property value
Type: boolean
Optional: True
Default Value: FalseorderByDescription
If true the result is ordered by Description instead of Value. Note that ordering is not always possible.
Type: boolean
Optional: True
Default Value: Falsetop
The top clause - default is 10
Type: int32
Optional: True
Default Value: 10skip
The skip clause - default is 0
Type: int32
Optional: True
Default Value: 0
CreateNotification
Create a notification immediately in a separate transaction, and send a real-time event to the user.
Return Type: void
Declaring Type: EntityObject
Domain API Request: POST
Parameters
user
The user.
Type: UsersnotificationClass
The notification class.
Type: stringsubject
The notification subject.
Type: string
CreateCopy
Duplicates the object and its child objects belonging to the same aggregate. The duplicated objects are not saved to the data source but remain in the same transaction as the original object.
Return Type: EntityObject
Declaring Type: EntityObject
Domain API Request: POST
Business Rules
Front-End Business Rules
None
API
Domain API Query: https://demodb.my.erp.net/api/domain/odata/Crm_Pricing_BonusPrograms?$top=10
Domain API Query Builder: https://demodb.my.erp.net/api/domain/querybuilder#Crm_Pricing_BonusPrograms?$top=10