0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-28 00:59:18 -05:00

feat(mobile) Enhance bottom app bar on home page (#934)

* Added bottom sheet

* Finished styling bottom app bar

* Fixed border radius
This commit is contained in:
Alex 2022-11-06 20:41:10 -06:00 committed by GitHub
parent c8538cc62f
commit f0874ff3fd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 181 additions and 122 deletions

View file

@ -28,13 +28,17 @@ class ControlBottomAppBar extends ConsumerWidget {
@override @override
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
Widget renderActionButtons() { Widget renderActionButtons() {
return Padding( return Row(
padding: const EdgeInsets.symmetric(vertical: 10, horizontal: 20),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
ControlBoxButton( ControlBoxButton(
iconData: Icons.delete_forever_rounded, iconData: Icons.ios_share_rounded,
label: "control_bottom_app_bar_share".tr(),
onPressed: () {
onShare();
},
),
ControlBoxButton(
iconData: Icons.delete_outline_rounded,
label: "control_bottom_app_bar_delete".tr(), label: "control_bottom_app_bar_delete".tr(),
onPressed: () { onPressed: () {
showDialog( showDialog(
@ -47,15 +51,7 @@ class ControlBottomAppBar extends ConsumerWidget {
); );
}, },
), ),
ControlBoxButton(
iconData: Icons.share,
label: "control_bottom_app_bar_share".tr(),
onPressed: () {
onShare();
},
),
], ],
),
); );
} }
@ -63,7 +59,9 @@ class ControlBottomAppBar extends ConsumerWidget {
Widget renderAlbum(AlbumResponseDto album) { Widget renderAlbum(AlbumResponseDto album) {
final box = Hive.box(userInfoBox); final box = Hive.box(userInfoBox);
return GestureDetector( return Padding(
padding: const EdgeInsets.only(left: 8.0),
child: GestureDetector(
onTap: () => onAddToAlbum(album), onTap: () => onAddToAlbum(album),
child: Container( child: Container(
width: 112, width: 112,
@ -77,8 +75,10 @@ class ControlBottomAppBar extends ConsumerWidget {
width: 100, width: 100,
height: 100, height: 100,
fit: BoxFit.cover, fit: BoxFit.cover,
imageUrl: imageUrl: getAlbumThumbnailUrl(
getAlbumThumbnailUrl(album, type: ThumbnailFormat.JPEG), album,
type: ThumbnailFormat.JPEG,
),
httpHeaders: { httpHeaders: {
"Authorization": "Bearer ${box.get(accessTokenKey)}" "Authorization": "Bearer ${box.get(accessTokenKey)}"
}, },
@ -89,16 +89,16 @@ class ControlBottomAppBar extends ConsumerWidget {
padding: const EdgeInsets.only(top: 12), padding: const EdgeInsets.only(top: 12),
child: Text( child: Text(
album.albumName, album.albumName,
style: TextStyle(fontWeight: FontWeight.bold), style: const TextStyle(
fontWeight: FontWeight.bold,
fontSize: 12.0,
),
), ),
), ),
Text(album.shared
? "control_bottom_app_bar_album_info_shared"
: "control_bottom_app_bar_album_info")
.tr(args: [album.assetCount.toString()]),
], ],
), ),
), ),
),
); );
} }
@ -112,34 +112,78 @@ class ControlBottomAppBar extends ConsumerWidget {
); );
} }
return Positioned( return DraggableScrollableSheet(
bottom: 0, initialChildSize: 0.30,
left: 0, minChildSize: 0.15,
child: Container( maxChildSize: 0.57,
width: MediaQuery.of(context).size.width, snap: true,
decoration: BoxDecoration( builder: (
borderRadius: const BorderRadius.only( BuildContext context,
topLeft: Radius.circular(10), ScrollController scrollController,
topRight: Radius.circular(10), ) {
return SingleChildScrollView(
controller: scrollController,
child: Card(
elevation: 12.0,
shape: const RoundedRectangleBorder(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(12),
topRight: Radius.circular(12),
),
),
margin: const EdgeInsets.all(0),
child: Container(
decoration: const BoxDecoration(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(12),
topRight: Radius.circular(12),
), ),
color: Theme.of(context).scaffoldBackgroundColor,
), ),
child: Column( child: Column(
crossAxisAlignment: CrossAxisAlignment.start, children: <Widget>[
children: [ const SizedBox(height: 12),
const CustomDraggingHandle(),
const SizedBox(height: 12),
renderActionButtons(), renderActionButtons(),
const Divider( const Divider(
thickness: 2, indent: 16,
endIndent: 16,
thickness: 1,
), ),
Padding( AddToAlbumTitleRow(
padding: const EdgeInsets.all(12), onCreateNewAlbum: () => onCreateNewAlbum(),
),
renderAlbums(),
const SizedBox(height: 12),
],
),
),
),
);
},
);
}
}
class AddToAlbumTitleRow extends StatelessWidget {
const AddToAlbumTitleRow({
super.key,
required this.onCreateNewAlbum,
});
final VoidCallback onCreateNewAlbum;
@override
Widget build(BuildContext context) {
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 16),
child: Row( child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween, mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [ children: [
const Text( const Text(
"control_bottom_app_bar_add_to_album", "control_bottom_app_bar_add_to_album",
style: TextStyle( style: TextStyle(
fontSize: 16, fontSize: 14,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
), ),
).tr(), ).tr(),
@ -150,14 +194,27 @@ class ControlBottomAppBar extends ConsumerWidget {
style: TextStyle( style: TextStyle(
color: Theme.of(context).primaryColor, color: Theme.of(context).primaryColor,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
fontSize: 14,
), ),
).tr(), ).tr(),
), ),
], ],
)),
renderAlbums(),
],
), ),
);
}
}
class CustomDraggingHandle extends StatelessWidget {
const CustomDraggingHandle({super.key});
@override
Widget build(BuildContext context) {
return Container(
height: 5,
width: 30,
decoration: BoxDecoration(
color: Colors.grey[500],
borderRadius: BorderRadius.circular(16),
), ),
); );
} }
@ -177,19 +234,20 @@ class ControlBoxButton extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return SizedBox( return MaterialButton(
width: 60, padding: const EdgeInsets.all(10),
shape: const CircleBorder(),
onPressed: () => onPressed(),
child: Column( child: Column(
mainAxisAlignment: MainAxisAlignment.start, mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center,
children: [ children: [
IconButton( Icon(iconData, size: 24),
onPressed: () { const SizedBox(height: 6),
onPressed(); Text(
}, label,
icon: Icon(iconData, size: 30), style: const TextStyle(fontSize: 12.0),
), ),
Text(label)
], ],
), ),
); );

