Skip to content
Snippets Groups Projects
timeline.dart 2.36 KiB
Newer Older
  • Learn to ignore specific revisions
  • import 'package:easy_localization/easy_localization.dart';
    import 'package:flutter/material.dart';
    
    Benoît Harrault's avatar
    Benoît Harrault committed
    import 'package:flutter_bloc/flutter_bloc.dart';
    
    Benoît Harrault's avatar
    Benoît Harrault committed
    import 'package:scrobbles/cubit/data_timeline_cubit.dart';
    
    import 'package:scrobbles/cubit/settings_cubit.dart';
    
    import 'package:scrobbles/models/timeline.dart';
    
    import 'package:scrobbles/network/scrobbles.dart';
    
    import 'package:scrobbles/ui/widgets/card_content.dart';
    import 'package:scrobbles/ui/widgets/charts/timeline_counts.dart';
    import 'package:scrobbles/ui/widgets/charts/timeline_eclecticism.dart';
    
    import 'package:scrobbles/ui/widgets/error.dart';
    
    
    class CardTimeline extends StatelessWidget {
      const CardTimeline({super.key});
    
      @override
      Widget build(BuildContext context) {
    
        SettingsCubit settings = BlocProvider.of<SettingsCubit>(context);
    
        final int daysCount = settings.getTimelineDaysCount();
    
        return BlocBuilder<DataTimelineCubit, DataTimelineState>(
          builder: (BuildContext context, DataTimelineState state) {
            return CardContent(
              color: Theme.of(context).colorScheme.surface,
              title: 'timeline_title'.tr(
                namedArgs: {
                  'daysCount': daysCount.toString(),
                },
              ),
    
              loader: updateTimeline(daysCount),
    
              content: Stack(
                children: [
                  ChartTimelineCounts(
    
                    chartData: TimelineData.fromJson(state.timeline?.toJson()),
    
                  ),
                  ChartTimelineEclecticism(
    
                    chartData: TimelineData.fromJson(state.timeline?.toJson()),
    
    
      Widget updateTimeline(int daysCount) {
        final Widget loading = const Text('⏳');
        final Widget done = const Text('');
    
        late Future<TimelineData> futureTimeline = ScrobblesApi.fetchTimeline(daysCount);
    
    
        return BlocBuilder<DataTimelineCubit, DataTimelineState>(
          builder: (BuildContext context, DataTimelineState dataTimelineState) {
            return FutureBuilder<TimelineData>(
              future: futureTimeline,
              builder: (context, snapshot) {
                if (snapshot.hasError) {
                  return ShowErrorWidget(message: '${snapshot.error}');
                }
    
                BlocProvider.of<DataTimelineCubit>(context).update(snapshot.data);
    
    
                return !snapshot.hasData ? loading : done;
              },
            );
          },