aves/lib/widgets/settings/common/collection_tile.dart
Thibault Deckers 4dcfc7568f minor fixes
2023-12-19 15:35:40 +01:00

74 lines
2.4 KiB
Dart

import 'package:aves/model/filters/filters.dart';
import 'package:aves/services/intent_service.dart';
import 'package:aves/theme/icons.dart';
import 'package:aves/widgets/collection/filter_bar.dart';
import 'package:aves/widgets/common/extensions/build_context.dart';
import 'package:flutter/material.dart';
class SettingsCollectionTile extends StatelessWidget {
final Set<CollectionFilter> filters;
final void Function(Set<CollectionFilter>) onSelection;
const SettingsCollectionTile({
super.key,
required this.filters,
required this.onSelection,
});
@override
Widget build(BuildContext context) {
final l10n = context.l10n;
final theme = Theme.of(context);
final textTheme = theme.textTheme;
final hasSubtitle = filters.isEmpty;
// size and padding to match `ListTile`
return ConstrainedBox(
constraints: BoxConstraints(
minHeight: (hasSubtitle ? 72.0 : 56.0) + theme.visualDensity.baseSizeAdjustment.dy,
),
child: Center(
child: Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(horizontal: 16),
child: Row(
children: [
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
l10n.settingsCollectionTile,
style: textTheme.titleMedium!,
),
if (hasSubtitle)
Text(
l10n.drawerCollectionAll,
style: textTheme.bodyMedium!.copyWith(color: theme.colorScheme.onSurfaceVariant),
),
],
),
const Spacer(),
IconButton(
onPressed: () async {
final selection = await IntentService.pickCollectionFilters(filters);
if (selection != null) {
onSelection(selection);
}
},
icon: const Icon(AIcons.edit),
),
],
),
),
if (filters.isNotEmpty)
FilterBar(
filters: filters,
interactive: false,
),
],
),
),
);
}
}