// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 // NOTE: This file is generated and may not follow lint rules defined in your app // Generated files can be excluded from analysis in analysis_options.yaml // For more info, see: https://dart.dev/guides/language/analysis-options#excluding-code-from-analysis // ignore_for_file: public_member_api_docs, annotate_overrides, dead_code, dead_codepublic_member_api_docs, depend_on_referenced_packages, file_names, library_private_types_in_public_api, no_leading_underscores_for_library_prefixes, no_leading_underscores_for_local_identifiers, non_constant_identifier_names, null_check_on_nullable_type_parameter, prefer_adjacent_string_concatenation, prefer_const_constructors, prefer_if_null_operators, prefer_interpolation_to_compose_strings, slash_for_doc_comments, sort_child_properties_last, unnecessary_const, unnecessary_constructor_name, unnecessary_late, unnecessary_new, unnecessary_null_aware_assignments, unnecessary_nullable_for_final_variable_declarations, unnecessary_string_interpolations, use_build_context_synchronously import 'package:amplify_core/amplify_core.dart'; import 'package:meta/meta.dart'; /// This is an auto generated class representing the Product type in your schema. @immutable class Product extends Model { static const classType = _ProductModelType(); final String? _productID; final String? _name; final int? _amount; final TemporalDateTime? _createdAt; final TemporalDateTime? _updatedAt; @override getInstanceType() => classType; @Deprecated( '[getId] is being deprecated in favor of custom primary key feature. Use getter [modelIdentifier] to get model identifier.') @override String getId() => modelIdentifier.serializeAsString(); ProductModelIdentifier get modelIdentifier { try { return ProductModelIdentifier(productID: _productID!); } catch (e) { throw AmplifyCodeGenModelException( AmplifyExceptionMessages .codeGenRequiredFieldForceCastExceptionMessage, recoverySuggestion: AmplifyExceptionMessages .codeGenRequiredFieldForceCastRecoverySuggestion, underlyingException: e.toString()); } } String get productID { try { return _productID!; } catch (e) { throw AmplifyCodeGenModelException( AmplifyExceptionMessages .codeGenRequiredFieldForceCastExceptionMessage, recoverySuggestion: AmplifyExceptionMessages .codeGenRequiredFieldForceCastRecoverySuggestion, underlyingException: e.toString()); } } String get name { try { return _name!; } catch (e) { throw AmplifyCodeGenModelException( AmplifyExceptionMessages .codeGenRequiredFieldForceCastExceptionMessage, recoverySuggestion: AmplifyExceptionMessages .codeGenRequiredFieldForceCastRecoverySuggestion, underlyingException: e.toString()); } } int get amount { try { return _amount!; } catch (e) { throw AmplifyCodeGenModelException( AmplifyExceptionMessages .codeGenRequiredFieldForceCastExceptionMessage, recoverySuggestion: AmplifyExceptionMessages .codeGenRequiredFieldForceCastRecoverySuggestion, underlyingException: e.toString()); } } TemporalDateTime? get createdAt { return _createdAt; } TemporalDateTime? get updatedAt { return _updatedAt; } const Product._internal( {required productID, required name, required amount, createdAt, updatedAt}) : _productID = productID, _name = name, _amount = amount, _createdAt = createdAt, _updatedAt = updatedAt; factory Product( {required String productID, required String name, required int amount}) { return Product._internal(productID: productID, name: name, amount: amount); } bool equals(Object other) { return this == other; } @override bool operator ==(Object other) { if (identical(other, this)) return true; return other is Product && _productID == other._productID && _name == other._name && _amount == other._amount; } @override int get hashCode => toString().hashCode; @override String toString() { var buffer = StringBuffer(); buffer.write("Product {"); buffer.write("productID=" + "$_productID" + ", "); buffer.write("name=" + "$_name" + ", "); buffer.write( "amount=" + (_amount != null ? _amount!.toString() : "null") + ", "); buffer.write("createdAt=" + (_createdAt != null ? _createdAt!.format() : "null") + ", "); buffer.write( "updatedAt=" + (_updatedAt != null ? _updatedAt!.format() : "null")); buffer.write("}"); return buffer.toString(); } Product copyWith({String? name, int? amount}) { return Product._internal( productID: productID, name: name ?? this.name, amount: amount ?? this.amount); } Product.fromJson(Map json) : _productID = json['productID'], _name = json['name'], _amount = (json['amount'] as num?)?.toInt(), _createdAt = json['createdAt'] != null ? TemporalDateTime.fromString(json['createdAt']) : null, _updatedAt = json['updatedAt'] != null ? TemporalDateTime.fromString(json['updatedAt']) : null; Map toJson() => { 'productID': _productID, 'name': _name, 'amount': _amount, 'createdAt': _createdAt?.format(), 'updatedAt': _updatedAt?.format() }; Map toMap() => { 'productID': _productID, 'name': _name, 'amount': _amount, 'createdAt': _createdAt, 'updatedAt': _updatedAt }; static final QueryModelIdentifier MODEL_IDENTIFIER = QueryModelIdentifier(); static final QueryField PRODUCTID = QueryField(fieldName: "productID"); static final QueryField NAME = QueryField(fieldName: "name"); static final QueryField AMOUNT = QueryField(fieldName: "amount"); static var schema = Model.defineSchema(define: (ModelSchemaDefinition modelSchemaDefinition) { modelSchemaDefinition.name = "Product"; modelSchemaDefinition.pluralName = "Products"; modelSchemaDefinition.indexes = [ ModelIndex(fields: const ["productID"], name: null) ]; modelSchemaDefinition.addField(ModelFieldDefinition.field( key: Product.PRODUCTID, isRequired: true, ofType: ModelFieldType(ModelFieldTypeEnum.string))); modelSchemaDefinition.addField(ModelFieldDefinition.field( key: Product.NAME, isRequired: true, ofType: ModelFieldType(ModelFieldTypeEnum.string))); modelSchemaDefinition.addField(ModelFieldDefinition.field( key: Product.AMOUNT, isRequired: true, ofType: ModelFieldType(ModelFieldTypeEnum.int))); modelSchemaDefinition.addField(ModelFieldDefinition.nonQueryField( fieldName: 'createdAt', isRequired: false, isReadOnly: true, ofType: ModelFieldType(ModelFieldTypeEnum.dateTime))); modelSchemaDefinition.addField(ModelFieldDefinition.nonQueryField( fieldName: 'updatedAt', isRequired: false, isReadOnly: true, ofType: ModelFieldType(ModelFieldTypeEnum.dateTime))); }); } class _ProductModelType extends ModelType { const _ProductModelType(); @override Product fromJson(Map jsonData) { return Product.fromJson(jsonData); } @override String modelName() { return 'Product'; } } /// This is an auto generated class representing the model identifier /// of [Product] in your schema. @immutable class ProductModelIdentifier implements ModelIdentifier { final String productID; /// Create an instance of ProductModelIdentifier using [productID] the primary key. const ProductModelIdentifier({required this.productID}); @override Map serializeAsMap() => ({'productID': productID}); @override List> serializeAsList() => serializeAsMap() .entries .map((entry) => ({entry.key: entry.value})) .toList(); @override String serializeAsString() => serializeAsMap().values.join('#'); @override String toString() => 'ProductModelIdentifier(productID: $productID)'; @override bool operator ==(Object other) { if (identical(this, other)) { return true; } return other is ProductModelIdentifier && productID == other.productID; } @override int get hashCode => productID.hashCode; }