squareup 2.13.0

Rust SDK for the Square Developer API
Documentation
//! Model struct for CatalogDiscount type.

use serde::{Deserialize, Serialize};

use super::{
    Money,
    enums::{CatalogDiscountModifyTaxBasis, CatalogDiscountType},
};

/// A discount applicable to items.
#[derive(Clone, Debug, Default, Deserialize, Eq, PartialEq, Serialize)]
pub struct CatalogDiscount {
    /// The discount name. This is a searchable attribute for use in applicable query filters, and
    /// its value length is of Unicode code points.
    pub name: Option<String>,
    /// Indicates whether the discount is a fixed amount or percentage, or entered at the time of sale.
    pub discount_type: Option<CatalogDiscountType>,
    /// The percentage of the discount as a string representation of a decimal number, using a `.`
    /// as the decimal separator and without a `%` sign. A value of `7.5` corresponds to `7.5%`.
    /// Specify a percentage of `0` if `discount_type` is `VARIABLE_PERCENTAGE`.
    ///
    /// Do not use this field for amount-based or variable discounts.
    pub percentage: Option<String>,
    /// The amount of the discount. Specify an amount of `0` if `discount_type` is
    /// `VARIABLE_AMOUNT`.
    ///
    /// Do not use this field for percentage-based or variable discounts.
    pub amount_money: Option<Money>,
    /// Indicates whether a mobile staff member needs to enter their PIN to apply the discount to a
    /// payment in the Square Point of Sale app.
    pub pin_required: Option<bool>,
    /// The color of the discount display label in the Square Point of Sale app. This must be a
    /// valid hex color code.
    pub label_color: Option<String>,
    /// Indicates whether this discount should reduce the price used to calculate tax.
    ///
    /// Most discounts should use `MODIFY_TAX_BASIS`. However, in some circumstances taxes must be
    /// calculated based on an item's price, ignoring a particular discount. For example, in many US
    /// jurisdictions, a manufacturer coupon or instant rebate reduces the price a customer pays but
    /// does not reduce the sale price used to calculate how much sales tax is due. In this case,
    /// the discount representing that manufacturer coupon should have `DO_NOT_MODIFY_TAX_BASIS` for
    /// this field.
    ///
    /// If you are unsure whether you need to use this field, consult your tax professional.
    pub modify_tax_basis: Option<CatalogDiscountModifyTaxBasis>,
    /// For a percentage discount, the maximum absolute value of the discount. For example, if a 50%
    /// discount has a `maximum_amount_money` of $20, a $100 purchase will yield a $20 discount, not
    /// a $50 discount.
    pub maximum_amount_money: Option<Money>,
}