154 lines
4.4 KiB
Dart
154 lines
4.4 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
|
|
import 'package:jisho_study_tool/bloc/kanji/kanji_bloc.dart';
|
|
import 'package:jisho_study_tool/components/kanji/kanji__search_page/kanji_search_page.dart';
|
|
import 'package:jisho_study_tool/components/kanji/kanji_suggestions.dart';
|
|
import 'package:jisho_study_tool/components/loading.dart';
|
|
|
|
class KanjiView extends StatelessWidget {
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return BlocListener<KanjiBloc, KanjiState>(
|
|
listener: (context, state) {
|
|
if (state is KanjiSearchInitial) {
|
|
FocusScope.of(context).unfocus();
|
|
} else if (state is KanjiSearchLoading) {
|
|
FocusScope.of(context).unfocus();
|
|
}
|
|
},
|
|
child: BlocBuilder<KanjiBloc, KanjiState>(
|
|
builder: (context, state) {
|
|
if (state is KanjiSearchInitial) return Container();
|
|
else if (state is KanjiSearchInput) return KanjiSuggestions(state.kanjiSuggestions);
|
|
else if (state is KanjiSearchLoading) return LoadingScreen();
|
|
else if (state is KanjiSearchFinished)
|
|
return WillPopScope(
|
|
child: KanjiResultCard(state.kanji),
|
|
onWillPop: () async {
|
|
BlocProvider.of<KanjiBloc>(context)
|
|
.add(ReturnToInitialState());
|
|
return false;
|
|
});
|
|
throw 'No such event found';
|
|
},
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class KanjiViewBar extends StatelessWidget {
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Container(
|
|
child: Row(
|
|
children: [
|
|
IconButton(
|
|
icon: Icon(Icons.arrow_back),
|
|
onPressed: () =>
|
|
BlocProvider.of<KanjiBloc>(context).add(ReturnToInitialState()),
|
|
),
|
|
Expanded(
|
|
child: Container(
|
|
child: _KanjiTextField(),
|
|
),
|
|
),
|
|
IconButton(
|
|
icon: Icon(Icons.star_border),
|
|
onPressed: null,
|
|
),
|
|
IconButton(
|
|
icon: Icon(Icons.add),
|
|
onPressed: null,
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class _KanjiTextField extends StatefulWidget {
|
|
@override
|
|
_KanjiTextFieldState createState() => new _KanjiTextFieldState();
|
|
}
|
|
|
|
enum TextFieldButton {clear, paste}
|
|
|
|
class _KanjiTextFieldState extends State<_KanjiTextField> {
|
|
FocusNode _focus = new FocusNode();
|
|
TextEditingController _textController = new TextEditingController();
|
|
TextFieldButton _button = TextFieldButton.paste;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
_focus.addListener(_onFocusChange);
|
|
}
|
|
|
|
void _getKanjiSuggestions(String text) =>
|
|
BlocProvider.of<KanjiBloc>(context).add(GetKanjiSuggestions(text));
|
|
|
|
void updateSuggestions() => _getKanjiSuggestions(_textController.text);
|
|
|
|
void _onFocusChange() {
|
|
debugPrint('TextField Focus Changed: ${_focus.hasFocus.toString()}');
|
|
|
|
setState(() {
|
|
_button = _focus.hasFocus ? TextFieldButton.clear : TextFieldButton.paste;
|
|
});
|
|
|
|
if (_focus.hasFocus)
|
|
updateSuggestions();
|
|
else
|
|
FocusScope.of(context).unfocus();
|
|
}
|
|
|
|
void _clearText() {
|
|
_textController.text = '';
|
|
updateSuggestions();
|
|
}
|
|
|
|
void _pasteText() async {
|
|
ClipboardData clipboardData = await Clipboard.getData('text/plain');
|
|
_textController.text = clipboardData.text;
|
|
updateSuggestions();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
IconButton _clearButton = IconButton(
|
|
icon: Icon(Icons.clear),
|
|
onPressed: () => _clearText(),
|
|
);
|
|
|
|
IconButton _pasteButton = IconButton(
|
|
icon: Icon(Icons.content_paste),
|
|
onPressed: () => _pasteText(),
|
|
);
|
|
|
|
return TextField(
|
|
focusNode: _focus,
|
|
controller: _textController,
|
|
onChanged: (text) => _getKanjiSuggestions(text),
|
|
onSubmitted: (text) =>
|
|
BlocProvider.of<KanjiBloc>(context).add(GetKanji(text)),
|
|
decoration: new InputDecoration(
|
|
prefixIcon: Icon(Icons.search),
|
|
hintText: 'Search for kanji',
|
|
fillColor: Colors.white,
|
|
filled: true,
|
|
border: OutlineInputBorder(
|
|
borderRadius: BorderRadius.circular(100.0),
|
|
),
|
|
contentPadding: EdgeInsets.symmetric(vertical: 10.0),
|
|
isDense: false,
|
|
suffixIcon: (_button == TextFieldButton.clear) ? _clearButton : _pasteButton,
|
|
),
|
|
style: TextStyle(
|
|
fontSize: 14.0,
|
|
),
|
|
);
|
|
}
|
|
}
|