You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
274 lines
8.6 KiB
Dart
274 lines
8.6 KiB
Dart
import 'package:hmg_patient_app/core/model/hospitals/hospitals_model.dart';
|
|
import 'package:hmg_patient_app/core/viewModels/medical/radiology_view_model.dart';
|
|
import 'package:hmg_patient_app/theme/colors.dart';
|
|
import 'package:hmg_patient_app/widgets/buttons/defaultButton.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
import '../../uitl/translations_delegate_base.dart';
|
|
|
|
class LocationSelectionDialog extends StatelessWidget {
|
|
final List<HospitalsModel> data;
|
|
final Function(int)? onValueSelected;
|
|
final int? selectedIndex;
|
|
final bool isArabic;
|
|
final String? title;
|
|
|
|
const LocationSelectionDialog({super.key, required this.data, this.onValueSelected, this.selectedIndex, required this.isArabic, this.title });
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
print("the title is $title");
|
|
return Dialog(
|
|
backgroundColor: Colors.white,
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.circular(8),
|
|
),
|
|
child: LocationDialogBody(
|
|
title: title,
|
|
isArabic: isArabic,
|
|
data: data,
|
|
onValueSelected: onValueSelected,
|
|
selectedIndex: selectedIndex,
|
|
));
|
|
}
|
|
}
|
|
|
|
class LocationDialogBody extends StatefulWidget {
|
|
final String? title;
|
|
final List<HospitalsModel> data;
|
|
final Function(int)? onValueSelected;
|
|
final int? selectedIndex;
|
|
final bool isArabic;
|
|
|
|
const LocationDialogBody({super.key, required this.data, this.onValueSelected, this.selectedIndex, required this.isArabic, this.title});
|
|
|
|
@override
|
|
State<LocationDialogBody> createState() => _LocationDialogBodyState();
|
|
}
|
|
|
|
class _LocationDialogBodyState extends State<LocationDialogBody> {
|
|
bool isListVisible = false;
|
|
int currentlySelected = -1;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return isListVisible
|
|
? LocationListExpandedBody(
|
|
title: widget.title,
|
|
isArabic: widget.isArabic,
|
|
data: widget.data,
|
|
onItemClick: (data) {
|
|
if (data.isEmpty) return;
|
|
var selected = widget.data.indexWhere(
|
|
(item) => item.name == data,
|
|
);
|
|
|
|
if (selected == -1) return;
|
|
setState(() {
|
|
currentlySelected = selected;
|
|
isListVisible = false;
|
|
});
|
|
},
|
|
)
|
|
: LocationListWrapBody(
|
|
title: widget.title,
|
|
onConfirmClicked: () {
|
|
widget.onValueSelected?.call(currentlySelected);
|
|
},
|
|
onTextBoxClicked: () {
|
|
setState(() {
|
|
isListVisible = true;
|
|
});
|
|
},
|
|
selectedText: currentlySelected == -1 ? "" : widget.data[currentlySelected].name ?? "");
|
|
}
|
|
}
|
|
|
|
class LocationListExpandedBody extends StatefulWidget {
|
|
final String? title;
|
|
final List<HospitalsModel> data;
|
|
final Function(String) onItemClick;
|
|
final bool isArabic;
|
|
|
|
const LocationListExpandedBody({super.key, required this.data, required this.onItemClick, required this.isArabic, this.title});
|
|
|
|
@override
|
|
State<LocationListExpandedBody> createState() => _LocationListExpandedBodyState();
|
|
}
|
|
|
|
class _LocationListExpandedBodyState extends State<LocationListExpandedBody> {
|
|
List<HospitalsModel> tempListData = [];
|
|
TextEditingController controller = new TextEditingController();
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
setState(() {
|
|
tempListData.addAll(widget.data);
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Container(
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(24),
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
SelectBranchHeader(title: widget.title,),
|
|
SizedBox(
|
|
height: 8,
|
|
),
|
|
TextField(
|
|
controller: controller,
|
|
onChanged: (v) {
|
|
tempListData.clear();
|
|
if (v.length > 0) {
|
|
for (int i = 0; i < widget.data.length; i++) {
|
|
if (widget.data[i].name?.toLowerCase().contains(v.toLowerCase()) == true) {
|
|
tempListData.add(widget.data[i]);
|
|
}
|
|
}
|
|
} else {
|
|
tempListData.addAll(widget.data);
|
|
}
|
|
setState(() {});
|
|
},
|
|
decoration: InputDecoration(
|
|
hintStyle: TextStyle(fontSize: 12),
|
|
hintText: TranslationBase.of(context).searchByBranch,
|
|
suffixIcon: Icon(Icons.search),
|
|
contentPadding: EdgeInsets.symmetric(vertical: 9, horizontal: 14),
|
|
border: OutlineInputBorder(
|
|
borderRadius: BorderRadius.circular(8.0),
|
|
borderSide: BorderSide(
|
|
color: Colors.grey, // Normal border color
|
|
width: 1.0,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 16,
|
|
),
|
|
ListView.builder(
|
|
itemCount: tempListData.length,
|
|
shrinkWrap: true,
|
|
itemBuilder: (context, index) {
|
|
return Padding(
|
|
padding: EdgeInsets.only(bottom: 8),
|
|
child: SizedBox(
|
|
height: 24,
|
|
child: InkWell(
|
|
onTap: () {
|
|
widget.onItemClick(tempListData[index].name ?? "");
|
|
},
|
|
child: Text(
|
|
"${widget.isArabic ? tempListData[index].nameN : tempListData[index].name ?? ""}",
|
|
style: TextStyle(fontSize: 14, fontWeight: FontWeight.w600, color: Colors.black, letterSpacing: -0.96),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
})
|
|
],
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class LocationListWrapBody extends StatelessWidget {
|
|
final String? title;
|
|
|
|
final VoidCallback? onConfirmClicked;
|
|
final VoidCallback? onTextBoxClicked;
|
|
final String selectedText;
|
|
|
|
const LocationListWrapBody({super.key, this.onConfirmClicked, this.onTextBoxClicked, required this.selectedText, this.title});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Padding(
|
|
padding: const EdgeInsets.all(24.0),
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
SelectBranchHeader(title: title,),
|
|
SizedBox(
|
|
height: 24,
|
|
),
|
|
ListTile(
|
|
onTap: () {
|
|
onTextBoxClicked?.call();
|
|
},
|
|
title: Text(
|
|
title?? TranslationBase.of(context).selectBranch,
|
|
style: TextStyle(fontSize: 14, fontWeight: FontWeight.w600, color: Colors.black, letterSpacing: -0.96),
|
|
),
|
|
subtitle: selectedText.isEmpty
|
|
? null
|
|
: Text(
|
|
selectedText,
|
|
style: TextStyle(fontSize: 16, fontWeight: FontWeight.w400, color: Colors.black, letterSpacing: -0.96),
|
|
),
|
|
trailing: Icon(
|
|
Icons.arrow_drop_down_outlined,
|
|
color: Colors.black,
|
|
),
|
|
shape: RoundedRectangleBorder(
|
|
side: BorderSide(color: Colors.grey, width: 1),
|
|
borderRadius: BorderRadius.circular(8),
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 24,
|
|
),
|
|
Row(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
Expanded(
|
|
child: DefaultButton(
|
|
TranslationBase.of(context).confirm,
|
|
() {
|
|
Navigator.pop(context);
|
|
onConfirmClicked?.call();
|
|
},
|
|
color: CustomColors.accentColor,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class SelectBranchHeader extends StatelessWidget {
|
|
final String? title;
|
|
|
|
const SelectBranchHeader({super.key, required this.title});
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: [
|
|
Text(
|
|
title??TranslationBase.of(context).selectBranch,
|
|
style: TextStyle(fontSize: 24, fontWeight: FontWeight.w600, color: Colors.black, letterSpacing: -0.96),
|
|
),
|
|
InkWell(
|
|
onTap: () {
|
|
Navigator.of(context).pop();
|
|
},
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(4.0),
|
|
child: Icon(Icons.close),
|
|
))
|
|
],
|
|
);
|
|
}
|
|
}
|