import 'package:flutter/material.dart'; import 'package:get/get.dart'; import 'package:solian/models/account.dart'; import 'package:solian/models/relations.dart'; import 'package:solian/providers/relation.dart'; import 'package:solian/widgets/account/account_avatar.dart'; class RelativeSelector extends StatefulWidget { final String title; final Widget? Function(Account item)? trailingBuilder; const RelativeSelector( {super.key, required this.title, this.trailingBuilder}); @override State<RelativeSelector> createState() => _RelativeSelectorState(); } class _RelativeSelectorState extends State<RelativeSelector> { final List<Relationship> _friends = List.empty(growable: true); _getFriends() async { final RelationshipProvider provider = Get.find(); final resp = await provider.listRelationWithStatus(1); setState(() { _friends.addAll(resp.body .map((e) => Relationship.fromJson(e)) .toList() .cast<Relationship>()); }); } @override void initState() { super.initState(); _getFriends(); } @override Widget build(BuildContext context) { return SizedBox( height: MediaQuery.of(context).size.height * 0.85, child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text( widget.title, style: Theme.of(context).textTheme.headlineSmall, ).paddingOnly(left: 24, right: 24, top: 32, bottom: 16), Expanded( child: ListView.builder( itemCount: _friends.length, itemBuilder: (context, index) { var element = _friends[index].related; return ListTile( title: Text(element.nick), subtitle: Text(element.name), leading: AccountAvatar(content: element.avatar), trailing: widget.trailingBuilder != null ? widget.trailingBuilder!(element) : null, onTap: () { Navigator.pop(context, element); }, ); }, ), ), ], ), ); } }