|
|
|
@ -7,6 +7,7 @@ import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/widgets/shared/buttons/app_buttons_widget.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:hexcolor/hexcolor.dart';
|
|
|
|
|
|
|
|
|
|
import '../../../../core/viewModel/profile/pharmacy_intervention_view_model.dart';
|
|
|
|
|
import '../../../../models/patient/patiant_info_model.dart';
|
|
|
|
|
import '../../../base/base_view.dart';
|
|
|
|
@ -15,15 +16,18 @@ import 'intervention_medication.dart';
|
|
|
|
|
class PharmacyInterventionScreen extends StatefulWidget {
|
|
|
|
|
final OutPatientFilterType outPatientFilterType;
|
|
|
|
|
|
|
|
|
|
const PharmacyInterventionScreen(
|
|
|
|
|
{Key key, this.outPatientFilterType, })
|
|
|
|
|
: super(key: key);
|
|
|
|
|
const PharmacyInterventionScreen({
|
|
|
|
|
Key key,
|
|
|
|
|
this.outPatientFilterType,
|
|
|
|
|
}) : super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
_PharmacyInterventionScreenState createState() => _PharmacyInterventionScreenState();
|
|
|
|
|
_PharmacyInterventionScreenState createState() =>
|
|
|
|
|
_PharmacyInterventionScreenState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen> {
|
|
|
|
|
class _PharmacyInterventionScreenState
|
|
|
|
|
extends State<PharmacyInterventionScreen> {
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
// TODO: implement initState
|
|
|
|
@ -50,7 +54,7 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
title: (OutPatientFilterType.Previous ==
|
|
|
|
|
widget.outPatientFilterType)
|
|
|
|
|
? ""
|
|
|
|
|
: " New Medication",
|
|
|
|
|
: " Pharmacy Intervention",
|
|
|
|
|
),
|
|
|
|
|
SizedBox(
|
|
|
|
|
height: 10.0,
|
|
|
|
@ -63,17 +67,26 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
Container(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
child: InkWell(
|
|
|
|
|
onTap: () => selectDate(context,model,
|
|
|
|
|
firstDate:
|
|
|
|
|
getFirstDate(widget.outPatientFilterType),
|
|
|
|
|
lastDate:
|
|
|
|
|
getLastDate(widget.outPatientFilterType)),
|
|
|
|
|
onTap: () => selectDate(
|
|
|
|
|
context,
|
|
|
|
|
model,
|
|
|
|
|
firstDate: DateTime(
|
|
|
|
|
DateTime.now().year - 20,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day),
|
|
|
|
|
lastDate: DateTime(
|
|
|
|
|
DateTime.now().year,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day + 100),
|
|
|
|
|
selectedDate: DateTime(
|
|
|
|
|
DateTime.now().year,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day),
|
|
|
|
|
),
|
|
|
|
|
child: TextField(
|
|
|
|
|
decoration: textFieldSelectorDecoration(
|
|
|
|
|
TranslationBase.of(context).fromDate,
|
|
|
|
|
model
|
|
|
|
|
.selectedFromDate !=
|
|
|
|
|
null
|
|
|
|
|
model.selectedFromDate != null
|
|
|
|
|
? "${AppDateUtils.convertStringToDateFormat(model.selectedFromDate.toString(), "yyyy-MM-dd")}"
|
|
|
|
|
: null,
|
|
|
|
|
true,
|
|
|
|
@ -91,18 +104,27 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
Container(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
child: InkWell(
|
|
|
|
|
onTap: () => selectDate(context,model,
|
|
|
|
|
onTap: () => selectDate(
|
|
|
|
|
context,
|
|
|
|
|
model,
|
|
|
|
|
isFromDate: false,
|
|
|
|
|
firstDate:
|
|
|
|
|
getFirstDate(widget.outPatientFilterType),
|
|
|
|
|
lastDate:
|
|
|
|
|
getLastDate(widget.outPatientFilterType)),
|
|
|
|
|
firstDate: DateTime(
|
|
|
|
|
DateTime.now().year - 20,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day),
|
|
|
|
|
lastDate: DateTime(
|
|
|
|
|
DateTime.now().year,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day + 100),
|
|
|
|
|
selectedDate: DateTime(
|
|
|
|
|
DateTime.now().year,
|
|
|
|
|
DateTime.now().month,
|
|
|
|
|
DateTime.now().day),
|
|
|
|
|
),
|
|
|
|
|
child: TextField(
|
|
|
|
|
decoration: textFieldSelectorDecoration(
|
|
|
|
|
TranslationBase.of(context).toDate,
|
|
|
|
|
model
|
|
|
|
|
.selectedToDate !=
|
|
|
|
|
null
|
|
|
|
|
model.selectedToDate != null
|
|
|
|
|
? "${AppDateUtils.convertStringToDateFormat(model.selectedToDate.toString(), "yyyy-MM-dd")}"
|
|
|
|
|
: null,
|
|
|
|
|
true,
|
|
|
|
@ -147,13 +169,12 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
padding: 5,
|
|
|
|
|
color: Color(0xFF359846),
|
|
|
|
|
onPressed: () async {
|
|
|
|
|
|
|
|
|
|
Navigator.push(
|
|
|
|
|
context,
|
|
|
|
|
MaterialPageRoute(builder: (context) => InterventionMedicationScreen(patient)),
|
|
|
|
|
MaterialPageRoute(
|
|
|
|
|
builder: (context) =>
|
|
|
|
|
InterventionMedicationScreen(patient)),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
@ -164,16 +185,15 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
))
|
|
|
|
|
);
|
|
|
|
|
)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
selectDate(BuildContext context, PharmacyInterventionViewModel model,
|
|
|
|
|
{bool isFromDate = true, DateTime firstDate, lastDate}) async {
|
|
|
|
|
{bool isFromDate = true,
|
|
|
|
|
DateTime firstDate,
|
|
|
|
|
lastDate,
|
|
|
|
|
selectedDate}) async {
|
|
|
|
|
Helpers.hideKeyboard(context);
|
|
|
|
|
DateTime selectedDate = isFromDate
|
|
|
|
|
? model.selectedFromDate ?? firstDate
|
|
|
|
|
: model.selectedToDate ?? lastDate;
|
|
|
|
|
final DateTime picked = await showDatePicker(
|
|
|
|
|
context: context,
|
|
|
|
|
initialDate: selectedDate,
|
|
|
|
@ -199,25 +219,25 @@ class _PharmacyInterventionScreenState extends State<PharmacyInterventionScreen>
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getFirstDate(OutPatientFilterType outPatientFilterType) {
|
|
|
|
|
if (outPatientFilterType == OutPatientFilterType.Previous) {
|
|
|
|
|
return DateTime(
|
|
|
|
|
DateTime.now().year - 20, DateTime.now().month, DateTime.now().day);
|
|
|
|
|
} else {
|
|
|
|
|
return DateTime(
|
|
|
|
|
DateTime.now().year, DateTime.now().month, DateTime.now().day + 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// getFirstDate(OutPatientFilterType outPatientFilterType) {
|
|
|
|
|
// if (outPatientFilterType == OutPatientFilterType.Previous) {
|
|
|
|
|
// return DateTime(F
|
|
|
|
|
// DateTime.now().year - 20, DateTime.now().month, DateTime.now().day);
|
|
|
|
|
// } else {
|
|
|
|
|
// return DateTime(
|
|
|
|
|
// DateTime.now().year, DateTime.now().month, DateTime.now().day + 1);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
getLastDate(OutPatientFilterType outPatientFilterType) {
|
|
|
|
|
if (outPatientFilterType == OutPatientFilterType.Previous) {
|
|
|
|
|
return DateTime(
|
|
|
|
|
DateTime.now().year, DateTime.now().month, DateTime.now().day - 1);
|
|
|
|
|
} else {
|
|
|
|
|
return DateTime(
|
|
|
|
|
DateTime.now().year, DateTime.now().month, DateTime.now().day + 7);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// getLastDate(OutPatientFilterType outPatientFilterType) {
|
|
|
|
|
// if (outPatientFilterType == OutPatientFilterType.Previous) {
|
|
|
|
|
// return DateTime(
|
|
|
|
|
// DateTime.now().year, DateTime.now().month, DateTime.now().day - 1);
|
|
|
|
|
// } else {
|
|
|
|
|
// return DateTime(
|
|
|
|
|
// DateTime.now().year , DateTime.now().month , DateTime.now().day + 100);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
InputDecoration textFieldSelectorDecoration(
|
|
|
|
|
String hintText, String selectedText, bool isDropDown,
|
|
|
|
|