Files
holobooth/lib/convert/view/convert_page.dart
Alejandro Santiago cb6741cc8e chore: bump Flutter and Dart SDK to latest versions (#438)
<!--
  Thanks for contributing!

Provide a description of your changes below and a general summary in the
title

Please look at the following checklist to ensure that your PR can be
accepted quickly:
-->

## Description

Changes:
- Bump min dart SDK to 2.19.0
- Bump Flutter version to 3.7.12
- Used Very Good Analysis 4.0.0
- Corrected new analyzer issues
- Dart format

## Type of Change

<!--- Put an `x` in all the boxes that apply: -->

- [ ]  New feature (non-breaking change which adds functionality)
- [ ] 🛠️ Bug fix (non-breaking change which fixes an issue)
- [ ]  Breaking change (fix or feature that would cause existing
functionality to change)
- [ ] 🧹 Code refactor
- [ ]  Build configuration change
- [ ] 📝 Documentation
- [X] 🗑️ Chore
2023-06-27 15:57:39 -07:00

156 lines
4.1 KiB
Dart

import 'package:camera/camera.dart';
import 'package:convert_repository/convert_repository.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:holobooth/assets/assets.dart';
import 'package:holobooth/convert/convert.dart';
import 'package:holobooth/footer/footer.dart';
import 'package:holobooth/l10n/l10n.dart';
import 'package:holobooth/share/share.dart';
import 'package:holobooth_ui/holobooth_ui.dart';
import 'package:screen_recorder/screen_recorder.dart';
@visibleForTesting
typedef PrecacheImageFn = Future<void> Function(
ImageProvider provider,
BuildContext context,
);
class ConvertPage extends StatelessWidget {
const ConvertPage({
required this.frames,
required this.camera,
super.key,
});
final List<Frame> frames;
final CameraDescription? camera;
static Route<void> route(
List<Frame> frames,
CameraDescription? camera,
) {
return AppPageRoute(
builder: (_) => ConvertPage(
frames: frames,
camera: camera,
),
);
}
@override
Widget build(BuildContext context) {
return BlocProvider(
create: (context) => ConvertBloc(
convertRepository: context.read<ConvertRepository>(),
frames: frames,
),
child: ConvertView(camera: camera),
);
}
}
@visibleForTesting
class ConvertView extends StatefulWidget {
const ConvertView({
super.key,
this.precacheImageFn = precacheImage,
this.camera,
});
final PrecacheImageFn precacheImageFn;
final CameraDescription? camera;
@override
State<ConvertView> createState() => _ConvertViewState();
}
class _ConvertViewState extends State<ConvertView> {
@override
void initState() {
super.initState();
WidgetsBinding.instance.addPostFrameCallback((_) async {
context.read<ConvertBloc>().add(const GenerateFramesRequested());
await widget.precacheImageFn(
Assets.backgrounds.shareBackground.provider(),
context,
);
});
}
@override
Widget build(BuildContext context) {
return BlocListener<ConvertBloc, ConvertState>(
listener: (context, state) {
if (state.status == ConvertStatus.errorLoadingFrames) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text(context.l10n.convertErrorMessage)),
);
} else if (state.status == ConvertStatus.loadedFrames) {
final convertBloc = context.read<ConvertBloc>()
..add(const GenerateVideoRequested());
Navigator.of(context).push(
SharePage.route(
convertBloc: convertBloc,
camera: widget.camera,
),
);
}
},
child: Scaffold(
body: Stack(
fit: StackFit.expand,
children: [
Positioned.fill(
child:
Assets.backgrounds.loadingBackground.image(fit: BoxFit.cover),
),
Positioned.fill(
child: Column(
children: [
Expanded(child: ConvertBody(camera: widget.camera)),
FullFooter(),
],
),
),
],
),
),
);
}
}
@visibleForTesting
class ConvertBody extends StatelessWidget {
const ConvertBody({required this.camera, super.key});
final CameraDescription? camera;
static const errorViewKey = Key('errorView');
@override
Widget build(BuildContext context) {
return Stack(
fit: StackFit.expand,
children: [
Align(
child: BlocBuilder<ConvertBloc, ConvertState>(
buildWhen: (previous, current) => previous.status != current.status,
builder: (context, state) {
if (state.status == ConvertStatus.errorLoadingFrames) {
return ConvertErrorView(
convertErrorOrigin: ConvertErrorOrigin.frames,
camera: camera,
);
} else if (state.status == ConvertStatus.loadingFrames) {
return const CreatingVideoView();
}
return const SizedBox();
},
),
),
],
);
}
}