fluffychat/lib/pages/chat_list/start_chat_fab.dart

87 lines
2.4 KiB
Dart
Raw Normal View History

import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';
import 'package:vrouter/vrouter.dart';
import '../../config/themes.dart';
import 'chat_list.dart';
class StartChatFloatingActionButton extends StatelessWidget {
2023-03-19 19:59:50 +01:00
final ActiveFilter activeFilter;
final ValueNotifier<bool> scrolledToTop;
2023-03-19 19:59:50 +01:00
final bool roomsIsEmpty;
2023-03-19 19:59:50 +01:00
const StartChatFloatingActionButton({
Key? key,
required this.activeFilter,
required this.scrolledToTop,
required this.roomsIsEmpty,
}) : super(key: key);
2022-08-30 20:24:36 +02:00
void _onPressed(BuildContext context) {
2023-03-19 19:59:50 +01:00
switch (activeFilter) {
2022-08-30 20:24:36 +02:00
case ActiveFilter.allChats:
case ActiveFilter.messages:
VRouter.of(context).to('/newprivatechat');
break;
case ActiveFilter.groups:
VRouter.of(context).to('/newgroup');
break;
case ActiveFilter.spaces:
VRouter.of(context).to('/newspace');
break;
}
}
IconData get icon {
2023-03-19 19:59:50 +01:00
switch (activeFilter) {
2022-08-30 20:24:36 +02:00
case ActiveFilter.allChats:
case ActiveFilter.messages:
2023-03-19 19:59:50 +01:00
return Icons.add_outlined;
2022-08-30 20:24:36 +02:00
case ActiveFilter.groups:
return Icons.group_add_outlined;
case ActiveFilter.spaces:
return Icons.workspaces_outlined;
}
}
String getLabel(BuildContext context) {
2023-03-19 19:59:50 +01:00
switch (activeFilter) {
2022-08-30 20:24:36 +02:00
case ActiveFilter.allChats:
case ActiveFilter.messages:
2023-03-19 19:59:50 +01:00
return roomsIsEmpty
2022-12-29 10:26:01 +01:00
? L10n.of(context)!.startFirstChat
: L10n.of(context)!.newChat;
2022-08-30 20:24:36 +02:00
case ActiveFilter.groups:
return L10n.of(context)!.newGroup;
case ActiveFilter.spaces:
return L10n.of(context)!.newSpace;
}
}
@override
Widget build(BuildContext context) {
return ValueListenableBuilder<bool>(
valueListenable: scrolledToTop,
2023-06-03 17:49:13 +02:00
builder: (context, scrolledToTop, _) => AnimatedSize(
duration: FluffyThemes.animationDuration,
curve: FluffyThemes.animationCurve,
2023-06-03 17:49:13 +02:00
clipBehavior: Clip.none,
child: scrolledToTop
? FloatingActionButton.extended(
onPressed: () => _onPressed(context),
icon: Icon(icon),
label: Text(
getLabel(context),
overflow: TextOverflow.fade,
),
)
: FloatingActionButton(
onPressed: () => _onPressed(context),
child: Icon(icon),
2022-08-30 20:24:36 +02:00
),
),
);
}
}