mirror of
https://bitbucket.org/myhomie/myhomie_app.git
synced 2025-12-06 17:11:19 +00:00
157 lines
4.4 KiB
Dart
157 lines
4.4 KiB
Dart
//
|
|
// AUTO-GENERATED FILE, DO NOT MODIFY!
|
|
//
|
|
// @dart=2.12
|
|
|
|
// 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 Book {
|
|
/// Returns a new [Book] instance.
|
|
Book({
|
|
this.id,
|
|
this.bookName,
|
|
this.price,
|
|
this.category,
|
|
this.author,
|
|
});
|
|
|
|
String? id;
|
|
|
|
String? bookName;
|
|
|
|
///
|
|
/// Please note: This property should have been non-nullable! Since the specification file
|
|
/// does not include a default value (using the "default:" property), however, the generated
|
|
/// source code must fall back to having a nullable type.
|
|
/// Consider adding a "default:" property in the specification file to hide this note.
|
|
///
|
|
num? price;
|
|
|
|
String? category;
|
|
|
|
String? author;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is Book &&
|
|
other.id == id &&
|
|
other.bookName == bookName &&
|
|
other.price == price &&
|
|
other.category == category &&
|
|
other.author == author;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(id == null ? 0 : id!.hashCode) +
|
|
(bookName == null ? 0 : bookName!.hashCode) +
|
|
(price == null ? 0 : price!.hashCode) +
|
|
(category == null ? 0 : category!.hashCode) +
|
|
(author == null ? 0 : author!.hashCode);
|
|
|
|
@override
|
|
String toString() => 'Book[id=$id, bookName=$bookName, price=$price, category=$category, author=$author]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final _json = <String, dynamic>{};
|
|
if (id != null) {
|
|
_json[r'id'] = id;
|
|
}
|
|
if (bookName != null) {
|
|
_json[r'bookName'] = bookName;
|
|
}
|
|
if (price != null) {
|
|
_json[r'price'] = price;
|
|
}
|
|
if (category != null) {
|
|
_json[r'category'] = category;
|
|
}
|
|
if (author != null) {
|
|
_json[r'author'] = author;
|
|
}
|
|
return _json;
|
|
}
|
|
|
|
/// Returns a new [Book] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static Book? 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 "Book[$key]" is missing from JSON.');
|
|
assert(json[key] != null, 'Required key "Book[$key]" has a null value in JSON.');
|
|
});
|
|
return true;
|
|
}());
|
|
|
|
return Book(
|
|
id: mapValueOfType<String>(json, r'id'),
|
|
bookName: mapValueOfType<String>(json, r'bookName'),
|
|
price: json[r'price'] == null
|
|
? null
|
|
: num.parse(json[r'price'].toString()),
|
|
category: mapValueOfType<String>(json, r'category'),
|
|
author: mapValueOfType<String>(json, r'author'),
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<Book>? listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <Book>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = Book.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, Book> mapFromJson(dynamic json) {
|
|
final map = <String, Book>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = Book.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of Book-objects as value to a dart map
|
|
static Map<String, List<Book>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<Book>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = Book.listFromJson(entry.value, growable: growable,);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
};
|
|
}
|
|
|