mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-04 03:27:09 -05:00 
			
		
		
		
	* fix: Enables videotimeline in readonly mode - Enables only the video controls in the bottom bar when readonlyMode is enabled. - Fixes the message on the app profile bar when readOnlyMode is enabled **but** betaTimeline is not enabled. Fixes https://github.com/immich-app/immich/issues/21441 Signed-off-by: Sudheer Puthana <Sud-Puth@users.noreply.github.com> * cleanup bottom bar handling --------- Signed-off-by: Sudheer Puthana <Sud-Puth@users.noreply.github.com> Co-authored-by: bwees <brandonwees@gmail.com>
		
			
				
	
	
		
			92 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
import 'package:flutter/material.dart';
 | 
						|
import 'package:hooks_riverpod/hooks_riverpod.dart';
 | 
						|
import 'package:immich_mobile/constants/enums.dart';
 | 
						|
import 'package:immich_mobile/domain/models/asset/base_asset.model.dart';
 | 
						|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/archive_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/delete_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/delete_local_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/edit_image_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/share_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/unarchive_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/action_buttons/upload_action_button.widget.dart';
 | 
						|
import 'package:immich_mobile/presentation/widgets/asset_viewer/asset_viewer.state.dart';
 | 
						|
import 'package:immich_mobile/providers/infrastructure/asset_viewer/current_asset.provider.dart';
 | 
						|
import 'package:immich_mobile/providers/infrastructure/readonly_mode.provider.dart';
 | 
						|
import 'package:immich_mobile/providers/routes.provider.dart';
 | 
						|
import 'package:immich_mobile/providers/user.provider.dart';
 | 
						|
import 'package:immich_mobile/widgets/asset_viewer/video_controls.dart';
 | 
						|
 | 
						|
class ViewerBottomBar extends ConsumerWidget {
 | 
						|
  const ViewerBottomBar({super.key});
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context, WidgetRef ref) {
 | 
						|
    final asset = ref.watch(currentAssetNotifier);
 | 
						|
    if (asset == null) {
 | 
						|
      return const SizedBox.shrink();
 | 
						|
    }
 | 
						|
 | 
						|
    final isReadonlyModeEnabled = ref.watch(readonlyModeProvider);
 | 
						|
    final user = ref.watch(currentUserProvider);
 | 
						|
    final isOwner = asset is RemoteAsset && asset.ownerId == user?.id;
 | 
						|
    final isSheetOpen = ref.watch(assetViewerProvider.select((s) => s.showingBottomSheet));
 | 
						|
    int opacity = ref.watch(assetViewerProvider.select((state) => state.backgroundOpacity));
 | 
						|
    final showControls = ref.watch(assetViewerProvider.select((s) => s.showingControls));
 | 
						|
    final isInLockedView = ref.watch(inLockedViewProvider);
 | 
						|
    final isArchived = asset is RemoteAsset && asset.visibility == AssetVisibility.archive;
 | 
						|
 | 
						|
    if (!showControls) {
 | 
						|
      opacity = 0;
 | 
						|
    }
 | 
						|
 | 
						|
    final actions = <Widget>[
 | 
						|
      const ShareActionButton(source: ActionSource.viewer),
 | 
						|
      if (asset.isLocalOnly) const UploadActionButton(source: ActionSource.viewer),
 | 
						|
      if (asset.type == AssetType.image) const EditImageActionButton(),
 | 
						|
      if (isOwner) ...[
 | 
						|
        if (asset.hasRemote && isOwner && isArchived)
 | 
						|
          const UnArchiveActionButton(source: ActionSource.viewer)
 | 
						|
        else
 | 
						|
          const ArchiveActionButton(source: ActionSource.viewer),
 | 
						|
        asset.isLocalOnly
 | 
						|
            ? const DeleteLocalActionButton(source: ActionSource.viewer)
 | 
						|
            : const DeleteActionButton(source: ActionSource.viewer, showConfirmation: true),
 | 
						|
      ],
 | 
						|
    ];
 | 
						|
 | 
						|
    return IgnorePointer(
 | 
						|
      ignoring: opacity < 255,
 | 
						|
      child: AnimatedOpacity(
 | 
						|
        opacity: opacity / 255,
 | 
						|
        duration: Durations.short2,
 | 
						|
        child: AnimatedSwitcher(
 | 
						|
          duration: Durations.short4,
 | 
						|
          child: isSheetOpen
 | 
						|
              ? const SizedBox.shrink()
 | 
						|
              : Theme(
 | 
						|
                  data: context.themeData.copyWith(
 | 
						|
                    iconTheme: const IconThemeData(size: 22, color: Colors.white),
 | 
						|
                    textTheme: context.themeData.textTheme.copyWith(
 | 
						|
                      labelLarge: context.themeData.textTheme.labelLarge?.copyWith(color: Colors.white),
 | 
						|
                    ),
 | 
						|
                  ),
 | 
						|
                  child: Container(
 | 
						|
                    color: Colors.black.withAlpha(125),
 | 
						|
                    padding: EdgeInsets.only(bottom: context.padding.bottom, top: 16),
 | 
						|
                    child: Column(
 | 
						|
                      mainAxisAlignment: MainAxisAlignment.end,
 | 
						|
                      children: [
 | 
						|
                        if (asset.isVideo) const VideoControls(),
 | 
						|
                        if (!isInLockedView && !isReadonlyModeEnabled)
 | 
						|
                          Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly, children: actions),
 | 
						|
                      ],
 | 
						|
                    ),
 | 
						|
                  ),
 | 
						|
                ),
 | 
						|
        ),
 | 
						|
      ),
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 |