From fbb76f92c6edcd2e7846aaf4d072d2666987c54b Mon Sep 17 00:00:00 2001 From: ManeraKai Date: Sun, 7 Apr 2024 12:24:38 +0300 Subject: [PATCH] Made loading progress indicator work everywhere --- lib/data.dart | 5 +---- lib/main.dart | 4 ---- lib/screens/translate/widgets/input/input.dart | 7 +------ .../translate/widgets/lang_selector/lang.dart | 12 ++---------- .../translate/widgets/lang_selector/switch_lang.dart | 2 -- lib/simplytranslate.dart | 7 +++++-- 6 files changed, 9 insertions(+), 28 deletions(-) diff --git a/lib/data.dart b/lib/data.dart index 487fc6a..5bd1a03 100644 --- a/lib/data.dart +++ b/lib/data.dart @@ -71,10 +71,7 @@ Future getSharedText() async { }); final translatedText = await simplytranslate.translate(_translationInput, 'auto', toLangVal); - setStateOverlord(() { - googleOutput = translatedText; - loading = false; - }); + setStateOverlord(() => googleOutput = translatedText); } } catch (_) { setStateOverlord(() => loading = false); diff --git a/lib/main.dart b/lib/main.dart index 1ac24ad..2a6541f 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -283,10 +283,6 @@ class _MyAppState extends State with WidgetsBindingObserver { preferredSize: Size(0, 60), child: Builder( builder: (context) => AppBar( - bottom: PreferredSize( - preferredSize: Size.fromHeight(2), - child: Container(height: 2, color: greenColor), - ), actions: [ PopupMenuButton( icon: Icon(Icons.more_vert, color: Colors.white), diff --git a/lib/screens/translate/widgets/input/input.dart b/lib/screens/translate/widgets/input/input.dart index 363a75c..5658ecd 100644 --- a/lib/screens/translate/widgets/input/input.dart +++ b/lib/screens/translate/widgets/input/input.dart @@ -74,13 +74,8 @@ class _TranslationInputState extends State { if (input == googleInCtrl.text) { if (googleInCtrl.text.length > 0 && googleInCtrl.text.length <= 5000) { isTranslationCanceled = false; - setStateOverlord(() => loading = true); final translatedText = await simplytranslate.translate(googleInCtrl.text, fromLangVal, toLangVal); - if (!isTranslationCanceled) - setStateOverlord(() { - googleOutput = translatedText; - loading = false; - }); + if (!isTranslationCanceled) setStateOverlord(() => googleOutput = translatedText); } } }); diff --git a/lib/screens/translate/widgets/lang_selector/lang.dart b/lib/screens/translate/widgets/lang_selector/lang.dart index bbf4273..d89675e 100644 --- a/lib/screens/translate/widgets/lang_selector/lang.dart +++ b/lib/screens/translate/widgets/lang_selector/lang.dart @@ -116,11 +116,7 @@ class _GoogleLangState extends State { changeToTxt!(toSelLangMap[toLangVal]!); } final translatedText = await translate(googleInCtrl.text, fromLangVal, toLangVal); - if (!isTranslationCanceled) - setStateOverlord(() { - googleOutput = translatedText; - loading = false; - }); + if (!isTranslationCanceled) setStateOverlord(() => googleOutput = translatedText); break; } } @@ -201,11 +197,7 @@ class _GoogleLangState extends State { FocusScope.of(context).unfocus(); } final translatedText = await translate(googleInCtrl.text, fromLangVal, toLangVal); - if (!isTranslationCanceled) - setStateOverlord(() { - googleOutput = translatedText; - loading = false; - }); + if (!isTranslationCanceled) setStateOverlord(() => googleOutput = translatedText); }, decoration: InputDecoration(contentPadding: const EdgeInsets.symmetric(vertical: 10, horizontal: 10), isDense: true), controller: txtCtrl, diff --git a/lib/screens/translate/widgets/lang_selector/switch_lang.dart b/lib/screens/translate/widgets/lang_selector/switch_lang.dart index 062ea18..31fce96 100644 --- a/lib/screens/translate/widgets/lang_selector/switch_lang.dart +++ b/lib/screens/translate/widgets/lang_selector/switch_lang.dart @@ -25,7 +25,6 @@ class GoogleSwitchLang extends StatelessWidget { setStateOverlord(() {}); } else if (googleInCtrl.text.length <= 5000) { FocusScope.of(context).unfocus(); - setStateOverlord(() => loading = true); try { final transInTmp = googleInCtrl.text; final fromLangValTransTmp = fromLangVal; @@ -50,7 +49,6 @@ class GoogleSwitchLang extends StatelessWidget { translatedText2 = ''; } setStateOverlord(() { - loading = false; googleInCtrl.text = translatedText['text']; googleOutput = translatedText2; }); diff --git a/lib/simplytranslate.dart b/lib/simplytranslate.dart index 226bbcf..b0be4cc 100644 --- a/lib/simplytranslate.dart +++ b/lib/simplytranslate.dart @@ -23,6 +23,8 @@ Future tts(String text, String language) async { Future> translate(String text, String from, String to) async { if (text.isEmpty) return {}; + setStateOverlord(() => loading = true); + final fromLast1 = session.read("fromLast1"); final fromLast2 = session.read("fromLast2"); final fromLast3 = session.read("fromLast3"); @@ -42,8 +44,9 @@ Future> translate(String text, String from, String to) asyn session.write("toLast2", toLast1); session.write("toLast3", toLast2); } - - return translate_(text, from, to); + final result = await translate_(text, from, to); + setStateOverlord(() => loading = false); + return result; } Future> translate_(String text, String from, String to) async {