import 'package:flutter/material.dart'; import 'package:flutter_example_packages/widgets/base/export.dart'; import 'package:flutter_example_packages/widgets/texts/export.dart'; import 'package:flutter_gen/gen_l10n/app_localizations.dart'; /// Block list item class BlockItem extends AppStatelessWidget { const BlockItem({ super.key, required this.title, required this.desc, this.future, this.stream, this.builder, }); final String title; final String desc; final Stream? stream; final Future? future; final Function(T)? builder; AsyncWidgetBuilder get widgetBuilder => (BuildContext context, AsyncSnapshot snapshot) { return Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ TextTitleSmall(title), const SizedBox(height: 8), TextBodySmall(desc), const SizedBox(height: 8), if (snapshot.hasData) TextBodyMedium( snapshot.data == null ? '-' : (builder == null ? snapshot.data.toString() : builder?.call(snapshot.data as T)), ), if (!snapshot.hasData) const SizedBox( width: 16, height: 16, child: CircularProgressIndicator( color: Colors.blueAccent, strokeWidth: 2, ), ), const SizedBox(height: 20), ], ); }; @override Widget buildWide( BuildContext context, MediaQueryData media, AppLocalizations l10n, ) { if (stream != null) { return StreamBuilder( stream: stream, builder: widgetBuilder, ); } if (future != null) { return FutureBuilder( future: future, builder: widgetBuilder, ); } throw "Please enter a value stream or future"; } }