com.commercetools.history.models.change.ChangeAmountPlannedChange Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of commercetools-sdk-java-history Show documentation
Show all versions of commercetools-sdk-java-history Show documentation
The e-commerce SDK from commercetools Composable Commerce for Java
package com.commercetools.history.models.change;
import java.time.*;
import java.util.*;
import java.util.function.Function;
import javax.annotation.Nullable;
import javax.validation.Valid;
import javax.validation.constraints.NotNull;
import com.commercetools.history.models.common.Money;
import com.fasterxml.jackson.annotation.*;
import com.fasterxml.jackson.databind.annotation.*;
import io.vrap.rmf.base.client.utils.Generated;
/**
* Change triggered by the Change AmountPlanned update action.
*
*
* Example to create an instance using the builder pattern
*
*
* ChangeAmountPlannedChange changeAmountPlannedChange = ChangeAmountPlannedChange.builder()
* .change("{change}")
* .previousValue(previousValueBuilder -> previousValueBuilder)
* .nextValue(nextValueBuilder -> nextValueBuilder)
* .build()
*
*
*/
@Generated(value = "io.vrap.rmf.codegen.rendering.CoreCodeGenerator", comments = "https://github.com/commercetools/rmf-codegen")
@JsonDeserialize(as = ChangeAmountPlannedChangeImpl.class)
public interface ChangeAmountPlannedChange extends Change {
/**
* discriminator value for ChangeAmountPlannedChange
*/
String CHANGE_AMOUNT_PLANNED_CHANGE = "ChangeAmountPlannedChange";
/**
*
* @return type
*/
@NotNull
@JsonProperty("type")
public String getType();
/**
*
* @return change
*/
@NotNull
@JsonProperty("change")
public String getChange();
/**
* Value before the change.
* @return previousValue
*/
@NotNull
@Valid
@JsonProperty("previousValue")
public Money getPreviousValue();
/**
* Value after the change.
* @return nextValue
*/
@NotNull
@Valid
@JsonProperty("nextValue")
public Money getNextValue();
/**
* set change
* @param change value to be set
*/
public void setChange(final String change);
/**
* Value before the change.
* @param previousValue value to be set
*/
public void setPreviousValue(final Money previousValue);
/**
* Value after the change.
* @param nextValue value to be set
*/
public void setNextValue(final Money nextValue);
/**
* factory method
* @return instance of ChangeAmountPlannedChange
*/
public static ChangeAmountPlannedChange of() {
return new ChangeAmountPlannedChangeImpl();
}
/**
* factory method to create a shallow copy ChangeAmountPlannedChange
* @param template instance to be copied
* @return copy instance
*/
public static ChangeAmountPlannedChange of(final ChangeAmountPlannedChange template) {
ChangeAmountPlannedChangeImpl instance = new ChangeAmountPlannedChangeImpl();
instance.setChange(template.getChange());
instance.setPreviousValue(template.getPreviousValue());
instance.setNextValue(template.getNextValue());
return instance;
}
/**
* factory method to create a deep copy of ChangeAmountPlannedChange
* @param template instance to be copied
* @return copy instance
*/
@Nullable
public static ChangeAmountPlannedChange deepCopy(@Nullable final ChangeAmountPlannedChange template) {
if (template == null) {
return null;
}
ChangeAmountPlannedChangeImpl instance = new ChangeAmountPlannedChangeImpl();
instance.setChange(template.getChange());
instance.setPreviousValue(com.commercetools.history.models.common.Money.deepCopy(template.getPreviousValue()));
instance.setNextValue(com.commercetools.history.models.common.Money.deepCopy(template.getNextValue()));
return instance;
}
/**
* builder factory method for ChangeAmountPlannedChange
* @return builder
*/
public static ChangeAmountPlannedChangeBuilder builder() {
return ChangeAmountPlannedChangeBuilder.of();
}
/**
* create builder for ChangeAmountPlannedChange instance
* @param template instance with prefilled values for the builder
* @return builder
*/
public static ChangeAmountPlannedChangeBuilder builder(final ChangeAmountPlannedChange template) {
return ChangeAmountPlannedChangeBuilder.of(template);
}
/**
* accessor map function
* @param mapped type
* @param helper function to map the object
* @return mapped value
*/
default T withChangeAmountPlannedChange(Function helper) {
return helper.apply(this);
}
/**
* gives a TypeReference for usage with Jackson DataBind
* @return TypeReference
*/
public static com.fasterxml.jackson.core.type.TypeReference typeReference() {
return new com.fasterxml.jackson.core.type.TypeReference() {
@Override
public String toString() {
return "TypeReference";
}
};
}
}