You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

159 lines
4.3 KiB

2 years ago
import 'package:flutter/material.dart';
import 'package:project_telephony/ui/home/set/specify_phone_page.dart';
import 'package:project_telephony/utils/headers.dart';
import '../../../base/base_style.dart';
import '../../widget/plone_back_button.dart';
// class setItem{
//
// }
class PhoneSetPage extends StatefulWidget {
const PhoneSetPage({Key? key}) : super(key: key);
@override
_PhoneSetPageState createState() => _PhoneSetPageState();
}
class _PhoneSetPageState extends State<PhoneSetPage> {
int select = 0;
List setList = [
{
"icon": Assets.icons.rylyphone.path,
"title": "任意来源号码发送",
"text": "所有的号码来电都会发送",
// "select": true,
},
{
"icon": Assets.icons.txlphone.path,
"title": "在通讯录中的号码发送",
"text": "只给在通讯录中的号码来电发送",
// "select": false,
},
{
"icon": Assets.icons.notxlphone.path,
"title": "不在通讯录中的号码发送",
"text": "只给不在通讯录中的号码来电发送",
// "select": false,
},
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
elevation: 0,
title: Text(
'发送号码设置',
style: TextStyle(
fontSize: BaseStyle.fontSize34,
color: BaseStyle.color333333,
fontWeight: FontWeight.bold),
),
titleSpacing: 162.w,
leading: const CloudBackButton(isSpecial: true),
backgroundColor: kForeGroundColor),
backgroundColor: kForeGroundColor,
body: Column(
children: [
_getList(),
24.hb,
GestureDetector(
onTap: () {
Get.to(()=>const SpecifyPhonePage());
},
child: Container(
padding: EdgeInsets.symmetric(horizontal: 32.w, vertical: 30.w),
height: 144.w,
child: ListTile(
leading: SizedBox(
width: 72.w,
height: 72.w,
child: Image.asset(
Assets.icons.zdphone.path,
fit: BoxFit.fill,
),
),
title: Text(
"指定号码不发送",
style:
TextStyle(fontSize: 32.sp, fontWeight: FontWeight.bold),
),
subtitle: Text(
"通过添加指定号码来设置不发送",
style: TextStyle(
fontSize: 28.sp, color: const Color(0xFF999999)),
),
trailing: SizedBox(
width: 48.w,
height: 48.w,
child: const Icon(Icons.arrow_forward_ios),
)),
),
)
],
),
);
}
_getList() {
return Container(
padding: EdgeInsets.symmetric(horizontal: 32.w, vertical: 30.w),
height: 500.w,
child: ListView.builder(
itemBuilder: (context, index) {
return _getListBox(setList, index);
},
itemCount: setList.length,
),
);
}
_getListBox(List item, int index) {
return GestureDetector(
onTap: () {
select = index;
// print(_selectIndex);
setState(() {});
},
child: ListTile(
leading: SizedBox(
width: 72.w,
height: 72.w,
child: Image.asset(
item[index]["icon"],
fit: BoxFit.fill,
)),
title: Text(
item[index]["title"],
style: TextStyle(fontSize: 32.sp, fontWeight: FontWeight.bold),
),
subtitle: Text(
item[index]["text"],
style: TextStyle(fontSize: 28.sp, color: const Color(0xFF999999)),
),
trailing: SizedBox(
width: 40.w,
height: 40.w,
child: Radio(
onChanged: (int? value) {
select = index;
// print(_selectIndex);
setState(() {});
},
groupValue: select,
value: index,
),
),
// BeeCheckRadio(
// value: index,
// groupValue: [select],
// ),
),
);
}
}