Merge branch 'pharmacy_redesign' into 'development'

Pharmacy redesign

See merge request Cloud_Solution/doctor_app_flutter!963
merge-requests/964/merge
Elham Ali 4 years ago
commit b22023cdbc

@ -84,8 +84,8 @@ const Map<String, Map<String, String>> localizedValues = {
"ar": "المريض الذي حضر للموعد" "ar": "المريض الذي حضر للموعد"
}, },
"searchMedicineNameHere": {"en": "Search Medicine ", "ar": "ابحث هنا"}, "searchMedicineNameHere": {"en": "Search Medicine ", "ar": "ابحث هنا"},
"youCanFind": {"en": "You Can Find ", "ar": "تستطيع ان تجد "}, "youCanFind": {"en": "You can find ", "ar": "تستطيع ان تجد "},
"itemsInSearch": {"en": "items in search", "ar": "عناصر في البحث"}, "medicineSearchResult": {"en": "as a search result for", "ar": "كنتيجة بحث عن"},
"qr": {"en": "QR", "ar": "QR"}, "qr": {"en": "QR", "ar": "QR"},
"reader": {"en": "Reader", "ar": "قارىء رمز ال"}, "reader": {"en": "Reader", "ar": "قارىء رمز ال"},
"startScanning": {"en": "Start Scanning", "ar": "بدء المسح"}, "startScanning": {"en": "Start Scanning", "ar": "بدء المسح"},