View file

@ -4,7 +4,6 @@ import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart'; import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/modules/album/providers/album.provider.dart'; import 'package:immich_mobile/modules/album/providers/album.provider.dart';
import 'package:immich_mobile/modules/album/providers/shared_album.provider.dart';
import 'package:immich_mobile/modules/album/services/album.service.dart'; import 'package:immich_mobile/modules/album/services/album.service.dart';
import 'package:immich_mobile/modules/home/providers/home_page_render_list_provider.dart'; import 'package:immich_mobile/modules/home/providers/home_page_render_list_provider.dart';
import 'package:immich_mobile/modules/home/providers/multiselect.provider.dart'; import 'package:immich_mobile/modules/home/providers/multiselect.provider.dart';
@ -79,10 +78,11 @@ class HomePage extends HookConsumerWidget {
void onAddToAlbum(AlbumResponseDto album) async { void onAddToAlbum(AlbumResponseDto album) async {
final result = await albumService.addAdditionalAssetToAlbum( final result = await albumService.addAdditionalAssetToAlbum(
selection.value, album.id); selection.value,
album.id,
);
if (result != null) { if (result != null) {
if (result.alreadyInAlbum.isNotEmpty) { if (result.alreadyInAlbum.isNotEmpty) {
ImmichToast.show( ImmichToast.show(
context: context, context: context,
@ -137,7 +137,9 @@ class HomePage extends HookConsumerWidget {
), ),
Padding( Padding(
padding: EdgeInsets.only( padding: EdgeInsets.only(
top: selectionEnabledHook.value ? 0 : 60, bottom: 0.0), top: selectionEnabledHook.value ? 0 : 60,
bottom: 0.0,
),
child: ImmichAssetGrid( child: ImmichAssetGrid(
renderList: renderList, renderList: renderList,
assetsPerRow: assetsPerRow:
@ -148,7 +150,7 @@ class HomePage extends HookConsumerWidget {
selectionActive: selectionEnabledHook.value, selectionActive: selectionEnabledHook.value,
), ),
), ),
if (selectionEnabledHook.value) ...[ if (selectionEnabledHook.value)
ControlBottomAppBar( ControlBottomAppBar(
onShare: onShareAssets, onShare: onShareAssets,
onDelete: onDelete, onDelete: onDelete,
@ -157,7 +159,6 @@ class HomePage extends HookConsumerWidget {
onCreateNewAlbum: onCreateNewAlbum, onCreateNewAlbum: onCreateNewAlbum,
), ),
], ],
],
), ),
); );
} }