2023-05-26 12:24:03 +00:00
|
|
|
import "package:flutter/material.dart";
|
|
|
|
import "package:logging/logging.dart";
|
|
|
|
import "package:photos/generated/l10n.dart";
|
|
|
|
import "package:photos/models/file.dart";
|
2023-05-26 15:35:18 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_save_button.dart";
|
2023-05-26 15:28:34 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_test_grid.dart";
|
2023-05-26 14:06:58 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_with_five_items.dart";
|
2023-05-26 13:31:51 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_with_four_items.dart";
|
2023-05-26 15:27:43 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_with_six_items.dart";
|
2023-05-26 13:31:51 +00:00
|
|
|
import "package:photos/ui/tools/collage/collage_with_three_items.dart";
|
|
|
|
import "package:photos/ui/tools/collage/collage_with_two_items.dart";
|
2023-05-26 12:24:03 +00:00
|
|
|
import "package:widgets_to_image/widgets_to_image.dart";
|
|
|
|
|
2023-05-26 13:10:39 +00:00
|
|
|
class CollageCreatorPage extends StatelessWidget {
|
2023-05-26 15:27:43 +00:00
|
|
|
static const int collageItemsMin = 2;
|
|
|
|
static const int collageItemsMax = 6;
|
|
|
|
|
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;
|
|
|
|
|
2023-05-26 13:10:39 +00:00
|
|
|
CollageCreatorPage(this.files, {super.key});
|
2023-05-26 12:27:30 +00:00
|
|
|
|
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:
|
2023-05-26 13:31:51 +00:00
|
|
|
collage = CollageWithTwoItems(
|
2023-05-26 13:06:39 +00:00
|
|
|
files[0],
|
|
|
|
files[1],
|
|
|
|
_widgetsToImageController,
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
case 3:
|
2023-05-26 13:31:51 +00:00
|
|
|
collage = CollageWithThreeItems(
|
2023-05-26 13:06:39 +00:00
|
|
|
files[0],
|
|
|
|
files[1],
|
|
|
|
files[2],
|
|
|
|
_widgetsToImageController,
|
|
|
|
);
|
|
|
|
break;
|
2023-05-26 13:25:23 +00:00
|
|
|
case 4:
|
|
|
|
collage = CollageWithFourItems(
|
|
|
|
files[0],
|
|
|
|
files[1],
|
|
|
|
files[2],
|
|
|
|
files[3],
|
|
|
|
_widgetsToImageController,
|
|
|
|
);
|
|
|
|
break;
|
2023-05-26 14:06:58 +00:00
|
|
|
case 5:
|
|
|
|
collage = CollageWithFiveItems(
|
|
|
|
files[0],
|
|
|
|
files[1],
|
|
|
|
files[2],
|
|
|
|
files[3],
|
|
|
|
files[4],
|
|
|
|
_widgetsToImageController,
|
|
|
|
);
|
|
|
|
break;
|
2023-05-26 15:27:43 +00:00
|
|
|
case 6:
|
|
|
|
collage = CollageWithSixItems(
|
|
|
|
files[0],
|
|
|
|
files[1],
|
|
|
|
files[2],
|
|
|
|
files[3],
|
|
|
|
files[4],
|
|
|
|
files[5],
|
|
|
|
_widgetsToImageController,
|
|
|
|
);
|
|
|
|
break;
|
2023-05-26 13:06:39 +00:00
|
|
|
default:
|
2023-05-26 15:35:18 +00:00
|
|
|
collage = const TestGrid();
|
2023-05-26 13:06:39 +00:00
|
|
|
}
|
2023-05-26 12:24:03 +00:00
|
|
|
|
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.all(12),
|
|
|
|
child: Column(
|
|
|
|
children: [
|
2023-05-26 15:27:43 +00:00
|
|
|
SizedBox(
|
|
|
|
width: 320,
|
|
|
|
child: collage,
|
|
|
|
),
|
2023-05-26 13:35:06 +00:00
|
|
|
const Expanded(child: SizedBox()),
|
2023-05-26 15:35:18 +00:00
|
|
|
SaveCollageButton(_widgetsToImageController),
|
2023-05-26 13:35:06 +00:00
|
|
|
const SafeArea(
|
|
|
|
child: SizedBox(
|
|
|
|
height: 12,
|
|
|
|
),
|
|
|
|
),
|
2023-05-26 12:24:03 +00:00
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|