diff --git a/lib/data/dtos/characters_dto.dart b/lib/data/dtos/characters_dto.dart new file mode 100644 index 0000000..c201de9 --- /dev/null +++ b/lib/data/dtos/characters_dto.dart @@ -0,0 +1,23 @@ +import 'package:json_annotation/json_annotation.dart'; + +part 'characters_dto.g.dart'; + +@JsonSerializable(createToJson: false) +class CharactersDto { + final List? array; + const CharactersDto ({this.array}); + + factory CharactersDto.fromJson(List json) => _$CharactersDtoFromJson(json); +} + +@JsonSerializable(createToJson: false) +class CharactersDataDto { + final int? id; + final String? fullName; + final String? title; + final String? family; + final String? imageUrl; + + const CharactersDataDto(this.id, this.fullName, this.title, this.family, this.imageUrl); + factory CharactersDataDto.fromJson(Map json) => _$CharactersDataDtoFromJson(json); +} \ No newline at end of file diff --git a/lib/data/dtos/characters_dto.g.dart b/lib/data/dtos/characters_dto.g.dart new file mode 100644 index 0000000..e54be99 --- /dev/null +++ b/lib/data/dtos/characters_dto.g.dart @@ -0,0 +1,22 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'characters_dto.dart'; + +// ************************************************************************** +// JsonSerializableGenerator +// ************************************************************************** + +CharactersDto _$CharactersDtoFromJson(List json) => + CharactersDto( + array: (json as List?)?.map((e) => CharactersDataDto.fromJson(e as Map)) + .toList(), + ); + +CharactersDataDto _$CharactersDataDtoFromJson(Map json) => + CharactersDataDto( + (json['id'] as num?)?.toInt(), + json['fullName'] as String?, + json['title'] as String?, + json['family'] as String?, + json['imageUrl'] as String?, + ); diff --git a/lib/data/mappers/characters_mapper.dart b/lib/data/mappers/characters_mapper.dart new file mode 100644 index 0000000..dd70cda --- /dev/null +++ b/lib/data/mappers/characters_mapper.dart @@ -0,0 +1,11 @@ +import 'package:mdp/data/dtos/characters_dto.dart'; +import 'package:mdp/models/card.dart'; + +extension CharactersDtoToModel on CharactersDataDto { + CardData toDomain() => CardData( + fullName, + family: family, + title: title, + imageUrl: imageUrl + ); +} \ No newline at end of file diff --git a/lib/main.dart b/lib/main.dart index 90fee27..340f72c 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -1,4 +1,6 @@ import 'package:flutter/material.dart'; +import 'package:mdp/models/card.dart'; +import 'package:mdp/repositories/got_repository.dart'; void main() { runApp(const MyApp()); @@ -13,26 +15,11 @@ class MyApp extends StatelessWidget { return MaterialApp( title: 'Flutter Demo', theme: ThemeData( - // This is the theme of your application. - // - // TRY THIS: Try running your application with "flutter run". You'll see - // the application has a purple toolbar. Then, without quitting the app, - // try changing the seedColor in the colorScheme below to Colors.green - // and then invoke "hot reload" (save your changes or press the "hot - // reload" button in a Flutter-supported IDE, or press "r" if you used - // the command line to start the app). - // - // Notice that the counter didn't reset back to zero; the application - // state is not lost during the reload. To reset the state, use hot - // restart instead. - // - // This works for code too, not just values: Most code changes can be - // tested with just a hot reload. colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), useMaterial3: true, ), home: const MyHomePage( - title: Text("Simbirsk-Oil", + title: Text("Персонажи Игры Престолов", style: TextStyle( fontSize: 28, fontWeight: FontWeight.w600, @@ -41,40 +28,69 @@ class MyApp extends StatelessWidget { } } -class MyHomePage extends StatefulWidget { +class MyHomePage extends StatelessWidget { const MyHomePage({super.key, required this.title}); - final Text title; - @override - State createState() => _MyHomePageState(); -} -class _MyHomePageState extends State { @override Widget build(BuildContext context) { + final data = GotRepository().loadData(); return Scaffold( appBar: AppBar( - backgroundColor: Colors.deepOrangeAccent, - title: widget.title, + backgroundColor: Colors.black54, + title: title, ), - body: Padding( - padding: const EdgeInsets.all(30), - child: ListView.separated( - itemBuilder: (context, index) => Card( - name: "Масло GM dexos2 ${index * 5}w-${index * 10 + 20}", - price: index * 500 + 4000), - separatorBuilder: (context, index) => const SizedBox(height: 40), - itemCount: 3, - ))); + body: Center( + child: FutureBuilder?>( + future: data, + builder: (context, snapshot) => SingleChildScrollView( + child: snapshot.hasData + ? Column( + mainAxisAlignment: MainAxisAlignment.center, + children: snapshot.data?.map((data) { + return GestureDetector( + child: Padding( + padding: const EdgeInsets.only(bottom: 15, left: 7, right: 7, top: 5), + child: Card( + fullName: data.fullName, + title: data.title, + family: data.family, + imageURL: data.imageUrl, + ), + ), + + onTap: () { + Navigator.push( + context, + MaterialPageRoute( + builder: (context) => CardInfo( + fullName: data.fullName.toString(), + title: data.title.toString(), + family: data.family.toString(), + imageURL: data.imageUrl.toString(), + ), + ), + ); + }, + ); + }).toList() ?? [], + ) + : const CircularProgressIndicator(), + ), + ), + ) + ); } } class Card extends StatefulWidget { - const Card({super.key, required this.name, required this.price}); + const Card({super.key, required this.fullName, required this.title, required this.family, required this.imageURL}); - final String name; - final int price; + final String? fullName; + final String? title; + final String? family; + final String? imageURL; @override State createState() => _CardState(); @@ -86,6 +102,13 @@ class _CardState extends State { void toggleIsFavourite() { setState(() { _isFavourite = !_isFavourite; + final snackBar = SnackBar( + duration: const Duration(seconds: 1), + backgroundColor: Colors.deepOrangeAccent, + content: Text( + _isFavourite ? 'Добавлено в любимое' : 'Удалено из любимого', style: const TextStyle(fontWeight: FontWeight.bold)) + ); + ScaffoldMessenger.of(context).showSnackBar(snackBar); }); } @@ -93,41 +116,41 @@ class _CardState extends State { Widget build(BuildContext context) { return Stack( children: [ - Container( - padding: - const EdgeInsets.only(top: 50, bottom: 15, left: 40, right: 40), - decoration: BoxDecoration( - border: Border.all(color: Colors.black12, width: 2), - borderRadius: BorderRadius.circular(40)), - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Center( - child: Image.network( - "https://berimaslo.ru/upload/iblock/1b4/4w95d0a1xk1wsgkyk6irpp7h4yt7lz3k.jpeg"), - ), - Padding( - padding: EdgeInsets.only(top: 30, right: 30), - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text(widget.name, - style: const TextStyle( - fontSize: 22, - fontWeight: FontWeight.bold, - color: Color.fromRGBO(70, 70, 70, 1))), - SizedBox(height: 7), - Text("${widget.price} ₽", - style: const TextStyle( - fontSize: 22, - color: Color.fromRGBO(70, 70, 70, 1), - fontWeight: FontWeight.bold)) - ], + new Container( + padding: + const EdgeInsets.only(top: 50, bottom: 15, left: 40, right: 40), + decoration: BoxDecoration( + border: Border.all(color: Colors.black45, width: 2), + borderRadius: BorderRadius.circular(40)), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Center( + child: Image.network( + widget.imageURL.toString()), ), - ) - ], + Padding( + padding: const EdgeInsets.only(top: 30, right: 30), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Text(widget.fullName.toString(), + style: const TextStyle( + fontSize: 22, + fontWeight: FontWeight.bold, + color: Color.fromRGBO(70, 70, 70, 1))), + const SizedBox(height: 7), + Text(widget.title.toString(), + style: const TextStyle( + fontSize: 22, + color: Color.fromRGBO(70, 70, 70, 1), + fontWeight: FontWeight.bold)) + ], + ), + ) + ], + ), ), - ), Positioned( right: 20, bottom: 10, @@ -140,3 +163,58 @@ class _CardState extends State { ); } } + +class CardInfo extends StatelessWidget { + final String fullName; + final String title; + final String family; + final String imageURL; + + const CardInfo({super.key, required this.fullName, required this.title, required this.family, required this.imageURL}); + + @override + Widget build(BuildContext context) { + return Scaffold( + appBar: AppBar( + backgroundColor: Colors.deepOrangeAccent, + title: Text(fullName, style: const TextStyle( + fontSize: 28, + fontWeight: FontWeight.w600, + color: Color.fromRGBO(240, 240, 240, 1))), + ), + body: Padding( + padding: const EdgeInsets.all(20), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Center( + child: Image.network( + imageURL), + ), + const SizedBox(height: 20), + Text(fullName, + style: + const TextStyle( + fontSize: 22, + fontWeight: FontWeight.bold, + color: Color.fromRGBO(70, 70, 70, 1))), + const SizedBox(height: 10), + Text(title, + style: + const TextStyle( + fontSize: 22, + color: Color.fromRGBO(70, 70, 70, 1), + fontWeight: FontWeight.bold)), + const SizedBox(height: 10), + Text(family, + style: + const TextStyle( + fontSize: 22, + color: Color.fromRGBO(70, 70, 70, 1), + fontWeight: FontWeight.bold)), + ], + ), + ), + ); + } +} diff --git a/lib/models/card.dart b/lib/models/card.dart new file mode 100644 index 0000000..8bd7005 --- /dev/null +++ b/lib/models/card.dart @@ -0,0 +1,13 @@ +class CardData{ + final String? fullName; + final String? title; + final String? family; + final String? imageUrl; + + CardData ( + this.fullName, { + required this.title, + required this.family, + required this.imageUrl + }); +} \ No newline at end of file diff --git a/lib/repositories/api_interface.dart b/lib/repositories/api_interface.dart new file mode 100644 index 0000000..650c573 --- /dev/null +++ b/lib/repositories/api_interface.dart @@ -0,0 +1,5 @@ +import 'package:mdp/models/card.dart'; + +abstract class ApiInterface { + Future?> loadData(); +} \ No newline at end of file diff --git a/lib/repositories/got_repository.dart b/lib/repositories/got_repository.dart new file mode 100644 index 0000000..5125ff3 --- /dev/null +++ b/lib/repositories/got_repository.dart @@ -0,0 +1,31 @@ +import 'dart:developer'; +import 'package:mdp/data/dtos/characters_dto.dart'; +import 'package:mdp/data/mappers/characters_mapper.dart'; +import 'package:mdp/models/card.dart'; +import 'package:mdp/repositories/api_interface.dart'; +import 'package:dio/dio.dart'; +import 'package:pretty_dio_logger/pretty_dio_logger.dart'; + +class GotRepository extends ApiInterface { + static final Dio _dio = Dio() + ..interceptors.add(PrettyDioLogger( + requestHeader: true, + requestBody: true + )); + static const String _baseURL = 'https://thronesapi.com'; + + @override + Future?> loadData() async { + try { + const String url = '$_baseURL/api/v2/Characters'; + + Response response = await _dio.get>(url); + final CharactersDto dto = CharactersDto.fromJson(response.data); + final List? data = dto.array?.map((e) => e.toDomain()).toList(); + return data; + } on DioException catch (e) { + log(e.stackTrace.toString()); + return null; + } + } +} \ No newline at end of file diff --git a/pubspec.lock b/pubspec.lock index b9fd799..f305f25 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -1,6 +1,35 @@ # Generated by pub # See https://dart.dev/tools/pub/glossary#lockfile packages: + _fe_analyzer_shared: + dependency: transitive + description: + name: _fe_analyzer_shared + sha256: f256b0c0ba6c7577c15e2e4e114755640a875e885099367bf6e012b19314c834 + url: "https://pub.dev" + source: hosted + version: "72.0.0" + _macros: + dependency: transitive + description: dart + source: sdk + version: "0.3.2" + analyzer: + dependency: transitive + description: + name: analyzer + sha256: b652861553cd3990d8ed361f7979dc6d7053a9ac8843fa73820ab68ce5410139 + url: "https://pub.dev" + source: hosted + version: "6.7.0" + args: + dependency: transitive + description: + name: args + sha256: bf9f5caeea8d8fe6721a9c358dd8a5c1947b27f1cfaa18b39c301273594919e6 + url: "https://pub.dev" + source: hosted + version: "2.6.0" async: dependency: transitive description: @@ -9,6 +38,14 @@ packages: url: "https://pub.dev" source: hosted version: "2.11.0" + bloc: + dependency: transitive + description: + name: bloc + sha256: "106842ad6569f0b60297619e9e0b1885c2fb9bf84812935490e6c5275777804e" + url: "https://pub.dev" + source: hosted + version: "8.1.4" boolean_selector: dependency: transitive description: @@ -17,6 +54,70 @@ packages: url: "https://pub.dev" source: hosted version: "2.1.1" + build: + dependency: transitive + description: + name: build + sha256: "80184af8b6cb3e5c1c4ec6d8544d27711700bc3e6d2efad04238c7b5290889f0" + url: "https://pub.dev" + source: hosted + version: "2.4.1" + build_config: + dependency: transitive + description: + name: build_config + sha256: bf80fcfb46a29945b423bd9aad884590fb1dc69b330a4d4700cac476af1708d1 + url: "https://pub.dev" + source: hosted + version: "1.1.1" + build_daemon: + dependency: transitive + description: + name: build_daemon + sha256: "79b2aef6ac2ed00046867ed354c88778c9c0f029df8a20fe10b5436826721ef9" + url: "https://pub.dev" + source: hosted + version: "4.0.2" + build_resolvers: + dependency: transitive + description: + name: build_resolvers + sha256: "339086358431fa15d7eca8b6a36e5d783728cf025e559b834f4609a1fcfb7b0a" + url: "https://pub.dev" + source: hosted + version: "2.4.2" + build_runner: + dependency: "direct dev" + description: + name: build_runner + sha256: "028819cfb90051c6b5440c7e574d1896f8037e3c96cf17aaeb054c9311cfbf4d" + url: "https://pub.dev" + source: hosted + version: "2.4.13" + build_runner_core: + dependency: transitive + description: + name: build_runner_core + sha256: f8126682b87a7282a339b871298cc12009cb67109cfa1614d6436fb0289193e0 + url: "https://pub.dev" + source: hosted + version: "7.3.2" + built_collection: + dependency: transitive + description: + name: built_collection + sha256: "376e3dd27b51ea877c28d525560790aee2e6fbb5f20e2f85d5081027d94e2100" + url: "https://pub.dev" + source: hosted + version: "5.1.1" + built_value: + dependency: transitive + description: + name: built_value + sha256: c7913a9737ee4007efedaffc968c049fd0f3d0e49109e778edc10de9426005cb + url: "https://pub.dev" + source: hosted + version: "8.9.2" characters: dependency: transitive description: @@ -25,6 +126,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.3.0" + checked_yaml: + dependency: transitive + description: + name: checked_yaml + sha256: feb6bed21949061731a7a75fc5d2aa727cf160b91af9a3e464c5e3a32e28b5ff + url: "https://pub.dev" + source: hosted + version: "2.0.3" clock: dependency: transitive description: @@ -33,6 +142,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.1.1" + code_builder: + dependency: transitive + description: + name: code_builder + sha256: f692079e25e7869c14132d39f223f8eec9830eb76131925143b2129c4bb01b37 + url: "https://pub.dev" + source: hosted + version: "4.10.0" collection: dependency: transitive description: @@ -41,6 +158,22 @@ packages: url: "https://pub.dev" source: hosted version: "1.18.0" + convert: + dependency: transitive + description: + name: convert + sha256: b30acd5944035672bc15c6b7a8b47d773e41e2f17de064350988c5d02adb1c68 + url: "https://pub.dev" + source: hosted + version: "3.1.2" + crypto: + dependency: transitive + description: + name: crypto + sha256: "1e445881f28f22d6140f181e07737b22f1e099a5e1ff94b0af2f9e4a463f4855" + url: "https://pub.dev" + source: hosted + version: "3.0.6" cupertino_icons: dependency: "direct main" description: @@ -49,6 +182,38 @@ packages: url: "https://pub.dev" source: hosted version: "1.0.8" + dart_style: + dependency: transitive + description: + name: dart_style + sha256: "7856d364b589d1f08986e140938578ed36ed948581fbc3bc9aef1805039ac5ab" + url: "https://pub.dev" + source: hosted + version: "2.3.7" + dio: + dependency: "direct main" + description: + name: dio + sha256: "5598aa796bbf4699afd5c67c0f5f6e2ed542afc956884b9cd58c306966efc260" + url: "https://pub.dev" + source: hosted + version: "5.7.0" + dio_web_adapter: + dependency: transitive + description: + name: dio_web_adapter + sha256: "33259a9276d6cea88774a0000cfae0d861003497755969c92faa223108620dc8" + url: "https://pub.dev" + source: hosted + version: "2.0.0" + equatable: + dependency: "direct main" + description: + name: equatable + sha256: c2b87cb7756efdf69892005af546c56c0b5037f54d2a88269b4f347a505e3ca2 + url: "https://pub.dev" + source: hosted + version: "2.0.5" fake_async: dependency: transitive description: @@ -57,11 +222,35 @@ packages: url: "https://pub.dev" source: hosted version: "1.3.1" + file: + dependency: transitive + description: + name: file + sha256: a3b4f84adafef897088c160faf7dfffb7696046cb13ae90b508c2cbc95d3b8d4 + url: "https://pub.dev" + source: hosted + version: "7.0.1" + fixnum: + dependency: transitive + description: + name: fixnum + sha256: b6dc7065e46c974bc7c5f143080a6764ec7a4be6da1285ececdc37be96de53be + url: "https://pub.dev" + source: hosted + version: "1.1.1" flutter: dependency: "direct main" description: flutter source: sdk version: "0.0.0" + flutter_bloc: + dependency: "direct main" + description: + name: flutter_bloc + sha256: b594505eac31a0518bdcb4b5b79573b8d9117b193cc80cc12e17d639b10aa27a + url: "https://pub.dev" + source: hosted + version: "8.1.6" flutter_lints: dependency: "direct dev" description: @@ -75,6 +264,78 @@ packages: description: flutter source: sdk version: "0.0.0" + frontend_server_client: + dependency: transitive + description: + name: frontend_server_client + sha256: f64a0333a82f30b0cca061bc3d143813a486dc086b574bfb233b7c1372427694 + url: "https://pub.dev" + source: hosted + version: "4.0.0" + glob: + dependency: transitive + description: + name: glob + sha256: "0e7014b3b7d4dac1ca4d6114f82bf1782ee86745b9b42a92c9289c23d8a0ab63" + url: "https://pub.dev" + source: hosted + version: "2.1.2" + graphs: + dependency: transitive + description: + name: graphs + sha256: "741bbf84165310a68ff28fe9e727332eef1407342fca52759cb21ad8177bb8d0" + url: "https://pub.dev" + source: hosted + version: "2.3.2" + http_multi_server: + dependency: transitive + description: + name: http_multi_server + sha256: "97486f20f9c2f7be8f514851703d0119c3596d14ea63227af6f7a481ef2b2f8b" + url: "https://pub.dev" + source: hosted + version: "3.2.1" + http_parser: + dependency: transitive + description: + name: http_parser + sha256: "2aa08ce0341cc9b354a498388e30986515406668dbcc4f7c950c3e715496693b" + url: "https://pub.dev" + source: hosted + version: "4.0.2" + io: + dependency: transitive + description: + name: io + sha256: "2ec25704aba361659e10e3e5f5d672068d332fc8ac516421d483a11e5cbd061e" + url: "https://pub.dev" + source: hosted + version: "1.0.4" + js: + dependency: transitive + description: + name: js + sha256: c1b2e9b5ea78c45e1a0788d29606ba27dc5f71f019f32ca5140f61ef071838cf + url: "https://pub.dev" + source: hosted + version: "0.7.1" + json_annotation: + dependency: "direct main" + description: + name: json_annotation + sha256: "1ce844379ca14835a50d2f019a3099f419082cfdd231cd86a142af94dd5c6bb1" + url: "https://pub.dev" + source: hosted + version: "4.9.0" + json_serializable: + dependency: "direct dev" + description: + name: json_serializable + sha256: ea1432d167339ea9b5bb153f0571d0039607a873d6e04e0117af043f14a1fd4b + url: "https://pub.dev" + source: hosted + version: "6.8.0" leak_tracker: dependency: transitive description: @@ -107,6 +368,22 @@ packages: url: "https://pub.dev" source: hosted version: "4.0.0" + logging: + dependency: transitive + description: + name: logging + sha256: c8245ada5f1717ed44271ed1c26b8ce85ca3228fd2ffdb75468ab01979309d61 + url: "https://pub.dev" + source: hosted + version: "1.3.0" + macros: + dependency: transitive + description: + name: macros + sha256: "0acaed5d6b7eab89f63350bccd82119e6c602df0f391260d0e32b5e23db79536" + url: "https://pub.dev" + source: hosted + version: "0.1.2-main.4" matcher: dependency: transitive description: @@ -131,6 +408,30 @@ packages: url: "https://pub.dev" source: hosted version: "1.15.0" + mime: + dependency: transitive + description: + name: mime + sha256: "41a20518f0cb1256669420fdba0cd90d21561e560ac240f26ef8322e45bb7ed6" + url: "https://pub.dev" + source: hosted + version: "2.0.0" + nested: + dependency: transitive + description: + name: nested + sha256: "03bac4c528c64c95c722ec99280375a6f2fc708eec17c7b3f07253b626cd2a20" + url: "https://pub.dev" + source: hosted + version: "1.0.0" + package_config: + dependency: transitive + description: + name: package_config + sha256: "1c5b77ccc91e4823a5af61ee74e6b972db1ef98c2ff5a18d3161c982a55448bd" + url: "https://pub.dev" + source: hosted + version: "2.1.0" path: dependency: transitive description: @@ -139,11 +440,83 @@ packages: url: "https://pub.dev" source: hosted version: "1.9.0" + pool: + dependency: transitive + description: + name: pool + sha256: "20fe868b6314b322ea036ba325e6fc0711a22948856475e2c2b6306e8ab39c2a" + url: "https://pub.dev" + source: hosted + version: "1.5.1" + pretty_dio_logger: + dependency: "direct main" + description: + name: pretty_dio_logger + sha256: "36f2101299786d567869493e2f5731de61ce130faa14679473b26905a92b6407" + url: "https://pub.dev" + source: hosted + version: "1.4.0" + provider: + dependency: transitive + description: + name: provider + sha256: c8a055ee5ce3fd98d6fc872478b03823ffdb448699c6ebdbbc71d59b596fd48c + url: "https://pub.dev" + source: hosted + version: "6.1.2" + pub_semver: + dependency: transitive + description: + name: pub_semver + sha256: "40d3ab1bbd474c4c2328c91e3a7df8c6dd629b79ece4c4bd04bee496a224fb0c" + url: "https://pub.dev" + source: hosted + version: "2.1.4" + pubspec_parse: + dependency: transitive + description: + name: pubspec_parse + sha256: c799b721d79eb6ee6fa56f00c04b472dcd44a30d258fac2174a6ec57302678f8 + url: "https://pub.dev" + source: hosted + version: "1.3.0" + shelf: + dependency: transitive + description: + name: shelf + sha256: ad29c505aee705f41a4d8963641f91ac4cee3c8fad5947e033390a7bd8180fa4 + url: "https://pub.dev" + source: hosted + version: "1.4.1" + shelf_web_socket: + dependency: transitive + description: + name: shelf_web_socket + sha256: "073c147238594ecd0d193f3456a5fe91c4b0abbcc68bf5cd95b36c4e194ac611" + url: "https://pub.dev" + source: hosted + version: "2.0.0" sky_engine: dependency: transitive description: flutter source: sdk version: "0.0.99" + source_gen: + dependency: transitive + description: + name: source_gen + sha256: "14658ba5f669685cd3d63701d01b31ea748310f7ab854e471962670abcf57832" + url: "https://pub.dev" + source: hosted + version: "1.5.0" + source_helper: + dependency: transitive + description: + name: source_helper + sha256: "6adebc0006c37dd63fe05bca0a929b99f06402fc95aa35bf36d67f5c06de01fd" + url: "https://pub.dev" + source: hosted + version: "1.3.4" source_span: dependency: transitive description: @@ -168,6 +541,14 @@ packages: url: "https://pub.dev" source: hosted version: "2.1.2" + stream_transform: + dependency: transitive + description: + name: stream_transform + sha256: "14a00e794c7c11aa145a170587321aedce29769c08d7f58b1d141da75e3b1c6f" + url: "https://pub.dev" + source: hosted + version: "2.1.0" string_scanner: dependency: transitive description: @@ -192,6 +573,22 @@ packages: url: "https://pub.dev" source: hosted version: "0.7.2" + timing: + dependency: transitive + description: + name: timing + sha256: "70a3b636575d4163c477e6de42f247a23b315ae20e86442bebe32d3cabf61c32" + url: "https://pub.dev" + source: hosted + version: "1.0.1" + typed_data: + dependency: transitive + description: + name: typed_data + sha256: f9049c039ebfeb4cf7a7104a675823cd72dba8297f264b6637062516699fa006 + url: "https://pub.dev" + source: hosted + version: "1.4.0" vector_math: dependency: transitive description: @@ -208,6 +605,46 @@ packages: url: "https://pub.dev" source: hosted version: "14.2.5" + watcher: + dependency: transitive + description: + name: watcher + sha256: "3d2ad6751b3c16cf07c7fca317a1413b3f26530319181b37e3b9039b84fc01d8" + url: "https://pub.dev" + source: hosted + version: "1.1.0" + web: + dependency: transitive + description: + name: web + sha256: cd3543bd5798f6ad290ea73d210f423502e71900302dde696f8bff84bf89a1cb + url: "https://pub.dev" + source: hosted + version: "1.1.0" + web_socket: + dependency: transitive + description: + name: web_socket + sha256: "3c12d96c0c9a4eec095246debcea7b86c0324f22df69893d538fcc6f1b8cce83" + url: "https://pub.dev" + source: hosted + version: "0.1.6" + web_socket_channel: + dependency: transitive + description: + name: web_socket_channel + sha256: "9f187088ed104edd8662ca07af4b124465893caf063ba29758f97af57e61da8f" + url: "https://pub.dev" + source: hosted + version: "3.0.1" + yaml: + dependency: transitive + description: + name: yaml + sha256: "75769501ea3489fca56601ff33454fe45507ea3bfb014161abc3b43ae25989d5" + url: "https://pub.dev" + source: hosted + version: "3.1.2" sdks: dart: ">=3.5.3 <4.0.0" flutter: ">=3.18.0-18.0.pre.54" diff --git a/pubspec.yaml b/pubspec.yaml index 045d0a1..433ded4 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -30,7 +30,12 @@ environment: dependencies: flutter: sdk: flutter - + json_annotation: ^4.8.1 + dio: ^5.4.2+1 + pretty_dio_logger: ^1.3.1 + #BLoC + equatable: ^2.0.5 + flutter_bloc: ^8.1.5 # The following adds the Cupertino Icons font to your application. # Use with the CupertinoIcons class for iOS style icons. @@ -47,6 +52,8 @@ dev_dependencies: # rules and activating additional ones. flutter_lints: ^4.0.0 + build_runner: ^2.4.9 + json_serializable: ^6.7.1 # For information on the generic Dart part of this file, see the # following page: https://dart.dev/tools/pub/pubspec