fluffychat merge

This commit is contained in:
ggurdin 2026-02-05 11:34:37 -05:00
commit 006ad4a09e
No known key found for this signature in database
GPG key ID: A01CB41737CBB478
5 changed files with 34 additions and 23 deletions

View file

@ -75,6 +75,7 @@ enum AppSettings<T> {
// #Pangea
volume<double>('pangea.volume', 1.0),
// Pangea#
emojiSuggestionLocale<String>('emoji_suggestion_locale', ''),
enableSoftLogout<bool>('chat.fluffy.enable_soft_logout', false);
final String key;

View file

@ -1,8 +1,5 @@
// import 'package:flutter/material.dart';
// import 'package:animations/animations.dart';
// import 'package:matrix/matrix.dart';
// import 'package:emoji_picker_flutter/locales/default_emoji_set_locale.dart';
// import 'package:fluffychat/config/setting_keys.dart';
// import 'package:fluffychat/l10n/l10n.dart';
// import 'package:fluffychat/pages/chat/recording_input_row.dart';
@ -11,6 +8,9 @@
// import 'package:fluffychat/utils/platform_infos.dart';
// import 'package:fluffychat/widgets/avatar.dart';
// import 'package:fluffychat/widgets/matrix.dart';
// import 'package:flutter/material.dart';
// import 'package:matrix/matrix.dart';
// import '../../config/themes.dart';
// import 'chat.dart';
// import 'input_bar.dart';
@ -334,6 +334,14 @@
// filled: false,
// ),
// onChanged: controller.onInputBarChanged,
// suggestionEmojis: getDefaultEmojiLocale(
// AppSettings.emojiSuggestionLocale.value.isNotEmpty
// ? Locale(AppSettings.emojiSuggestionLocale.value)
// : Localizations.localeOf(context),
// ).fold(
// [],
// (emojis, category) => emojis..addAll(category.emoji),
// ),
// ),
// ),
// ),

View file

@ -1,7 +1,7 @@
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:emojis/emoji.dart';
import 'package:emoji_picker_flutter/emoji_picker_flutter.dart';
import 'package:matrix/matrix.dart';
import 'package:slugify/slugify.dart';
@ -42,6 +42,7 @@ class InputBar extends StatelessWidget {
final ValueChanged<String>? onChanged;
final bool? autofocus;
final bool readOnly;
final List<Emoji> suggestionEmojis;
const InputBar({
required this.room,
@ -61,6 +62,7 @@ class InputBar extends StatelessWidget {
required this.choreographer,
required this.showNextMatch,
// Pangea#
required this.suggestionEmojis,
super.key,
});
@ -135,13 +137,12 @@ class InputBar extends StatelessWidget {
}
}
}
// aside of emote packs, also propose normal (tm) unicode emojis
final matchingUnicodeEmojis = Emoji.all()
.where(
(element) => [element.name, ...element.keywords]
.any((element) => element.toLowerCase().contains(emoteSearch)),
)
final matchingUnicodeEmojis = suggestionEmojis
.where((emoji) => emoji.name.toLowerCase().contains(emoteSearch))
.toList();
// sort by the index of the search term in the name in order to have
// best matches first
// (thanks for the hint by github.com/nextcloud/circles devs)
@ -161,9 +162,8 @@ class InputBar extends StatelessWidget {
for (final emoji in matchingUnicodeEmojis) {
ret.add({
'type': 'emoji',
'emoji': emoji.char,
// don't include sub-group names, splitting at `:` hence
'label': '${emoji.char} - ${emoji.name.split(':').first}',
'emoji': emoji.emoji,
'label': emoji.name,
'current_word': ':$emoteSearch',
});
if (ret.length > maxResults) {
@ -269,7 +269,18 @@ class InputBar extends StatelessWidget {
waitDuration: const Duration(days: 1), // don't show on hover
child: ListTile(
onTap: () => onSelected(suggestion),
title: Text(label, style: const TextStyle(fontFamily: 'RobotoMono')),
leading: SizedBox.square(
dimension: size,
child: Text(
suggestion['emoji']!,
style: const TextStyle(fontSize: 16),
),
),
title: Text(
label,
maxLines: 1,
overflow: TextOverflow.ellipsis,
),
),
);
}

View file

@ -513,14 +513,6 @@ packages:
url: "https://pub.dev"
source: hosted
version: "4.3.0"
emojis:
dependency: "direct main"
description:
name: emojis
sha256: "2e4d847c3f1e2670f30dc355909ce6fa7808b4e626c34a4dd503a360995a38bf"
url: "https://pub.dev"
source: hosted
version: "0.9.9"
equatable:
dependency: transitive
description:

View file

@ -31,7 +31,6 @@ dependencies:
diacritic: ^0.1.6
dynamic_color: ^1.8.1
emoji_picker_flutter: ^4.3.0
emojis: ^0.9.9
file_picker: ^10.3.6
file_selector: ^1.0.4
flutter: