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

com.commercetools.history.models.change.SetLanguagesChange Maven / Gradle / Ivy

There is a newer version: 17.12.0
Show newest version

package com.commercetools.history.models.change;

import java.time.*;
import java.util.*;
import java.util.function.Function;

import javax.annotation.Nullable;
import javax.validation.constraints.NotNull;

import com.fasterxml.jackson.annotation.*;
import com.fasterxml.jackson.databind.annotation.*;

import io.vrap.rmf.base.client.utils.Generated;

/**
 *  

Change triggered by Set Languages update action.

* *
* Example to create an instance using the builder pattern *
*

 *     SetLanguagesChange setLanguagesChange = SetLanguagesChange.builder()
 *             .change("{change}")
 *             .plusPreviousValue(previousValueBuilder -> previousValueBuilder)
 *             .plusNextValue(nextValueBuilder -> nextValueBuilder)
 *             .build()
 * 
*
*/ @Generated(value = "io.vrap.rmf.codegen.rendering.CoreCodeGenerator", comments = "https://github.com/commercetools/rmf-codegen") @JsonDeserialize(as = SetLanguagesChangeImpl.class) public interface SetLanguagesChange extends Change { /** * discriminator value for SetLanguagesChange */ String SET_LANGUAGES_CHANGE = "SetLanguagesChange"; /** * * @return type */ @NotNull @JsonProperty("type") public String getType(); /** * * @return change */ @NotNull @JsonProperty("change") public String getChange(); /** *

Value before the change.

* @return previousValue */ @NotNull @JsonProperty("previousValue") public List getPreviousValue(); /** *

Value after the change.

* @return nextValue */ @NotNull @JsonProperty("nextValue") public List getNextValue(); /** * set change * @param change value to be set */ public void setChange(final String change); /** *

Value before the change.

* @param previousValue values to be set */ @JsonIgnore public void setPreviousValue(final String... previousValue); /** *

Value before the change.

* @param previousValue values to be set */ public void setPreviousValue(final List previousValue); /** *

Value after the change.

* @param nextValue values to be set */ @JsonIgnore public void setNextValue(final String... nextValue); /** *

Value after the change.

* @param nextValue values to be set */ public void setNextValue(final List nextValue); /** * factory method * @return instance of SetLanguagesChange */ public static SetLanguagesChange of() { return new SetLanguagesChangeImpl(); } /** * factory method to create a shallow copy SetLanguagesChange * @param template instance to be copied * @return copy instance */ public static SetLanguagesChange of(final SetLanguagesChange template) { SetLanguagesChangeImpl instance = new SetLanguagesChangeImpl(); instance.setChange(template.getChange()); instance.setPreviousValue(template.getPreviousValue()); instance.setNextValue(template.getNextValue()); return instance; } /** * factory method to create a deep copy of SetLanguagesChange * @param template instance to be copied * @return copy instance */ @Nullable public static SetLanguagesChange deepCopy(@Nullable final SetLanguagesChange template) { if (template == null) { return null; } SetLanguagesChangeImpl instance = new SetLanguagesChangeImpl(); instance.setChange(template.getChange()); instance.setPreviousValue(Optional.ofNullable(template.getPreviousValue()).map(ArrayList::new).orElse(null)); instance.setNextValue(Optional.ofNullable(template.getNextValue()).map(ArrayList::new).orElse(null)); return instance; } /** * builder factory method for SetLanguagesChange * @return builder */ public static SetLanguagesChangeBuilder builder() { return SetLanguagesChangeBuilder.of(); } /** * create builder for SetLanguagesChange instance * @param template instance with prefilled values for the builder * @return builder */ public static SetLanguagesChangeBuilder builder(final SetLanguagesChange template) { return SetLanguagesChangeBuilder.of(template); } /** * accessor map function * @param mapped type * @param helper function to map the object * @return mapped value */ default T withSetLanguagesChange(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"; } }; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy