|
|
|
@ -5,12 +5,15 @@ import 'package:test_sa/models/subtitle.dart';
|
|
|
|
|
import 'package:test_sa/views/app_style/sizing.dart';
|
|
|
|
|
import 'package:test_sa/views/widgets/buttons/app_button.dart';
|
|
|
|
|
import 'package:test_sa/views/widgets/buttons/app_small_button.dart';
|
|
|
|
|
import 'package:test_sa/views/widgets/equipment/device_button.dart';
|
|
|
|
|
|
|
|
|
|
import '../../../controllers/providers/api/hospitals_provider.dart';
|
|
|
|
|
import '../app_text_form_field.dart';
|
|
|
|
|
import '../date_and_time/date_picker.dart';
|
|
|
|
|
import '../status/report/service_report_visit_date_operator.dart';
|
|
|
|
|
import '../gas_refill/building_type_menu.dart';
|
|
|
|
|
import '../gas_refill/department_type_menu.dart';
|
|
|
|
|
import '../gas_refill/floor_type_menu.dart';
|
|
|
|
|
import '../hospitals/hospital_auto_complete_field.dart';
|
|
|
|
|
import '../switch_button.dart';
|
|
|
|
|
import '../titles/app_sub_title.dart';
|
|
|
|
|
|
|
|
|
|
class AssetTransferSearchDialog extends StatefulWidget {
|
|
|
|
|
final DeviceTransferSearch initialSearchValue;
|
|
|
|
@ -25,6 +28,7 @@ class AssetTransferSearchDialog extends StatefulWidget {
|
|
|
|
|
class AssetTransferSearchDialogState extends State<AssetTransferSearchDialog> with TickerProviderStateMixin {
|
|
|
|
|
DeviceTransferSearch _search;
|
|
|
|
|
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
|
|
|
|
|
bool _isLoading = false;
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
@ -36,165 +40,161 @@ class AssetTransferSearchDialogState extends State<AssetTransferSearchDialog> wi
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
Subtitle subtitle = AppLocalization.of(context).subtitle;
|
|
|
|
|
return SizedBox(
|
|
|
|
|
height: MediaQuery.of(context).size.height / 1.3,
|
|
|
|
|
child: Form(
|
|
|
|
|
key: _formKey,
|
|
|
|
|
child: ListView(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
|
|
|
|
|
children: [
|
|
|
|
|
Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
|
return Padding(
|
|
|
|
|
padding: EdgeInsets.only(bottom: MediaQuery.of(context).viewInsets.bottom),
|
|
|
|
|
child: ClipRRect(
|
|
|
|
|
borderRadius: const BorderRadius.only(topLeft: Radius.circular(15), topRight: Radius.circular(15)),
|
|
|
|
|
clipBehavior: Clip.antiAliasWithSaveLayer,
|
|
|
|
|
child: Container(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
height: MediaQuery.of(context).size.height / 1.3,
|
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: 8, vertical: 20),
|
|
|
|
|
child: Form(
|
|
|
|
|
key: _formKey,
|
|
|
|
|
child: ListView(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
|
|
|
|
|
children: [
|
|
|
|
|
ASmallButton(
|
|
|
|
|
text: subtitle.cancel,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
|
Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
|
children: [
|
|
|
|
|
ASmallButton(
|
|
|
|
|
text: subtitle.cancel,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
ASmallButton(
|
|
|
|
|
text: subtitle.search,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
ASwitchButton(
|
|
|
|
|
title: "Most Recent",
|
|
|
|
|
value: _search.mostRecent ?? false,
|
|
|
|
|
onChange: (value) {
|
|
|
|
|
_search.mostRecent = value;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
ASmallButton(
|
|
|
|
|
text: subtitle.search,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
SizedBox(height: 8.0 * AppStyle.getScaleFactor(context)),
|
|
|
|
|
DeviceButton(
|
|
|
|
|
device: _search.device,
|
|
|
|
|
onDevicePick: (device) {
|
|
|
|
|
_search.device = device;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(height: 8.0 * AppStyle.getScaleFactor(context)),
|
|
|
|
|
ATextFormField(
|
|
|
|
|
initialValue: _search.title,
|
|
|
|
|
hintText: subtitle.title,
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge,
|
|
|
|
|
textInputAction: TextInputAction.search,
|
|
|
|
|
onAction: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
ASwitchButton(
|
|
|
|
|
title: "Most Recent",
|
|
|
|
|
value: _search.mostRecent ?? false,
|
|
|
|
|
onChange: (value) {
|
|
|
|
|
_search.mostRecent = value;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(
|
|
|
|
|
height: 8.0 * AppStyle.getScaleFactor(context),
|
|
|
|
|
),
|
|
|
|
|
ATextFormField(
|
|
|
|
|
initialValue: _search.assetNumber,
|
|
|
|
|
hintText: subtitle.assetNumber,
|
|
|
|
|
style: Theme.of(context).textTheme.headline6,
|
|
|
|
|
textInputAction: TextInputAction.search,
|
|
|
|
|
onAction: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
_search.assetNumber = value;
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(
|
|
|
|
|
height: 8.0 * AppStyle.getScaleFactor(context),
|
|
|
|
|
),
|
|
|
|
|
ATextFormField(
|
|
|
|
|
initialValue: _search.assetName,
|
|
|
|
|
hintText: subtitle.assetName,
|
|
|
|
|
style: Theme.of(context).textTheme.headline6,
|
|
|
|
|
textInputAction: TextInputAction.search,
|
|
|
|
|
onAction: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
_search.site = value;
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(
|
|
|
|
|
height: 8.0 * AppStyle.getScaleFactor(context),
|
|
|
|
|
),
|
|
|
|
|
ATextFormField(
|
|
|
|
|
initialValue: _search.site,
|
|
|
|
|
hintText: subtitle.site,
|
|
|
|
|
style: Theme.of(context).textTheme.headline6,
|
|
|
|
|
textInputAction: TextInputAction.search,
|
|
|
|
|
onAction: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
_search.assetName = value;
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(
|
|
|
|
|
height: 8.0 * AppStyle.getScaleFactor(context),
|
|
|
|
|
),
|
|
|
|
|
const ASubTitle("Request Date"),
|
|
|
|
|
const SizedBox(height: 4),
|
|
|
|
|
ServiceReportVisitDateOperator(
|
|
|
|
|
initialValue: _search.dateOperator,
|
|
|
|
|
onSelect: (status) {
|
|
|
|
|
_search.dateOperator = status;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
Row(
|
|
|
|
|
children: [
|
|
|
|
|
Expanded(
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
|
|
|
children: [
|
|
|
|
|
if (_search?.dateOperator?.name?.toLowerCase()?.contains("between") ?? false) const ASubTitle("From"),
|
|
|
|
|
ADatePicker(
|
|
|
|
|
date: DateTime.tryParse(_search.from ?? ""),
|
|
|
|
|
from: DateTime(1950),
|
|
|
|
|
onDatePicker: (date) {
|
|
|
|
|
_search.from = date?.toIso8601String();
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
_search.title = value;
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
if (_search?.dateOperator?.name?.toLowerCase()?.contains("between") ?? false) const SizedBox(width: 16),
|
|
|
|
|
if (_search?.dateOperator?.name?.toLowerCase()?.contains("between") ?? false)
|
|
|
|
|
Expanded(
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
|
|
|
children: [
|
|
|
|
|
const ASubTitle("To"),
|
|
|
|
|
ADatePicker(
|
|
|
|
|
date: DateTime.tryParse(_search.to ?? ""),
|
|
|
|
|
from: DateTime(1950),
|
|
|
|
|
onDatePicker: (date) {
|
|
|
|
|
_search.to = date?.toIso8601String();
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
const SizedBox(width: 16),
|
|
|
|
|
Visibility(
|
|
|
|
|
visible: _search.toMap().isNotEmpty,
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
|
|
|
|
|
child: AButton(
|
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
|
text: subtitle.clearSearch,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
_search = DeviceTransferSearch();
|
|
|
|
|
SizedBox(height: 8.0 * AppStyle.getScaleFactor(context)),
|
|
|
|
|
HospitalAutoCompleteField(
|
|
|
|
|
initialValue: _search?.hospital?.name,
|
|
|
|
|
onSearch: (selected) async {
|
|
|
|
|
_search.building = null;
|
|
|
|
|
_search.floor = null;
|
|
|
|
|
_search.department = null;
|
|
|
|
|
_search.buildingsList = null;
|
|
|
|
|
_search.floorsList = null;
|
|
|
|
|
_search.departmentsList = null;
|
|
|
|
|
_isLoading = true;
|
|
|
|
|
setState(() {});
|
|
|
|
|
await HospitalsProvider().getHospitalsListByVal(searchVal: selected?.name ?? "").then((value) {
|
|
|
|
|
_search.hospital = value?.firstWhere((element) => element.name == selected.name, orElse: () => null);
|
|
|
|
|
_search.buildingsList = _search.hospital?.buildings;
|
|
|
|
|
});
|
|
|
|
|
_isLoading = false;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
const SizedBox(height: 8),
|
|
|
|
|
BuildingTypeMenu(
|
|
|
|
|
initialValue: _search?.building,
|
|
|
|
|
building: _search.buildingsList,
|
|
|
|
|
enabled: !_isLoading,
|
|
|
|
|
onSelect: (status) {
|
|
|
|
|
_search.building = status;
|
|
|
|
|
_search.floorsList = status?.floors;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
const SizedBox(height: 8),
|
|
|
|
|
FloorTypeMenu(
|
|
|
|
|
initialValue: _search?.floor,
|
|
|
|
|
floors: _search.floorsList,
|
|
|
|
|
enabled: !_isLoading,
|
|
|
|
|
onSelect: (status) {
|
|
|
|
|
_search.floor = status;
|
|
|
|
|
_search.departmentsList = _search.floor?.departments;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
const SizedBox(height: 8),
|
|
|
|
|
DepartmentTypeMenu(
|
|
|
|
|
initialValue: _search?.department,
|
|
|
|
|
departments: _search.departmentsList,
|
|
|
|
|
enabled: !_isLoading,
|
|
|
|
|
onSelect: (status) {
|
|
|
|
|
_search.department = status;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
SizedBox(height: 8.0 * AppStyle.getScaleFactor(context)),
|
|
|
|
|
ATextFormField(
|
|
|
|
|
initialValue: _search.room,
|
|
|
|
|
hintText: subtitle.room,
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge,
|
|
|
|
|
textInputAction: TextInputAction.search,
|
|
|
|
|
onAction: () {
|
|
|
|
|
if (!_formKey.currentState.validate()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
_formKey.currentState.save();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
_search.room = value;
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
SizedBox(height: 16.0 * AppStyle.getScaleFactor(context)),
|
|
|
|
|
Visibility(
|
|
|
|
|
visible: _search.toMap().isNotEmpty,
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
|
|
|
|
|
child: AButton(
|
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
|
text: subtitle.clearSearch,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
_search = DeviceTransferSearch();
|
|
|
|
|
Navigator.of(context).pop(_search);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|