mirror of
https://github.com/immich-app/immich.git
synced 2025-01-21 11:12:45 +01:00
92 lines
3.3 KiB
Dart
92 lines
3.3 KiB
Dart
|
import 'package:flutter/material.dart';
|
||
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||
|
import 'package:immich_mobile/providers/asset_viewer/asset_stack.provider.dart';
|
||
|
import 'package:immich_mobile/providers/asset_viewer/current_asset.provider.dart';
|
||
|
import 'package:immich_mobile/providers/asset_viewer/show_controls.provider.dart';
|
||
|
import 'package:immich_mobile/providers/image/immich_remote_image_provider.dart';
|
||
|
|
||
|
class GalleryStackedChildren extends HookConsumerWidget {
|
||
|
final ValueNotifier<int> stackIndex;
|
||
|
|
||
|
const GalleryStackedChildren(this.stackIndex, {super.key});
|
||
|
|
||
|
@override
|
||
|
Widget build(BuildContext context, WidgetRef ref) {
|
||
|
final asset = ref.watch(currentAssetProvider);
|
||
|
if (asset == null) {
|
||
|
return const SizedBox();
|
||
|
}
|
||
|
|
||
|
final stackId = asset.stackId;
|
||
|
if (stackId == null) {
|
||
|
return const SizedBox();
|
||
|
}
|
||
|
|
||
|
final stackElements = ref.watch(assetStackStateProvider(stackId));
|
||
|
final showControls = ref.watch(showControlsProvider);
|
||
|
|
||
|
return IgnorePointer(
|
||
|
ignoring: !showControls,
|
||
|
child: AnimatedOpacity(
|
||
|
duration: const Duration(milliseconds: 100),
|
||
|
opacity: showControls ? 1.0 : 0.0,
|
||
|
child: SizedBox(
|
||
|
height: 80,
|
||
|
child: ListView.builder(
|
||
|
shrinkWrap: true,
|
||
|
scrollDirection: Axis.horizontal,
|
||
|
itemCount: stackElements.length,
|
||
|
padding: const EdgeInsets.only(
|
||
|
left: 5,
|
||
|
right: 5,
|
||
|
bottom: 30,
|
||
|
),
|
||
|
itemBuilder: (context, index) {
|
||
|
final currentAsset = stackElements.elementAt(index);
|
||
|
final assetId = currentAsset.remoteId;
|
||
|
if (assetId == null) {
|
||
|
return const SizedBox();
|
||
|
}
|
||
|
|
||
|
return Padding(
|
||
|
key: ValueKey(currentAsset.id),
|
||
|
padding: const EdgeInsets.only(right: 5),
|
||
|
child: GestureDetector(
|
||
|
onTap: () {
|
||
|
stackIndex.value = index;
|
||
|
ref.read(currentAssetProvider.notifier).set(currentAsset);
|
||
|
},
|
||
|
child: Container(
|
||
|
width: 60,
|
||
|
height: 60,
|
||
|
decoration: index == stackIndex.value
|
||
|
? const BoxDecoration(
|
||
|
color: Colors.white,
|
||
|
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||
|
border: Border.fromBorderSide(
|
||
|
BorderSide(color: Colors.white, width: 2),
|
||
|
),
|
||
|
)
|
||
|
: const BoxDecoration(
|
||
|
color: Colors.white,
|
||
|
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||
|
border: null,
|
||
|
),
|
||
|
child: ClipRRect(
|
||
|
borderRadius: const BorderRadius.all(Radius.circular(4)),
|
||
|
child: Image(
|
||
|
fit: BoxFit.cover,
|
||
|
image: ImmichRemoteImageProvider(assetId: assetId),
|
||
|
),
|
||
|
),
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
},
|
||
|
),
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
}
|