ExpandableItem widget

merge-requests/73/head
Amjad Amireh 6 years ago
parent be60383916
commit fff2b32dee

@ -5,8 +5,9 @@
*@desc:
*/
import 'package:doctor_app_flutter/widgets/patients/list_item.dart';
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
import 'package:doctor_app_flutter/widgets/shared/expandable_item_widget.dart';
import 'package:flutter/material.dart';
class PatientReferredScreen extends StatefulWidget {
@ -52,7 +53,7 @@ class _PatientReferredScreenState extends State<PatientReferredScreen> {
children: <Widget>[
for(final map in list_product)
for(final keys in map.keys)
ListItem(keys,map[keys].toList())
ExpandableItem(keys,map[keys].toList())
,
],
)

@ -0,0 +1,91 @@
/*
*@author: Amjad Amireh
*@Date:27/5/2020
*@param:listItems , headerTitle
*@return:ListItem Expand
*@desc:
*/
import 'package:flutter/material.dart';
class ExpandableItem extends StatefulWidget{
final List<String>listItems;
final String headerTitle;
ExpandableItem(this.headerTitle,this.listItems);
@override
_ExpandableItemState createState() => _ExpandableItemState();
}
class _ExpandableItemState extends State<ExpandableItem>
{
bool isExpand=false;
@override
void initState() {
super.initState();
isExpand=false;
}
@override
Widget build(BuildContext context) {
List<String>listItem=this.widget.listItems;
return Container(
child: Padding(
padding: (isExpand==true)?const EdgeInsets.all(6.0):const EdgeInsets.all(8.0),
child: Container(
decoration:BoxDecoration(
color: Colors.white,
borderRadius: (isExpand!=true)?BorderRadius.all(Radius.circular(50)):BorderRadius.all(Radius.circular(25)),
),
child: ExpansionTile(
key: PageStorageKey<String>(this.widget.headerTitle),
title: Container(
width: double.infinity,
child: Text(this.widget.headerTitle,style: TextStyle(fontSize: (isExpand!=true)?18:22,color: Colors.black,fontWeight: FontWeight.bold),)),
trailing: (isExpand==true)?Icon(Icons.keyboard_arrow_up,color: Colors.black,):Icon(Icons.keyboard_arrow_down,color: Colors.black),
onExpansionChanged: (value){
setState(() {
isExpand=value;
});
},
children: [
for(final item in listItem)
Padding(
padding: const EdgeInsets.all(8.0),
child: InkWell(
onTap: (){
print(Text("Selected Item $item "+this.widget.headerTitle ));
//========Stop Snak bar=========== Scaffold.of(context).showSnackBar(SnackBar(backgroundColor: Colors.black,duration:Duration(microseconds: 500),content: Text("Selected Item $item "+this.widget.headerTitle )));
},
child: Container(
width: double.infinity,
decoration:BoxDecoration(
color: Colors.white,
border: Border(top: BorderSide(color: Theme.of(context).dividerColor))
),
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Text(item,style: TextStyle(color: Colors.black),),
)),
),
)
],
),
),
),
);
}
}
Loading…
Cancel
Save