diff --git a/lib/data/dtos/house_dto_json.dart b/lib/data/dtos/house_dto_json.dart new file mode 100644 index 0000000..d151646 --- /dev/null +++ b/lib/data/dtos/house_dto_json.dart @@ -0,0 +1,33 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'houses_dto.dart'; + +// ************************************************************************** +// JsonSerializableGenerator +// ************************************************************************** + + +HousesDto _$HousesDtoFromJson(Map json) => + HousesDto( + data: (json['data'] as List?) + ?.map((e) => HouseDataDto.fromJson(e as Map)) + .toList(), + ); + +HouseDataDto _$HouseDataDtoFromJson(Map json) => + HouseDataDto( + json['id'] as String?, + json['attributes'] == null + ? null + : HouseAttributesDataDto.fromJson( + json['attributes'] as Map), + ); + +HouseAttributesDataDto _$HouseAttributesDataDtoFromJson( + Map json) => + HouseAttributesDataDto( + json['name'] as String?, + json['location'] as String?, + json['image'] as String?, + json['description'] as String?, + ); diff --git a/lib/data/dtos/houses_dto.dart b/lib/data/dtos/houses_dto.dart new file mode 100644 index 0000000..505260f --- /dev/null +++ b/lib/data/dtos/houses_dto.dart @@ -0,0 +1,37 @@ +import 'package:json_annotation/json_annotation.dart'; + +// dart run build_runner build --delete-conflicting-outputs + +part 'house_dto_json.dart'; + + +@JsonSerializable(createToJson: false) +class HousesDto { + final List? data; + + const HousesDto({this.data}); + + factory HousesDto.fromJson(Map json) => _$HousesDtoFromJson(json); +} + +@JsonSerializable(createToJson: false) +class HouseDataDto { + final String? id; + final HouseAttributesDataDto? attributes; + + const HouseDataDto(this.id, this.attributes); + + factory HouseDataDto.fromJson(Map json) => _$HouseDataDtoFromJson(json); +} + +@JsonSerializable(createToJson: false) +class HouseAttributesDataDto { + final String? name; + final String? location; + final String? image; + final String? description; + + HouseAttributesDataDto(this.name, this.location, this.image, this.description); + + factory HouseAttributesDataDto.fromJson(Map json) => _$HouseAttributesDataDtoFromJson(json); +} diff --git a/lib/data/mapper/house_mapper.dart b/lib/data/mapper/house_mapper.dart new file mode 100644 index 0000000..72c563e --- /dev/null +++ b/lib/data/mapper/house_mapper.dart @@ -0,0 +1,11 @@ +import '../dtos/houses_dto.dart'; +import 'package:pmd/models/card_data.dart'; + +extension HouseDataDtoToModel on HouseDataDto { + CardData toDomain() => CardData( + name: attributes?.name ?? "UNKNOWN", + location: attributes?.location ?? "UNKNOWN", // Безопасный доступ к location + image: attributes?.image ?? "https://upload.wikimedia.org/wikipedia/commons/a/a2/Person_Image_Placeholder.png", + description: attributes?.description ?? "UNKNOWN" + ); +} \ No newline at end of file diff --git a/lib/details_page/details_page.dart b/lib/details_page/details_page.dart new file mode 100644 index 0000000..cc43ab6 --- /dev/null +++ b/lib/details_page/details_page.dart @@ -0,0 +1,48 @@ +import 'package:pmd/models/card_data.dart'; +import 'package:flutter/material.dart'; + +class DetailsPage extends StatelessWidget { + final CardData data; + + const DetailsPage({super.key, required this.data}); + + @override + Widget build(BuildContext context) { + return Scaffold( + appBar: AppBar( + title: Text('House ${data.name}'), + ), + body: SingleChildScrollView( + padding: const EdgeInsets.all(30), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Center( + child: ClipRRect( + borderRadius: BorderRadius.circular(20.0), + child: Image.network( + data.image, + height: 250, + width: 250, + ), + ), + ), + const SizedBox(height: 20), + Text( + "Название ${data.name}", + style: const TextStyle(fontSize: 20, color: Colors.blue), + ), + Text( + "Описание: ${data.location}.", + style: TextStyle(fontSize: 18), + ), + Text( + "Описание: ${data.description}.", + style: TextStyle(fontSize: 18), + ), + ], + ), + ), + ); + } +} diff --git a/lib/home_page/card.dart b/lib/home_page/card.dart new file mode 100644 index 0000000..6b79065 --- /dev/null +++ b/lib/home_page/card.dart @@ -0,0 +1,112 @@ +part of "home_page.dart"; + +typedef OnLikeFunction = void Function(String text); + +class _Card extends StatefulWidget { + final String name; + final String location; + final String image; + final String description; + + final OnLikeFunction? onLike; + final VoidCallback? onTap; + + const _Card( + {required this.name, required this.location, required this.image, required this.description, required this.onLike, required this.onTap}); + + factory _Card.fromData(CardData data, OnLikeFunction? onLike, + VoidCallback? onTap) => + _Card( + name: data.name, + location: data.location, + image: data.image, + description: data.description, + onLike: onLike, + onTap: onTap); + + @override + State createState() => _CardState(); +} + +class _CardState extends State<_Card> { + bool _isFavourite = false; + + void toggleIsFavourite() { + setState(() { + _isFavourite = !_isFavourite; + }); + + widget.onLike?.call(_isFavourite + ? "Property liked me" + : "Property has been removed from the likes"); + } + + @override + Widget build(BuildContext context) { + return GestureDetector( + onTap: widget.onTap, + child: Container( + width: double.infinity, + padding: + const EdgeInsets.only(top: 15, bottom: 15, left: 30, right: 30), + decoration: BoxDecoration( + border: Border.all(color: Colors.black12, width: 2), + color: Colors.blue, + borderRadius: BorderRadius.circular(20)), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Row( + mainAxisAlignment: MainAxisAlignment.start, // Выравниваем по левому краю + children: [ + GestureDetector( + onTap: toggleIsFavourite, + child: AnimatedSwitcher( + duration: const Duration(milliseconds: 200), + child: _isFavourite + ? const Icon( + Icons.favorite, + color: Colors.red, + key: ValueKey(0), + ) + : const Icon( + Icons.favorite_border, + color: Colors.red, + key: ValueKey(1), + ), + ), + ) + ], + ), + const SizedBox(height: 20), + Center( + child: ClipRRect( + borderRadius: BorderRadius.circular(20.0), + // Радиус скругления + child: Image.network( + widget.image, + width: 280, // Ширина изображения + height: 350, // Высота изображения + fit: BoxFit.cover + )// Позволяет изображению подстраиваться под рамки), + ), + ), + Padding( + padding: const EdgeInsets.only(top: 50), + child: Column( + crossAxisAlignment: CrossAxisAlignment.start, + children: [ + Text(widget.name, style: TextStyle(fontSize: 17)), + Text("Местоположение: ${widget.location}", + style: TextStyle(fontSize: 15)), + Text("${widget.description}", + style: TextStyle(fontSize: 17, color: Colors.orange)) + ], + ), + ) + ], + ), + ), + ); + } +} \ No newline at end of file diff --git a/lib/home_page/home_page.dart b/lib/home_page/home_page.dart new file mode 100644 index 0000000..7e46d5c --- /dev/null +++ b/lib/home_page/home_page.dart @@ -0,0 +1,104 @@ +import 'package:flutter/cupertino.dart'; +import 'package:flutter/material.dart'; +import 'package:pmd/models/card_data.dart'; +import 'package:pmd/details_page/details_page.dart'; +import 'package:pmd/repositories/api_interface.dart'; + +import '../repositories/potter_repository.dart'; + +part 'card.dart'; + +class MyHomePage extends StatefulWidget { + const MyHomePage({super.key, required this.title}); + + final String title; + + @override + State createState() => _MyHomePageState(); +} + +class _MyHomePageState extends State { + final TextEditingController _searchController = TextEditingController(); + final ApiInterface repository = PotterRepository(); + late Future?> _data; + + @override + void initState() { + super.initState(); + _data = repository.loadData(null); + } + + void _showSnackBar(BuildContext context, String text) { + WidgetsBinding.instance.addPostFrameCallback((_) { + ScaffoldMessenger.of(context).showSnackBar(SnackBar( + content: Text(text), + duration: const Duration(seconds: 2), + backgroundColor: Colors.black54, + )); + }); + } + + void _navigateToDetailsPage(BuildContext context, CardData data) { + Navigator.push( + context, + CupertinoPageRoute(builder: (context) => DetailsPage(data: data)), + ); + } + + @override + Widget build(BuildContext context) { + return Scaffold( + appBar: AppBar( + backgroundColor: Theme.of(context).colorScheme.inversePrimary, + title: Text(widget.title), + ), + body: ListView( + children: [ + Column( + children: [ + Padding( + padding: const EdgeInsets.only(right: 30, left: 30, top: 20), + child: CupertinoSearchTextField( + controller: _searchController, + onChanged: (search) { + setState(() { + _data = repository.loadData(search); + }); + }), + ), + FutureBuilder?>( + future: _data, + builder: (context, snapshot) => SingleChildScrollView( + padding: const EdgeInsets.symmetric( + horizontal: 30, + vertical: 15, + ), + child: snapshot.hasData + ? Column( + mainAxisAlignment: MainAxisAlignment.center, + children: snapshot.data?.map((cardData) { + return Column( + children: [ + const SizedBox(height: 20), + _Card.fromData( + cardData, + (String text) => + _showSnackBar(context, text), + () => _navigateToDetailsPage( + context, cardData), + ), + const SizedBox(height: 20) + ], + ); + }).toList() ?? + []) + : const CircularProgressIndicator(), + ), + ), + ], + ) + ], + ), + ); + } +} diff --git a/lib/main.dart b/lib/main.dart index 5035444..f7c5220 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -1,4 +1,5 @@ import 'package:flutter/material.dart'; +import 'package:pmd/home_page/home_page.dart'; void main() { runApp(const MyApp()); @@ -13,109 +14,10 @@ class MyApp extends StatelessWidget { title: 'Flutter Demo', debugShowCheckedModeBanner: false, theme: ThemeData( - colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepOrange), + colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), useMaterial3: true, ), - home: const MyHomePage(title: 'Laboratory 3: Cards'), + home: const MyHomePage(title: 'Laboratory 5: API..... '), ); } } - -class MyHomePage extends StatefulWidget { - const MyHomePage({super.key, required this.title}); - - final String title; - - @override - State createState() => _MyHomePageState(); -} - -class _MyHomePageState extends State { - @override - Widget build(BuildContext context) { - return Scaffold( - appBar: AppBar( - backgroundColor: Theme - .of(context) - .colorScheme - .inversePrimary, - title: Text(widget.title), - ), - body: Padding( - padding: const EdgeInsets.all(30), - child: ListView.separated( - itemBuilder: (context, index) => - Card(name: "House $index", location: "Moscow", price: 1100.0), - separatorBuilder: (context, index) => const SizedBox(height: 20), - itemCount: 5, - ))); - } -} - -class Card extends StatefulWidget { - const Card({super.key, required this.name, required this.price, required this.location}); - - final String name; - final double price; - final String location; - - @override - State createState() => _CardState(); -} - -class _CardState extends State { - bool _isFavorite = false; - - void toggleIsFavorite() { - setState(() { - _isFavorite = !_isFavorite; - }); - } - - @override - 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(20)), - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Center( - child: Image.network( - "https://cdn0.youla.io/files/images/780_780/63/29/6329d9f543eedb62b7695786-1.jpg"), - ), - Padding( - padding: EdgeInsets.only(top: 50), - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text(widget.name, style: TextStyle(fontSize: 17)), - Text("Местоположение: ${widget.location}", style: TextStyle(fontSize: 15)), - Text("${widget.price} Рублей/сутки", - style: TextStyle( - fontSize: 17, color: Colors.orange)) - ], - ), - ) - ], - ), - ), - - Positioned( - right: 300, - top: 10, - child: IconButton( - icon: Icon(_isFavorite ? Icons.favorite : Icons.favorite_border), - color: Colors.red, - onPressed: toggleIsFavorite, - )) - ], - ); - } -} - diff --git a/lib/models/card_data.dart b/lib/models/card_data.dart new file mode 100644 index 0000000..7ee8185 --- /dev/null +++ b/lib/models/card_data.dart @@ -0,0 +1,9 @@ +class CardData { + final String name; + final String location; + final String image; + final String description; + + const CardData({required this.name, required this.location, + required this.image, required this.description}); +} \ 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..2c96211 --- /dev/null +++ b/lib/repositories/api_interface.dart @@ -0,0 +1,5 @@ +import 'package:pmd/models/card_data.dart'; + +abstract class ApiInterface { + Future?> loadData (String? q); +} \ No newline at end of file diff --git a/lib/repositories/mock_repository.dart b/lib/repositories/mock_repository.dart new file mode 100644 index 0000000..651333c --- /dev/null +++ b/lib/repositories/mock_repository.dart @@ -0,0 +1,28 @@ +import 'package:pmd/models/card_data.dart'; +import 'package:pmd/repositories/api_interface.dart'; + +class MockRepository extends ApiInterface { + @override + Future> loadData(String? q) async { + return [ + CardData( + name: "house 0", + image: + "https://cdn0.youla.io/files/images/780_780/63/29/6329d9f543eedb62b7695786-1.jpg", + location: "Moscow", + description: "description null"), + CardData( + name: "house 1", + image: + "https://cdn0.youla.io/files/images/780_780/63/29/6329d9f543eedb62b7695786-1.jpg", + location: "Samara", + description: "null"), + CardData( + name: "house 2", + image: + "https://cdn0.youla.io/files/images/780_780/63/29/6329d9f543eedb62b7695786-1.jpg", + location: "Moscow", + description: "house good, very good") + ]; + } +} \ No newline at end of file diff --git a/lib/repositories/potter_repository.dart b/lib/repositories/potter_repository.dart new file mode 100644 index 0000000..91cb562 --- /dev/null +++ b/lib/repositories/potter_repository.dart @@ -0,0 +1,44 @@ +import 'dart:developer'; + +import 'package:dio/dio.dart'; +import 'package:pmd/data/mapper/house_mapper.dart'; +import 'package:pmd/data/dtos/houses_dto.dart'; +import 'package:pmd/models/card_data.dart'; +import 'package:pmd/repositories/api_interface.dart'; +import 'package:pretty_dio_logger/pretty_dio_logger.dart'; + +import '../data/dtos/houses_dto.dart'; + +class PotterRepository extends ApiInterface { + static final Dio _dio = Dio( + BaseOptions(connectTimeout: Duration(seconds: 10))) + ..interceptors.add( + PrettyDioLogger(request: true, requestHeader: true, requestBody: true)); + + static const String _baseUrl = "https://api.potterdb.com/v1"; //https://api.realtor.com/v1 + + @override + Future?> loadData(String? q) async { + try { + const String url = '$_baseUrl/characters?page[size]=5'; + + final Response response = await _dio.get>( + url, + queryParameters: q != null ? {"filter[name_cont]": q} : null, + ); + + final HousesDto dto = + HousesDto.fromJson(response.data as Map); + + final List? data = dto.data?.map((e) => e.toDomain()).toList(); + + return data; + } on DioException catch (e) { + log("DioException: $e"); + return null; + } catch (e) { + log('Unknown error: $e'); + return null; + } + } +} diff --git a/pubspec.lock b/pubspec.lock index 7e0d928..cb2934a 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: "7cf60b9f0cc88203c5a190b4cd62a99feea42759a7fa695010eb5de1c0b2252a" + url: "https://pub.dev" + source: hosted + version: "2.5.0" async: dependency: transitive description: @@ -17,6 +46,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: dd09dd4e2b078992f42aac7f1a622f01882a8492fef08486b27ddde929c19f04 + url: "https://pub.dev" + source: hosted + version: "2.4.12" + 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 +118,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 +134,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 +150,22 @@ packages: url: "https://pub.dev" source: hosted version: "1.18.0" + convert: + dependency: transitive + description: + name: convert + sha256: "0f08b14755d163f6e2134cb58222dd25ea2a2ee8a195e53983d57c075324d592" + url: "https://pub.dev" + source: hosted + version: "3.1.1" + crypto: + dependency: transitive + description: + name: crypto + sha256: ec30d999af904f33454ba22ed9a86162b35e52b44ac4807d1d93c288041d7d27 + url: "https://pub.dev" + source: hosted + version: "3.0.5" cupertino_icons: dependency: "direct main" description: @@ -49,6 +174,30 @@ 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" fake_async: dependency: transitive description: @@ -57,6 +206,22 @@ packages: url: "https://pub.dev" source: hosted version: "1.3.1" + file: + dependency: transitive + description: + name: file + sha256: "5fc22d7c25582e38ad9a8515372cd9a93834027aacf1801cf01164dac0ffa08c" + url: "https://pub.dev" + source: hosted + version: "7.0.0" + fixnum: + dependency: transitive + description: + name: fixnum + sha256: "25517a4deb0c03aa0f32fd12db525856438902d9c16536311e76cdc57b31d7d1" + url: "https://pub.dev" + source: hosted + version: "1.1.0" flutter: dependency: "direct main" description: flutter @@ -75,6 +240,46 @@ 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" intl: dependency: "direct main" description: @@ -83,6 +288,38 @@ packages: url: "https://pub.dev" source: hosted version: "0.18.1" + 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: @@ -115,6 +352,22 @@ packages: url: "https://pub.dev" source: hosted version: "4.0.0" + logging: + dependency: transitive + description: + name: logging + sha256: "623a88c9594aa774443aa3eb2d41807a48486b5613e67599fb4c41c0ad47c340" + url: "https://pub.dev" + source: hosted + version: "1.2.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: @@ -139,6 +392,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.15.0" + mime: + dependency: transitive + description: + name: mime + sha256: "801fd0b26f14a4a58ccb09d5892c3fbdeff209594300a542492cf13fba9d247a" + url: "https://pub.dev" + source: hosted + version: "1.0.6" nested: dependency: transitive description: @@ -147,6 +408,14 @@ packages: 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: @@ -155,6 +424,22 @@ 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: "direct main" description: @@ -163,11 +448,59 @@ packages: 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: @@ -192,6 +525,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: @@ -216,6 +557,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: facc8d6582f16042dd49f2463ff1bd6e2c9ef9f3d5da3d9b087e244a7b564b3c + url: "https://pub.dev" + source: hosted + version: "1.3.2" vector_math: dependency: transitive description: @@ -232,6 +589,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: d43c1d6b787bf0afad444700ae7f4db8827f701bc61c255ac8d328c6f4d52062 + url: "https://pub.dev" + source: hosted + version: "1.0.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 be46704..a39488c 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -38,6 +38,11 @@ dependencies: # Use with the CupertinoIcons class for iOS style icons. cupertino_icons: ^1.0.8 + # Для Json + json_annotation: ^4.8.1 + dio: ^5.4.2+1 + pretty_dio_logger: ^1.3.1 + dev_dependencies: flutter_test: sdk: flutter @@ -49,6 +54,10 @@ dev_dependencies: # rules and activating additional ones. flutter_lints: ^4.0.0 + # Добавляем JSON и добавляем зависимость от http + 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