99 lines
3.7 KiB
Dart
99 lines
3.7 KiB
Dart
import 'package:aves/model/settings/settings.dart';
|
|
import 'package:aves/theme/colors.dart';
|
|
import 'package:aves/theme/icons.dart';
|
|
import 'package:aves/widgets/common/extensions/build_context.dart';
|
|
import 'package:aves/widgets/common/identity/aves_expansion_tile.dart';
|
|
import 'package:aves/widgets/common/identity/aves_icons.dart';
|
|
import 'package:aves/widgets/settings/common/tile_leading.dart';
|
|
import 'package:aves/widgets/settings/common/tiles.dart';
|
|
import 'package:aves/widgets/settings/thumbnails/collection_actions_editor.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
class ThumbnailsSection extends StatelessWidget {
|
|
final ValueNotifier<String?> expandedNotifier;
|
|
|
|
const ThumbnailsSection({
|
|
Key? key,
|
|
required this.expandedNotifier,
|
|
}) : super(key: key);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final iconSize = IconTheme.of(context).size! * MediaQuery.textScaleFactorOf(context);
|
|
final iconColor = context.select<AvesColorsData, Color>((v) => v.neutral);
|
|
return AvesExpansionTile(
|
|
leading: SettingsTileLeading(
|
|
icon: AIcons.grid,
|
|
color: context.select<AvesColorsData, Color>((v) => v.thumbnails),
|
|
),
|
|
title: context.l10n.settingsSectionThumbnails,
|
|
expandedNotifier: expandedNotifier,
|
|
showHighlight: false,
|
|
children: [
|
|
const CollectionActionsTile(),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailFavourite,
|
|
onChanged: (v) => settings.showThumbnailFavourite = v,
|
|
title: context.l10n.settingsThumbnailShowFavouriteIcon,
|
|
trailing: Padding(
|
|
padding: EdgeInsets.symmetric(horizontal: iconSize * (1 - FavouriteIcon.scale) / 2),
|
|
child: Icon(
|
|
AIcons.favourite,
|
|
size: iconSize * FavouriteIcon.scale,
|
|
color: iconColor,
|
|
),
|
|
),
|
|
),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailLocation,
|
|
onChanged: (v) => settings.showThumbnailLocation = v,
|
|
title: context.l10n.settingsThumbnailShowLocationIcon,
|
|
trailing: Icon(
|
|
AIcons.location,
|
|
size: iconSize,
|
|
color: iconColor,
|
|
),
|
|
),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailMotionPhoto,
|
|
onChanged: (v) => settings.showThumbnailMotionPhoto = v,
|
|
title: context.l10n.settingsThumbnailShowMotionPhotoIcon,
|
|
trailing: Padding(
|
|
padding: EdgeInsets.symmetric(horizontal: iconSize * (1 - MotionPhotoIcon.scale) / 2),
|
|
child: Icon(
|
|
AIcons.motionPhoto,
|
|
size: iconSize * MotionPhotoIcon.scale,
|
|
color: iconColor,
|
|
),
|
|
),
|
|
),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailRating,
|
|
onChanged: (v) => settings.showThumbnailRating = v,
|
|
title: context.l10n.settingsThumbnailShowRating,
|
|
trailing: Icon(
|
|
AIcons.rating,
|
|
size: iconSize,
|
|
color: iconColor,
|
|
),
|
|
),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailRaw,
|
|
onChanged: (v) => settings.showThumbnailRaw = v,
|
|
title: context.l10n.settingsThumbnailShowRawIcon,
|
|
trailing: Icon(
|
|
AIcons.raw,
|
|
size: iconSize,
|
|
color: iconColor,
|
|
),
|
|
),
|
|
SettingsSwitchListTile(
|
|
selector: (context, s) => s.showThumbnailVideoDuration,
|
|
onChanged: (v) => settings.showThumbnailVideoDuration = v,
|
|
title: context.l10n.settingsThumbnailShowVideoDuration,
|
|
),
|
|
],
|
|
);
|
|
}
|
|
}
|