60e47f7c
liangchengyou
feat:课程选择功能
|
1
2
|
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
3
|
import 'package:wow_english/common/extension/string_extension.dart';
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
4
|
import 'package:wow_english/common/widgets/ow_image_widget.dart';
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
5
|
import 'package:wow_english/models/course_module_entity.dart';
|
60e47f7c
liangchengyou
feat:课程选择功能
|
6
|
|
2187c85f
吴启风
feat:课程结构调整
|
7
|
import '../../section/courese_module_model.dart';
|
68dd7ba8
liangchengyou
feat:首页主题颜色+已知问题修改
|
8
|
|
2187c85f
吴启风
feat:课程结构调整
|
9
10
|
class ModuleItemWidget extends StatelessWidget {
const ModuleItemWidget({super.key, required this.isSelected, this.model, this.onClickEvent});
|
60e47f7c
liangchengyou
feat:课程选择功能
|
11
12
|
///是否被选中
final bool isSelected;
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
13
14
|
final CourseModuleEntity? model;
final Function()? onClickEvent;
|
60e47f7c
liangchengyou
feat:课程选择功能
|
15
16
17
|
@override
Widget build(BuildContext context) {
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
18
19
20
21
22
23
24
25
26
|
return GestureDetector(
onTap: () {
if (!isSelected) {
return;
}
onClickEvent?.call();
},
child: isSelected?_selectWidget():_unSelectWidget(),
);
|
60e47f7c
liangchengyou
feat:课程选择功能
|
27
28
29
30
|
}
Widget _unSelectWidget() {
return Container(
|
49787541
liangchengyou
feat:添加ios快速打包脚本
|
31
|
padding: const EdgeInsets.all(20),
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
32
|
decoration: BoxDecoration(
|
60e47f7c
liangchengyou
feat:课程选择功能
|
33
|
image: DecorationImage(
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
34
|
image: AssetImage('gendubeij'.assetPng)
|
60e47f7c
liangchengyou
feat:课程选择功能
|
35
36
|
)
),
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
37
38
|
child: OwImageWidget(
name: model?.picUrl??'',
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
39
|
),
|
60e47f7c
liangchengyou
feat:课程选择功能
|
40
41
42
43
44
45
46
|
);
}
Widget _selectWidget() {
return Container(
padding: const EdgeInsets.all(10),
decoration: BoxDecoration(
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
47
48
49
50
51
52
|
image: DecorationImage(
image: AssetImage(
'gendubeij'.assetPng,
),
fit: BoxFit.fill
),
|
60e47f7c
liangchengyou
feat:课程选择功能
|
53
54
55
56
57
|
),
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Expanded(
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
58
59
|
child: OwImageWidget(
name: model?.picUrl??'',
|
60e47f7c
liangchengyou
feat:课程选择功能
|
60
61
62
63
|
),
),
10.verticalSpace,
Container(
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
64
|
decoration: BoxDecoration(
|
68dd7ba8
liangchengyou
feat:首页主题颜色+已知问题修改
|
65
|
color: CourseModuleModel(model?.code??'Phase-1').color,
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
66
67
68
69
70
71
|
borderRadius: BorderRadius.circular(6.r),
border: Border.all(
color: const Color(0xFF333333),
width: 1.0
)
),
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
72
73
|
padding: EdgeInsets.symmetric(horizontal: 10.w),
child: Column(
|
60e47f7c
liangchengyou
feat:课程选择功能
|
74
|
children: [
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
75
76
77
78
79
80
81
|
Text(
model?.name??'',
style: TextStyle(
color: Colors.white,
fontSize: 12.sp
),
),
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
82
83
84
|
Text(
model?.des??'',
maxLines: 1,
|
6f617434
liangchengyou
feat:磨耳朵/视频跟读列表页接口调整
|
85
86
87
88
|
style: TextStyle(
color: Colors.white,
fontSize: 12.sp
),
|
8988aa69
liangchengyou
feat:首页+课程列表数据获取
|
89
|
)
|
60e47f7c
liangchengyou
feat:课程选择功能
|
90
91
92
93
94
95
96
97
|
],
),
)
],
),
);
}
}
|