parent
e37d8fa2f8
commit
c66c1191ce
After Width: | Height: | Size: 801 B |
After Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.7 KiB |
@ -0,0 +1,213 @@
|
|||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter/rendering.dart';
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
import 'package:recook/widgets/custom_app_bar.dart';
|
||||||
|
import 'package:get/get.dart';
|
||||||
|
import 'package:recook/constants/styles.dart';
|
||||||
|
import 'package:recook/constants/header.dart';
|
||||||
|
import 'package:recook/widgets/recook_back_button.dart';
|
||||||
|
import 'package:velocity_x/velocity_x.dart';
|
||||||
|
|
||||||
|
class RechargePage extends StatefulWidget {
|
||||||
|
RechargePage({
|
||||||
|
Key key,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_RechargePageState createState() => _RechargePageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _RechargePageState extends State<RechargePage>
|
||||||
|
with TickerProviderStateMixin {
|
||||||
|
|
||||||
|
final items = [
|
||||||
|
BottomNavigationBarItem(
|
||||||
|
icon: Image.asset(R.ASSETS_TICKET_ORDER_TAB_ICON_PNG,width: 18.rw,height: 19.rw,),
|
||||||
|
label: '订单',
|
||||||
|
),
|
||||||
|
];
|
||||||
|
String _phone = '';
|
||||||
|
//手机号的控制器
|
||||||
|
TextEditingController _phoneController = TextEditingController();
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Scaffold(
|
||||||
|
backgroundColor: AppColor.frenchColor,
|
||||||
|
resizeToAvoidBottomInset: false,
|
||||||
|
appBar: CustomAppBar(
|
||||||
|
appBackground: Colors.white,
|
||||||
|
leading: RecookBackButton(
|
||||||
|
white: false,
|
||||||
|
),
|
||||||
|
elevation: 0,
|
||||||
|
title: Text(
|
||||||
|
"话费充值",
|
||||||
|
style: TextStyle(
|
||||||
|
color: Color(0xFF333333),
|
||||||
|
fontSize: 18.rsp,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
bottomNavigationBar: Container(
|
||||||
|
width: double.infinity,
|
||||||
|
height: 48.rw,
|
||||||
|
color: Colors.white,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
16.hb,
|
||||||
|
Image.asset(R.ASSETS_TICKET_ORDER_TAB_ICON_PNG,width: 18.rw,height: 19.rw,),
|
||||||
|
Text('充值记录',style: TextStyle(color: Color(0xFF666666),fontSize: 10.rsp),)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
),
|
||||||
|
body: Container(
|
||||||
|
|
||||||
|
child: _bodyWidget(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void onTap(int index) {
|
||||||
|
if (index == 0) {
|
||||||
|
//Get.to(); //充值记录页面
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_bodyWidget() {
|
||||||
|
return Container(
|
||||||
|
width: 375.rw,
|
||||||
|
child: Stack(
|
||||||
|
children: [
|
||||||
|
Positioned(
|
||||||
|
top:0,
|
||||||
|
left: 0,
|
||||||
|
child: Container(
|
||||||
|
|
||||||
|
width: 375.rw,
|
||||||
|
height: 150.rw,
|
||||||
|
color: Color(0xFF04C580),
|
||||||
|
child: Row(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
34.wb,
|
||||||
|
TextField(
|
||||||
|
controller:_phoneController,
|
||||||
|
decoration: InputDecoration(
|
||||||
|
|
||||||
|
contentPadding: EdgeInsets.only(left: 2.rw, bottom: 4.rw,top: 30.rw),
|
||||||
|
hintText: '请输入11位手机号码',
|
||||||
|
counterText: '',
|
||||||
|
border:UnderlineInputBorder(
|
||||||
|
borderSide: BorderSide(
|
||||||
|
color: Colors.white,
|
||||||
|
width: 260.rw
|
||||||
|
),
|
||||||
|
),
|
||||||
|
suffixIconConstraints:BoxConstraints(
|
||||||
|
minHeight: 17.rw,
|
||||||
|
minWidth: 17.rw,
|
||||||
|
),
|
||||||
|
suffixIcon:
|
||||||
|
Padding(
|
||||||
|
padding: EdgeInsets.all(5.rw),
|
||||||
|
child:GestureDetector(
|
||||||
|
onTap: (){
|
||||||
|
_phoneController.clear();
|
||||||
|
setState(() {
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child:_phone!=''?Container(
|
||||||
|
|
||||||
|
width: 17.rw,
|
||||||
|
height: 17.rw,
|
||||||
|
child: ImageIcon(
|
||||||
|
AssetImage(R.ASSETS_CANCEL_ICON_PNG),
|
||||||
|
size: 17.rw,
|
||||||
|
color: Colors.white,
|
||||||
|
),
|
||||||
|
):SizedBox(),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
|
||||||
|
focusedBorder: UnderlineInputBorder(
|
||||||
|
borderSide: BorderSide(
|
||||||
|
color: Colors.white,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
hintStyle:
|
||||||
|
AppTextStyle.generate(22.rsp, color: Color(0xFFFFFFFF)),
|
||||||
|
),
|
||||||
|
inputFormatters: [
|
||||||
|
FilteringTextInputFormatter.digitsOnly,
|
||||||
|
LengthLimitingTextInputFormatter(11),//最大长度
|
||||||
|
],
|
||||||
|
|
||||||
|
keyboardType: TextInputType.number,
|
||||||
|
style: AppTextStyle.generate(22.rsp,color: Colors.white),
|
||||||
|
maxLength: 11,
|
||||||
|
maxLines: 1,
|
||||||
|
onChanged: (text) {
|
||||||
|
|
||||||
|
|
||||||
|
if (text == null) return;
|
||||||
|
_phone = text;
|
||||||
|
_phoneController.text = _getPhone(_phone);
|
||||||
|
_phoneController.selection = TextSelection.fromPosition(
|
||||||
|
TextPosition(
|
||||||
|
offset: _phoneController.text.length, affinity: TextAffinity.upstream));
|
||||||
|
setState(() {
|
||||||
|
|
||||||
|
});
|
||||||
|
//print(_phone);
|
||||||
|
},
|
||||||
|
).expand(),
|
||||||
|
100.wb,
|
||||||
|
Container(
|
||||||
|
padding: EdgeInsets.only(top: 34.rw),
|
||||||
|
child: Image.asset(R.ASSETS_TICKET_ORDER_TAB_ICON_PNG,width: 19.rw,height: 22.rw,color: Colors.white,),
|
||||||
|
|
||||||
|
),
|
||||||
|
|
||||||
|
60.wb,
|
||||||
|
],
|
||||||
|
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
_getPhone(String text){
|
||||||
|
if(text.isEmpty){
|
||||||
|
return text;
|
||||||
|
}else{
|
||||||
|
if(text.length<=3){
|
||||||
|
|
||||||
|
}else if(text.length>3&&text.length<8){
|
||||||
|
|
||||||
|
text = text.insert(" ",3);
|
||||||
|
|
||||||
|
}else if(text.length>=8){
|
||||||
|
text = text.insert(" ",3);
|
||||||
|
text = text.insert(" ",8);
|
||||||
|
}
|
||||||
|
return text;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue