Я пытаюсь реализовать toJson / from Json для объединения, созданного замороженным пакетом . Допустим, у нас есть следующий класс:
@freezed
abstract class Result with _$Result {
const factory Result.error(String message) = Error;
const factory Result.success() = Success;
factory Result.fromJson(Map<String, dynamic> json) => _$ResultFromJson(json);
}
Где я хочу / из Json вести себя следующим образом:
Result error = Result.error('some error');
expect(error.toJson(), {'type': 'error', 'message': 'some error'});
expect(Result.fromJson({'type': 'error', 'message': 'some error'}), error);
В документации указано, что вы можете использовать a JsonConverter
(из JSON с несколькими классами) , но я не знаю, как его правильно использовать.
class ResultConverter implements JsonConverter<Result, Map<String, dynamic>> {
const ResultConverter();
@override
Result fromJson(Map<String, dynamic> json) {
if (json == null) {
return null;
}
switch (json['type'] as String) {
case 'success':
return Success.fromJson(json);
case 'error':
return Error.fromJson(json);
default:
throw FallThroughError();
}
}
@override
Map<String, dynamic> toJson(Result object) => object.map(
error: (e) => {'type': 'error', ...e.toJson()},
success: (s) => {'type': 'success', ...s.toJson()},
);
}
fromJson
отлично работает, если вызывает заводской метод ResultConverter().fromJson(this)
вместо сгенерированного, но это похоже на обходной путь и не будет работать с Json.
Можно ли как-то аннотировать класс Result, чтобы генерация кода использовала конвертер?