Merge branch 'main' into blue-branch

This commit is contained in:
bluearevalo 2024-07-03 14:13:41 -04:00
commit b1bf8ce02a
2 changed files with 9 additions and 26 deletions

View file

@ -47,27 +47,22 @@ class IgcRepo {
tokens: [
PangeaToken(
text: PangeaTokenText(content: "This", offset: 0, length: 4),
hasInfo: true,
lemmas: [Lemma(form: "This", text: "this", saveVocab: true)],
),
PangeaToken(
text: PangeaTokenText(content: "be", offset: 5, length: 2),
hasInfo: true,
lemmas: [Lemma(form: "be", text: "be", saveVocab: true)],
),
PangeaToken(
text: PangeaTokenText(content: "a", offset: 8, length: 1),
hasInfo: false,
lemmas: [],
),
PangeaToken(
text: PangeaTokenText(content: "sample", offset: 10, length: 6),
hasInfo: false,
lemmas: [],
),
PangeaToken(
text: PangeaTokenText(content: "text", offset: 17, length: 4),
hasInfo: false,
lemmas: [],
),
],

View file

@ -29,41 +29,26 @@ class MessageTranslationCardState extends State<MessageTranslationCard> {
PangeaRepresentation? repEvent;
String? selectionTranslation;
String? oldSelectedText;
String? l1Code;
String? l2Code;
bool _fetchingRepresentation = false;
String? translationLangCode() {
if (widget.immersionMode) return l1Code;
final String? originalSentCode =
widget.messageEvent.originalSent?.content.langCode;
return (l1Code == originalSentCode || originalSentCode == null)
? l2Code
: l1Code;
}
Future<void> fetchRepresentation(BuildContext context) async {
final String? langCode = translationLangCode();
if (langCode == null) return;
if (l1Code == null) return;
repEvent = widget.messageEvent
.representationByLanguage(
langCode,
l1Code!,
)
?.content;
if (repEvent == null && mounted) {
repEvent = await widget.messageEvent.representationByLanguageGlobal(
langCode: langCode,
langCode: l1Code!,
);
}
}
Future<void> translateSelection() async {
final String? targetLang = translationLangCode();
if (widget.selection.selectedText == null ||
targetLang == null ||
l1Code == null ||
l2Code == null) {
selectionTranslation = null;
@ -78,7 +63,7 @@ class MessageTranslationCardState extends State<MessageTranslationCard> {
accessToken: accessToken,
request: FullTextTranslationRequestModel(
text: widget.selection.messageText,
tgtLang: translationLangCode()!,
tgtLang: l1Code!,
userL1: l1Code!,
userL2: l2Code!,
srcLang: widget.messageEvent.messageDisplayLangCode,
@ -106,11 +91,14 @@ class MessageTranslationCardState extends State<MessageTranslationCard> {
}
}
String? get l1Code =>
MatrixState.pangeaController.languageController.activeL1Code();
String? get l2Code =>
MatrixState.pangeaController.languageController.activeL2Code();
@override
void initState() {
super.initState();
l1Code = MatrixState.pangeaController.languageController.activeL1Code();
l2Code = MatrixState.pangeaController.languageController.activeL2Code();
if (mounted) {
setState(() {});
}