nc-photos/lib/widget/album_grid_item.dart

128 lines
3.7 KiB
Dart
Raw Normal View History

2021-04-10 06:28:12 +02:00
import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
import 'package:nc_photos/theme.dart';
class AlbumGridItem extends StatelessWidget {
AlbumGridItem({
Key key,
@required this.cover,
@required this.title,
this.subtitle,
this.subtitle2,
2021-06-29 07:12:48 +02:00
this.icon,
2021-04-10 06:28:12 +02:00
this.isSelected = false,
this.onTap,
this.onLongPress,
}) : super(key: key);
@override
build(BuildContext context) {
return Stack(
fit: StackFit.expand,
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Expanded(
child: cover,
),
const SizedBox(height: 8),
Text(
title ?? "",
2021-04-17 10:59:16 +02:00
style: Theme.of(context).textTheme.bodyText1.copyWith(
color: AppTheme.getPrimaryTextColor(context),
),
2021-04-10 06:28:12 +02:00
textAlign: TextAlign.start,
maxLines: 1,
overflow: TextOverflow.ellipsis,
),
const SizedBox(height: 4),
Row(
children: [
Expanded(
child: Text(
subtitle ?? "",
style: Theme.of(context).textTheme.bodyText2.copyWith(
fontSize: 10,
color: AppTheme.getSecondaryTextColor(context),
),
textAlign: TextAlign.start,
maxLines: 1,
overflow: TextOverflow.ellipsis,
2021-04-10 06:28:12 +02:00
),
),
if (subtitle2?.isNotEmpty == true)
Text(
subtitle2,
style: Theme.of(context).textTheme.bodyText2.copyWith(
fontSize: 10,
color: AppTheme.getSecondaryTextColor(context),
),
textAlign: TextAlign.end,
maxLines: 1,
),
],
)
2021-04-10 06:28:12 +02:00
],
),
),
2021-06-29 07:12:48 +02:00
if (icon != null)
Padding(
padding: const EdgeInsets.all(16),
child: Align(
alignment: AlignmentDirectional.topEnd,
child: Icon(
2021-06-29 07:12:48 +02:00
icon,
size: 16,
color: Colors.white,
),
),
),
2021-04-10 06:28:12 +02:00
if (isSelected)
Positioned.fill(
child: Container(
decoration: BoxDecoration(
color: AppTheme.getSelectionOverlayColor(context),
borderRadius: BorderRadius.circular(8),
),
),
),
if (isSelected)
Positioned.fill(
child: Align(
alignment: Alignment.center,
child: Icon(
Icons.check_circle_outlined,
size: 48,
color: AppTheme.getSelectionCheckColor(context),
),
),
),
Positioned.fill(
child: Material(
type: MaterialType.transparency,
child: InkWell(
onTap: onTap,
onLongPress: onLongPress,
borderRadius: BorderRadius.circular(8),
),
),
)
],
);
}
final Widget cover;
final String title;
final String subtitle;
/// Appears after [subtitle], aligned to the end side of parent
final String subtitle2;
2021-06-29 07:12:48 +02:00
final IconData icon;
2021-04-10 06:28:12 +02:00
final bool isSelected;
final VoidCallback onTap;
final VoidCallback onLongPress;
}