152 lines
4.3 KiB
Dart
Raw Normal View History

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
2024-10-01 18:21:37 +04:00
import 'package:laba1/data/repositories/potter_repository.dart';
import 'package:laba1/presentation/details_page/details_page.dart';
2024-10-01 18:21:37 +04:00
import '../../data/repositories/mock_repository.dart';
import '../../domain/models/card.dart';
2024-10-01 18:21:37 +04:00
import '../dialogs/show_dialog.dart';
import 'bloc/bloc.dart';
import 'bloc/events.dart';
import 'bloc/state.dart';
part 'card.dart';
class MyHomePage extends StatefulWidget {
const MyHomePage({super.key, required this.title});
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
backgroundColor: Colors.amber,
),
backgroundColor: Colors.yellow,
body: const _Body());
}
}
class _Body extends StatefulWidget {
const _Body({Key? key}) : super(key: key);
2024-10-01 18:21:37 +04:00
@override
State<_Body> createState() => _BodyState();
2024-10-01 18:21:37 +04:00
}
class _BodyState extends State<_Body> {
2024-10-01 18:21:37 +04:00
final searchController = TextEditingController();
@override
2024-10-01 22:57:57 +04:00
void initState() {
WidgetsBinding.instance.addPostFrameCallback((_) {
context.read<HomeBloc>().add(const HomeLoadDataEvent());
});
2024-10-01 22:57:57 +04:00
super.initState();
}
@override
void dispose() {
searchController.dispose();
super.dispose();
}
2024-10-01 22:57:57 +04:00
@override
Widget build(BuildContext context) {
return Center(
2024-10-01 22:57:57 +04:00
child: Stack(
children: [
Positioned.fill(
child: BlocBuilder<HomeBloc, HomeState > (
builder: (context, state) =>
FutureBuilder<List<CardData>?>(
future: state.data,
2024-10-01 22:57:57 +04:00
builder: (context, snapshot) {
var cards = Column(
children: [],
);
cards.children.add(Padding(
padding: const EdgeInsets.only(left: 8.0, right: 8),
child: CupertinoSearchTextField(
borderRadius: BorderRadius.only(
bottomLeft: Radius.circular(20),
bottomRight: Radius.circular(20),
),
backgroundColor: Colors.amberAccent,
),
2024-10-01 22:57:57 +04:00
));
cards.children.addAll(
snapshot.data
?.map((e) =>
_Card.fromData(
e,
onLike: (String title, bool isLiked) {
_showSnackBar(context, title, isLiked);
},
onTap: () => _navToDetails(context, e),
))
.toList() ??
2024-10-01 22:57:57 +04:00
[],
2024-10-01 18:21:37 +04:00
);
return snapshot.hasData
2024-10-01 22:57:57 +04:00
? SingleChildScrollView(
child: cards,
)
: Center(child: CircularProgressIndicator());
2024-10-01 18:21:37 +04:00
},
),
),),
Align(
alignment: Alignment.topCenter,
child: Padding(
padding: const EdgeInsets.only(left: 8.0, right: 8),
child: CupertinoSearchTextField(
borderRadius: BorderRadius.only(
bottomLeft: Radius.circular(20),
bottomRight: Radius.circular(20),
2024-10-01 22:57:57 +04:00
),
backgroundColor: Colors.amberAccent,
controller: searchController,
onChanged: (search) {
//TODO
},
2024-10-01 18:21:37 +04:00
),
2024-10-01 22:57:57 +04:00
),
),
2024-10-01 22:57:57 +04:00
],
),
);
}
void _navToDetails(BuildContext context, CardData data) {
Navigator.push(
context,
CupertinoPageRoute(builder: (context) => DetailsPage(data)),
);
}
void _showSnackBar(BuildContext context, String title, bool isLiked) {
WidgetsBinding.instance.addPostFrameCallback((_) {
ScaffoldMessenger.of(context).showSnackBar(SnackBar(
content: Text(
'$title ${isLiked ? 'liked' : 'unliked'}',
style: Theme
.of(context)
.textTheme
.bodyLarge,
),
backgroundColor: Colors.orangeAccent,
duration: const Duration(seconds: 1),
));
});
}
}