Compare commits

..

2 Commits

Author SHA1 Message Date
Yaël Perret
6429854028 feat : EvenDetails --> Add Animator with widget 2025-09-13 17:53:24 +02:00
Yaël Perret
8067125921 feat : EventDetails --> Add description 2025-09-13 17:08:01 +02:00
3 changed files with 100 additions and 16 deletions

View File

@@ -0,0 +1,56 @@
import 'package:flutter/material.dart';
class AnimatorWidget extends StatefulWidget {
final String authorName;
final String authorImageUrl;
final DateTime? publishDate;
final List<String>? imageUrls;
final int likesCount;
final int commentsCount;
final int sharesCount;
final VoidCallback? onLike;
final VoidCallback? onComment;
final VoidCallback? onShare;
final double? aspectRatio; // Nouveau paramètre pour le ratio (largeur/hauteur)
const AnimatorWidget({
Key? key,
required this.authorName,
required this.authorImageUrl,
this.publishDate,
this.imageUrls,
this.likesCount = 0,
this.commentsCount = 0,
this.sharesCount = 0,
this.onLike,
this.onComment,
this.onShare,
this.aspectRatio, // null = ratio naturel de l'image, ex: 16/9, 4/3, 1/1
}) : super(key: key);
@override
State<AnimatorWidget> createState() => _AnimatorWidgetWidgetState();
}
class _AnimatorWidgetWidgetState extends State<AnimatorWidget> {
@override
Widget build(BuildContext context) {
return Row(
children: [
CircleAvatar(
backgroundImage: NetworkImage(widget.authorImageUrl),
),
const SizedBox(width: 8),
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(widget.authorName, style: Theme.of(context).textTheme.bodyLarge?.copyWith(color: Colors.black)),
//Text('${widget.publishDate.toLocal()}'.split(' ')[0], style: const TextStyle(color: Colors.grey, fontSize: 12)),
],
),
],
);
}
}

View File

@@ -2,7 +2,9 @@ import 'package:flutter/material.dart';
import 'package:stacked/stacked.dart';
import 'event_details_viewmodel.dart';
import '../../common/post_card_widget.dart';
import 'package:bahla_front/ui/common/ReadMoreText.dart';
import 'package:bahla_front/ui/common/animator_widget.dart';
import 'package:bahla_front/ui/common/post_card_widget.dart';
class EventDetailsView extends StackedView<EventDetailsViewModel> {
final int eventId;
@@ -240,25 +242,38 @@ class EventDetailsView extends StackedView<EventDetailsViewModel> {
// Tab 2: À propos
Container(
color: const Color(0xFFEFF0FF),
child: ListView(
padding: const EdgeInsets.all(16.0),
child: Column(
children: [
Text(
'À propos de L\'Octonelle',
style: Theme.of(context).textTheme.headlineSmall?.copyWith(
color: Colors.black,
fontWeight: FontWeight.bold,
Container(
padding: const EdgeInsets.all(16.0),
child: ReadMoreText(
'Bienvenue à Disc\'Octonelle 2 ! \n\nRejoignez-nous pour une soirée inoubliable de musique, de danse et de bonne humeur. \n\nQue vous soyez amateur de rock, de pop, de jazz ou d\'électro, il y en aura pour tous les goûts. \nVenez découvrir des artistes locaux et internationaux dans une ambiance conviviale et festive. \nNe manquez pas cette occasion unique de faire la fête et de créer des souvenirs mémorables avec vos amis. Nous avons hâte de vous accueillir à Disc\'Octonelle 2 !',
trimLines: 10,
collapsedText: '... Voir plus',
expandedText: ' Voir moins',
textStyle: Theme.of(context).textTheme.bodyMedium?.copyWith(
color: Colors.black,
height: 1.4,
),
),
),
const SizedBox(height: 16),
const Text(
'Description détaillée de l\'organisation L\'Octonelle et de ses activités...',
style: TextStyle(color: Colors.black87),
Divider(height: 2, indent: 20, endIndent: 20, color: Theme.of(context).colorScheme.primary),
// The ListView inside a Column needs bounded height => wrap with Expanded
Expanded(
child: ListView.builder(
padding: const EdgeInsets.all(16.0),
itemCount: 10,
itemBuilder: (context, index) {
return Padding(
padding: const EdgeInsets.only(bottom: 12.0),
child: AnimatorWidget(
authorName: 'Animateur ${index + 1}',
authorImageUrl: 'https://placehold.co/400x400/png',
),
);
},
),
),
...List.generate(20, (index) => Padding(
padding: const EdgeInsets.symmetric(vertical: 8.0),
child: Text('Ligne de contenu ${index + 1}'),
)),
],
),
),

View File

@@ -32,4 +32,17 @@ class Post {
required this.title,
required this.content,
});
}
class Animator {
final String id;
final String name;
final String content;
final String authorImageUrl = 'https://placehold.co/400x400/png';
Animator({
required this.id,
required this.name,
required this.content,
});
}