@ -1,12 +1,14 @@
import 'dart:math'; import 'dart:math';
import 'package:autocomplete_textfield/autocomplete_textfield.dart'; import 'package:autocomplete_textfield/autocomplete_textfield.dart';
import 'package:doctor_app_flutter/config/config.dart';
import 'package:doctor_app_flutter/config/size_config.dart'; import 'package:doctor_app_flutter/config/size_config.dart';
import 'package:doctor_app_flutter/core/model/search_drug/get_medication_response_model.dart'; import 'package:doctor_app_flutter/core/model/search_drug/get_medication_response_model.dart';
import 'package:doctor_app_flutter/core/viewModel/medicine_view_model.dart'; import 'package:doctor_app_flutter/core/viewModel/medicine_view_model.dart';
import 'package:doctor_app_flutter/screens/base/base_view.dart'; import 'package:doctor_app_flutter/screens/base/base_view.dart';
import 'package:doctor_app_flutter/screens/medicine/pharmacies_list_screen.dart'; import 'package:doctor_app_flutter/screens/medicine/pharmacies_list_screen.dart';
import 'package:doctor_app_flutter/screens/patients/patient_search/patient_search_header.dart'; import 'package:doctor_app_flutter/screens/patients/patient_search/patient_search_header.dart';
import 'package:doctor_app_flutter/screens/patients/profile/soap_update/shared_soap_widgets/bottom_sheet_title.dart';
import 'package:doctor_app_flutter/util/dr_app_shared_pref.dart'; import 'package:doctor_app_flutter/util/dr_app_shared_pref.dart';
import 'package:doctor_app_flutter/util/dr_app_toast_msg.dart'; import 'package:doctor_app_flutter/util/dr_app_toast_msg.dart';
import 'package:doctor_app_flutter/util/helpers.dart'; import 'package:doctor_app_flutter/util/helpers.dart';
@ -18,6 +20,7 @@ import 'package:doctor_app_flutter/widgets/shared/buttons/app_buttons_widget.dar
import 'package:doctor_app_flutter/widgets/shared/loader/gif_loader_dialog_utils.dart'; import 'package:doctor_app_flutter/widgets/shared/loader/gif_loader_dialog_utils.dart';
import 'package:doctor_app_flutter/widgets/shared/text_fields/app_text_field_custom_serach.dart'; import 'package:doctor_app_flutter/widgets/shared/text_fields/app_text_field_custom_serach.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:hexcolor/hexcolor.dart';
import 'package:permission_handler/permission_handler.dart'; import 'package:permission_handler/permission_handler.dart';
import 'package:speech_to_text/speech_recognition_error.dart'; import 'package:speech_to_text/speech_recognition_error.dart';
import 'package:speech_to_text/speech_recognition_result.dart'; import 'package:speech_to_text/speech_recognition_result.dart';
@ -87,152 +90,140 @@ class _MedicineSearchState extends State<MedicineSearchScreen> {
}); });
} }
InputDecoration textFieldSelectorDecoration(
String hintText, String selectedText, bool isDropDown,
{IconData icon}) {
return InputDecoration(
focusedBorder: OutlineInputBorder(
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
borderRadius: BorderRadius.circular(8),
),
enabledBorder: OutlineInputBorder(
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
borderRadius: BorderRadius.circular(8),
),
disabledBorder: OutlineInputBorder(
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
borderRadius: BorderRadius.circular(8),
),
hintText: selectedText != null ? selectedText : hintText,
suffixIcon: isDropDown ? Icon(icon ?? Icons.arrow_drop_down) : null,
hintStyle: TextStyle(
fontSize: 14,
color: Colors.grey.shade600,
),
);
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return BaseView<MedicineViewModel>(onModelReady: (model) async { return BaseView<MedicineViewModel>(onModelReady: (model) async {
// if (model.allMedicationList.length == 0)
// await model.getMedicationList();
}, builder: (_, model, w) { }, builder: (_, model, w) {
myController.text = model.searchText; myController.text = model.searchText;
return AppScaffold( return AppScaffold(
// baseViewModel: model, // baseViewModel: model,
isShowAppBar: true, isShowAppBar: true,
appBar: PatientSearchHeader( appBar: BottomSheetTitle(
title: TranslationBase.of(context).searchMedicine, title: TranslationBase.of(context).searchMedicine,
), ),
//appBarTitle: TranslationBase.of(context).searchMedicine + "6", //appBarTitle: TranslationBase.of(context).searchMedicine + "6",
body: SingleChildScrollView( body: SingleChildScrollView(
child: FractionallySizedBox( child: Column(
widthFactor: 0.97, mainAxisAlignment: MainAxisAlignment.start,
child: SingleChildScrollView( children: <Widget>[
child: Container( SizedBox(
// height: SizeConfig.screenHeight, height: 20,
child: Column( ),
mainAxisAlignment: MainAxisAlignment.start, AppTextFieldCustomSearch(
children: <Widget>[ hintText:
SizedBox( TranslationBase.of(context).searchMedicineNameHere,
height: 20, searchController: myController,
), onFieldSubmitted: (value) {
FractionallySizedBox( searchMedicine(context, model);
widthFactor: 0.9, },
child: AppTextFieldCustomSearch( marginTop: 5,
hintText: ),
TranslationBase.of(context).searchMedicineNameHere, Container(
searchController: myController, margin: EdgeInsets.only(left: 16, right: 16, bottom: 16, top: 0),
onFieldSubmitted: (value) {
searchMedicine(context, model); child: Row(
}, crossAxisAlignment: CrossAxisAlignment.start,
marginTop: 5, children: <Widget>[
), Expanded(
), child: AppText(
SizedBox(
height: 20,
),
FractionallySizedBox(
widthFactor: 0.9,
child: Container(
child: Wrap(
alignment: WrapAlignment.center,
children: <Widget>[
// TODO change it secondary button and add loading
AppButton(
title: TranslationBase.of(context).search,
onPressed: () async {
await searchMedicine(context, model);
},
),
],
),
),
),
Container(
margin:
EdgeInsets.only(left: SizeConfig.heightMultiplier * 2),
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
AppText(
TranslationBase.of(context).youCanFind + TranslationBase.of(context).youCanFind +
(myController.text != '' (myController.text != ''
? model.pharmacyItemsList.length.toString() ? model.pharmacyItemsList.length.toString()
: '0') + : '0') +
" " + " " +
TranslationBase.of(context).itemsInSearch, TranslationBase.of(context).medicineSearchResult +" '${myController.text}'",
fontWeight: FontWeight.bold, fontHeight: 1.4,
color: AppGlobal.appTextColor,
textAlign: TextAlign.start,
fontWeight: FontWeight.w600,
letterSpacing: -0.9,
), ),
], ),
), ],
), ),
SizedBox( ),
height: 10, SizedBox(
height: 5,
),
if (myController.text != '')
Container(
margin: EdgeInsets.only(left: 16, right: 16, bottom: 16, top: 0),
height: MediaQuery.of(context).size.height * 0.6,
child: ListView.builder(
padding: const EdgeInsets.only(top: 20),
scrollDirection: Axis.vertical,
// shrinkWrap: true,
itemCount: model.pharmacyItemsList == null
? 0
: model.pharmacyItemsList.length,
itemBuilder: (BuildContext context, int index) {
return InkWell(
child: MedicineItemWidget(
label: model.pharmacyItemsList[index]
["ItemDescription"],
url: model.pharmacyItemsList[index]
["ImageSRCUrl"],
),
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PharmaciesListScreen(
itemID: model.pharmacyItemsList[index]
["ItemID"],
url: model.pharmacyItemsList[index]
["ImageSRCUrl"]),
settings: RouteSettings(
name: 'PharmaciesListScreen'),
),
);
},
);
},
),
), ),
if (myController.text != '') ],
Container( )),
height: MediaQuery.of(context).size.height * 0.6, bottomSheet: Container(
child: ListView.builder( decoration: BoxDecoration(
padding: const EdgeInsets.only(top: 20), color: Colors.white,
borderRadius: BorderRadius.all(
Radius.circular(0.0),
),
border: Border.all(color: HexColor('#707070'), width: 0),
),
height: MediaQuery.of(context).size.height * 0.1,
width: double.infinity,
child: Column(
children: [
SizedBox(
height: 10,
),
Container(
child: FractionallySizedBox(
widthFactor: .80,
child: Center(
child: AppButton(
fontWeight: FontWeight.w700,
title: TranslationBase.of(context).search,
onPressed: () async {
// onSubmitSearch();
await searchMedicine(context, model);
scrollDirection: Axis.vertical, },
// shrinkWrap: true, color: AppGlobal.appRedColor,
itemCount: model.pharmacyItemsList == null
? 0
: model.pharmacyItemsList.length,
itemBuilder: (BuildContext context, int index) {
return InkWell(
child: MedicineItemWidget(
label: model.pharmacyItemsList[index]
["ItemDescription"],
url: model.pharmacyItemsList[index]
["ImageSRCUrl"],
),
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => PharmaciesListScreen(
itemID: model.pharmacyItemsList[index]
["ItemID"],
url: model.pharmacyItemsList[index]
["ImageSRCUrl"]),
settings: RouteSettings(
name: 'PharmaciesListScreen'),
),
);
},
);
},
),
), ),
], ),
),
), ),
)), SizedBox(
height: 5,
),
],
), ),
), ),
); );
}); });
} }

