decode method
Decodes a data
to a ConfirmationStatus.
If allowNull
is true and the data
cannot be decoded successfully,
then null is returned. However, if allowNull
is false and the data
cannot be decoded successfully, then an UnimplementedError is thrown.
The allowNull
is very handy when an API changes and a new enum value is added or removed,
and users are still using an old app with the old code.
Implementation
ConfirmationStatus? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data.toString()) {
case r'processed': return ConfirmationStatus.processed;
case r'confirmed': return ConfirmationStatus.confirmed;
case r'finalized': return ConfirmationStatus.finalized;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}