@ProviderType
public interface FragmentData
In general, FragmentData
works as a wrapper around a (generic) Java object
that represents the actual value. This avoids using Object
in the API and also
allows to provide helper functionality to access the generic value in a controlled way.
Values are typed. For more information about data types, see DataType
.
Values of a given type - represented by an Object
wrapped by
FragmentData
- may need to be converted to the needs of the client. Basically,
getValue(Class)
supports to convert each value to a String
(and back).
For the conversion to a String
the following rules are followed:
Xxxx.toString()
/Xxx.parseXxx
rather than NumberFormat
Calendar
is based on ISO-8601.
Modifier and Type | Method and Description |
---|---|
@Nullable java.lang.String |
getContentType()
Returns the content type for textbased data types.
|
@NotNull DataType |
getDataType()
Gets the data type of the value.
|
@Nullable java.util.Calendar |
getLastModified()
Returns the date the value was last modified.
|
@Nullable java.lang.Object |
getValue()
Gets the original value as a generic Java object.
|
<T> T |
getValue(java.lang.Class<T> type)
Gets the value, converted to the provided type.
|
boolean |
isTypeSupported(java.lang.Class type)
Checks if the specified Java data type is supported for calls to
getValue(Class) and setValue(Object) . |
void |
setContentType(@Nullable java.lang.String contentType)
Sets the content type for text-based data types.
|
void |
setValue(@Nullable java.lang.Object value)
Sets the value.
|
@NotNull @NotNull DataType getDataType()
@Nullable <T> T getValue(java.lang.Class<T> type)
For information about supported type conversions: see DataType
.
Note that this method is supposed to return a suitably converted value for all
types where isTypeSupported(Class)
returns true
T
- Describes the type parametertype
- The type the value should be converted tonull
if the value could not be converted to the provided
typeboolean isTypeSupported(java.lang.Class type)
getValue(Class)
and setValue(Object)
.type
- The class object representing the typetrue
if the type is supported@Nullable @Nullable java.lang.Object getValue()
void setValue(@Nullable @Nullable java.lang.Object value) throws ContentFragmentException
The general rule is that a non-null value that was retrieved using
getValue(Class)
needs to be accepted and converted to a suitable original
value. Also, every value of a type where isTypeSupported(Class)
returns
true
needs to be accepted and converted accordingly.
Note that for the value to be persisted,
ContentElement.setValue(FragmentData)
or
ContentVariation.setValue(FragmentData)
have to be called explicitly.
This allows for manipulating the value multiple times before actually persisting it.
value
- The valueContentFragmentException
- if the type of the value provided is unsupported@Nullable @Nullable java.lang.String getContentType()
This will return a MIME type only when applicable. For numbers, dates, booleans,
it will typically be null
.
null
if not applicablevoid setContentType(@Nullable @Nullable java.lang.String contentType)
For data other than text-based types null
should be provided.
contentType
- The content type; null
if not applicable@Nullable @Nullable java.util.Calendar getLastModified()
null
if not availableCopyright © 2010 - 2023 Adobe. All Rights Reserved