keys router ui

This commit is contained in:
DASHU
2024-08-30 12:58:44 +08:00
parent db050386b5
commit 7c109f15c4
10 changed files with 384 additions and 21 deletions

View File

@@ -0,0 +1,73 @@
import 'package:flutter/material.dart';
import 'package:nostr_sdk/utils/string_util.dart';
import '../../../util/router_util.dart';
import '../../const/base.dart';
import 'text_input_dialog_inner_component.dart';
class TextInputDialog extends StatefulWidget {
String title;
String? hintText;
String? value;
bool Function(BuildContext, String)? valueCheck;
TextInputDialog(
this.title, {
this.hintText,
this.value,
this.valueCheck,
});
@override
State<StatefulWidget> createState() {
return _TextInputDialog();
}
static Future<String?> show(BuildContext context, String title,
{String? value,
String? hintText,
bool Function(BuildContext, String)? valueCheck}) async {
return await showDialog<String>(
context: context,
builder: (_context) {
return TextInputDialog(
StringUtil.breakWord(title),
hintText: hintText,
value: value,
valueCheck: valueCheck,
);
});
}
}
class _TextInputDialog extends State<TextInputDialog> {
@override
Widget build(BuildContext context) {
var themeData = Theme.of(context);
var main = TextInputDialogInnerComponent(
widget.title,
hintText: widget.hintText,
value: widget.value,
valueCheck: widget.valueCheck,
);
return Dialog(
child: FocusScope(
autofocus: true,
child: GestureDetector(
behavior: HitTestBehavior.opaque,
onTap: () {
RouterUtil.back(context);
},
child: Container(
padding: EdgeInsets.all(Base.BASE_PADDING * 2),
child: main,
),
),
),
);
}
}

View File

@@ -0,0 +1,106 @@
import 'package:flutter/material.dart';
import '../../../generated/l10n.dart';
import '../../../util/router_util.dart';
import '../../const/base.dart';
class TextInputDialogInnerComponent extends StatefulWidget {
String title;
String? hintText;
String? value;
bool Function(BuildContext, String)? valueCheck;
TextInputDialogInnerComponent(
this.title, {
this.hintText,
this.value,
this.valueCheck,
});
@override
State<StatefulWidget> createState() {
return _TextInputDialogInnerComponent();
}
}
class _TextInputDialogInnerComponent
extends State<TextInputDialogInnerComponent> {
late TextEditingController controller;
@override
void initState() {
super.initState();
controller = TextEditingController(text: widget.value);
}
@override
Widget build(BuildContext context) {
var themeData = Theme.of(context);
Color cardColor = themeData.cardColor;
var mainColor = themeData.primaryColor;
var titleFontSize = themeData.textTheme.bodyLarge!.fontSize;
List<Widget> list = [];
list.add(Container(
margin: EdgeInsets.only(bottom: Base.BASE_PADDING),
child: Text(
widget.title,
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: titleFontSize,
),
),
));
list.add(Container(
child: TextField(
controller: controller,
minLines: 4,
maxLines: 4,
autofocus: true,
decoration: InputDecoration(
hintText: widget.hintText,
border: OutlineInputBorder(borderSide: BorderSide(width: 1)),
),
),
));
list.add(Container(
margin: EdgeInsets.only(top: Base.BASE_PADDING),
width: double.infinity,
child: FilledButton(
onPressed: _onConfirm,
child: Text("Confirm"),
),
));
var main = Container(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: list,
),
);
return main;
}
void _onConfirm() {
var value = controller.text;
// if (StringUtil.isBlank(value)) {
// BotToast.showText(text: "Input can't be null");
// return;
// }
if (widget.valueCheck != null) {
if (!widget.valueCheck!(context, value)) {
return;
}
}
return RouterUtil.back(context, value);
}
}