mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2024-11-27 23:09:35 +01:00
refactor: move start chat FAB to implementation file
- moved the start chat FAB to an own implementation file - added some required animation to the FAB Signed-off-by: TheOneWithTheBraid <the-one@with-the-braid.cf>
This commit is contained in:
parent
a522a90e35
commit
6ba440cc7b
@ -1,4 +1,3 @@
|
|||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
|
|
||||||
@ -11,6 +10,7 @@ import 'package:fluffychat/pages/chat_list/chat_list_drawer.dart';
|
|||||||
import '../../widgets/matrix.dart';
|
import '../../widgets/matrix.dart';
|
||||||
import 'chat_list_body.dart';
|
import 'chat_list_body.dart';
|
||||||
import 'chat_list_header.dart';
|
import 'chat_list_header.dart';
|
||||||
|
import 'start_chat_fab.dart';
|
||||||
|
|
||||||
class ChatListView extends StatelessWidget {
|
class ChatListView extends StatelessWidget {
|
||||||
final ChatListController controller;
|
final ChatListController controller;
|
||||||
@ -35,15 +35,8 @@ class ChatListView extends StatelessWidget {
|
|||||||
drawer: ChatListDrawer(controller),
|
drawer: ChatListDrawer(controller),
|
||||||
floatingActionButton: selectMode == SelectMode.normal
|
floatingActionButton: selectMode == SelectMode.normal
|
||||||
? KeyBoardShortcuts(
|
? KeyBoardShortcuts(
|
||||||
child: FloatingActionButton.extended(
|
child:
|
||||||
isExtended: controller.scrolledToTop,
|
StartChatFloatingActionButton(controller: controller),
|
||||||
backgroundColor: Theme.of(context).colorScheme.primary,
|
|
||||||
foregroundColor: Theme.of(context).colorScheme.onPrimary,
|
|
||||||
onPressed: () =>
|
|
||||||
VRouter.of(context).to('/newprivatechat'),
|
|
||||||
icon: const Icon(CupertinoIcons.chat_bubble),
|
|
||||||
label: Text(L10n.of(context)!.newChat),
|
|
||||||
),
|
|
||||||
keysToPress: {
|
keysToPress: {
|
||||||
LogicalKeyboardKey.controlLeft,
|
LogicalKeyboardKey.controlLeft,
|
||||||
LogicalKeyboardKey.keyN
|
LogicalKeyboardKey.keyN
|
||||||
|
51
lib/pages/chat_list/start_chat_fab.dart
Normal file
51
lib/pages/chat_list/start_chat_fab.dart
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
import 'package:animations/animations.dart';
|
||||||
|
import 'package:flutter_gen/gen_l10n/l10n.dart';
|
||||||
|
import 'package:vrouter/vrouter.dart';
|
||||||
|
|
||||||
|
import 'chat_list.dart';
|
||||||
|
|
||||||
|
class StartChatFloatingActionButton extends StatelessWidget {
|
||||||
|
final ChatListController controller;
|
||||||
|
|
||||||
|
const StartChatFloatingActionButton({Key? key, required this.controller})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return PageTransitionSwitcher(
|
||||||
|
reverse: !controller.scrolledToTop,
|
||||||
|
transitionBuilder: (
|
||||||
|
Widget child,
|
||||||
|
Animation<double> primaryAnimation,
|
||||||
|
Animation<double> secondaryAnimation,
|
||||||
|
) {
|
||||||
|
return SharedAxisTransition(
|
||||||
|
animation: primaryAnimation,
|
||||||
|
secondaryAnimation: secondaryAnimation,
|
||||||
|
transitionType: SharedAxisTransitionType.horizontal,
|
||||||
|
child: child,
|
||||||
|
fillColor: Colors.transparent,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
layoutBuilder: (children) => Stack(
|
||||||
|
alignment: Alignment.centerRight,
|
||||||
|
children: children,
|
||||||
|
),
|
||||||
|
child: FloatingActionButton.extended(
|
||||||
|
key: ValueKey(controller.scrolledToTop),
|
||||||
|
isExtended: controller.scrolledToTop,
|
||||||
|
backgroundColor: Theme.of(context).colorScheme.primary,
|
||||||
|
foregroundColor: Theme.of(context).colorScheme.onPrimary,
|
||||||
|
onPressed: () => VRouter.of(context).to('/newprivatechat'),
|
||||||
|
icon: const Icon(CupertinoIcons.chat_bubble),
|
||||||
|
label: Text(
|
||||||
|
L10n.of(context)!.newChat,
|
||||||
|
overflow: TextOverflow.fade,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user