* updated toolbar buttons * initial work for toolbar updates * Add WordZoomWidget to display word and lemma information (#1214) --- For more details, open the [Copilot Workspace session](https://copilot-workspace.githubnext.com/pangeachat/client/tree/1179-toolbar-changes?shareId=XXXX-XXXX-XXXX-XXXX). * word zoom card prototyped, activity generation in progress * adding copy for new construct uses * laying down TODOs * initial work for word zoom card * Always add part of speech to token's morph list * Prevent duplicate choices in lemma activity * Don't play token audio at start of morph activity * Only grant +1 points for emoji activity * Uncomment tryToSpeak function * Always update activity once complete * Added queuing / UI logic for morph activity buttons * code cleanup * added required data argument to logError calls * fix overflowing practice activity card and audio player on mobile --------- Co-authored-by: wcjord <32568597+wcjord@users.noreply.github.com>
125 lines
4.3 KiB
Dart
125 lines
4.3 KiB
Dart
import 'package:fluffychat/config/app_config.dart';
|
|
import 'package:fluffychat/config/themes.dart';
|
|
import 'package:fluffychat/pangea/enum/message_mode_enum.dart';
|
|
import 'package:fluffychat/pangea/matrix_event_wrappers/pangea_message_event.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/message_audio_card.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/message_selection_overlay.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/message_speech_to_text_card.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/message_translation_card.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/message_unsubscribed_card.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/toolbar_content_loading_indicator.dart';
|
|
import 'package:fluffychat/pangea/widgets/chat/tts_controller.dart';
|
|
import 'package:fluffychat/pangea/widgets/practice_activity/practice_activity_card.dart';
|
|
import 'package:fluffychat/pangea/widgets/word_zoom/word_zoom_widget.dart';
|
|
import 'package:fluffychat/widgets/matrix.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:matrix/matrix_api_lite/model/message_types.dart';
|
|
|
|
const double minCardHeight = 70;
|
|
|
|
class MessageToolbar extends StatelessWidget {
|
|
final PangeaMessageEvent pangeaMessageEvent;
|
|
final MessageOverlayController overlayController;
|
|
|
|
const MessageToolbar({
|
|
super.key,
|
|
required this.pangeaMessageEvent,
|
|
required this.overlayController,
|
|
});
|
|
|
|
TtsController get ttsController =>
|
|
overlayController.widget.chatController.choreographer.tts;
|
|
|
|
Widget? toolbarContent(BuildContext context) {
|
|
final bool subscribed =
|
|
MatrixState.pangeaController.subscriptionController.isSubscribed;
|
|
|
|
if (!subscribed) {
|
|
return MessageUnsubscribedCard(
|
|
controller: overlayController,
|
|
);
|
|
}
|
|
|
|
if (overlayController.messageAnalyticsEntry?.hasHiddenWordActivity ??
|
|
false) {
|
|
return PracticeActivityCard(
|
|
pangeaMessageEvent: pangeaMessageEvent,
|
|
overlayController: overlayController,
|
|
targetTokensAndActivityType:
|
|
overlayController.messageAnalyticsEntry!.nextActivity!,
|
|
);
|
|
}
|
|
|
|
if (!overlayController.initialized) {
|
|
return const ToolbarContentLoadingIndicator();
|
|
}
|
|
|
|
switch (overlayController.toolbarMode) {
|
|
case MessageMode.translation:
|
|
return MessageTranslationCard(
|
|
messageEvent: pangeaMessageEvent,
|
|
selection: overlayController.selectedSpan,
|
|
);
|
|
case MessageMode.textToSpeech:
|
|
return MessageAudioCard(
|
|
messageEvent: pangeaMessageEvent,
|
|
overlayController: overlayController,
|
|
selection: overlayController.selectedSpan,
|
|
tts: ttsController,
|
|
setIsPlayingAudio: overlayController.setIsPlayingAudio,
|
|
);
|
|
case MessageMode.speechToText:
|
|
return MessageSpeechToTextCard(
|
|
messageEvent: pangeaMessageEvent,
|
|
);
|
|
case MessageMode.noneSelected:
|
|
return const SizedBox();
|
|
case MessageMode.practiceActivity:
|
|
case MessageMode.wordZoom:
|
|
if (overlayController.selectedToken == null) {
|
|
return const SizedBox();
|
|
}
|
|
return WordZoomWidget(
|
|
token: overlayController.selectedToken!,
|
|
messageEvent: overlayController.pangeaMessageEvent!,
|
|
tts: ttsController,
|
|
overlayController: overlayController,
|
|
);
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
if (overlayController.toolbarMode == MessageMode.noneSelected ||
|
|
![MessageTypes.Text, MessageTypes.Audio].contains(
|
|
pangeaMessageEvent.event.messageType,
|
|
)) {
|
|
return const SizedBox();
|
|
}
|
|
|
|
return Container(
|
|
decoration: BoxDecoration(
|
|
color: Theme.of(context).cardColor,
|
|
borderRadius: const BorderRadius.all(
|
|
Radius.circular(AppConfig.borderRadius),
|
|
),
|
|
),
|
|
constraints: const BoxConstraints(
|
|
maxHeight: AppConfig.toolbarMaxHeight,
|
|
minWidth: AppConfig.toolbarMinWidth,
|
|
minHeight: AppConfig.toolbarMinHeight,
|
|
// maxWidth is set by MessageSelectionOverlay
|
|
),
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
children: [
|
|
AnimatedSize(
|
|
duration: FluffyThemes.animationDuration,
|
|
child: toolbarContent(context),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|