bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
1
|
import 'package:flutter/gestures.dart';
|
2a29701f
liangchengyou
feat:提交代码
|
2
3
|
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
|
e1f36554
liangchengyou
feat:调整状态监听逻辑
|
4
|
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
5
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
6
|
import 'package:wow_english/common/extension/string_extension.dart';
|
1d5315dd
liangchengyou
feat:添加字体,调整文件结构
|
7
8
|
import 'package:wow_english/common/widgets/textfield_customer_widget.dart';
import 'package:wow_english/login/loginpage/bloc/login_bloc.dart';
|
17a80689
liangchengyou
feat:倒计时功能开发
|
9
|
import 'package:wow_english/login/loginpage/time_widget.dart';
|
95edef4f
liangchengyou
feat:更新适配代码
|
10
|
import 'package:wow_english/route/route.dart';
|
2a29701f
liangchengyou
feat:提交代码
|
11
|
|
2a29701f
liangchengyou
feat:提交代码
|
12
|
class LoginPage extends StatelessWidget {
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
13
|
const LoginPage({super.key});
|
2a29701f
liangchengyou
feat:提交代码
|
14
15
16
|
@override
Widget build(BuildContext context) {
|
2a29701f
liangchengyou
feat:提交代码
|
17
18
|
return BlocProvider(
create: (context) => LoginBloc(),
|
e1f36554
liangchengyou
feat:调整状态监听逻辑
|
19
20
21
22
23
24
25
26
27
28
29
30
|
child: _LoginPageView(),
);
}
}
class _LoginPageView extends StatelessWidget {
@override
Widget build(BuildContext context) {
return BlocListener<LoginBloc,LoginState>(
listener: (context, state){
if (state is LoginResultChangeState) {
EasyLoading.showToast('登陆接口回调');
|
60e47f7c
liangchengyou
feat:课程选择功能
|
31
|
Navigator.of(context).pushNamed(AppRouteName.home);
|
e1f36554
liangchengyou
feat:调整状态监听逻辑
|
32
33
|
}
},
|
2a29701f
liangchengyou
feat:提交代码
|
34
35
36
37
38
39
40
41
|
child: _buildLoginViewWidget(),
);
}
Widget _buildLoginViewWidget() => BlocBuilder<LoginBloc,LoginState> (
builder: (context, state) {
final bloc = BlocProvider.of<LoginBloc>(context);
return Scaffold(
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
42
43
|
body: SafeArea(
child: ListView(
|
2a29701f
liangchengyou
feat:提交代码
|
44
|
children: [
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
Container(
padding: EdgeInsets.only(top: 25.h),
child: Stack(
children: [
Positioned(
right: 29.w,
child: GestureDetector(
onTap: () => bloc.add(ChangeLoginTypeEvent()),
child: Container(
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage(
'login_logo'.assetPng
),
fit: BoxFit.fill
),
),
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
62
|
padding: EdgeInsets.symmetric(horizontal: 18.w,vertical: 5.h),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
63
|
child: Text(
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
64
65
66
67
|
bloc.loginType == LoginType.sms?'密码登陆':'验证码密码',
style: TextStyle(
fontSize: 16.sp
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
68
69
70
71
72
73
74
75
76
77
|
),
),
)
),
Center(
child: Column(
children: [
Image.asset(
'wow_logo'.assetPng,
height: 81.h,
|
1a43bf7c
liangchengyou
feat:更新UI
|
78
79
|
width: 131.w,
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
80
81
82
83
84
85
86
87
|
Offstage(
offstage: bloc.loginType == LoginType.pwd,
child: _buildSmsViewWidget(),
),
Offstage(
offstage: bloc.loginType == LoginType.sms,
child: _buildPwdViewWidget(),
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
88
89
90
91
92
93
94
95
96
97
|
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
GestureDetector(
onTap: () => bloc.add(AgreementChangeEvent()),
child: Icon(
bloc.agreement ? Icons.check_circle_outlined:Icons.circle_outlined,
color:bloc.agreement ? Colors.green:Colors.black),
),
6.horizontalSpace,
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
98
99
100
|
RichText(
text: TextSpan(
children:[
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
101
|
TextSpan(
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
102
103
|
text: '我已阅读并同意',
style: TextStyle(
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
104
105
|
fontSize: 12.sp,
color: const Color(0xFF333333),
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
106
107
108
109
|
)
),
TextSpan(
text: '《用户隐私协议》',
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
110
111
112
|
style: TextStyle(
fontSize: 12.sp,
color: const Color(0xFF333333),
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
113
114
115
116
117
118
119
120
121
|
),
recognizer: TapGestureRecognizer()..onTap = (){
Navigator.of(context).pushNamed(
AppRouteName.webView,
arguments: {
'urlStr':'https://www.zhihu.com',
'webViewTitle':'用户隐私协议'
});
}),
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
122
|
TextSpan(
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
123
124
|
text: ',',
style: TextStyle(
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
125
126
|
fontSize: 12.sp,
color: const Color(0xFF333333)
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
127
128
129
130
|
)
),
TextSpan(
text: '《儿童隐私政策》',
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
131
132
133
|
style: TextStyle(
fontSize: 12.sp,
color: const Color(0xFF333333)
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
134
135
136
137
138
139
140
141
142
143
144
145
|
),
recognizer: TapGestureRecognizer()..onTap = (){
Navigator.of(context).pushNamed(
AppRouteName.webView,
arguments: {
'urlStr':'https://www.zhihu.com',
'webViewTitle':'儿童隐私协议'
});
})
]
),
)
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
146
147
|
],
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
148
|
GestureDetector(
|
1a43bf7c
liangchengyou
feat:更新UI
|
149
150
151
152
153
|
onTap: () {
if (bloc.canLogin) {
bloc.add(RequestLoginEvent());
}
},
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
154
155
156
157
158
159
160
161
162
|
child: Container(
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage(
bloc.canLogin?'login_enter'.assetPng:'login_enter_dis'.assetPng
),
fit: BoxFit.fill
),
),
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
163
164
165
|
padding: EdgeInsets.symmetric(
horizontal: 28.w,
vertical: 14.h
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
166
|
),
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
167
168
169
170
171
|
child: Text(
'登录',
style: TextStyle(
fontSize: 16.sp
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
172
173
174
175
176
177
178
|
),
),
)
],
),
)
],
|
2a29701f
liangchengyou
feat:提交代码
|
179
180
181
182
183
184
185
186
|
),
)
],
),
),
);
},
);
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
187
188
|
Widget _buildSmsViewWidget()=> BlocBuilder<LoginBloc,LoginState>(
|
17a80689
liangchengyou
feat:倒计时功能开发
|
189
|
builder: (context,state) {
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
190
|
final bloc = BlocProvider.of<LoginBloc>(context);
|
2ca1b8bf
liangchengyou
feat:更新适配
|
191
|
return Padding(
|
1a43bf7c
liangchengyou
feat:更新UI
|
192
|
padding: EdgeInsets.symmetric(horizontal: 135.w),
|
2ca1b8bf
liangchengyou
feat:更新适配
|
193
194
195
|
child: Column(
children: [
15.verticalSpace,
|
1d5315dd
liangchengyou
feat:添加字体,调整文件结构
|
196
|
TextFieldCustomerWidget(
|
4bf67b91
liangchengyou
feat:设置密码
|
197
198
199
200
201
202
203
204
|
height: 55.h,
hitText: '请输入手机号',
textInputType: TextInputType.phone,
bgImageName: 'Input_layer_up',
onChangeValue: (String value) {
bloc.add(PhoneNumChangeEvent());
},
controller: bloc.phoneNumController,
|
2ca1b8bf
liangchengyou
feat:更新适配
|
205
206
|
),
6.5.verticalSpace,
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
207
208
209
210
211
|
Text('未注册用户登录默认注册',
style: TextStyle(
fontSize: 12.sp,
color: const Color(0xFF999999)
),),
|
2ca1b8bf
liangchengyou
feat:更新适配
|
212
213
|
4.5.verticalSpace,
Row(
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
214
215
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
|
1a43bf7c
liangchengyou
feat:更新UI
|
216
|
Expanded(
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
217
218
219
220
221
222
223
224
225
226
|
child: TextFieldCustomerWidget(
height: 50.h,
hitText: '请输入验证码',
textInputType: TextInputType.number,
bgImageName: 'Input_layer_down',
onChangeValue: (String value) {
bloc.add(CheckFieldChangeEvent());
},
controller: bloc.checkNumController,
)
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
227
|
),
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
228
|
TimerWidget(canSendSms: bloc.canSendSms)
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
229
|
],
|
2ca1b8bf
liangchengyou
feat:更新适配
|
230
231
232
|
)
],
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
233
234
235
236
237
238
|
);
});
Widget _buildPwdViewWidget()=> BlocBuilder<LoginBloc,LoginState>(
builder: (context,state){
final bloc = BlocProvider.of<LoginBloc>(context);
|
1a43bf7c
liangchengyou
feat:更新UI
|
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
|
return Padding(
padding: EdgeInsets.symmetric(horizontal: 90.w),
child: Column(
children: [
15.verticalSpace,
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Image.asset(
'phone'.assetPng,
height: 45.h,
width: 35.w,
),
10.5.horizontalSpace,
Expanded(
|
1d5315dd
liangchengyou
feat:添加字体,调整文件结构
|
254
|
child: TextFieldCustomerWidget(
|
4bf67b91
liangchengyou
feat:设置密码
|
255
256
257
258
259
260
261
262
263
264
|
height: 50.h,
hitText: '请输入手机号',
textInputType: TextInputType.phone,
bgImageName: 'Input_layer_up',
onChangeValue: (String value) {
bloc.add(PhoneNumChangeEvent());
},
controller: bloc.phoneNumController,
)
),
|
1a43bf7c
liangchengyou
feat:更新UI
|
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
|
5.horizontalSpace,
SizedBox(
width: 100.w,
height: 55.h,
)
],
),
12.verticalSpace,
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Image.asset(
'lock'.assetPng,
height: 34.h,
width: 31.w,
),
10.5.horizontalSpace,
Expanded(
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
283
284
285
286
287
288
289
290
|
child: TextFieldCustomerWidget(
hitText: '请输入密码',
bgImageName: 'Input_layer_down',
onChangeValue: (String value) {
bloc.add(CheckFieldChangeEvent());
},
controller: bloc.checkNumController,
)
|
1a43bf7c
liangchengyou
feat:更新UI
|
291
292
293
|
),
5.horizontalSpace,
GestureDetector(
|
95edef4f
liangchengyou
feat:更新适配代码
|
294
|
onTap: () {
|
1d5315dd
liangchengyou
feat:添加字体,调整文件结构
|
295
|
Navigator.of(context).pushNamed(AppRouteName.fogPwd);
|
95edef4f
liangchengyou
feat:更新适配代码
|
296
|
},
|
1a43bf7c
liangchengyou
feat:更新UI
|
297
298
299
300
|
child: Container(
width: 100.w,
height: 55.h,
alignment: Alignment.centerLeft,
|
f0d56772
liangchengyou
feat:更新尺寸适配
|
301
302
303
304
305
|
child: Text(
'忘记密码 ?',
style: TextStyle(
fontSize: 12.sp
),
|
2ca1b8bf
liangchengyou
feat:更新适配
|
306
|
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
307
|
),
|
1a43bf7c
liangchengyou
feat:更新UI
|
308
309
310
311
312
|
)
],
)
],
),
|
062f0df2
liangchengyou
feat:登录模块代码提交
|
313
314
|
);
});
|
2a29701f
liangchengyou
feat:提交代码
|
315
|
}
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
|
|
bfb40cd0
liangchengyou
feat:忘记密码获取验证码
|
|
|