import 'dart:async'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:photos/core/event_bus.dart'; import 'package:photos/events/user_details_changed_event.dart'; import 'package:photos/models/user_details.dart'; import 'package:photos/services/user_service.dart'; import 'package:photos/ui/loading_widget.dart'; import 'package:photos/ui/settings/usage_details_widget.dart'; import 'package:photos/utils/data_util.dart'; import 'package:photos/utils/toast_util.dart'; import 'package:pie_chart/pie_chart.dart'; class DetailsSectionWidget extends StatefulWidget { DetailsSectionWidget({Key key}) : super(key: key); @override _DetailsSectionWidgetState createState() => _DetailsSectionWidgetState(); } class _DetailsSectionWidgetState extends State { UserDetails _userDetails; StreamSubscription _userDetailsChangedEvent; @override void initState() { super.initState(); _fetchUserDetails(); _userDetailsChangedEvent = Bus.instance.on().listen((event) { _fetchUserDetails(); }); } void _fetchUserDetails() { UserService.instance.getUserDetailsV2(memberCount: true).then((details) { setState(() { _userDetails = details; }); }); } @override void dispose() { _userDetailsChangedEvent.cancel(); super.dispose(); } @override Widget build(BuildContext context) { return SizedBox( height: 196, child: _userDetails == null ? loadWidget : getContainer(), ); } Widget getContainer() { return UsageDetailsWidget(_userDetails); } Container getOldContainer() { return Container( decoration: BoxDecoration( color: Colors.grey.withBlue(210).withOpacity(0.1), borderRadius: BorderRadius.circular(10), ), width: double.infinity, padding: EdgeInsets.fromLTRB(20, 20, 20, 20), margin: EdgeInsets.fromLTRB(12, 8, 12, 8), child: Row( mainAxisAlignment: MainAxisAlignment.spaceAround, crossAxisAlignment: CrossAxisAlignment.center, children: [ GestureDetector( onTap: () { int totalStorage = _userDetails.isPartOfFamily() ? _userDetails.familyData.storage : _userDetails.subscription.storage; String usageText = formatBytes(_userDetails.getFreeStorage()) + " / " + convertBytesToReadableFormat(totalStorage) + " free"; if (_userDetails.isPartOfFamily()) { usageText += "\npersonal usage: ${convertBytesToReadableFormat(_userDetails.getPersonalUsage())}\n" "family usage: ${convertBytesToReadableFormat(_userDetails.getFamilyOrPersonalUsage() - _userDetails.getPersonalUsage())}"; } showToast(usageText); }, child: PieChart( dataMap: { "used": _userDetails.getPersonalUsage().toDouble(), "family_usage": (_userDetails.getFamilyOrPersonalUsage() - _userDetails.getPersonalUsage()) .toDouble(), "free": _userDetails.getFreeStorage().toDouble(), }, colorList: const [ Colors.redAccent, Colors.blueGrey, Color.fromRGBO(50, 194, 100, 1.0), ], legendOptions: LegendOptions( showLegends: false, ), chartValuesOptions: ChartValuesOptions( showChartValues: false, showChartValueBackground: false, ), chartRadius: 80, ringStrokeWidth: 4, chartType: ChartType.ring, centerText: convertBytesToReadableFormat( _userDetails.getPersonalUsage()) + "\nused", centerTextStyle: TextStyle( color: Colors.white, fontSize: 12, ), initialAngleInDegree: 270, ), ), Padding(padding: EdgeInsets.all(4)), Expanded( child: Column( mainAxisAlignment: MainAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.start, children: [ Text( _userDetails.email, style: TextStyle( fontSize: 16, ), overflow: TextOverflow.ellipsis, ), Padding(padding: EdgeInsets.all(6)), Text( _userDetails.fileCount.toString() + " memories preserved", style: TextStyle( color: Colors.white.withOpacity(0.6), fontSize: 14, ), ), Padding(padding: EdgeInsets.all(3)), Text( _userDetails.sharedCollectionsCount.toString() + " albums shared", style: TextStyle( color: Colors.white.withOpacity(0.6), fontSize: 14, ), ), ], ), ), ], ), ); } }