Clean up UI
This commit is contained in:
@@ -3,6 +3,7 @@ import 'dart:math';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:tangocard_reader/models/data_entry.dart';
|
||||
import 'package:tangocard_reader/screens/practise/kanji.dart';
|
||||
|
||||
import 'flashcard.dart';
|
||||
|
||||
@@ -26,80 +27,142 @@ const encouragingWords = [
|
||||
'頑張れ〜!',
|
||||
'できるぞ!',
|
||||
'ヨッシャー!',
|
||||
'いけいけいけー!',
|
||||
'いけいけー!',
|
||||
];
|
||||
|
||||
class _PractiseViewState extends State<PractiseView> {
|
||||
String title = '';
|
||||
late int currentCard;
|
||||
final List<bool> _isSelected = [false, false];
|
||||
final List<bool> _flashcardToggles = [false, false];
|
||||
final List<bool> _kanjiToggles = [false, false];
|
||||
|
||||
get isShuffleMode => _isSelected[0];
|
||||
get isLanguageSwitchedMode => _isSelected[1];
|
||||
get randomCard => Random().nextInt(widget.entries.length);
|
||||
bool get isShuffleMode => _flashcardToggles[0];
|
||||
bool get isLanguageSwitchedMode => _flashcardToggles[1];
|
||||
bool get isKanjiDrawingMode => _kanjiToggles[0];
|
||||
bool get isKanjiAnimationMode => _kanjiToggles[1];
|
||||
|
||||
int get randomCard => Random().nextInt(widget.entries.length);
|
||||
String get randomEncouragingWord =>
|
||||
encouragingWords[Random().nextInt(encouragingWords.length)];
|
||||
bool get isPhone =>
|
||||
MediaQueryData.fromWindow(WidgetsBinding.instance!.window)
|
||||
.size
|
||||
.shortestSide <
|
||||
600;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
title = encouragingWords[Random().nextInt(encouragingWords.length)];
|
||||
currentCard = widget.index;
|
||||
|
||||
final isPhone = MediaQueryData.fromWindow(WidgetsBinding.instance!.window)
|
||||
.size
|
||||
.shortestSide <
|
||||
600;
|
||||
if (isPhone) {
|
||||
SystemChrome.setPreferredOrientations([
|
||||
DeviceOrientation.landscapeLeft,
|
||||
DeviceOrientation.landscapeRight,
|
||||
]);
|
||||
if (widget.isKanji) {
|
||||
SystemChrome.setPreferredOrientations([
|
||||
DeviceOrientation.portraitUp,
|
||||
DeviceOrientation.portraitDown,
|
||||
]);
|
||||
} else {
|
||||
SystemChrome.setPreferredOrientations([
|
||||
DeviceOrientation.landscapeLeft,
|
||||
DeviceOrientation.landscapeRight,
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
super.initState();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) => Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Row(
|
||||
children: [
|
||||
Expanded(child: Container()),
|
||||
Text(title),
|
||||
Expanded(child: Container()),
|
||||
IconButton(
|
||||
onPressed: () => setState(() {
|
||||
currentCard = 0;
|
||||
}),
|
||||
icon: const Icon(Icons.repeat),
|
||||
),
|
||||
ToggleButtons(
|
||||
children: const [
|
||||
Icon(Icons.shuffle),
|
||||
Icon(Icons.translate),
|
||||
],
|
||||
isSelected: _isSelected,
|
||||
onPressed: (int index) {
|
||||
setState(() {
|
||||
_isSelected[index] = !_isSelected[index];
|
||||
});
|
||||
})
|
||||
],
|
||||
),
|
||||
centerTitle: true,
|
||||
void dispose() {
|
||||
SystemChrome.setPreferredOrientations([
|
||||
DeviceOrientation.landscapeRight,
|
||||
DeviceOrientation.landscapeLeft,
|
||||
DeviceOrientation.portraitUp,
|
||||
DeviceOrientation.portraitDown,
|
||||
]);
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
AppBar get flashcardAppBar => AppBar(
|
||||
title: Row(
|
||||
children: [
|
||||
Expanded(child: Container()),
|
||||
Text(randomEncouragingWord),
|
||||
Expanded(child: Container()),
|
||||
IconButton(
|
||||
onPressed: () => setState(() => currentCard = 0),
|
||||
icon: const Icon(Icons.repeat),
|
||||
),
|
||||
ToggleButtons(
|
||||
selectedColor: Colors.white,
|
||||
children: const [
|
||||
Icon(Icons.shuffle),
|
||||
Icon(Icons.translate),
|
||||
],
|
||||
isSelected: _flashcardToggles,
|
||||
onPressed: (int index) =>
|
||||
setState(() => _flashcardToggles[index] = !_flashcardToggles[index])),
|
||||
],
|
||||
),
|
||||
centerTitle: true,
|
||||
);
|
||||
|
||||
AppBar get kanjiAppBar => AppBar(
|
||||
title: Row(
|
||||
children: [
|
||||
Expanded(child: Container()),
|
||||
Text(randomEncouragingWord),
|
||||
Expanded(child: Container()),
|
||||
IconButton(
|
||||
onPressed: () => setState(() => currentCard = 0),
|
||||
icon: const Icon(Icons.repeat),
|
||||
),
|
||||
ToggleButtons(
|
||||
selectedColor: Colors.white,
|
||||
children: const [
|
||||
Icon(Icons.edit),
|
||||
Icon(Icons.animation),
|
||||
],
|
||||
isSelected: _flashcardToggles,
|
||||
onPressed: (int index) =>
|
||||
setState(() => _flashcardToggles[index] = !_flashcardToggles[index])),
|
||||
],
|
||||
),
|
||||
centerTitle: true,
|
||||
);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) => Scaffold(
|
||||
appBar: widget.isKanji ? kanjiAppBar : flashcardAppBar,
|
||||
body: widget.isKanji
|
||||
? Container()
|
||||
? KanjiPage(
|
||||
entry: widget.entries[currentCard] as KanjiEntry,
|
||||
index: currentCard,
|
||||
showDrawingPanel: isKanjiDrawingMode,
|
||||
showStrokeOrder: isKanjiAnimationMode,
|
||||
onNextCard: () => setState(() {
|
||||
currentCard = isShuffleMode ? randomCard : currentCard + 1;
|
||||
if (currentCard == widget.entries.length) currentCard = 0;
|
||||
}),
|
||||
onPreviousCard: () => setState(() {
|
||||
currentCard = isShuffleMode ? randomCard : currentCard - 1;
|
||||
if (currentCard == -1) {
|
||||
currentCard = widget.entries.length - 1;
|
||||
}
|
||||
}),
|
||||
)
|
||||
: FlashcardPage(
|
||||
card: widget.entries[currentCard] as YokutangoEntry,
|
||||
index: currentCard,
|
||||
languageFlipped: isLanguageSwitchedMode,
|
||||
onNextCard: () {
|
||||
setState(() {
|
||||
currentCard = isShuffleMode ? randomCard : currentCard + 1;
|
||||
if (currentCard == widget.entries.length) currentCard = 0;
|
||||
title = encouragingWords[
|
||||
Random().nextInt(encouragingWords.length)];
|
||||
});
|
||||
},
|
||||
onNextCard: () => setState(() {
|
||||
currentCard = isShuffleMode ? randomCard : currentCard + 1;
|
||||
if (currentCard == widget.entries.length) currentCard = 0;
|
||||
}),
|
||||
onPreviousCard: () => setState(() {
|
||||
currentCard = isShuffleMode ? randomCard : currentCard - 1;
|
||||
if (currentCard == -1) {
|
||||
currentCard = widget.entries.length - 1;
|
||||
}
|
||||
}),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user