import 'package:flutter/material.dart'; import 'package:stacked/stacked.dart'; import '../../common/app_colors.dart'; import '../../common/ui_helpers.dart'; import '../../widgets/course_progress_section.dart'; import '../../widgets/learning_progress_card.dart'; import '../../widgets/small_app_bar.dart'; import 'progress_viewmodel.dart'; class ProgressView extends StackedView { const ProgressView({Key? key}) : super(key: key); @override ProgressViewModel viewModelBuilder(BuildContext context) => ProgressViewModel(); @override Widget builder( BuildContext context, ProgressViewModel viewModel, Widget? child, ) => _buildScaffoldWrapper(viewModel); Widget _buildScaffoldWrapper(ProgressViewModel viewModel) => Scaffold( backgroundColor: kcBackgroundColor, body: _buildScaffold(viewModel), ); Widget _buildScaffold(ProgressViewModel viewModel) => SafeArea(child: _buildBodyWrapper(viewModel)); Widget _buildBodyWrapper(ProgressViewModel viewModel) => _buildBody(viewModel); Widget _buildBody(ProgressViewModel viewModel) => _buildNestedScrollView(viewModel); Widget _buildNestedScrollView(ProgressViewModel viewModel) => NestedScrollView( scrollDirection: Axis.vertical, headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) => [_buildSliverAppbarWrapper(viewModel)], body: _buildContentScrollViewWrapper(viewModel)); Widget _buildSliverAppbarWrapper(ProgressViewModel viewModel) => SliverAppBar( pinned: true, automaticallyImplyLeading: false, backgroundColor: kcBackgroundColor, surfaceTintColor: kcBackgroundColor, title: _buildAppbar(viewModel), ); Widget _buildAppbar(ProgressViewModel viewModel) => SmallAppBar( title: 'My Progress', showBackButton: true, onPop: viewModel.pop, ); Widget _buildContentScrollViewWrapper(ProgressViewModel viewModel) => SingleChildScrollView( child: _buildContentWrapper(viewModel), ); Widget _buildContentWrapper(ProgressViewModel viewModel) => Padding( padding: const EdgeInsets.symmetric(horizontal: 15), child: _buildContentColumn(viewModel), ); Widget _buildContentColumn(ProgressViewModel viewModel) => Column( mainAxisSize: MainAxisSize.min, crossAxisAlignment: CrossAxisAlignment.start, children: _buildContentChildren(viewModel), ); List _buildContentChildren(ProgressViewModel viewModel) => [ verticalSpaceMedium, _buildText(), verticalSpaceMedium, _buildLearningProgressCard(), verticalSpaceMedium, _buildCourseProgressSection() ]; Widget _buildText() => const Text( 'Track your learning journey and see your growth over time.', style: TextStyle(color: kcDarkGrey), ); Widget _buildLearningProgressCard() => const LearningProgressCard(); Widget _buildCourseProgressSection() => const CourseProgressSection(); }