@ -117,7 +117,7 @@ class _PatientSearchScreenState extends State<PatientSearchScreen> {
onPressed: () { onPressed: () {
onSubmitSearch(); onSubmitSearch();
}, },
color: Colors.red[800], color: AppGlobal.appRedColor,
), ),
), ),
), ),

@ -100,7 +100,7 @@ class _ReferredPatientScreenState extends State<ReferredPatientScreen> {
), ),
isMonthShort: true isMonthShort: true
), ),
referredTime:AppDateUtils.getHour( referredTime:model.state == ViewState.BusyLocal ?"":AppDateUtils.getHour(
patientType == PatientType.IN_PATIENT? patientType == PatientType.IN_PATIENT?
AppDateUtils.getDateTimeFromServerFormat( AppDateUtils.getDateTimeFromServerFormat(
model.getReferredPatientItem(index).referralDate, model.getReferredPatientItem(index).referralDate,

@ -179,8 +179,8 @@ class TranslationBase {
String get youCanFind => localizedValues['youCanFind'][locale.languageCode]; String get youCanFind => localizedValues['youCanFind'][locale.languageCode];
String get itemsInSearch => String get medicineSearchResult =>
localizedValues['itemsInSearch'][locale.languageCode]; localizedValues['medicineSearchResult'][locale.languageCode];
String get qr => localizedValues['qr'][locale.languageCode]; String get qr => localizedValues['qr'][locale.languageCode];

@ -1,34 +1,33 @@
import 'dart:convert'; import 'dart:convert';
import 'dart:typed_data'; import 'dart:typed_data';
import 'package:doctor_app_flutter/config/config.dart';
import 'package:doctor_app_flutter/config/size_config.dart'; import 'package:doctor_app_flutter/config/size_config.dart';
import 'package:doctor_app_flutter/util/helpers.dart';
import 'package:doctor_app_flutter/widgets/shared/card_with_bg_widget.dart';
import 'package:eva_icons_flutter/eva_icons_flutter.dart'; import 'package:eva_icons_flutter/eva_icons_flutter.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import '../shared/app_texts_widget.dart'; import '../shared/app_texts_widget.dart';
import '../shared/rounded_container_widget.dart'; import '../shared/rounded_container_widget.dart';
/*
*@author: ibrahim albitar
*@Date:28/4/2020
*@param:
*@return:
*@desc:
*/
class MedicineItemWidget extends StatefulWidget { class MedicineItemWidget extends StatefulWidget {
final String label; final String label;
final Color backgroundColor; final Color backgroundColor;
final bool showBorder; final bool showBorder;
final bool showArrow;
final bool showPrice;
final Color borderColor; final Color borderColor;
final String url; final String url;
final String price;
MedicineItemWidget( MedicineItemWidget(
{@required this.label, {@required this.label,
this.backgroundColor = Colors.white, this.backgroundColor = Colors.white,
this.showBorder = false, this.showBorder = true,
this.borderColor = Colors.white, this.borderColor = Colors.white,
this.url}); this.url,
this.showArrow = true, this.showPrice = false, this.price});
@override @override
_MedicineItemWidgetState createState() => _MedicineItemWidgetState(); _MedicineItemWidgetState createState() => _MedicineItemWidgetState();
@ -37,43 +36,72 @@ class MedicineItemWidget extends StatefulWidget {
class _MedicineItemWidgetState extends State<MedicineItemWidget> { class _MedicineItemWidgetState extends State<MedicineItemWidget> {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return new RoundedContainer( return CardWithBgWidget(
height: SizeConfig.heightMultiplier * 8, // height: SizeConfig.heightMultiplier * 12.9,
child: Padding( bgColor: Colors.transparent,
padding: const EdgeInsets.all(5.0), hasBorder: false,
widget: Padding(
padding: const EdgeInsets.symmetric(
vertical: 4,
),
child: Row( child: Row(
crossAxisAlignment: CrossAxisAlignment.stretch,
mainAxisAlignment: MainAxisAlignment.start, mainAxisAlignment: MainAxisAlignment.start,
children: <Widget>[ children: <Widget>[
if (widget.url != null) if (widget.url != null)
Container( ClipRRect(
height: 39, borderRadius: BorderRadius.circular(20.0),
width: 39,
child: ClipRRect(
borderRadius: BorderRadius.all(Radius.circular(7)),
child: Image.network( child: Image.network(
widget.url, widget.url,
height: SizeConfig.imageSizeMultiplier * 15, height: 25,
width: SizeConfig.imageSizeMultiplier * 15, width: 30,
fit: BoxFit.cover, errorBuilder: (BuildContext context, Object exception,
StackTrace stackTrace) {
return Text('');
},
)),
Expanded(
child: Center(
child: Padding(
padding: EdgeInsets.all(2.5),
child: Align(
alignment: Alignment.centerLeft,
child: Column(
crossAxisAlignment:CrossAxisAlignment.start,
children: [
AppText(
Helpers.convertToTitleCase(widget.label ?? ''),
fontHeight: 1.4,
color: AppGlobal.appTextColor,
textAlign: TextAlign.start,
fontWeight: FontWeight.w600,
letterSpacing: -0.33,
),
if(widget.showPrice)
AppText(
Helpers.convertToTitleCase(widget.price ?? ''),
fontHeight: 1.4,
color: AppGlobal.appTextColor,
textAlign: TextAlign.start,
fontWeight: FontWeight.w600,
letterSpacing: -0.33,
),
],
),
), ),
), ),
), ),
Expanded( ),
child: Padding( if(widget.showArrow)
padding: EdgeInsets.all(5), Icon(EvaIcons.arrowForward)
child: Align(
alignment: Alignment.centerLeft,
child: AppText(widget.label)))),
Icon(EvaIcons.eye)
], ],
), ),
), ),
backgroundColor: widget.backgroundColor, // backgroundColor: widget.backgroundColor,
showBorder: widget.showBorder, // showBorder: widget.showBorder,
borderColor: widget.borderColor, // borderColor: widget.borderColor,
margin: EdgeInsets.all(4), // // margin: 4.0,
raduis: 10, // // margin: EdgeInsets.all(4),
// raduis: 10,
); );
} }

@ -160,7 +160,7 @@ class PatientReferralItemWidget extends StatelessWidget {
? TranslationBase.of(context).sameBranch ? TranslationBase.of(context).sameBranch
: TranslationBase.of(context) : TranslationBase.of(context)
.otherBranch .otherBranch
: " " + referralClinic, : " " + Helpers.convertToTitleCase(referralClinic ?? ""),
), ),
], ],
), ),
@ -252,7 +252,7 @@ class PatientReferralItemWidget extends StatelessWidget {
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: [ children: [
AppText( AppText(
referralDoctorName ?? "", Helpers.convertToTitleCase(referralDoctorName ?? ""),
fontFamily: 'Poppins', fontFamily: 'Poppins',
fontWeight: FontWeight.w600, fontWeight: FontWeight.w600,
fontSize: 14.0, fontSize: 14.0,
@ -261,7 +261,8 @@ class PatientReferralItemWidget extends StatelessWidget {
), ),
if (clinicDescription != null) if (clinicDescription != null)
AppText( AppText(
clinicDescription, Helpers.convertToTitleCase(clinicDescription ?? "")
,
fontFamily: 'Poppins', fontFamily: 'Poppins',
fontWeight: FontWeight.w600, fontWeight: FontWeight.w600,
fontSize: 10.0, fontSize: 10.0,

@ -49,7 +49,8 @@ class AppScaffold extends StatelessWidget {
FocusScope.of(context).requestFocus(new FocusNode()); FocusScope.of(context).requestFocus(new FocusNode());
}, },
child: Scaffold( child: Scaffold(
backgroundColor: backgroundColor ?? Colors.white, backgroundColor: backgroundColor ?? Theme.of(context).scaffoldBackgroundColor
,
drawer: drawer, drawer: drawer,
extendBody: extendBody, extendBody: extendBody,
bottomNavigationBar: bottomNavigationBar, bottomNavigationBar: bottomNavigationBar,

Loading…
Cancel
Save