All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.sphere.sdk.carts.CustomLineItemDraft Maven / Gradle / Ivy

package io.sphere.sdk.carts;

import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.sphere.sdk.models.LocalizedString;
import io.sphere.sdk.models.Reference;
import io.sphere.sdk.models.Referenceable;
import io.sphere.sdk.taxcategories.ExternalTaxRateDraft;
import io.sphere.sdk.taxcategories.TaxCategory;
import io.sphere.sdk.types.CustomDraft;
import io.sphere.sdk.types.CustomFieldsDraft;

import javax.annotation.Nullable;
import javax.money.MonetaryAmount;

/**
 * 

Draft for adding a custom line item to the cart.

* *

Example for adding a {@link CustomLineItem} to a {@link Cart}:

{@include.example io.sphere.sdk.carts.commands.CartUpdateCommandIntegrationTest#addCustomLineItem()} @see CustomLineItem */ @JsonDeserialize(as = CustomLineItemDraftImpl.class) public interface CustomLineItemDraft extends CustomDraft { LocalizedString getName(); MonetaryAmount getMoney(); String getSlug(); /** * Gets the tax category for this custom line item. * * @return tax category or null * @see TaxMode */ @Nullable Reference getTaxCategory(); /** * Possible custom tax rate. * If set, this tax rate will override the tax rate selected by the platform. * * @return external tax rate or null * @see #getTaxCategory() * @see TaxMode */ @Nullable ExternalTaxRateDraft getExternalTaxRate(); Long getQuantity(); @Nullable @Override CustomFieldsDraft getCustom(); /** * Creates a draft having a standard tax category and no custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param taxCategory the tax category of the custom line item * @param quantity the count of items of this line item in the cart * @return draft */ static CustomLineItemDraft of(final LocalizedString name, final String slug, final MonetaryAmount money, final Referenceable taxCategory, final long quantity) { return of(name, slug, money, taxCategory, quantity, null); } /** * Creates a draft having a standard tax category and custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param taxCategory the tax category of the custom line item * @param quantity the count of items of this line item in the cart * @param custom custom fields for the custom line item * @return draft */ static CustomLineItemDraft of(final LocalizedString name, final String slug, final MonetaryAmount money, final Referenceable taxCategory, final long quantity, @Nullable final CustomFieldsDraft custom) { return new CustomLineItemDraftImpl(name, slug, money, taxCategory.toReference(), quantity, custom, null); } /** * Creates a draft having an external tax rate and no custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param externalTaxRate tax rate specific for this line item if the standard tax rates do not suffice * @param quantity the count of items of this line item in the cart * @return draft */ static CustomLineItemDraft ofExternalTaxCalculation(final LocalizedString name, final String slug, final MonetaryAmount money, final ExternalTaxRateDraft externalTaxRate, final long quantity) { return new CustomLineItemDraftImpl(name, slug, money, null, quantity, null, externalTaxRate); } /** * Creates a draft having no tax rate (for external tax calculation) and no custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param quantity the count of items of this line item in the cart * @return draft */ static CustomLineItemDraft ofExternalTaxCalculation(final LocalizedString name, final String slug, final MonetaryAmount money, final long quantity) { return new CustomLineItemDraftImpl(name, slug, money, null, quantity, null, null); } /** * Creates a draft having an external tax rate and custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param externalTaxRate tax rate specific for this line item if the standard tax rates do not suffice * @param quantity the count of items of this line item in the cart * @param custom custom fields for the custom line item * @return draft */ static CustomLineItemDraft ofExternalTaxCalculation(final LocalizedString name, final String slug, final MonetaryAmount money, final ExternalTaxRateDraft externalTaxRate, final long quantity, @Nullable final CustomFieldsDraft custom) { return new CustomLineItemDraftImpl(name, slug, money, null, quantity, custom, externalTaxRate); } /** * Creates a draft having no tax rate (for external tax calculation) and custom fields. * @param name the display name of the custom line item (corresponds to a product name) * @param slug unique field in the cart which is intended to identify the custom line item (not translated) * @param money the amount of the custom line item * @param quantity the count of items of this line item in the cart * @param custom custom fields for the custom line item * @return draft * * @see io.sphere.sdk.carts.commands.updateactions.SetCustomLineItemTaxRate * @see CustomLineItemDraft */ static CustomLineItemDraft ofExternalTaxCalculation(final LocalizedString name, final String slug, final MonetaryAmount money, final long quantity, @Nullable final CustomFieldsDraft custom) { return new CustomLineItemDraftImpl(name, slug, money, null, quantity, custom, null); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy