Blame view

lib/pages/home/home_page.dart 8.3 KB
95edef4f   liangchengyou   feat:更新适配代码
1
  import 'package:flutter/material.dart';
60e47f7c   liangchengyou   feat:课程选择功能
2
  import 'package:flutter_bloc/flutter_bloc.dart';
d35a4e87   liangchengyou   feat:磨耳朵功能UI
3
  import 'package:flutter_screenutil/flutter_screenutil.dart';
f5fc01c1   liangchengyou   feat:修复首页进入个人信息页闪退问题
4
  import 'package:wow_english/common/core/user_util.dart';
d35a4e87   liangchengyou   feat:磨耳朵功能UI
5
  import 'package:wow_english/common/extension/string_extension.dart';
8988aa69   liangchengyou   feat:首页+课程列表数据获取
6
7
  import 'package:wow_english/models/course_entity.dart';
  import 'package:wow_english/pages/home/widgets/home_bouns_item.dart';
4b358e22   liangchengyou   feat:调整文件结构
8
  import 'package:wow_english/pages/home/widgets/home_tab_header_widget.dart';
8988aa69   liangchengyou   feat:首页+课程列表数据获取
9
  import 'package:wow_english/pages/home/widgets/home_vidoe_item.dart';
60e47f7c   liangchengyou   feat:课程选择功能
10
  import 'package:wow_english/route/route.dart';
e5c9e98f   liangchengyou   feat:首页模块颜色
11
  import 'package:wow_english/utils/color_util.dart';
c61b3c1a   Key   feat: toast_util....
12
  import 'package:wow_english/utils/toast_util.dart';
95edef4f   liangchengyou   feat:更新适配代码
13
  
4b358e22   liangchengyou   feat:调整文件结构
14
15
  import 'bloc/home_bloc.dart';
  
95edef4f   liangchengyou   feat:更新适配代码
16
  class HomePage extends StatelessWidget {
8988aa69   liangchengyou   feat:首页+课程列表数据获取
17
18
19
20
    const HomePage({super.key, this.moduleId});
  
    /// 模块id
    final String? moduleId;
95edef4f   liangchengyou   feat:更新适配代码
21
22
23
  
    @override
    Widget build(BuildContext context) {
60e47f7c   liangchengyou   feat:课程选择功能
24
      return BlocProvider(
842b7132   liangchengyou   feat:磨耳朵/练习页面调整
25
        create: (context) => HomeBloc(moduleId)..add(RequestDataEvent()),
60e47f7c   liangchengyou   feat:课程选择功能
26
27
28
29
30
31
32
33
        child: _HomePageView(),
      );
    }
  }
  
  class _HomePageView extends StatelessWidget {
    void _headerActionEvent(HeaderActionType type) {
      if (type == HeaderActionType.video) {
08a0f5a8   liangchengyou   feat:路由方式更新
34
        pushNamed(AppRouteName.reAfter);
60e47f7c   liangchengyou   feat:课程选择功能
35
      } else if (type == HeaderActionType.phase) {
49787541   liangchengyou   feat:添加ios快速打包脚本
36
37
38
39
40
        if(UserUtil.token.isEmpty) {
          pushNamed(AppRouteName.login);
        } else {
          pushNamed(AppRouteName.lesson);
        }
60e47f7c   liangchengyou   feat:课程选择功能
41
      } else if (type == HeaderActionType.listen) {
08a0f5a8   liangchengyou   feat:路由方式更新
42
        pushNamed(AppRouteName.listen);
d35a4e87   liangchengyou   feat:磨耳朵功能UI
43
      } else if (type == HeaderActionType.shop) {
08a0f5a8   liangchengyou   feat:路由方式更新
44
        pushNamed(AppRouteName.shop);
056970d8   Key   feat: api
45
      } else if (type == HeaderActionType.user) {
f5fc01c1   liangchengyou   feat:修复首页进入个人信息页闪退问题
46
47
48
49
50
        if(UserUtil.token.isEmpty) {
          pushNamed(AppRouteName.login);
        } else {
          pushNamed(AppRouteName.user);
        }
60e47f7c   liangchengyou   feat:课程选择功能
51
      } else {
608c05b4   liangchengyou   feat:兑换课程
52
  
60e47f7c   liangchengyou   feat:课程选择功能
53
54
55
56
57
      }
    }
  
    @override
    Widget build(BuildContext context) {
3c1d5c64   liangchengyou   feat:练习功能完成
58
      final bloc = BlocProvider.of<HomeBloc>(context);
c61b3c1a   Key   feat: toast_util....
59
      return BlocListener<HomeBloc, HomeState>(
3c1d5c64   liangchengyou   feat:练习功能完成
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
        listener: (context, state) {
          if (state is RequestVideoLessonState) {
            final videoUrl = bloc.processEntity?.videos?.videoUrl??'';
            var title = '';
            if (state.type == 1) {
              title = 'song';
            }
  
            if (state.type == 2) {
              title = 'video';
            }
  
            if (state.type == 5) {
              title = 'bonus';
            }
997ea0d6   liangchengyou   feat:绘本闪退问题修复
75
  
934e2b47   liangchengyou   feat:权限调整+课程进度接口对接
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
            if (videoUrl.isEmpty || !videoUrl.contains('http')) {
              return;
            }
            pushNamed(AppRouteName.lookVideo,arguments: {'videoUrl':videoUrl,'title':title,'courseLessonId':state.courseLessonId}).then((value) {
              if (value != null) {
                Map<String,String> dataMap = value as Map<String,String>;
                bloc.add(RequestExitClassEvent(
                  dataMap['courseLessonId']!,
                  '0',
                  dataMap['currentTime']!,
                ));
              }
            });
            return;
          }
  
          if (state is RequestEnterClassState) {
            if (state.courseType != 3 && state.courseType != 4) {///视频类型
              ///获取视频课程内容
              bloc.add(RequestVideoLessonEvent(state.courseLessonId,state.courseType));
              return;
            }
  
            if (state.courseType == 4) {//绘本
              pushNamed(AppRouteName.reading, arguments: {'courseLessonId':state.courseLessonId}).then((value) {
                if (value != null) {
                  Map<String,String> dataMap = value as Map<String,String>;
                  bloc.add(RequestExitClassEvent(
                      dataMap['courseLessonId']!,
                      dataMap['currentStep']!,
                      '0'
                  ));
                }
              });
              return;
            }
  
            if (state.courseType == 3) {//练习
              pushNamed(AppRouteName.topicPic,arguments: {'courseLessonId':state.courseLessonId}).then((value) {
                if (value != null) {
                  Map<String,String> dataMap = value as Map<String,String>;
                  bloc.add(RequestExitClassEvent(
                      dataMap['courseLessonId']!,
                      dataMap['currentStep']!,
                      '0'
                  ));
                }
              });
3c1d5c64   liangchengyou   feat:练习功能完成
124
125
              return;
            }
3c1d5c64   liangchengyou   feat:练习功能完成
126
127
          }
        },
d35a4e87   liangchengyou   feat:磨耳朵功能UI
128
        child: _homeView(),
95edef4f   liangchengyou   feat:更新适配代码
129
130
      );
    }
d35a4e87   liangchengyou   feat:磨耳朵功能UI
131
  
c61b3c1a   Key   feat: toast_util....
132
    Widget _homeView() => BlocBuilder<HomeBloc, HomeState>(builder: (context, state) {
08a0f5a8   liangchengyou   feat:路由方式更新
133
134
135
136
137
138
139
140
141
      final bloc = BlocProvider.of<HomeBloc>(context);
      return Scaffold(
        body: Container(
          color: Colors.white,
          child: Center(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.spaceBetween,
              children: [
                HomeTabHeaderWidget(
e5c9e98f   liangchengyou   feat:首页模块颜色
142
                  themColor: bloc.modelData?.courseModuleThemeColor,
08a0f5a8   liangchengyou   feat:路由方式更新
143
144
145
146
147
148
                  actionTap: (HeaderActionType type) {
                    _headerActionEvent(type);
                  },
                ),
                Expanded(
                    child: ListView.builder(
e5c9e98f   liangchengyou   feat:首页模块颜色
149
                        itemCount: bloc.modelData?.totalCourseLesson??0,
08a0f5a8   liangchengyou   feat:路由方式更新
150
151
152
153
154
155
156
                        scrollDirection: Axis.horizontal,
                        itemBuilder: (BuildContext context, int index) {
                          CourseCourseLessons? data = bloc.modelData?.courseLessons?[index];
                          if (data?.courseType == 5) {
                            //彩蛋
                            return GestureDetector(
                              onTap: () {
71fb0fb2   liangchengyou   feat:首页未登陆状态下逻辑调整
157
158
159
160
                                if(UserUtil.token.isEmpty) {
                                  pushNamed(AppRouteName.login);
                                  return;
                                }
08a0f5a8   liangchengyou   feat:路由方式更新
161
162
163
164
                                if (data!.lock!) {
                                  showToast('当前课程暂未解锁');
                                  return;
                                }
934e2b47   liangchengyou   feat:权限调整+课程进度接口对接
165
166
                                ///进入课堂
                                bloc.add(RequestEnterClassEvent(data.id!,data.courseType!));
08a0f5a8   liangchengyou   feat:路由方式更新
167
168
169
170
171
172
173
174
                              },
                              child: HomeBoundsItem(
                                imageUrl: data?.coverUrl,
                              ),
                            );
                          } else {
                            return GestureDetector(
                              onTap: () {
71fb0fb2   liangchengyou   feat:首页未登陆状态下逻辑调整
175
176
177
178
                                if(UserUtil.token.isEmpty) {
                                  pushNamed(AppRouteName.login);
                                  return;
                                }
08a0f5a8   liangchengyou   feat:路由方式更新
179
180
181
182
                                if (data!.lock!) {
                                  showToast('当前课程暂未解锁');
                                  return;
                                }
934e2b47   liangchengyou   feat:权限调整+课程进度接口对接
183
184
                                ///进入课堂
                                bloc.add(RequestEnterClassEvent(data.id!,data.courseType!));
08a0f5a8   liangchengyou   feat:路由方式更新
185
186
                              },
                              child: HomeVideoItem(
e5c9e98f   liangchengyou   feat:首页模块颜色
187
                                themColor: bloc.modelData?.courseModuleThemeColor,
08a0f5a8   liangchengyou   feat:路由方式更新
188
                                lessons: data,
d35a4e87   liangchengyou   feat:磨耳朵功能UI
189
                              ),
08a0f5a8   liangchengyou   feat:路由方式更新
190
191
192
193
194
195
196
197
198
199
200
201
                            );
                          }
                        })),
                SafeArea(
                  child: Padding(
                    padding: EdgeInsets.symmetric(horizontal: 13.w),
                    child: Row(
                      mainAxisAlignment: MainAxisAlignment.spaceBetween,
                      children: [
                        SizedBox(
                          height: 47.h,
                          width: 80.w,
d35a4e87   liangchengyou   feat:磨耳朵功能UI
202
                        ),
08a0f5a8   liangchengyou   feat:路由方式更新
203
204
                        Container(
                          decoration: BoxDecoration(
e5c9e98f   liangchengyou   feat:首页模块颜色
205
                            color: HexColor(bloc.modelData?.courseModuleThemeColor??''),
08a0f5a8   liangchengyou   feat:路由方式更新
206
207
208
209
                            borderRadius: BorderRadius.circular(14.5.r),
                          ),
                          padding: EdgeInsets.symmetric(vertical: 8.h, horizontal: 24.w),
                          child: Text(
e5c9e98f   liangchengyou   feat:首页模块颜色
210
                            '${(bloc.modelData?.nowCourseLesson??0)}/${bloc.modelData?.totalCourseLesson??0}',
08a0f5a8   liangchengyou   feat:路由方式更新
211
212
213
214
215
216
217
218
219
220
221
222
223
224
                            style: TextStyle(color: Colors.white, fontSize: 12.sp),
                          ),
                        ),
                        Image.asset(
                          'blue-positive'.assetPng,
                          height: 47.h,
                          width: 80.w,
                          // color: Colors.red,
                        ),
                      ],
                    ),
                  ),
                )
              ],
d35a4e87   liangchengyou   feat:磨耳朵功能UI
225
            ),
08a0f5a8   liangchengyou   feat:路由方式更新
226
227
228
229
          ),
        ),
      );
    });
056970d8   Key   feat: api
230
  }