ente/lib/ui/viewer/file/file_icons_widget.dart

213 lines
5.3 KiB
Dart
Raw Normal View History

2022-07-02 17:30:04 +00:00
import 'package:flutter/material.dart';
2022-07-03 05:37:04 +00:00
import 'package:photos/ente_theme_data.dart';
import 'package:photos/models/collection.dart';
2022-07-02 17:30:04 +00:00
import 'package:photos/models/trash_file.dart';
import 'package:photos/theme/colors.dart';
import 'package:photos/ui/sharing/user_avator_widget.dart';
2022-07-02 17:30:04 +00:00
import 'package:photos/utils/date_time_util.dart';
class ThumbnailPlaceHolder extends StatelessWidget {
2022-10-19 09:02:33 +00:00
const ThumbnailPlaceHolder({Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
return Container(
alignment: Alignment.center,
2022-07-03 05:37:04 +00:00
color: Theme.of(context).colorScheme.galleryThumbBackgroundColor,
2022-07-02 17:30:04 +00:00
);
}
}
class UnSyncedIcon extends StatelessWidget {
2022-10-19 09:02:33 +00:00
const UnSyncedIcon({Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
return Container(
2022-11-17 11:53:32 +00:00
decoration: const BoxDecoration(
2022-07-02 17:30:04 +00:00
gradient: LinearGradient(
2022-11-17 11:53:32 +00:00
begin: Alignment.centerLeft,
end: Alignment.centerRight,
// background: linear-gradient(73.58deg, rgba(0, 0, 0, 0.3) -6.66%, rgba(255, 255, 255, 0) 44.44%);
2022-07-02 17:30:04 +00:00
colors: [
2022-11-17 11:53:32 +00:00
Color.fromRGBO(255, 255, 255, 0),
2022-07-02 17:30:04 +00:00
Colors.transparent,
2022-11-17 11:53:32 +00:00
// Color.fromRGBO(0, 0, 0, 0.3),
2022-07-02 17:30:04 +00:00
],
2022-11-17 11:53:32 +00:00
stops: [-0.067, 0.445],
2022-07-02 17:30:04 +00:00
),
),
2022-11-17 11:53:32 +00:00
child: const Align(
alignment: Alignment.bottomLeft,
2022-07-02 17:30:04 +00:00
child: Padding(
2022-11-17 11:53:32 +00:00
padding: EdgeInsets.only(left: 4, bottom: 4),
2022-07-02 17:30:04 +00:00
child: Icon(
Icons.cloud_off_outlined,
size: 18,
2022-11-17 11:53:32 +00:00
color: fixedStrokeMutedWhite,
2022-07-02 17:30:04 +00:00
),
),
),
);
}
}
class VideoOverlayIcon extends StatelessWidget {
2022-10-19 09:02:33 +00:00
const VideoOverlayIcon({Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
2022-07-04 06:02:17 +00:00
return const SizedBox(
2022-07-02 17:30:04 +00:00
height: 64,
child: Icon(
Icons.play_circle_outline,
size: 40,
color: Colors.white70,
),
);
}
}
class LivePhotoOverlayIcon extends StatelessWidget {
2022-10-19 09:02:33 +00:00
const LivePhotoOverlayIcon({Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
return const Align(
alignment: Alignment.bottomRight,
2022-07-02 17:30:04 +00:00
child: Padding(
padding: EdgeInsets.only(right: 4, bottom: 4),
2022-07-02 17:30:04 +00:00
child: Icon(
Icons.album_outlined,
2022-07-02 17:30:04 +00:00
size: 14,
color: Colors.white, // fixed
2022-07-02 17:30:04 +00:00
),
),
);
}
}
class OwnerAvatarOverlayIcon extends StatelessWidget {
final User user;
2022-12-16 04:20:08 +00:00
const OwnerAvatarOverlayIcon(this.user, {Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Align(
alignment: Alignment.topRight,
child: Padding(
padding: const EdgeInsets.only(right: 4, top: 4),
child: UserAvatarWidget(
user,
type: AvatarType.tiny,
2022-12-16 13:09:14 +00:00
thumbnailView: true,
),
),
);
}
}
2022-11-17 05:30:51 +00:00
class FavoriteOverlayIcon extends StatelessWidget {
const FavoriteOverlayIcon({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
2022-12-20 06:26:52 +00:00
return const BottomLeftOverlayIcon(Icons.favorite_rounded);
2022-11-17 05:30:51 +00:00
}
}
2022-07-02 17:30:04 +00:00
class TrashedFileOverlayText extends StatelessWidget {
final TrashFile file;
2022-10-19 09:02:33 +00:00
const TrashedFileOverlayText(this.file, {Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
return Container(
decoration: BoxDecoration(
gradient: LinearGradient(
begin: Alignment.bottomCenter,
end: Alignment.topCenter,
colors: [Colors.black.withOpacity(0.33), Colors.transparent],
),
),
2022-07-03 09:45:00 +00:00
alignment: Alignment.bottomCenter,
2022-07-04 06:02:17 +00:00
padding: const EdgeInsets.only(bottom: 5),
2022-07-02 17:30:04 +00:00
child: Text(
daysLeft(file.deleteBy),
style: Theme.of(context)
.textTheme
2022-10-19 09:02:33 +00:00
.subtitle2!
2022-07-02 17:30:04 +00:00
.copyWith(color: Colors.white), //same for both themes
),
);
}
}
class ArchiveOverlayIcon extends StatelessWidget {
2022-10-19 09:02:33 +00:00
const ArchiveOverlayIcon({Key? key}) : super(key: key);
2022-07-02 17:30:04 +00:00
@override
Widget build(BuildContext context) {
return const Align(
alignment: Alignment.bottomLeft,
2022-07-02 17:30:04 +00:00
child: Padding(
padding: EdgeInsets.only(left: 4, bottom: 4),
2022-07-02 17:30:04 +00:00
child: Icon(
Icons.archive_outlined,
size: 20,
2022-11-17 11:53:32 +00:00
color: fixedStrokeMutedWhite,
2022-07-02 17:30:04 +00:00
),
),
);
}
}
2022-12-20 06:26:52 +00:00
// Base variations
/// Icon overlay in the bottom left.
///
/// This usually indicates ente specific state of a file, e.g. if it is
/// favorited/archived.
class BottomLeftOverlayIcon extends StatelessWidget {
final IconData icon;
/// Overriddable color. Default is a fixed white.
final Color color;
const BottomLeftOverlayIcon(
this.icon, {
Key? key,
this.color = Colors.white, // fixed
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Container(
decoration: const BoxDecoration(
gradient: LinearGradient(
begin: Alignment.bottomLeft,
end: Alignment.center,
colors: [
Color.fromRGBO(0, 0, 0, 0.14),
Color.fromRGBO(0, 0, 0, 0.05),
Color.fromRGBO(0, 0, 0, 0.0),
],
stops: [0, 0.6, 1],
),
),
child: Align(
alignment: Alignment.bottomLeft,
child: Padding(
padding: const EdgeInsets.only(left: 4, bottom: 4),
child: Icon(
icon,
size: 22,
color: color,
),
),
),
);
}
}