ente/lib/ui/tools/collage/create_collage_page.dart

160 lines
4.4 KiB
Dart
Raw Normal View History

2023-05-26 12:24:03 +00:00
import "package:flutter/material.dart";
import "package:flutter_staggered_grid_view/flutter_staggered_grid_view.dart";
import "package:logging/logging.dart";
import "package:photo_manager/photo_manager.dart";
import "package:photos/core/event_bus.dart";
import "package:photos/db/files_db.dart";
import "package:photos/events/local_photos_updated_event.dart";
import "package:photos/generated/l10n.dart";
import "package:photos/models/file.dart";
import "package:photos/services/sync_service.dart";
import "package:photos/ui/components/buttons/button_widget.dart";
import "package:photos/ui/components/models/button_type.dart";
2023-05-26 13:06:39 +00:00
import "package:photos/ui/tools/collage/three_image_collage_creator.dart";
2023-05-26 12:50:21 +00:00
import 'package:photos/ui/tools/collage/two_image_collage_creator.dart';
2023-05-26 12:24:03 +00:00
import "package:photos/ui/viewer/file/detail_page.dart";
import "package:photos/utils/navigation_util.dart";
import "package:photos/utils/toast_util.dart";
import "package:widgets_to_image/widgets_to_image.dart";
2023-05-26 12:27:30 +00:00
class CreateCollagePage extends StatelessWidget {
2023-05-26 12:24:03 +00:00
final _logger = Logger("CreateCollagePage");
final _widgetsToImageController = WidgetsToImageController();
2023-05-26 12:27:30 +00:00
final List<File> files;
CreateCollagePage(this.files, {super.key});
2023-05-26 12:24:03 +00:00
@override
Widget build(BuildContext context) {
2023-05-26 12:27:30 +00:00
for (final file in files) {
2023-05-26 12:24:03 +00:00
_logger.info(file.displayName);
}
return Scaffold(
appBar: AppBar(
elevation: 0,
title: Text(S.of(context).createCollage),
),
2023-05-26 12:27:30 +00:00
body: _getBody(context),
2023-05-26 12:24:03 +00:00
);
}
2023-05-26 12:27:30 +00:00
Widget _getBody(BuildContext context) {
final count = files.length;
2023-05-26 13:06:39 +00:00
Widget collage;
switch (count) {
case 2:
collage = TwoImageCollageCreator(
files[0],
files[1],
_widgetsToImageController,
);
break;
case 3:
collage = ThreeImageCollageCreator(
files[0],
files[1],
files[2],
_widgetsToImageController,
);
break;
default:
collage = _getGrid();
}
2023-05-26 12:24:03 +00:00
return Padding(
padding: const EdgeInsets.all(12),
child: Column(
children: [
2023-05-26 13:06:39 +00:00
collage,
2023-05-26 12:24:03 +00:00
const SizedBox(
height: 24,
),
ButtonWidget(
buttonType: ButtonType.neutral,
labelText: S.of(context).saveCollage,
2023-05-26 12:27:30 +00:00
onTap: () {
return _onSaveClicked(context);
},
2023-05-26 12:24:03 +00:00
shouldSurfaceExecutionStates: true,
),
],
),
);
}
2023-05-26 12:27:30 +00:00
Future<void> _onSaveClicked(context) async {
2023-05-26 12:24:03 +00:00
final bytes = await _widgetsToImageController.capture();
final fileName = "ente_collage_" +
DateTime.now().microsecondsSinceEpoch.toString() +
".jpeg";
//Disabling notifications for assets changing to insert the file into
//files db before triggering a sync.
PhotoManager.stopChangeNotify();
final AssetEntity? newAsset =
await (PhotoManager.editor.saveImage(bytes!, title: fileName));
final newFile = await File.fromAsset('', newAsset!);
newFile.generatedID = await FilesDB.instance.insert(newFile);
Bus.instance
.fire(LocalPhotosUpdatedEvent([newFile], source: "collageSave"));
SyncService.instance.sync();
showShortToast(context, S.of(context).collageSaved);
replacePage(
context,
DetailPage(
DetailPageConfiguration([newFile], null, 0, "collage"),
),
);
}
Widget _getGrid() {
return const TestGrid();
}
}
class Tile extends StatelessWidget {
final String text;
const Tile(this.text, {super.key});
@override
Widget build(BuildContext context) {
return Container(
color: Colors.blue,
child: Center(child: Text(text)),
);
}
}
class TestGrid extends StatelessWidget {
const TestGrid({
super.key,
});
@override
Widget build(BuildContext context) {
return StaggeredGrid.count(
2023-05-26 12:50:21 +00:00
crossAxisCount: 3,
2023-05-26 12:24:03 +00:00
mainAxisSpacing: 4,
crossAxisSpacing: 4,
axisDirection: AxisDirection.down,
children: const [
StaggeredGridTile.count(
2023-05-26 12:50:21 +00:00
crossAxisCellCount: 3,
2023-05-26 12:24:03 +00:00
mainAxisCellCount: 1,
2023-05-26 12:50:21 +00:00
child: Tile("1"),
2023-05-26 12:24:03 +00:00
),
StaggeredGridTile.count(
2023-05-26 12:50:21 +00:00
crossAxisCellCount: 3,
2023-05-26 12:24:03 +00:00
mainAxisCellCount: 1,
2023-05-26 12:50:21 +00:00
child: Tile("2"),
),
StaggeredGridTile.count(
crossAxisCellCount: 3,
mainAxisCellCount: 1,
child: Tile("3"),
2023-05-26 12:24:03 +00:00
),
],
);
}
}