Search Sub Work Order Screen DONE
parent
33758f4cfd
commit
27d3a74d3b
@ -0,0 +1,7 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="50.481" height="50.488" viewBox="0 0 50.481 50.488">
|
||||||
|
<g id="research_1_" data-name="research (1)" transform="translate(-2 -2)">
|
||||||
|
<path id="Path_4616" data-name="Path 4616" d="M9.2,15H3.8A1.8,1.8,0,0,0,2,16.8V31.226a1.8,1.8,0,0,0,1.8,1.8H18.226a1.8,1.8,0,0,0,1.8-1.8v-.937a16.379,16.379,0,0,1-6.094-3.858A16.215,16.215,0,0,1,9.2,15Z" transform="translate(0 10.437)" fill="#5bb0d9"/>
|
||||||
|
<path id="Path_4617" data-name="Path 4617" d="M3.8,20.028h6.292a15.865,15.865,0,0,1,3.84-6.094,16.379,16.379,0,0,1,6.094-3.856V3.8a1.8,1.8,0,0,0-1.8-1.8H3.8A1.8,1.8,0,0,0,2,3.8V18.226a1.8,1.8,0,0,0,1.8,1.8ZM7.03,9.41a1.785,1.785,0,0,1,2.56,0l.739.739,2.109-2.091A1.8,1.8,0,0,1,15,10.6l-3.389,3.371a1.763,1.763,0,0,1-2.542,0L7.03,11.952a1.8,1.8,0,0,1,0-2.54Z" fill="#5bb0d9"/>
|
||||||
|
<path id="Path_4618" data-name="Path 4618" d="M46.922,39.274a1.945,1.945,0,0,0-.22-.193L37.78,32.706a1.8,1.8,0,0,0-2.322.193L32.82,30.262a14.452,14.452,0,1,0-2.558,2.558L32.9,35.458a1.8,1.8,0,0,0-.193,2.322L39.081,46.7a1.785,1.785,0,0,0,.193.227,5.408,5.408,0,1,0,7.648-7.648Zm-33.145-10.2a10.817,10.817,0,1,1,7.648,3.168,10.817,10.817,0,0,1-7.648-3.168Z" transform="translate(3.975 3.975)" fill="#5bb0d9"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.2 KiB |
@ -0,0 +1,75 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:http/http.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/api_manager.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/urls.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
|
||||||
|
class ServiceReportMaintenanceSituationProvider extends ChangeNotifier {
|
||||||
|
//reset provider data
|
||||||
|
void reset() {
|
||||||
|
_calls = null;
|
||||||
|
_loading = null;
|
||||||
|
_stateCode = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// state code of current request to defied error message
|
||||||
|
// like 400 customer request failed
|
||||||
|
// 500 service not available
|
||||||
|
int _stateCode;
|
||||||
|
int get stateCode => _stateCode;
|
||||||
|
|
||||||
|
// contain user data
|
||||||
|
// when user not login or register _user = null
|
||||||
|
List<Lookup> _calls;
|
||||||
|
List<Lookup> get operators => _calls;
|
||||||
|
|
||||||
|
// when categories in-process _loading = true
|
||||||
|
// done _loading = true
|
||||||
|
// failed _loading = false
|
||||||
|
bool _loading;
|
||||||
|
bool get isLoading => _loading;
|
||||||
|
set isLoading(bool isLoading) {
|
||||||
|
_loading = isLoading;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// return -2 if request in progress
|
||||||
|
/// return -1 if error happen when sending request
|
||||||
|
/// return state code if request complete may be 200, 404 or 403
|
||||||
|
/// for more details check http state manager
|
||||||
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
||||||
|
Future<int> getOperators() async {
|
||||||
|
if (_loading == true) return -2;
|
||||||
|
_loading = true;
|
||||||
|
notifyListeners();
|
||||||
|
Response response;
|
||||||
|
try {
|
||||||
|
response = await ApiManager.instance.get(
|
||||||
|
"${URLs.getMaintenanceSituation}",
|
||||||
|
);
|
||||||
|
// response = await get(
|
||||||
|
// Uri.parse(
|
||||||
|
// URLs.getServiceReportLastCalls
|
||||||
|
// +(serviceStatus == null ? "" : "?service_status=$serviceStatus")
|
||||||
|
// ),
|
||||||
|
// );
|
||||||
|
_stateCode = response.statusCode;
|
||||||
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
||||||
|
// client's request was successfully received
|
||||||
|
List categoriesListJson = json.decode(response.body)["data"];
|
||||||
|
_calls = categoriesListJson.map((type) => Lookup.fromJson(type)).toList();
|
||||||
|
}
|
||||||
|
_loading = false;
|
||||||
|
notifyListeners();
|
||||||
|
return response.statusCode;
|
||||||
|
} catch (error) {
|
||||||
|
_loading = false;
|
||||||
|
_stateCode = -1;
|
||||||
|
notifyListeners();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,75 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:http/http.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/api_manager.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/urls.dart';
|
||||||
|
import 'package:test_sa/models/engineer.dart';
|
||||||
|
|
||||||
|
class ServiceReportUsersProvider extends ChangeNotifier {
|
||||||
|
//reset provider data
|
||||||
|
void reset() {
|
||||||
|
_calls = null;
|
||||||
|
_loading = null;
|
||||||
|
_stateCode = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// state code of current request to defied error message
|
||||||
|
// like 400 customer request failed
|
||||||
|
// 500 service not available
|
||||||
|
int _stateCode;
|
||||||
|
int get stateCode => _stateCode;
|
||||||
|
|
||||||
|
// contain user data
|
||||||
|
// when user not login or register _user = null
|
||||||
|
List<Engineer> _calls;
|
||||||
|
List<Engineer> get users => _calls;
|
||||||
|
|
||||||
|
// when categories in-process _loading = true
|
||||||
|
// done _loading = true
|
||||||
|
// failed _loading = false
|
||||||
|
bool _loading;
|
||||||
|
bool get isLoading => _loading;
|
||||||
|
set isLoading(bool isLoading) {
|
||||||
|
_loading = isLoading;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// return -2 if request in progress
|
||||||
|
/// return -1 if error happen when sending request
|
||||||
|
/// return state code if request complete may be 200, 404 or 403
|
||||||
|
/// for more details check http state manager
|
||||||
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
||||||
|
Future<int> getAllUsers() async {
|
||||||
|
if (_loading == true) return -2;
|
||||||
|
_loading = true;
|
||||||
|
notifyListeners();
|
||||||
|
Response response;
|
||||||
|
try {
|
||||||
|
response = await ApiManager.instance.get(
|
||||||
|
"${URLs.getAllUsers}",
|
||||||
|
);
|
||||||
|
// response = await get(
|
||||||
|
// Uri.parse(
|
||||||
|
// URLs.getServiceReportLastCalls
|
||||||
|
// +(serviceStatus == null ? "" : "?service_status=$serviceStatus")
|
||||||
|
// ),
|
||||||
|
// );
|
||||||
|
_stateCode = response.statusCode;
|
||||||
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
||||||
|
// client's request was successfully received
|
||||||
|
List usersListJson = json.decode(response.body);
|
||||||
|
_calls = usersListJson.map((type) => Engineer.fromJson(type)).toList();
|
||||||
|
}
|
||||||
|
_loading = false;
|
||||||
|
notifyListeners();
|
||||||
|
return response.statusCode;
|
||||||
|
} catch (error) {
|
||||||
|
_loading = false;
|
||||||
|
_stateCode = -1;
|
||||||
|
notifyListeners();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,75 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:http/http.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/api_manager.dart';
|
||||||
|
import 'package:test_sa/controllers/api_routes/urls.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
|
||||||
|
class ServiceReportVisitOperatorProvider extends ChangeNotifier {
|
||||||
|
//reset provider data
|
||||||
|
void reset() {
|
||||||
|
_calls = null;
|
||||||
|
_loading = null;
|
||||||
|
_stateCode = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// state code of current request to defied error message
|
||||||
|
// like 400 customer request failed
|
||||||
|
// 500 service not available
|
||||||
|
int _stateCode;
|
||||||
|
int get stateCode => _stateCode;
|
||||||
|
|
||||||
|
// contain user data
|
||||||
|
// when user not login or register _user = null
|
||||||
|
List<Lookup> _calls;
|
||||||
|
List<Lookup> get operators => _calls;
|
||||||
|
|
||||||
|
// when categories in-process _loading = true
|
||||||
|
// done _loading = true
|
||||||
|
// failed _loading = false
|
||||||
|
bool _loading;
|
||||||
|
bool get isLoading => _loading;
|
||||||
|
set isLoading(bool isLoading) {
|
||||||
|
_loading = isLoading;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// return -2 if request in progress
|
||||||
|
/// return -1 if error happen when sending request
|
||||||
|
/// return state code if request complete may be 200, 404 or 403
|
||||||
|
/// for more details check http state manager
|
||||||
|
/// lib\controllers\http_status_manger\http_status_manger.dart
|
||||||
|
Future<int> getOperators() async {
|
||||||
|
if (_loading == true) return -2;
|
||||||
|
_loading = true;
|
||||||
|
notifyListeners();
|
||||||
|
Response response;
|
||||||
|
try {
|
||||||
|
response = await ApiManager.instance.get(
|
||||||
|
"${URLs.getDateOperators}",
|
||||||
|
);
|
||||||
|
// response = await get(
|
||||||
|
// Uri.parse(
|
||||||
|
// URLs.getServiceReportLastCalls
|
||||||
|
// +(serviceStatus == null ? "" : "?service_status=$serviceStatus")
|
||||||
|
// ),
|
||||||
|
// );
|
||||||
|
_stateCode = response.statusCode;
|
||||||
|
if (response.statusCode >= 200 && response.statusCode < 300) {
|
||||||
|
// client's request was successfully received
|
||||||
|
List categoriesListJson = json.decode(response.body)["data"];
|
||||||
|
_calls = categoriesListJson.map((type) => Lookup.fromJson(type)).toList();
|
||||||
|
}
|
||||||
|
_loading = false;
|
||||||
|
notifyListeners();
|
||||||
|
return response.statusCode;
|
||||||
|
} catch (error) {
|
||||||
|
_loading = false;
|
||||||
|
_stateCode = -1;
|
||||||
|
notifyListeners();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,207 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:fluttertoast/fluttertoast.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/service_requests_provider.dart';
|
||||||
|
import 'package:test_sa/models/engineer.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
import 'package:test_sa/models/service_request/search_work_order.dart';
|
||||||
|
import 'package:test_sa/models/subtitle.dart';
|
||||||
|
import 'package:test_sa/views/widgets/app_text_form_field.dart';
|
||||||
|
import 'package:test_sa/views/widgets/date_and_time/date_picker.dart';
|
||||||
|
|
||||||
|
import '../../../controllers/api_routes/http_status_manger.dart';
|
||||||
|
import '../../../controllers/localization/localization.dart';
|
||||||
|
import '../../app_style/colors.dart';
|
||||||
|
import '../../widgets/buttons/app_back_button.dart';
|
||||||
|
import '../../widgets/buttons/app_button.dart';
|
||||||
|
import '../../widgets/loaders/app_loading.dart';
|
||||||
|
import '../../widgets/status/report/service_report_all_users.dart';
|
||||||
|
import '../../widgets/status/report/service_report_maintenance_situation.dart';
|
||||||
|
import '../../widgets/status/report/service_report_visit_date_operator.dart';
|
||||||
|
import '../../widgets/titles/app_sub_title.dart';
|
||||||
|
|
||||||
|
class SubWorkOrderPage extends StatefulWidget {
|
||||||
|
static String id = "/SubWorkOrderPage";
|
||||||
|
const SubWorkOrderPage({Key key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<SubWorkOrderPage> createState() => _SubWorkOrderPageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _SubWorkOrderPageState extends State<SubWorkOrderPage> {
|
||||||
|
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
|
||||||
|
final SearchWorkOrders _searchWorkOrders = SearchWorkOrders();
|
||||||
|
Subtitle _subtitle;
|
||||||
|
bool _isLoading = false;
|
||||||
|
String _callerId = "", _site = "";
|
||||||
|
Lookup _dateOperator;
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
_subtitle = AppLocalization.of(context).subtitle;
|
||||||
|
return Scaffold(
|
||||||
|
body: SafeArea(
|
||||||
|
child: SingleChildScrollView(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
color: AColors.primaryColor,
|
||||||
|
padding: const EdgeInsets.symmetric(horizontal: 0, vertical: 4),
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
const ABackButton(),
|
||||||
|
Expanded(
|
||||||
|
child: Center(
|
||||||
|
child: Text(
|
||||||
|
"Search Work Order",
|
||||||
|
style: Theme.of(context).textTheme.headline6.copyWith(color: AColors.white, fontStyle: FontStyle.italic),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(
|
||||||
|
width: 48,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 8),
|
||||||
|
Form(
|
||||||
|
key: _formKey,
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.all(16.0),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
ATextFormField(
|
||||||
|
labelText: "Caller ID",
|
||||||
|
onSaved: (value) {
|
||||||
|
_callerId = value;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
ATextFormField(
|
||||||
|
labelText: "Asset S.N.",
|
||||||
|
textInputType: TextInputType.number,
|
||||||
|
onSaved: (value) {
|
||||||
|
_searchWorkOrders.assetType = value;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
ATextFormField(
|
||||||
|
labelText: "Work Order No.",
|
||||||
|
onSaved: (value) {
|
||||||
|
_searchWorkOrders.workOrderNo = value;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
ASubTitle(_subtitle.assignedEmployee),
|
||||||
|
const SizedBox(height: 4),
|
||||||
|
ServiceReportAllUsers(
|
||||||
|
initialValue: _searchWorkOrders.assignedEmployee == null ? null : Engineer(id: _searchWorkOrders.assignedEmployee.id, name: _searchWorkOrders.assignedEmployee.name),
|
||||||
|
onSelect: (engineer) {
|
||||||
|
_searchWorkOrders.assignedEmployee = AssignedEmployee(id: engineer.id, name: engineer.name);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
const ASubTitle("Maintenance Situation"),
|
||||||
|
const SizedBox(height: 4),
|
||||||
|
ServiceReportMaintenanceSituation(
|
||||||
|
initialValue: _searchWorkOrders.calllastSituation,
|
||||||
|
onSelect: (status) {
|
||||||
|
if (status?.value == 12 || _searchWorkOrders.calllastSituation?.value == 12) {
|
||||||
|
_searchWorkOrders.calllastSituation = status;
|
||||||
|
setState(() {});
|
||||||
|
} else {
|
||||||
|
_searchWorkOrders.calllastSituation = status;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
ATextFormField(
|
||||||
|
labelText: "Site",
|
||||||
|
onSaved: (value) {
|
||||||
|
_site = value;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
ASubTitle(_subtitle.visitDate),
|
||||||
|
const SizedBox(height: 4),
|
||||||
|
ServiceReportVisitDateOperator(
|
||||||
|
initialValue: _dateOperator,
|
||||||
|
onSelect: (status) {
|
||||||
|
_dateOperator = status;
|
||||||
|
},
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Expanded(
|
||||||
|
child: ADatePicker(
|
||||||
|
date: DateTime.tryParse(_searchWorkOrders.visitDate ?? ""),
|
||||||
|
from: DateTime(1950),
|
||||||
|
onDatePicker: (date) {
|
||||||
|
_searchWorkOrders.visitDate = date?.toIso8601String();
|
||||||
|
setState(() {});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 100),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
floatingActionButtonLocation: FloatingActionButtonLocation.centerFloat,
|
||||||
|
floatingActionButton: _isLoading
|
||||||
|
? const ALoading()
|
||||||
|
: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(horizontal: 16),
|
||||||
|
child: AButton(
|
||||||
|
text: _subtitle.search,
|
||||||
|
onPressed: () async {
|
||||||
|
_isLoading = true;
|
||||||
|
setState(() {});
|
||||||
|
if (_formKey.currentState?.validate() ?? false) {}
|
||||||
|
_formKey.currentState?.save();
|
||||||
|
final serviceRequestsProvider = Provider.of<ServiceRequestsProvider>(context, listen: false);
|
||||||
|
final List<SearchWorkOrders> woList = await serviceRequestsProvider.searchForWorkOrders(
|
||||||
|
_searchWorkOrders,
|
||||||
|
_callerId,
|
||||||
|
_dateOperator,
|
||||||
|
_site,
|
||||||
|
);
|
||||||
|
_isLoading = false;
|
||||||
|
setState(() {});
|
||||||
|
if (serviceRequestsProvider.stateCode >= 200 && serviceRequestsProvider.stateCode < 300) {
|
||||||
|
Fluttertoast.showToast(msg: _subtitle.requestCompleteSuccessfully);
|
||||||
|
Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => Scaffold(
|
||||||
|
body: ListView.builder(
|
||||||
|
itemCount: woList.length,
|
||||||
|
shrinkWrap: true,
|
||||||
|
itemBuilder: (context, index) => Text(
|
||||||
|
woList[index].id?.toString(),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
String errorMessage = HttpStatusManger.getStatusMessage(status: serviceRequestsProvider.stateCode, subtitle: _subtitle);
|
||||||
|
ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text(errorMessage)));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,29 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/status_drop_down/report/service_report_users_provider.dart';
|
||||||
|
import 'package:test_sa/models/engineer.dart';
|
||||||
|
import 'package:test_sa/views/widgets/loaders/loading_manager.dart';
|
||||||
|
import 'package:test_sa/views/widgets/status/users_menu.dart';
|
||||||
|
|
||||||
|
class ServiceReportAllUsers extends StatelessWidget {
|
||||||
|
final Function(Engineer) onSelect;
|
||||||
|
final Engineer initialValue;
|
||||||
|
const ServiceReportAllUsers({Key key, @required this.onSelect, this.initialValue}) : super(key: key);
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
ServiceReportUsersProvider menuProvider = Provider.of<ServiceReportUsersProvider>(context);
|
||||||
|
return LoadingManager(
|
||||||
|
isLoading: menuProvider.isLoading,
|
||||||
|
isFailedLoading: menuProvider.users == null,
|
||||||
|
stateCode: menuProvider.stateCode,
|
||||||
|
onRefresh: () async {
|
||||||
|
menuProvider.getAllUsers();
|
||||||
|
},
|
||||||
|
child: UsersMenu(
|
||||||
|
initialStatus: initialValue,
|
||||||
|
statuses: menuProvider.users,
|
||||||
|
onSelect: onSelect,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/status_drop_down/report/service_report_maintenance_situation_provider.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
import 'package:test_sa/views/widgets/loaders/loading_manager.dart';
|
||||||
|
import 'package:test_sa/views/widgets/status/single_status_menu.dart';
|
||||||
|
|
||||||
|
class ServiceReportMaintenanceSituation extends StatelessWidget {
|
||||||
|
final Function(Lookup) onSelect;
|
||||||
|
final Lookup initialValue;
|
||||||
|
|
||||||
|
const ServiceReportMaintenanceSituation({Key key, @required this.onSelect, @required this.initialValue}) : super(key: key);
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
ServiceReportMaintenanceSituationProvider menuProvider = Provider.of<ServiceReportMaintenanceSituationProvider>(context);
|
||||||
|
return LoadingManager(
|
||||||
|
isLoading: menuProvider.isLoading,
|
||||||
|
isFailedLoading: menuProvider.operators == null,
|
||||||
|
stateCode: menuProvider.stateCode,
|
||||||
|
onRefresh: () async {
|
||||||
|
menuProvider.getOperators();
|
||||||
|
},
|
||||||
|
child: SingleStatusMenu(
|
||||||
|
initialStatus: initialValue,
|
||||||
|
statuses: menuProvider.operators,
|
||||||
|
onSelect: onSelect,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/status_drop_down/report/service_report_visit_date_operator_provider.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
import 'package:test_sa/views/widgets/loaders/loading_manager.dart';
|
||||||
|
import 'package:test_sa/views/widgets/status/single_status_menu.dart';
|
||||||
|
|
||||||
|
class ServiceReportVisitDateOperator extends StatelessWidget {
|
||||||
|
final Function(Lookup) onSelect;
|
||||||
|
final Lookup initialValue;
|
||||||
|
|
||||||
|
const ServiceReportVisitDateOperator({Key key, @required this.onSelect, @required this.initialValue}) : super(key: key);
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
ServiceReportVisitOperatorProvider menuProvider = Provider.of<ServiceReportVisitOperatorProvider>(context);
|
||||||
|
return LoadingManager(
|
||||||
|
isLoading: menuProvider.isLoading,
|
||||||
|
isFailedLoading: menuProvider.operators == null,
|
||||||
|
stateCode: menuProvider.stateCode,
|
||||||
|
onRefresh: () async {
|
||||||
|
menuProvider.getOperators();
|
||||||
|
},
|
||||||
|
child: SingleStatusMenu(
|
||||||
|
initialStatus: initialValue,
|
||||||
|
statuses: menuProvider.operators,
|
||||||
|
onSelect: onSelect,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,109 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:test_sa/views/app_style/colors.dart';
|
||||||
|
import 'package:test_sa/views/app_style/sizing.dart';
|
||||||
|
|
||||||
|
import '../../../models/engineer.dart';
|
||||||
|
|
||||||
|
class UsersMenu extends StatefulWidget {
|
||||||
|
final List<Engineer> statuses;
|
||||||
|
final Engineer initialStatus;
|
||||||
|
final Function(Engineer) onSelect;
|
||||||
|
|
||||||
|
const UsersMenu({Key key, this.statuses, this.onSelect, this.initialStatus}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_SingleUsersMenuState createState() => _SingleUsersMenuState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _SingleUsersMenuState extends State<UsersMenu> {
|
||||||
|
Engineer _selectedStatus;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void setState(VoidCallback fn) {
|
||||||
|
if (mounted) super.setState(fn);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didUpdateWidget(covariant UsersMenu oldWidget) {
|
||||||
|
if (widget.initialStatus != null) {
|
||||||
|
final result = widget.statuses?.where((element) {
|
||||||
|
return element == widget.initialStatus;
|
||||||
|
});
|
||||||
|
if (result.isNotEmpty) {
|
||||||
|
_selectedStatus = result.first;
|
||||||
|
} else {
|
||||||
|
_selectedStatus = null;
|
||||||
|
}
|
||||||
|
if ((widget.initialStatus?.id ?? "") != (_selectedStatus?.id ?? "")) {
|
||||||
|
widget.onSelect(_selectedStatus);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
_selectedStatus = null;
|
||||||
|
}
|
||||||
|
super.didUpdateWidget(oldWidget);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
if (widget.initialStatus != null) {
|
||||||
|
final result = widget.statuses?.where((element) {
|
||||||
|
return element == widget.initialStatus;
|
||||||
|
});
|
||||||
|
if (result.isNotEmpty) _selectedStatus = result.first;
|
||||||
|
if (widget.initialStatus.id != _selectedStatus?.id) {
|
||||||
|
widget.onSelect(_selectedStatus);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
padding: const EdgeInsets.symmetric(horizontal: 16),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: AColors.inputFieldBackgroundColor,
|
||||||
|
border: Border.all(
|
||||||
|
color: Color(0xffefefef),
|
||||||
|
),
|
||||||
|
borderRadius: BorderRadius.circular(AppStyle.borderRadius * AppStyle.getScaleFactor(context)),
|
||||||
|
// boxShadow: const [
|
||||||
|
// AppStyle.boxShadow
|
||||||
|
// ]
|
||||||
|
),
|
||||||
|
child: DropdownButton<Engineer>(
|
||||||
|
value: _selectedStatus,
|
||||||
|
iconSize: 24,
|
||||||
|
icon: const Icon(Icons.keyboard_arrow_down_rounded),
|
||||||
|
elevation: 0,
|
||||||
|
isExpanded: true,
|
||||||
|
hint: Text(
|
||||||
|
"Select",
|
||||||
|
style: Theme.of(context).textTheme.subtitle1,
|
||||||
|
),
|
||||||
|
style: TextStyle(color: Theme.of(context).primaryColor),
|
||||||
|
underline: SizedBox.shrink(),
|
||||||
|
onChanged: (Engineer newValue) {
|
||||||
|
setState(() {
|
||||||
|
_selectedStatus = newValue;
|
||||||
|
});
|
||||||
|
widget.onSelect(newValue);
|
||||||
|
},
|
||||||
|
items: widget.statuses.map<DropdownMenuItem<Engineer>>((Engineer value) {
|
||||||
|
return DropdownMenuItem<Engineer>(
|
||||||
|
value: value,
|
||||||
|
child: Text(
|
||||||
|
value.name,
|
||||||
|
style: Theme.of(context).textTheme.subtitle1.copyWith(
|
||||||
|
color: Theme.of(context).primaryColor,
|
||||||
|
fontSize: 11,
|
||||||
|
//fontWeight: FontWeight.bold
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue