mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-03 19:17:11 -05:00 
			
		
		
		
	* feat(mobile): Add Scrollbar for vertical scrolling on the actions button of a selected asset. * fixed error scroll position and add more space for the scrollbar * revert scrollbar change and display always 5.5 icons button * minWidth set to 5.5 and used * fix: logic and fine tuning --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
import 'package:flutter/material.dart';
 | 
						|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
 | 
						|
 | 
						|
class CustomDraggingHandle extends StatelessWidget {
 | 
						|
  const CustomDraggingHandle({super.key});
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context) {
 | 
						|
    return Container(
 | 
						|
      height: 4,
 | 
						|
      width: 30,
 | 
						|
      decoration: BoxDecoration(
 | 
						|
        color: context.themeData.dividerColor,
 | 
						|
        borderRadius: const BorderRadius.all(Radius.circular(20)),
 | 
						|
      ),
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
class ControlBoxButton extends StatelessWidget {
 | 
						|
  const ControlBoxButton({
 | 
						|
    super.key,
 | 
						|
    required this.label,
 | 
						|
    required this.iconData,
 | 
						|
    this.onPressed,
 | 
						|
    this.onLongPressed,
 | 
						|
  });
 | 
						|
 | 
						|
  final String label;
 | 
						|
  final IconData iconData;
 | 
						|
  final void Function()? onPressed;
 | 
						|
  final void Function()? onLongPressed;
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context) {
 | 
						|
    final minWidth =
 | 
						|
        context.isMobile ? MediaQuery.sizeOf(context).width / 4.5 : 75.0;
 | 
						|
 | 
						|
    return MaterialButton(
 | 
						|
      padding: const EdgeInsets.all(10),
 | 
						|
      shape: const RoundedRectangleBorder(
 | 
						|
        borderRadius: BorderRadius.all(Radius.circular(20)),
 | 
						|
      ),
 | 
						|
      onPressed: onPressed,
 | 
						|
      onLongPress: onLongPressed,
 | 
						|
      minWidth: minWidth,
 | 
						|
      child: Column(
 | 
						|
        mainAxisAlignment: MainAxisAlignment.start,
 | 
						|
        crossAxisAlignment: CrossAxisAlignment.center,
 | 
						|
        children: [
 | 
						|
          Icon(iconData, size: 24),
 | 
						|
          const SizedBox(height: 8),
 | 
						|
          Text(
 | 
						|
            label,
 | 
						|
            style: const TextStyle(fontSize: 14.0, fontWeight: FontWeight.w400),
 | 
						|
            maxLines: 3,
 | 
						|
            textAlign: TextAlign.center,
 | 
						|
          ),
 | 
						|
        ],
 | 
						|
      ),
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 |