From d32a283114e09bbded707c166f7e980681a37c21 Mon Sep 17 00:00:00 2001 From: Ashita Prasad Date: Sat, 30 Nov 2024 22:14:24 +0530 Subject: [PATCH] Add seed --- packages/seed/.gitignore | 8 + packages/seed/.pubignore | 6 + packages/seed/CHANGELOG.md | 3 + packages/seed/LICENSE | 201 ++++++++++++++++++ packages/seed/README.md | 3 + packages/seed/analysis_options.yaml | 30 +++ packages/seed/example/seed_example.dart | 13 ++ packages/seed/lib/consts.dart | 1 + packages/seed/lib/models/form_data_model.dart | 23 ++ .../lib/models/form_data_model.freezed.dart | 200 +++++++++++++++++ .../seed/lib/models/form_data_model.g.dart | 26 +++ packages/seed/lib/models/models.dart | 2 + .../seed/lib/models/name_value_model.dart | 17 ++ .../lib/models/name_value_model.freezed.dart | 184 ++++++++++++++++ .../seed/lib/models/name_value_model.g.dart | 20 ++ packages/seed/lib/seed.dart | 4 + packages/seed/pubspec.yaml | 19 ++ .../test/models/form_data_model_test.dart | 43 ++++ .../test/models/name_value_model_test.dart | 43 ++++ 19 files changed, 846 insertions(+) create mode 100644 packages/seed/.gitignore create mode 100644 packages/seed/.pubignore create mode 100644 packages/seed/CHANGELOG.md create mode 100644 packages/seed/LICENSE create mode 100644 packages/seed/README.md create mode 100644 packages/seed/analysis_options.yaml create mode 100644 packages/seed/example/seed_example.dart create mode 100644 packages/seed/lib/consts.dart create mode 100644 packages/seed/lib/models/form_data_model.dart create mode 100644 packages/seed/lib/models/form_data_model.freezed.dart create mode 100644 packages/seed/lib/models/form_data_model.g.dart create mode 100644 packages/seed/lib/models/models.dart create mode 100644 packages/seed/lib/models/name_value_model.dart create mode 100644 packages/seed/lib/models/name_value_model.freezed.dart create mode 100644 packages/seed/lib/models/name_value_model.g.dart create mode 100644 packages/seed/lib/seed.dart create mode 100644 packages/seed/pubspec.yaml create mode 100644 packages/seed/test/models/form_data_model_test.dart create mode 100644 packages/seed/test/models/name_value_model_test.dart diff --git a/packages/seed/.gitignore b/packages/seed/.gitignore new file mode 100644 index 00000000..23d09241 --- /dev/null +++ b/packages/seed/.gitignore @@ -0,0 +1,8 @@ +# https://dart.dev/guides/libraries/private-files +# Created by `dart pub` +.dart_tool/ + +# Avoid committing pubspec.lock for library packages; see +# https://dart.dev/guides/libraries/private-files#pubspeclock. +pubspec.lock +build/ diff --git a/packages/seed/.pubignore b/packages/seed/.pubignore new file mode 100644 index 00000000..c88e4d24 --- /dev/null +++ b/packages/seed/.pubignore @@ -0,0 +1,6 @@ +pubspec.lock +melos_seed.iml +.dart_tool/ +build/ +coverage/ +test/ diff --git a/packages/seed/CHANGELOG.md b/packages/seed/CHANGELOG.md new file mode 100644 index 00000000..09f4ae76 --- /dev/null +++ b/packages/seed/CHANGELOG.md @@ -0,0 +1,3 @@ +## 0.0.1 + +- Added initial core models. diff --git a/packages/seed/LICENSE b/packages/seed/LICENSE new file mode 100644 index 00000000..498fbbb0 --- /dev/null +++ b/packages/seed/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2023 Ashita Prasad, Ankit Mahato + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/packages/seed/README.md b/packages/seed/README.md new file mode 100644 index 00000000..288f6a61 --- /dev/null +++ b/packages/seed/README.md @@ -0,0 +1,3 @@ +## seed + +Seed is a foundational package designed to provide reusable building blocks (classes, functions, etc.) for API Dash projects. diff --git a/packages/seed/analysis_options.yaml b/packages/seed/analysis_options.yaml new file mode 100644 index 00000000..dee8927a --- /dev/null +++ b/packages/seed/analysis_options.yaml @@ -0,0 +1,30 @@ +# This file configures the static analysis results for your project (errors, +# warnings, and lints). +# +# This enables the 'recommended' set of lints from `package:lints`. +# This set helps identify many issues that may lead to problems when running +# or consuming Dart code, and enforces writing Dart using a single, idiomatic +# style and format. +# +# If you want a smaller set of lints you can change this to specify +# 'package:lints/core.yaml'. These are just the most critical lints +# (the recommended set includes the core lints). +# The core lints are also what is used by pub.dev for scoring packages. + +include: package:lints/recommended.yaml + +# Uncomment the following section to specify additional rules. + +# linter: +# rules: +# - camel_case_types + +# analyzer: +# exclude: +# - path/to/excluded/files/** + +# For more information about the core and recommended set of lints, see +# https://dart.dev/go/core-lints + +# For additional information about configuring this file, see +# https://dart.dev/guides/language/analysis-options diff --git a/packages/seed/example/seed_example.dart b/packages/seed/example/seed_example.dart new file mode 100644 index 00000000..fe370341 --- /dev/null +++ b/packages/seed/example/seed_example.dart @@ -0,0 +1,13 @@ +import 'package:seed/seed.dart'; + +void main() { + const fdm = FormDataModel( + name: "harry", + value: "23", + type: FormDataType.text, + ); + print(fdm); + + const nm = NameValueModel(name: "harry", value: 23); + print(nm); +} diff --git a/packages/seed/lib/consts.dart b/packages/seed/lib/consts.dart new file mode 100644 index 00000000..2be7a4d0 --- /dev/null +++ b/packages/seed/lib/consts.dart @@ -0,0 +1 @@ +enum FormDataType { text, file } diff --git a/packages/seed/lib/models/form_data_model.dart b/packages/seed/lib/models/form_data_model.dart new file mode 100644 index 00000000..1ffc25d6 --- /dev/null +++ b/packages/seed/lib/models/form_data_model.dart @@ -0,0 +1,23 @@ +import 'package:freezed_annotation/freezed_annotation.dart'; +import '../consts.dart'; + +part 'form_data_model.freezed.dart'; +part 'form_data_model.g.dart'; + +@freezed +class FormDataModel with _$FormDataModel { + const factory FormDataModel({ + required String name, + required String value, + required FormDataType type, + }) = _FormDataModel; + + factory FormDataModel.fromJson(Map json) => + _$FormDataModelFromJson(json); +} + +const kFormDataEmptyModel = FormDataModel( + name: "", + value: "", + type: FormDataType.text, +); diff --git a/packages/seed/lib/models/form_data_model.freezed.dart b/packages/seed/lib/models/form_data_model.freezed.dart new file mode 100644 index 00000000..3ad9fb92 --- /dev/null +++ b/packages/seed/lib/models/form_data_model.freezed.dart @@ -0,0 +1,200 @@ +// coverage:ignore-file +// GENERATED CODE - DO NOT MODIFY BY HAND +// ignore_for_file: type=lint +// ignore_for_file: unused_element, deprecated_member_use, deprecated_member_use_from_same_package, use_function_type_syntax_for_parameters, unnecessary_const, avoid_init_to_null, invalid_override_different_default_values_named, prefer_expression_function_bodies, annotate_overrides, invalid_annotation_target, unnecessary_question_mark + +part of 'form_data_model.dart'; + +// ************************************************************************** +// FreezedGenerator +// ************************************************************************** + +T _$identity(T value) => value; + +final _privateConstructorUsedError = UnsupportedError( + 'It seems like you constructed your class using `MyClass._()`. This constructor is only meant to be used by freezed and you are not supposed to need it nor use it.\nPlease check the documentation here for more information: https://github.com/rrousselGit/freezed#adding-getters-and-methods-to-our-models'); + +FormDataModel _$FormDataModelFromJson(Map json) { + return _FormDataModel.fromJson(json); +} + +/// @nodoc +mixin _$FormDataModel { + String get name => throw _privateConstructorUsedError; + String get value => throw _privateConstructorUsedError; + FormDataType get type => throw _privateConstructorUsedError; + + /// Serializes this FormDataModel to a JSON map. + Map toJson() => throw _privateConstructorUsedError; + + /// Create a copy of FormDataModel + /// with the given fields replaced by the non-null parameter values. + @JsonKey(includeFromJson: false, includeToJson: false) + $FormDataModelCopyWith get copyWith => + throw _privateConstructorUsedError; +} + +/// @nodoc +abstract class $FormDataModelCopyWith<$Res> { + factory $FormDataModelCopyWith( + FormDataModel value, $Res Function(FormDataModel) then) = + _$FormDataModelCopyWithImpl<$Res, FormDataModel>; + @useResult + $Res call({String name, String value, FormDataType type}); +} + +/// @nodoc +class _$FormDataModelCopyWithImpl<$Res, $Val extends FormDataModel> + implements $FormDataModelCopyWith<$Res> { + _$FormDataModelCopyWithImpl(this._value, this._then); + + // ignore: unused_field + final $Val _value; + // ignore: unused_field + final $Res Function($Val) _then; + + /// Create a copy of FormDataModel + /// with the given fields replaced by the non-null parameter values. + @pragma('vm:prefer-inline') + @override + $Res call({ + Object? name = null, + Object? value = null, + Object? type = null, + }) { + return _then(_value.copyWith( + name: null == name + ? _value.name + : name // ignore: cast_nullable_to_non_nullable + as String, + value: null == value + ? _value.value + : value // ignore: cast_nullable_to_non_nullable + as String, + type: null == type + ? _value.type + : type // ignore: cast_nullable_to_non_nullable + as FormDataType, + ) as $Val); + } +} + +/// @nodoc +abstract class _$$FormDataModelImplCopyWith<$Res> + implements $FormDataModelCopyWith<$Res> { + factory _$$FormDataModelImplCopyWith( + _$FormDataModelImpl value, $Res Function(_$FormDataModelImpl) then) = + __$$FormDataModelImplCopyWithImpl<$Res>; + @override + @useResult + $Res call({String name, String value, FormDataType type}); +} + +/// @nodoc +class __$$FormDataModelImplCopyWithImpl<$Res> + extends _$FormDataModelCopyWithImpl<$Res, _$FormDataModelImpl> + implements _$$FormDataModelImplCopyWith<$Res> { + __$$FormDataModelImplCopyWithImpl( + _$FormDataModelImpl _value, $Res Function(_$FormDataModelImpl) _then) + : super(_value, _then); + + /// Create a copy of FormDataModel + /// with the given fields replaced by the non-null parameter values. + @pragma('vm:prefer-inline') + @override + $Res call({ + Object? name = null, + Object? value = null, + Object? type = null, + }) { + return _then(_$FormDataModelImpl( + name: null == name + ? _value.name + : name // ignore: cast_nullable_to_non_nullable + as String, + value: null == value + ? _value.value + : value // ignore: cast_nullable_to_non_nullable + as String, + type: null == type + ? _value.type + : type // ignore: cast_nullable_to_non_nullable + as FormDataType, + )); + } +} + +/// @nodoc +@JsonSerializable() +class _$FormDataModelImpl implements _FormDataModel { + const _$FormDataModelImpl( + {required this.name, required this.value, required this.type}); + + factory _$FormDataModelImpl.fromJson(Map json) => + _$$FormDataModelImplFromJson(json); + + @override + final String name; + @override + final String value; + @override + final FormDataType type; + + @override + String toString() { + return 'FormDataModel(name: $name, value: $value, type: $type)'; + } + + @override + bool operator ==(Object other) { + return identical(this, other) || + (other.runtimeType == runtimeType && + other is _$FormDataModelImpl && + (identical(other.name, name) || other.name == name) && + (identical(other.value, value) || other.value == value) && + (identical(other.type, type) || other.type == type)); + } + + @JsonKey(includeFromJson: false, includeToJson: false) + @override + int get hashCode => Object.hash(runtimeType, name, value, type); + + /// Create a copy of FormDataModel + /// with the given fields replaced by the non-null parameter values. + @JsonKey(includeFromJson: false, includeToJson: false) + @override + @pragma('vm:prefer-inline') + _$$FormDataModelImplCopyWith<_$FormDataModelImpl> get copyWith => + __$$FormDataModelImplCopyWithImpl<_$FormDataModelImpl>(this, _$identity); + + @override + Map toJson() { + return _$$FormDataModelImplToJson( + this, + ); + } +} + +abstract class _FormDataModel implements FormDataModel { + const factory _FormDataModel( + {required final String name, + required final String value, + required final FormDataType type}) = _$FormDataModelImpl; + + factory _FormDataModel.fromJson(Map json) = + _$FormDataModelImpl.fromJson; + + @override + String get name; + @override + String get value; + @override + FormDataType get type; + + /// Create a copy of FormDataModel + /// with the given fields replaced by the non-null parameter values. + @override + @JsonKey(includeFromJson: false, includeToJson: false) + _$$FormDataModelImplCopyWith<_$FormDataModelImpl> get copyWith => + throw _privateConstructorUsedError; +} diff --git a/packages/seed/lib/models/form_data_model.g.dart b/packages/seed/lib/models/form_data_model.g.dart new file mode 100644 index 00000000..f539458f --- /dev/null +++ b/packages/seed/lib/models/form_data_model.g.dart @@ -0,0 +1,26 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'form_data_model.dart'; + +// ************************************************************************** +// JsonSerializableGenerator +// ************************************************************************** + +_$FormDataModelImpl _$$FormDataModelImplFromJson(Map json) => + _$FormDataModelImpl( + name: json['name'] as String, + value: json['value'] as String, + type: $enumDecode(_$FormDataTypeEnumMap, json['type']), + ); + +Map _$$FormDataModelImplToJson(_$FormDataModelImpl instance) => + { + 'name': instance.name, + 'value': instance.value, + 'type': _$FormDataTypeEnumMap[instance.type]!, + }; + +const _$FormDataTypeEnumMap = { + FormDataType.text: 'text', + FormDataType.file: 'file', +}; diff --git a/packages/seed/lib/models/models.dart b/packages/seed/lib/models/models.dart new file mode 100644 index 00000000..04890905 --- /dev/null +++ b/packages/seed/lib/models/models.dart @@ -0,0 +1,2 @@ +export 'form_data_model.dart'; +export 'name_value_model.dart'; diff --git a/packages/seed/lib/models/name_value_model.dart b/packages/seed/lib/models/name_value_model.dart new file mode 100644 index 00000000..36a1bd83 --- /dev/null +++ b/packages/seed/lib/models/name_value_model.dart @@ -0,0 +1,17 @@ +import 'package:freezed_annotation/freezed_annotation.dart'; + +part 'name_value_model.freezed.dart'; +part 'name_value_model.g.dart'; + +@freezed +class NameValueModel with _$NameValueModel { + const factory NameValueModel({ + required String name, + required dynamic value, + }) = _NameValueModel; + + factory NameValueModel.fromJson(Map json) => + _$NameValueModelFromJson(json); +} + +const kNameValueEmptyModel = NameValueModel(name: "", value: ""); diff --git a/packages/seed/lib/models/name_value_model.freezed.dart b/packages/seed/lib/models/name_value_model.freezed.dart new file mode 100644 index 00000000..0aa966fe --- /dev/null +++ b/packages/seed/lib/models/name_value_model.freezed.dart @@ -0,0 +1,184 @@ +// coverage:ignore-file +// GENERATED CODE - DO NOT MODIFY BY HAND +// ignore_for_file: type=lint +// ignore_for_file: unused_element, deprecated_member_use, deprecated_member_use_from_same_package, use_function_type_syntax_for_parameters, unnecessary_const, avoid_init_to_null, invalid_override_different_default_values_named, prefer_expression_function_bodies, annotate_overrides, invalid_annotation_target, unnecessary_question_mark + +part of 'name_value_model.dart'; + +// ************************************************************************** +// FreezedGenerator +// ************************************************************************** + +T _$identity(T value) => value; + +final _privateConstructorUsedError = UnsupportedError( + 'It seems like you constructed your class using `MyClass._()`. This constructor is only meant to be used by freezed and you are not supposed to need it nor use it.\nPlease check the documentation here for more information: https://github.com/rrousselGit/freezed#adding-getters-and-methods-to-our-models'); + +NameValueModel _$NameValueModelFromJson(Map json) { + return _NameValueModel.fromJson(json); +} + +/// @nodoc +mixin _$NameValueModel { + String get name => throw _privateConstructorUsedError; + dynamic get value => throw _privateConstructorUsedError; + + /// Serializes this NameValueModel to a JSON map. + Map toJson() => throw _privateConstructorUsedError; + + /// Create a copy of NameValueModel + /// with the given fields replaced by the non-null parameter values. + @JsonKey(includeFromJson: false, includeToJson: false) + $NameValueModelCopyWith get copyWith => + throw _privateConstructorUsedError; +} + +/// @nodoc +abstract class $NameValueModelCopyWith<$Res> { + factory $NameValueModelCopyWith( + NameValueModel value, $Res Function(NameValueModel) then) = + _$NameValueModelCopyWithImpl<$Res, NameValueModel>; + @useResult + $Res call({String name, dynamic value}); +} + +/// @nodoc +class _$NameValueModelCopyWithImpl<$Res, $Val extends NameValueModel> + implements $NameValueModelCopyWith<$Res> { + _$NameValueModelCopyWithImpl(this._value, this._then); + + // ignore: unused_field + final $Val _value; + // ignore: unused_field + final $Res Function($Val) _then; + + /// Create a copy of NameValueModel + /// with the given fields replaced by the non-null parameter values. + @pragma('vm:prefer-inline') + @override + $Res call({ + Object? name = null, + Object? value = freezed, + }) { + return _then(_value.copyWith( + name: null == name + ? _value.name + : name // ignore: cast_nullable_to_non_nullable + as String, + value: freezed == value + ? _value.value + : value // ignore: cast_nullable_to_non_nullable + as dynamic, + ) as $Val); + } +} + +/// @nodoc +abstract class _$$NameValueModelImplCopyWith<$Res> + implements $NameValueModelCopyWith<$Res> { + factory _$$NameValueModelImplCopyWith(_$NameValueModelImpl value, + $Res Function(_$NameValueModelImpl) then) = + __$$NameValueModelImplCopyWithImpl<$Res>; + @override + @useResult + $Res call({String name, dynamic value}); +} + +/// @nodoc +class __$$NameValueModelImplCopyWithImpl<$Res> + extends _$NameValueModelCopyWithImpl<$Res, _$NameValueModelImpl> + implements _$$NameValueModelImplCopyWith<$Res> { + __$$NameValueModelImplCopyWithImpl( + _$NameValueModelImpl _value, $Res Function(_$NameValueModelImpl) _then) + : super(_value, _then); + + /// Create a copy of NameValueModel + /// with the given fields replaced by the non-null parameter values. + @pragma('vm:prefer-inline') + @override + $Res call({ + Object? name = null, + Object? value = freezed, + }) { + return _then(_$NameValueModelImpl( + name: null == name + ? _value.name + : name // ignore: cast_nullable_to_non_nullable + as String, + value: freezed == value + ? _value.value + : value // ignore: cast_nullable_to_non_nullable + as dynamic, + )); + } +} + +/// @nodoc +@JsonSerializable() +class _$NameValueModelImpl implements _NameValueModel { + const _$NameValueModelImpl({required this.name, required this.value}); + + factory _$NameValueModelImpl.fromJson(Map json) => + _$$NameValueModelImplFromJson(json); + + @override + final String name; + @override + final dynamic value; + + @override + String toString() { + return 'NameValueModel(name: $name, value: $value)'; + } + + @override + bool operator ==(Object other) { + return identical(this, other) || + (other.runtimeType == runtimeType && + other is _$NameValueModelImpl && + (identical(other.name, name) || other.name == name) && + const DeepCollectionEquality().equals(other.value, value)); + } + + @JsonKey(includeFromJson: false, includeToJson: false) + @override + int get hashCode => Object.hash( + runtimeType, name, const DeepCollectionEquality().hash(value)); + + /// Create a copy of NameValueModel + /// with the given fields replaced by the non-null parameter values. + @JsonKey(includeFromJson: false, includeToJson: false) + @override + @pragma('vm:prefer-inline') + _$$NameValueModelImplCopyWith<_$NameValueModelImpl> get copyWith => + __$$NameValueModelImplCopyWithImpl<_$NameValueModelImpl>( + this, _$identity); + + @override + Map toJson() { + return _$$NameValueModelImplToJson( + this, + ); + } +} + +abstract class _NameValueModel implements NameValueModel { + const factory _NameValueModel( + {required final String name, + required final dynamic value}) = _$NameValueModelImpl; + + factory _NameValueModel.fromJson(Map json) = + _$NameValueModelImpl.fromJson; + + @override + String get name; + @override + dynamic get value; + + /// Create a copy of NameValueModel + /// with the given fields replaced by the non-null parameter values. + @override + @JsonKey(includeFromJson: false, includeToJson: false) + _$$NameValueModelImplCopyWith<_$NameValueModelImpl> get copyWith => + throw _privateConstructorUsedError; +} diff --git a/packages/seed/lib/models/name_value_model.g.dart b/packages/seed/lib/models/name_value_model.g.dart new file mode 100644 index 00000000..5fb91b66 --- /dev/null +++ b/packages/seed/lib/models/name_value_model.g.dart @@ -0,0 +1,20 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'name_value_model.dart'; + +// ************************************************************************** +// JsonSerializableGenerator +// ************************************************************************** + +_$NameValueModelImpl _$$NameValueModelImplFromJson(Map json) => + _$NameValueModelImpl( + name: json['name'] as String, + value: json['value'], + ); + +Map _$$NameValueModelImplToJson( + _$NameValueModelImpl instance) => + { + 'name': instance.name, + 'value': instance.value, + }; diff --git a/packages/seed/lib/seed.dart b/packages/seed/lib/seed.dart new file mode 100644 index 00000000..6c699c54 --- /dev/null +++ b/packages/seed/lib/seed.dart @@ -0,0 +1,4 @@ +library seed; + +export 'models/models.dart'; +export 'consts.dart'; diff --git a/packages/seed/pubspec.yaml b/packages/seed/pubspec.yaml new file mode 100644 index 00000000..c91506aa --- /dev/null +++ b/packages/seed/pubspec.yaml @@ -0,0 +1,19 @@ +name: seed +description: Seed is a foundational package designed to provide reusable building blocks for API Dash projects. +version: 0.0.1 +homepage: https://github.com/foss42/apidash/tree/main/packages/seed +repository: https://github.com/foss42/apidash/tree/main/packages/seed +issue_tracker: https://github.com/foss42/apidash/issues +documentation: https://github.com/foss42/apidash/tree/main/packages/seed + +environment: + sdk: ">=3.0.0 <4.0.0" + +dependencies: + freezed_annotation: ^2.4.1 + +dev_dependencies: + build_runner: ^2.4.12 + freezed: ^2.5.7 + lints: ^4.0.0 + test: ^1.24.0 diff --git a/packages/seed/test/models/form_data_model_test.dart b/packages/seed/test/models/form_data_model_test.dart new file mode 100644 index 00000000..03112c98 --- /dev/null +++ b/packages/seed/test/models/form_data_model_test.dart @@ -0,0 +1,43 @@ +import 'package:seed/seed.dart'; +import 'package:test/test.dart'; + +void main() { + const fdmRow1 = FormDataModel( + name: "harry", + value: "23", + type: FormDataType.text, + ); + + test('Testing toString()', () { + const resultExpected = + 'FormDataModel(name: harry, value: 23, type: FormDataType.text)'; + expect(fdmRow1.toString(), resultExpected); + }); + + test('Testing toJson()', () { + const resultExpected = {"name": "harry", "value": "23", "type": "text"}; + expect(fdmRow1.toJson(), resultExpected); + }); + test('Testing fromJson()', () { + const resultExpected = fdmRow1; + expect( + FormDataModel.fromJson( + {"name": "harry", "value": "23", "type": "text"}), + resultExpected); + }); + + test('Testing copyWith()', () { + const resultExpected = FormDataModel( + name: "winter", + value: "26", + type: FormDataType.file, + ); + expect( + fdmRow1.copyWith(name: "winter", value: "26", type: FormDataType.file), + resultExpected); + }); + + test('Testing hashcode', () { + expect(fdmRow1.hashCode, greaterThan(0)); + }); +} diff --git a/packages/seed/test/models/name_value_model_test.dart b/packages/seed/test/models/name_value_model_test.dart new file mode 100644 index 00000000..e166d4cc --- /dev/null +++ b/packages/seed/test/models/name_value_model_test.dart @@ -0,0 +1,43 @@ +import 'package:seed/seed.dart'; +import 'package:test/test.dart'; + +void main() { + const nmRow1 = NameValueModel( + name: "harry", + value: 23, + ); + + test('Testing toString()', () { + const resultExpected = 'NameValueModel(name: harry, value: 23)'; + expect(nmRow1.toString(), resultExpected); + }); + + test('Testing toJson()', () { + const resultExpected = { + "name": "harry", + "value": 23, + }; + expect(nmRow1.toJson(), resultExpected); + }); + test('Testing fromJson()', () { + const resultExpected = nmRow1; + expect( + NameValueModel.fromJson({ + "name": "harry", + "value": 23, + }), + resultExpected); + }); + + test('Testing copyWith()', () { + const resultExpected = NameValueModel( + name: "winter", + value: "26", + ); + expect(nmRow1.copyWith(name: "winter", value: "26"), resultExpected); + }); + + test('Testing hashcode', () { + expect(nmRow1.hashCode, greaterThan(0)); + }); +}