Skip to content

Commit

Permalink
TW-1360: fix slidable colors
Browse files Browse the repository at this point in the history
  • Loading branch information
Julian KOUNE authored and hoangdat committed Feb 6, 2024
1 parent ee6bcba commit 0688b39
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 15 deletions.
78 changes: 66 additions & 12 deletions lib/pages/chat_list/chat_list_view_builder.dart
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,10 @@ import 'package:fluffychat/pages/chat_list/chat_list_item.dart';
import 'package:collection/collection.dart';
import 'package:fluffychat/pages/chat_list/chat_list_view_style.dart';
import 'package:fluffychat/presentation/enum/chat_list/chat_list_enum.dart';
import 'package:fluffychat/resource/image_paths.dart';
import 'package:flutter/material.dart';
import 'package:flutter_slidable/flutter_slidable.dart';
import 'package:linagora_design_flutter/linagora_design_flutter.dart';
import 'package:flutter_svg/flutter_svg.dart';
import 'package:matrix/matrix.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';

Expand Down Expand Up @@ -54,34 +55,87 @@ class ChatListViewBuilder extends StatelessWidget {
List<Widget> _getSlidables(BuildContext context, Room room) {
return [
if (!room.isInvitation) ...[
SlidableAction(
autoClose: true,
padding: ChatListViewStyle.slidablePadding,
_ChatCustomSlidableAction(
label:
room.isUnread ? L10n.of(context)!.read : L10n.of(context)!.unread,
icon: room.isUnread ? Icons.mark_chat_read : Icons.mark_chat_unread,
icon: Icon(
room.isUnread
? Icons.mark_chat_read_outlined
: Icons.mark_chat_unread_outlined,
size: ChatListViewStyle.slidableIconSize,
),
onPressed: (_) => controller.toggleRead(room),
foregroundColor: Theme.of(context).colorScheme.onPrimary,
backgroundColor: LinagoraRefColors.material().neutral[70] ??
ChatListViewStyle.readSlidableColorRaw,
backgroundColor: ChatListViewStyle.readSlidableColor(room.isUnread)!,
),
SlidableAction(
autoClose: true,
padding: ChatListViewStyle.slidablePadding,
_ChatCustomSlidableAction(
label: room.isFavourite
? L10n.of(context)!.unpin
: L10n.of(context)!.pin,
icon: room.isFavourite ? Icons.push_pin_outlined : Icons.push_pin,
icon: room.isFavourite
? SvgPicture.asset(
ImagePaths.icUnpin,
width: ChatListViewStyle.slidableIconSize,
colorFilter: ColorFilter.mode(
Theme.of(context).colorScheme.onPrimary,
BlendMode.srcIn,
),
)
: const Icon(
Icons.push_pin_outlined,
size: ChatListViewStyle.slidableIconSize,
),
onPressed: (_) => controller.togglePin(room),
foregroundColor: Theme.of(context).colorScheme.onPrimary,
backgroundColor:
Colors.greenAccent[700] ?? ChatListViewStyle.pinSlidableColorRaw,
ChatListViewStyle.pinSlidableColor(room.isFavourite)!,
),
],
];
}
}

class _ChatCustomSlidableAction extends StatelessWidget {
const _ChatCustomSlidableAction({
required this.icon,
required this.label,
required this.onPressed,
required this.backgroundColor,
required this.foregroundColor,
});

final Widget icon;
final String label;
final SlidableActionCallback? onPressed;
final Color backgroundColor;
final Color foregroundColor;

@override
Widget build(BuildContext context) {
return CustomSlidableAction(
autoClose: true,
padding: ChatListViewStyle.slidablePadding,
onPressed: onPressed,
backgroundColor: backgroundColor,
foregroundColor: foregroundColor,
child: Column(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
children: [
icon,
const SizedBox(height: ChatListViewStyle.slidableIconTextGap),
Text(
label,
style: Theme.of(context).textTheme.labelMedium?.copyWith(
color: foregroundColor,
),
),
],
),
);
}
}

class _CommonChatListItem extends StatelessWidget {
const _CommonChatListItem({
required this.controller,
Expand Down
20 changes: 17 additions & 3 deletions lib/pages/chat_list/chat_list_view_style.dart
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import 'package:fluffychat/di/global/get_it_initializer.dart';
import 'package:fluffychat/utils/responsive/responsive_utils.dart';
import 'package:flutter/material.dart';
import 'package:linagora_design_flutter/linagora_design_flutter.dart';

class ChatListViewStyle {
static final responsiveUtils = getIt.get<ResponsiveUtils>();
Expand All @@ -10,12 +11,25 @@ class ChatListViewStyle {
static Size preferredSizeAppBar(BuildContext context) =>
const Size.fromHeight(120);

// Between 0 and 1, scale on actions length
// Slidable Ratio of one slidable item
static const double slidableSizeRatio = 0.23;
static double slidableExtentRatio(int slidablesLength) {
return slidableSizeRatio * slidablesLength;
}

static const Color pinSlidableColorRaw = Color(0xFF00C853);
static const Color readSlidableColorRaw = Color(0xFFAEAAAE);
static const EdgeInsets slidablePadding = EdgeInsets.all(4.0);
static const double slidableIconTextGap = 4.0;

static const double slidableIconSize = 24.0;
static Color? pinSlidableColor(bool isFavourite) {
return isFavourite
? LinagoraRefColors.material().neutral[70]
: Colors.greenAccent[700];
}

static Color? readSlidableColor(bool isUnread) {
return isUnread
? LinagoraRefColors.material().neutral[70]
: LinagoraRefColors.material().primary[40];
}
}

0 comments on commit 0688b39

Please sign in to comment.