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.
91 lines
2.7 KiB
91 lines
2.7 KiB
4 years ago
|
import 'package:flutter/material.dart';
|
||
|
import 'package:flutter/cupertino.dart';
|
||
|
import 'package:flutter_icons/flutter_icons.dart';
|
||
|
import 'package:akuCommunity/utils/screenutil.dart';
|
||
|
import 'package:akuCommunity/base/base_style.dart';
|
||
|
|
||
|
class RefundTileCard extends StatefulWidget {
|
||
|
final List<Map<String, dynamic>> listTile;
|
||
|
RefundTileCard({Key key, this.listTile}) : super(key: key);
|
||
|
|
||
|
@override
|
||
|
_RefundTileCardState createState() => _RefundTileCardState();
|
||
|
}
|
||
|
|
||
|
class _RefundTileCardState extends State<RefundTileCard> {
|
||
|
Container _refundTile(String title, subtitle) {
|
||
|
return Container(
|
||
|
width: double.infinity,
|
||
|
padding: EdgeInsets.only(bottom: Screenutil.length(26)),
|
||
|
decoration: BoxDecoration(
|
||
|
border: Border(
|
||
|
bottom: BorderSide(color: BaseStyle.coloreeeeee, width: 0.5)),
|
||
|
),
|
||
|
child: Column(
|
||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||
|
children: [
|
||
|
Text(
|
||
|
title,
|
||
|
style: TextStyle(
|
||
|
fontSize: BaseStyle.fontSize34,
|
||
|
color: BaseStyle.color333333,
|
||
|
),
|
||
|
),
|
||
|
SizedBox(height: Screenutil.length(24)),
|
||
|
Text(
|
||
|
subtitle,
|
||
|
style: TextStyle(
|
||
|
fontSize: BaseStyle.fontSize28,
|
||
|
color: BaseStyle.color999999,
|
||
|
),
|
||
|
),
|
||
|
],
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
@override
|
||
|
Widget build(BuildContext context) {
|
||
|
return Container(
|
||
|
width: double.infinity,
|
||
|
child: Column(
|
||
|
children: widget.listTile
|
||
|
.map(
|
||
|
(item) => InkWell(
|
||
|
onTap: item['fun'],
|
||
|
child: Container(
|
||
|
width: double.infinity,
|
||
|
padding: EdgeInsets.only(
|
||
|
top: Screenutil.length(22),
|
||
|
left: Screenutil.length(32),
|
||
|
right: Screenutil.length(32),
|
||
|
),
|
||
|
color: Colors.white,
|
||
|
child: Stack(
|
||
|
children: [
|
||
|
_refundTile(
|
||
|
item['title'],
|
||
|
item['subtitle'],
|
||
|
),
|
||
|
item['isRight']
|
||
|
? Positioned(
|
||
|
top: Screenutil.length(45),
|
||
|
right: 0,
|
||
|
child: Icon(
|
||
|
AntDesign.right,
|
||
|
size: Screenutil.size(40),
|
||
|
color: BaseStyle.colord8d8d8,
|
||
|
),
|
||
|
)
|
||
|
: SizedBox(),
|
||
|
],
|
||
|
),
|
||
|
),
|
||
|
),
|
||
|
)
|
||
|
.toList(),
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
}
|