pmu/lib/widgets/hero_card.dart
2024-12-16 22:27:12 +04:00

69 lines
1.7 KiB
Dart

import 'package:flutter/material.dart';
import '../../data/dtos/hero_dto.dart';
import '../components/screens/hero_detail_screen.dart';
import '../services/like_service.dart';
class HeroCard extends StatefulWidget {
final HeroDto hero;
const HeroCard({Key? key, required this.hero}) : super(key: key);
@override
_HeroCardState createState() => _HeroCardState();
}
class _HeroCardState extends State<HeroCard> {
final LikeService _likeService = LikeService();
bool _isLiked = false;
@override
void initState() {
super.initState();
_loadLikeStatus();
}
Future<void> _loadLikeStatus() async {
final isLiked = await _likeService.isHeroLiked(widget.hero.id);
setState(() {
_isLiked = isLiked;
});
}
Future<void> _toggleLike() async {
if (_isLiked) {
await _likeService.unlikeHero(widget.hero.id);
} else {
await _likeService.likeHero(widget.hero.id);
}
setState(() {
_isLiked = !_isLiked;
});
}
@override
Widget build(BuildContext context) {
return Card(
child: ListTile(
leading: widget.hero.portraitUrl != null
? Image.network(widget.hero.portraitUrl!)
: Icon(Icons.image),
title: Text(widget.hero.name),
trailing: IconButton(
icon: Icon(
_isLiked ? Icons.favorite : Icons.favorite_border,
color: _isLiked ? Colors.red : null,
),
onPressed: _toggleLike,
),
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => HeroDetailScreen(heroId: widget.hero.id),
),
);
},
),
);
}
}