ente/lib/ui/tools/collage/collage_creator_page.dart
2023-05-26 19:01:51 +05:30

175 lines
4.8 KiB
Dart

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";
import "package:photos/ui/tools/collage/collage_with_four_items.dart";
import "package:photos/ui/tools/collage/collage_with_three_items.dart";
import "package:photos/ui/tools/collage/collage_with_two_items.dart";
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";
class CollageCreatorPage extends StatelessWidget {
final _logger = Logger("CreateCollagePage");
final _widgetsToImageController = WidgetsToImageController();
final List<File> files;
CollageCreatorPage(this.files, {super.key});
@override
Widget build(BuildContext context) {
for (final file in files) {
_logger.info(file.displayName);
}
return Scaffold(
appBar: AppBar(
elevation: 0,
title: Text(S.of(context).createCollage),
),
body: _getBody(context),
);
}
Widget _getBody(BuildContext context) {
final count = files.length;
Widget collage;
switch (count) {
case 2:
collage = CollageWithTwoItems(
files[0],
files[1],
_widgetsToImageController,
);
break;
case 3:
collage = CollageWithThreeItems(
files[0],
files[1],
files[2],
_widgetsToImageController,
);
break;
case 4:
collage = CollageWithFourItems(
files[0],
files[1],
files[2],
files[3],
_widgetsToImageController,
);
break;
default:
collage = _getGrid();
}
return Padding(
padding: const EdgeInsets.all(12),
child: Column(
children: [
collage,
const SizedBox(
height: 24,
),
ButtonWidget(
buttonType: ButtonType.neutral,
labelText: S.of(context).saveCollage,
onTap: () {
return _onSaveClicked(context);
},
shouldSurfaceExecutionStates: true,
),
],
),
);
}
Future<void> _onSaveClicked(context) async {
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(
crossAxisCount: 4,
mainAxisSpacing: 4,
crossAxisSpacing: 4,
axisDirection: AxisDirection.down,
children: const [
StaggeredGridTile.count(
crossAxisCellCount: 4,
mainAxisCellCount: 1,
child: Tile("1"),
),
StaggeredGridTile.count(
crossAxisCellCount: 2,
mainAxisCellCount: 2,
child: Tile("2"),
),
StaggeredGridTile.count(
crossAxisCellCount: 2,
mainAxisCellCount: 2,
child: Tile("3"),
),
StaggeredGridTile.count(
crossAxisCellCount: 4,
mainAxisCellCount: 1,
child: Tile("4"),
),
],
);
}
}