2025-07-17 12:11:59 +02:00

197 lines
6.1 KiB
Dart

//
// AUTO-GENERATED FILE, DO NOT MODIFY!
//
// @dart=2.18
// ignore_for_file: unused_element, unused_import
// ignore_for_file: always_put_required_named_parameters_first
// ignore_for_file: constant_identifier_names
// ignore_for_file: lines_longer_than_80_chars
part of openapi.api;
class QuestionDTO {
/// Returns a new [QuestionDTO] instance.
QuestionDTO({
this.id,
this.label = const [],
this.responses = const [],
this.imageBackgroundResourceId,
this.imageBackgroundResourceType,
this.imageBackgroundResourceUrl,
this.order,
});
int? id;
List<TranslationAndResourceDTO>? label;
List<ResponseDTO>? responses;
String? imageBackgroundResourceId;
ResourceType? imageBackgroundResourceType;
String? imageBackgroundResourceUrl;
int? order;
@override
bool operator ==(Object other) =>
identical(this, other) ||
other is QuestionDTO &&
other.id == id &&
_deepEquality.equals(other.label, label) &&
_deepEquality.equals(other.responses, responses) &&
other.imageBackgroundResourceId == imageBackgroundResourceId &&
other.imageBackgroundResourceType == imageBackgroundResourceType &&
other.imageBackgroundResourceUrl == imageBackgroundResourceUrl &&
other.order == order;
@override
int get hashCode =>
// ignore: unnecessary_parenthesis
(id == null ? 0 : id!.hashCode) +
(label == null ? 0 : label!.hashCode) +
(responses == null ? 0 : responses!.hashCode) +
(imageBackgroundResourceId == null
? 0
: imageBackgroundResourceId!.hashCode) +
(imageBackgroundResourceType == null
? 0
: imageBackgroundResourceType!.hashCode) +
(imageBackgroundResourceUrl == null
? 0
: imageBackgroundResourceUrl!.hashCode) +
(order == null ? 0 : order!.hashCode);
@override
String toString() =>
'QuestionDTO[id=$id, label=$label, responses=$responses, imageBackgroundResourceId=$imageBackgroundResourceId, imageBackgroundResourceType=$imageBackgroundResourceType, imageBackgroundResourceUrl=$imageBackgroundResourceUrl, order=$order]';
Map<String, dynamic> toJson() {
final json = <String, dynamic>{};
if (this.id != null) {
json[r'id'] = this.id;
} else {
json[r'id'] = null;
}
if (this.label != null) {
json[r'label'] = this.label;
} else {
json[r'label'] = null;
}
if (this.responses != null) {
json[r'responses'] = this.responses;
} else {
json[r'responses'] = null;
}
if (this.imageBackgroundResourceId != null) {
json[r'imageBackgroundResourceId'] = this.imageBackgroundResourceId;
} else {
json[r'imageBackgroundResourceId'] = null;
}
if (this.imageBackgroundResourceType != null) {
json[r'imageBackgroundResourceType'] = this.imageBackgroundResourceType;
} else {
json[r'imageBackgroundResourceType'] = null;
}
if (this.imageBackgroundResourceUrl != null) {
json[r'imageBackgroundResourceUrl'] = this.imageBackgroundResourceUrl;
} else {
json[r'imageBackgroundResourceUrl'] = null;
}
if (this.order != null) {
json[r'order'] = this.order;
} else {
json[r'order'] = null;
}
return json;
}
/// Returns a new [QuestionDTO] instance and imports its values from
/// [value] if it's a [Map], null otherwise.
// ignore: prefer_constructors_over_static_methods
static QuestionDTO? fromJson(dynamic value) {
if (value is Map) {
final json = value.cast<String, dynamic>();
// Ensure that the map contains the required keys.
// Note 1: the values aren't checked for validity beyond being non-null.
// Note 2: this code is stripped in release mode!
assert(() {
requiredKeys.forEach((key) {
assert(json.containsKey(key),
'Required key "QuestionDTO[$key]" is missing from JSON.');
assert(json[key] != null,
'Required key "QuestionDTO[$key]" has a null value in JSON.');
});
return true;
}());
return QuestionDTO(
id: mapValueOfType<int>(json, r'id'),
label: TranslationAndResourceDTO.listFromJson(json[r'label']),
responses: ResponseDTO.listFromJson(json[r'responses']),
imageBackgroundResourceId: mapValueOfType<String>(json, r'imageBackgroundResourceId'),
imageBackgroundResourceType: ResourceType.fromJson(json[r'imageBackgroundResourceType']),
imageBackgroundResourceUrl: mapValueOfType<String>(json, r'imageBackgroundResourceUrl'),
order: mapValueOfType<int>(json, r'order'),
);
}
return null;
}
static List<QuestionDTO> listFromJson(
dynamic json, {
bool growable = false,
}) {
final result = <QuestionDTO>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = QuestionDTO.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
static Map<String, QuestionDTO> mapFromJson(dynamic json) {
final map = <String, QuestionDTO>{};
if (json is Map && json.isNotEmpty) {
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
for (final entry in json.entries) {
final value = QuestionDTO.fromJson(entry.value);
if (value != null) {
map[entry.key] = value;
}
}
}
return map;
}
// maps a json object with a list of QuestionDTO-objects as value to a dart map
static Map<String, List<QuestionDTO>> mapListFromJson(
dynamic json, {
bool growable = false,
}) {
final map = <String, List<QuestionDTO>>{};
if (json is Map && json.isNotEmpty) {
// ignore: parameter_assignments
json = json.cast<String, dynamic>();
for (final entry in json.entries) {
map[entry.key] = QuestionDTO.listFromJson(
entry.value,
growable: growable,
);
}
}
return map;
}
/// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{};
}