finish the nursing DiagnosisScreen
parent
72c948371a
commit
1a3567f917
@ -0,0 +1,32 @@
|
|||||||
|
class GetDiagnosisForInPatientRequestModel {
|
||||||
|
int patientID;
|
||||||
|
int admissionNo;
|
||||||
|
String setupID;
|
||||||
|
int patientType;
|
||||||
|
int patientTypeID;
|
||||||
|
|
||||||
|
GetDiagnosisForInPatientRequestModel(
|
||||||
|
{this.patientID,
|
||||||
|
this.admissionNo,
|
||||||
|
this.setupID,
|
||||||
|
this.patientType,
|
||||||
|
this.patientTypeID});
|
||||||
|
|
||||||
|
GetDiagnosisForInPatientRequestModel.fromJson(Map<String, dynamic> json) {
|
||||||
|
patientID = json['PatientID'];
|
||||||
|
admissionNo = json['AdmissionNo'];
|
||||||
|
setupID = json['SetupID'];
|
||||||
|
patientType = json['PatientType'];
|
||||||
|
patientTypeID = json['PatientTypeID'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
data['PatientID'] = this.patientID;
|
||||||
|
data['AdmissionNo'] = this.admissionNo;
|
||||||
|
data['SetupID'] = this.setupID;
|
||||||
|
data['PatientType'] = this.patientType;
|
||||||
|
data['PatientTypeID'] = this.patientTypeID;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,48 @@
|
|||||||
|
class GetDiagnosisForInPatientResponseModel {
|
||||||
|
String iCDCode10ID;
|
||||||
|
int diagnosisTypeID;
|
||||||
|
int conditionID;
|
||||||
|
bool complexDiagnosis;
|
||||||
|
String asciiDesc;
|
||||||
|
int createdBy;
|
||||||
|
String createdOn;
|
||||||
|
int editedBy;
|
||||||
|
String editedOn;
|
||||||
|
|
||||||
|
GetDiagnosisForInPatientResponseModel(
|
||||||
|
{this.iCDCode10ID,
|
||||||
|
this.diagnosisTypeID,
|
||||||
|
this.conditionID,
|
||||||
|
this.complexDiagnosis,
|
||||||
|
this.asciiDesc,
|
||||||
|
this.createdBy,
|
||||||
|
this.createdOn,
|
||||||
|
this.editedBy,
|
||||||
|
this.editedOn});
|
||||||
|
|
||||||
|
GetDiagnosisForInPatientResponseModel.fromJson(Map<String, dynamic> json) {
|
||||||
|
iCDCode10ID = json['ICDCode10ID'];
|
||||||
|
diagnosisTypeID = json['DiagnosisTypeID'];
|
||||||
|
conditionID = json['ConditionID'];
|
||||||
|
complexDiagnosis = json['ComplexDiagnosis'];
|
||||||
|
asciiDesc = json['Ascii_Desc'];
|
||||||
|
createdBy = json['CreatedBy'];
|
||||||
|
createdOn = json['CreatedOn'];
|
||||||
|
editedBy = json['EditedBy'];
|
||||||
|
editedOn = json['EditedOn'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
data['ICDCode10ID'] = this.iCDCode10ID;
|
||||||
|
data['DiagnosisTypeID'] = this.diagnosisTypeID;
|
||||||
|
data['ConditionID'] = this.conditionID;
|
||||||
|
data['ComplexDiagnosis'] = this.complexDiagnosis;
|
||||||
|
data['Ascii_Desc'] = this.asciiDesc;
|
||||||
|
data['CreatedBy'] = this.createdBy;
|
||||||
|
data['CreatedOn'] = this.createdOn;
|
||||||
|
data['EditedBy'] = this.editedBy;
|
||||||
|
data['EditedOn'] = this.editedOn;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,238 @@
|
|||||||
|
import 'package:doctor_app_flutter/config/shared_pref_kay.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/model/diagnosis/GetDiagnosisForInPatientRequestModel.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/model/note/GetNursingProgressNoteRequestModel.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/model/note/note_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/model/note/update_note_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/service/AnalyticsService.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/authentication_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/patient_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/project_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||||
|
import 'package:doctor_app_flutter/locator.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/patient/progress_note_request.dart';
|
||||||
|
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||||
|
import 'package:doctor_app_flutter/screens/patients/profile/notes/note/update_note.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/dr_app_shared_pref.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/add-order/addNewOrder.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/patient-profile-app-bar.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/card_with_bg_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/errors/dr_app_embedded_error.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/loader/gif_loader_dialog_utils.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
|
||||||
|
DrAppSharedPreferances sharedPref = new DrAppSharedPreferances();
|
||||||
|
|
||||||
|
class DiagnosisScreen extends StatefulWidget {
|
||||||
|
const DiagnosisScreen({Key key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_ProgressNoteState createState() => _ProgressNoteState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _ProgressNoteState extends State<DiagnosisScreen> {
|
||||||
|
bool isDischargedPatient = false;
|
||||||
|
AuthenticationViewModel authenticationViewModel;
|
||||||
|
ProjectViewModel projectViewModel;
|
||||||
|
|
||||||
|
getDiagnosisForInPatient(BuildContext context, PatientViewModel model,
|
||||||
|
{bool isLocalBusy = false}) async {
|
||||||
|
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||||
|
PatiantInformtion patient = routeArgs['patient'];
|
||||||
|
String type = await sharedPref.getString(SLECTED_PATIENT_TYPE);
|
||||||
|
|
||||||
|
print(type);
|
||||||
|
GetDiagnosisForInPatientRequestModel getDiagnosisForInPatientRequestModel =
|
||||||
|
GetDiagnosisForInPatientRequestModel(
|
||||||
|
admissionNo: int.parse(patient.admissionNo),
|
||||||
|
patientTypeID: patient.patientType,
|
||||||
|
patientID: patient.patientId, setupID: "010266");
|
||||||
|
model.getDiagnosisForInPatient(getDiagnosisForInPatientRequestModel);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
authenticationViewModel = Provider.of(context);
|
||||||
|
projectViewModel = Provider.of(context);
|
||||||
|
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||||
|
PatiantInformtion patient = routeArgs['patient'];
|
||||||
|
if (routeArgs.containsKey('isDischargedPatient'))
|
||||||
|
isDischargedPatient = routeArgs['isDischargedPatient'];
|
||||||
|
return BaseView<PatientViewModel>(
|
||||||
|
onModelReady: (model) => getDiagnosisForInPatient(context, model),
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
baseViewModel: model,
|
||||||
|
backgroundColor: Theme.of(context).scaffoldBackgroundColor,
|
||||||
|
appBar: PatientProfileAppBar(
|
||||||
|
patient,
|
||||||
|
isInpatient: true,
|
||||||
|
),
|
||||||
|
body: model.diagnosisForInPatientList == null ||
|
||||||
|
model.diagnosisForInPatientList.length == 0
|
||||||
|
? DrAppEmbeddedError(
|
||||||
|
error: TranslationBase.of(context).errorNoProgressNote)
|
||||||
|
: Container(
|
||||||
|
color: Colors.grey[200],
|
||||||
|
child: Column(
|
||||||
|
children: <Widget>[
|
||||||
|
Expanded(
|
||||||
|
child: Container(
|
||||||
|
child: ListView.builder(
|
||||||
|
itemCount:
|
||||||
|
model.diagnosisForInPatientList.length,
|
||||||
|
itemBuilder: (BuildContext ctxt, int index) {
|
||||||
|
return FractionallySizedBox(
|
||||||
|
widthFactor: 0.95,
|
||||||
|
child: CardWithBgWidget(
|
||||||
|
hasBorder: false,
|
||||||
|
bgColor: Colors.black38,
|
||||||
|
widget: Column(
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
width: MediaQuery.of(context)
|
||||||
|
.size
|
||||||
|
.width *
|
||||||
|
0.60,
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
TranslationBase.of(
|
||||||
|
context)
|
||||||
|
.createdBy,
|
||||||
|
fontSize: 10,
|
||||||
|
),
|
||||||
|
Expanded(
|
||||||
|
child: AppText(
|
||||||
|
model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.createdBy
|
||||||
|
.toString() ??
|
||||||
|
'',
|
||||||
|
fontWeight:
|
||||||
|
FontWeight.w600,
|
||||||
|
fontSize: 12,
|
||||||
|
isCopyable: true,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.createdOn !=
|
||||||
|
null
|
||||||
|
? AppDateUtils.getDayMonthYearDateFormatted(
|
||||||
|
AppDateUtils
|
||||||
|
.getDateTimeFromServerFormat(model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.createdOn),
|
||||||
|
isArabic:
|
||||||
|
projectViewModel
|
||||||
|
.isArabic,
|
||||||
|
isMonthShort: true)
|
||||||
|
: AppDateUtils
|
||||||
|
.getDayMonthYearDateFormatted(
|
||||||
|
DateTime.now(),
|
||||||
|
isArabic:
|
||||||
|
projectViewModel
|
||||||
|
.isArabic),
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
fontSize: 14,
|
||||||
|
isCopyable: true,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.createdOn !=
|
||||||
|
null
|
||||||
|
? AppDateUtils.getHour(
|
||||||
|
AppDateUtils
|
||||||
|
.getDateTimeFromServerFormat(model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.createdOn))
|
||||||
|
: AppDateUtils.getHour(
|
||||||
|
DateTime.now()),
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
fontSize: 14,
|
||||||
|
isCopyable: true,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.end,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 8,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Expanded(
|
||||||
|
child: AppText(
|
||||||
|
model
|
||||||
|
.diagnosisForInPatientList[
|
||||||
|
index]
|
||||||
|
.iCDCode10ID,
|
||||||
|
fontSize: 10,
|
||||||
|
isCopyable: true,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
])
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue