Merge remote-tracking branch 'atoms_main/main' into main_latest_merged
# Conflicts: # lib/controllers/api_routes/urls.dart # lib/controllers/providers/api/departments_provider.dart # lib/controllers/providers/api/device_transfer_provider.dart # lib/controllers/providers/api/devices_provider.dart # lib/controllers/providers/api/gas_refill_provider.dart # lib/controllers/providers/api/hospitals_provider.dart # lib/controllers/providers/api/parts_provider.dart # lib/controllers/providers/api/regular_visits_provider.dart # lib/controllers/providers/api/service_requests_provider.dart # lib/controllers/providers/api/status_drop_down/employee/assigned_to_provider.dart # lib/controllers/providers/api/status_drop_down/gas_refill/gas_cylinder_size_provider.dart # lib/controllers/providers/api/status_drop_down/gas_refill/gas_status_provider.dart # lib/controllers/providers/api/status_drop_down/gas_refill/gas_types_provider.dart # lib/controllers/providers/api/status_drop_down/pentry/pentry_status_provider.dart # lib/controllers/providers/api/status_drop_down/pentry/pentry_task_status_provider.dart # lib/controllers/providers/api/status_drop_down/pentry/pentry_visit_status_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_defect_types_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_last_calls_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_priority_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_reasons_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_status_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_report_types_provider.dart # lib/controllers/providers/api/status_drop_down/report/service_types_provider.dart # lib/main.dart # lib/models/device/device.dart # lib/models/device/device_transfer.dart # lib/models/device/device_transfer_info.dart # lib/models/gas_refill/gas_refill_details.dart # lib/models/gas_refill/gas_refill_model.dart # lib/models/lookup.dart # lib/models/pantry/calibration_tools.dart # lib/models/pantry/lookups/contact_person.dart # lib/models/pantry/lookups/contact_title.dart # lib/models/pantry/pentry.dart # lib/models/pantry/pm_kit.dart # lib/models/pantry/ppm_check_list.dart # lib/models/service_report.dart # lib/models/service_request/service_request.dart # lib/models/user.dart # lib/models/visits/visit.dart # lib/models/visits/visits_group.dart # lib/views/app_style/colors.dart # lib/views/pages/login.dart # lib/views/pages/register.dart # lib/views/pages/splash_screen.dart # lib/views/pages/user/land_page.dart # lib/views/pages/user/requests/create_request.dart # lib/views/pages/user/requests/report/create_service_report.dart # lib/views/pages/user/requests/report/edit_service_report.dart # lib/views/pages/user/requests/request_details.dart # lib/views/pages/user/visits/pantry/edit_pentry.dart # lib/views/pages/user/visits/preventive_maintenance_visits_page.dart # lib/views/pages/user/visits/regular_visits_page.dart # lib/views/pages/user/visits/update_visits_group_sheet.dart # lib/views/pages/user/visits/visit_details.dart # lib/views/widgets/app_text_form_field.dart # lib/views/widgets/buttons/app_back_button.dart # lib/views/widgets/departments/department_button.dart # lib/views/widgets/drawer/drawer_item.dart # lib/views/widgets/equipment/auto_complete_devices_field.dart # lib/views/widgets/equipment/device_button.dart # lib/views/widgets/equipment/single_device_picker.dart # lib/views/widgets/hospitals/hospital_auto_complete_field.dart # lib/views/widgets/hospitals/hospital_button.dart # lib/views/widgets/images/multi_image_picker.dart # lib/views/widgets/loaders/loading_manager.dart # lib/views/widgets/parts/auto_complete_parts_field.dart # lib/views/widgets/pentry/auto_complete_fields/auto_complete_devices_field.dart # lib/views/widgets/pentry/pentry_calibration_tool_form.dart # lib/views/widgets/pentry/pentry_info_form.dart # lib/views/widgets/pentry/pentry_pm_kit_form.dart # lib/views/widgets/requests/service_request_update_dialog.dart # lib/views/widgets/search/service_request_search_bar.dart # lib/views/widgets/search/visits_search_bar.dart # lib/views/widgets/sound/record_sound.dart # lib/views/widgets/sound/sound_player.dart # lib/views/widgets/speech_to_text/speech_to_text.dart # lib/views/widgets/status/employee/assigned_to_mune.dart # lib/views/widgets/status/multi_status_menu.dart # lib/views/widgets/status/report/service_status.dart # lib/views/widgets/status/single_status_menu.dart # lib/views/widgets/timer/app_timer.dart # lib/views/widgets/visits/visit_item.dart # pubspec.yamlmerge-requests/22/head
commit
c5c96a4fce
@ -0,0 +1,150 @@
|
||||
import 'dart:convert';
|
||||
import 'dart:developer';
|
||||
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:fluttertoast/fluttertoast.dart';
|
||||
import 'package:http/http.dart' as http;
|
||||
import 'package:http/http.dart';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
|
||||
class ApiManager {
|
||||
|
||||
ApiManager._();
|
||||
|
||||
Map<String,String> get _headers => {
|
||||
'Content-Type': 'application/json',
|
||||
if(user != null) 'Authorization': 'Bearer ${user.token}',
|
||||
};
|
||||
|
||||
static ApiManager instance = ApiManager._();
|
||||
|
||||
User user;
|
||||
|
||||
Future<http.Response> get(
|
||||
String url,
|
||||
{Map<String,String> headers,}
|
||||
) async{
|
||||
|
||||
headers ??= {};
|
||||
|
||||
headers.addAll(_headers);
|
||||
|
||||
Uri _url = Uri.parse(url);
|
||||
// print(_url);
|
||||
// print(headers);
|
||||
http.Response response = await http.get(_url,headers: headers);
|
||||
if(jsonDecode(response.body) is Map<String,dynamic>){
|
||||
final message = jsonDecode(response.body)["message"];
|
||||
if(message != null && message.toString().isNotEmpty){
|
||||
Fluttertoast.showToast(msg: message ?? "",toastLength: Toast.LENGTH_LONG);
|
||||
}
|
||||
}
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
Future<http.Response> post(
|
||||
String url, {
|
||||
Map<String,String> headers,
|
||||
@required Map<String,dynamic> body,
|
||||
}
|
||||
) async{
|
||||
|
||||
headers ??= {};
|
||||
|
||||
headers.addAll(_headers);
|
||||
|
||||
Uri _url = Uri.parse(url);
|
||||
// print(_url);
|
||||
// print(headers);
|
||||
// log(json.encode(body));
|
||||
var request = http.Request('POST', _url);
|
||||
request.body = json.encode(body);
|
||||
request.headers.addAll(headers);
|
||||
|
||||
http.StreamedResponse _streamedResponse = await request.send();
|
||||
http.Response response = await http.Response.fromStream(_streamedResponse);
|
||||
// print(response.statusCode);
|
||||
// log(response.body);
|
||||
|
||||
if(jsonDecode(response.body) is Map<String,dynamic>){
|
||||
final message = jsonDecode(response.body)["message"];
|
||||
if(message != null && message.toString().isNotEmpty){
|
||||
Fluttertoast.showToast(msg: message ?? "",toastLength: Toast.LENGTH_LONG);
|
||||
}
|
||||
}
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
Future<http.Response> put(
|
||||
String url, {
|
||||
Map<String,String> headers,
|
||||
@required Map<String,dynamic> body,
|
||||
}
|
||||
) async{
|
||||
|
||||
headers ??= {};
|
||||
|
||||
headers.addAll(_headers);
|
||||
|
||||
Uri _url = Uri.parse(url);
|
||||
// print(_url);
|
||||
// print(headers);
|
||||
// log(json.encode(body));
|
||||
var request = http.Request('PUT', _url);
|
||||
request.body = json.encode(body);
|
||||
request.headers.addAll(headers);
|
||||
|
||||
http.StreamedResponse streamedResponse = await request.send();
|
||||
http.Response response = await http.Response.fromStream(streamedResponse);
|
||||
// print(response.statusCode);
|
||||
// log(response.body);
|
||||
if(jsonDecode(response.body) is Map<String,dynamic>){
|
||||
final message = jsonDecode(response.body)["message"];
|
||||
if(message != null && message.toString().isNotEmpty){
|
||||
Fluttertoast.showToast(msg: message ?? "",toastLength: Toast.LENGTH_LONG);
|
||||
}
|
||||
}
|
||||
return response;
|
||||
}
|
||||
|
||||
Future<http.Response> multiPart(
|
||||
String url, {
|
||||
Map<String,String> headers,
|
||||
@required Map<String,String> body,
|
||||
@required List<Future<MultipartFile>> files,
|
||||
}) async{
|
||||
Map<String,String> _headers = const {'Content-Type': 'multipart/form-data',};
|
||||
|
||||
headers ??= {};
|
||||
|
||||
headers.addAll(_headers);
|
||||
|
||||
Uri _url = Uri.parse(url);
|
||||
// print(_url);
|
||||
// print(_headers);
|
||||
// print(json.encode(body));
|
||||
var request = http.MultipartRequest('POST', _url);
|
||||
request.fields.addAll(body);
|
||||
request.headers.addAll(_headers);
|
||||
|
||||
for (var element in files) {
|
||||
request.files.add(await element);
|
||||
}
|
||||
|
||||
//request.files.addAll(_files);
|
||||
// print(request.files);
|
||||
http.StreamedResponse streamedResponse = await request.send();
|
||||
http.Response response = await http.Response.fromStream(streamedResponse);
|
||||
// print(response.statusCode);
|
||||
// log(response.body);
|
||||
if(jsonDecode(response.body) is Map<String,dynamic>){
|
||||
final message = jsonDecode(response.body)["message"];
|
||||
if(message != null && message.toString().isNotEmpty){
|
||||
Fluttertoast.showToast(msg: message ?? "",toastLength: Toast.LENGTH_LONG);
|
||||
}
|
||||
}
|
||||
return response;
|
||||
}
|
||||
}
|
||||
@ -1,5 +1,5 @@
|
||||
import 'package:test_sa/models/subtitle.dart';
|
||||
import 'package:meta/meta.dart';
|
||||
import 'package:test_sa/models/subtitle.dart';
|
||||
|
||||
class HttpStatusManger{
|
||||
static String getStatusMessage({
|
||||
@ -1,68 +1,87 @@
|
||||
class URLs{
|
||||
URLs._();
|
||||
static const host2 = "http://194.163.164.213/atoms/api";
|
||||
// static const host1 = "https://atoms.hmg.com/api"; // production url
|
||||
static const host1 = "https://atomsdev.hmg.com/api"; // uat url
|
||||
// static const host1 = "https://atomsdev.hmg.com/api"; // uat url
|
||||
|
||||
static const host1 = "http://109.123.243.118:9000";
|
||||
|
||||
static String _baseUrl = "$_host/mobile";
|
||||
|
||||
static String _host = host1;
|
||||
|
||||
set host(String value) => _host = value;
|
||||
|
||||
static String getFileUrl(String file) => file == null || file.isEmpty
|
||||
? null : "$_host/attachment/$file";
|
||||
|
||||
// API Routes
|
||||
static const login = "/handle/user/login"; // post
|
||||
static const register = "/handle/create/user"; // post
|
||||
static const updateProfile = "/update/user/profile"; // post
|
||||
static const getHospitals = "/handle/return/all/clients"; // get
|
||||
static const getDepartments = "/handle/return/all/departments"; // get
|
||||
static const getEquipment = "/handle/return/all/client/equipments"; // get ?client=208051
|
||||
static const getServiceRequests = "/return/user/calls"; // get
|
||||
|
||||
static const getPreventiveMaintenanceVisits = "/return/user/calibrations"; // get
|
||||
static const updatePreventiveMaintenanceVisits = "/update/user/calibrations"; // get
|
||||
|
||||
static const getRegularVisits = "/return/user/ppm"; // get
|
||||
static const updateRegularVisits = "/update/user/ppm"; // get
|
||||
|
||||
static const getSingleServiceRequest = "/return/call/information"; // get
|
||||
static const getNotifications = "/return/user/notification"; // get
|
||||
static const getRecentNotifications = "/return/user/recent/notification"; // get
|
||||
static const createRequest = "/handle/create/request"; // get
|
||||
static const createReport = "/handle/create/report/issue"; // get
|
||||
static const updateRequestDate = "/handle/update/request"; // get
|
||||
static get login => "$_baseUrl/MobileAuth/Login"; // post
|
||||
static get register => "$_baseUrl/handle/create/user"; // post
|
||||
static get updateProfile => "$_baseUrl/update/user/profile"; // post
|
||||
static get getHospitals => "$_baseUrl/Customer/GetCustomers"; // get
|
||||
static get getDepartments => "$_baseUrl/Customer/GetDepartmentLookup"; // get
|
||||
static get getEquipment => "$_baseUrl/Asset/GetAssets"; // get ?client=208051
|
||||
static get getModels => "$_baseUrl/ModelDefinition/GetModelDefinitionAsset"; // get ?client=2
|
||||
// 08051
|
||||
static get getServiceRequests => "$_baseUrl/CallRequest/GetCallRequests"; // get
|
||||
static get getServiceRequestThrough => "$_baseUrl/Lookups/GetLookup?lookupEnum=603"; // get
|
||||
static get getServiceRequestTypes => "$_baseUrl/Lookups/GetLookup?lookupEnum=604"; // get
|
||||
static get getServiceRequestStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=503";
|
||||
|
||||
static get getPreventiveMaintenanceVisits => "$_baseUrl/return/user/calibrations"; // get
|
||||
static get updatePreventiveMaintenanceVisits => "$_baseUrl/Visit/UpdateVisits"; // get
|
||||
|
||||
static get getRegularVisits => "$_baseUrl/Visit/GetVisits"; // get
|
||||
static get updateRegularVisits => "$_baseUrl/Visit/UpdateVisits"; // get
|
||||
|
||||
static get getSingleServiceRequest => "$_baseUrl/return/call/information"; // get
|
||||
static get getNotifications => "$_baseUrl/return/user/notification"; // get
|
||||
static get getRecentNotifications => "$_baseUrl/return/user/recent/notification"; // get
|
||||
static get createRequest => "$_baseUrl/CallRequest/AddCallRequest"; // get
|
||||
static get createReport => "$_baseUrl/handle/create/report/issue"; // get
|
||||
static get updateRequestDate => "$_baseUrl/handle/update/request"; // get
|
||||
|
||||
// service report
|
||||
static const createServiceReport = "/handle/create/service/report"; // get
|
||||
static const updateServiceReport = "/handle/update/service/report"; // get
|
||||
static const getServiceReport = "/handle/view/service/report"; // get
|
||||
static const createDuplicatedReport = "/handle/duplicate/request"; // get
|
||||
|
||||
static const getServiceReportReasons = "/return/service/report/reasons"; // get
|
||||
static const getServiceReportTypes = "/return/service/report/type"; // get
|
||||
static const getServiceReportStatus = "/return/service/report/status"; // get
|
||||
static const getServiceReportLastCalls = "/return/call/last/situation"; // get
|
||||
static const getServiceTypes = "/return/service/type"; // get
|
||||
static const getPartNumber = "/handle/return/all/parts"; // get
|
||||
static const getServiceReportPriority = "/return/call/priority/list"; // get
|
||||
static const getServiceReportDefectTypes = "/return/call/defect/type/list"; // get
|
||||
static get createServiceReport => "$_baseUrl/WorkOrder/AddWorkOrder"; // get
|
||||
static get updateServiceReport => "$_baseUrl/WorkOrder/UpdateWorkOrder"; // get
|
||||
static get getServiceReport => "$_baseUrl/WorkOrder/GetWorkOrderById"; // get
|
||||
static get createDuplicatedReport => "$_baseUrl/handle/duplicate/request"; // get
|
||||
|
||||
static get getServiceReportReasons => "$_baseUrl/Lookups/GetLookup?lookupEnum=522"; // get
|
||||
static get getServiceReportTypes => "$_baseUrl/Lookups/GetLookup?lookupEnum=501"; // get
|
||||
static get getServiceReportStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=521"; // get
|
||||
static get getServiceReportLastCalls => "$_baseUrl/Lookups/GetLookup?lookupEnum=520"; // get
|
||||
static get getAssetTypes => "$_baseUrl/Lookups/GetLookup?lookupEnum=28"; // get
|
||||
static get getPartNumber => "$_baseUrl/PartCatalog/GetPartAutoComplete"; // get
|
||||
static get getServiceReportPriority => "$_baseUrl/Lookups/GetLookup?lookupEnum=602"; // get
|
||||
static get getServiceReportDefectTypes => "$_baseUrl/Lookups/GetLookup?lookupEnum=601"; // get
|
||||
|
||||
//gas refill
|
||||
static const getGasTypes = "/return/gas/refill/types"; // get
|
||||
static const getGasCylinderSize = "/return/gas/refill/size/cylinder"; // get
|
||||
static const getGasStatus = "/return/gas/refill/status"; // get
|
||||
static const requestGasRefill = "/create/gas/refill"; // get
|
||||
static const updateGasRefill = "/update/gas/refill/"; // get
|
||||
static const getGasRefill = "/search/gas/refill"; // get
|
||||
static get getGasTypes => "$_baseUrl/Lookups/GetLookup?lookupEnum=606"; // get
|
||||
// todo check edits with backend
|
||||
static get getGasCylinderSize => "$_baseUrl/Lookups/GetLookup?lookupEnum=608"; // get
|
||||
static get getGasCylinderType => "$_baseUrl/Lookups/GetLookup?lookupEnum=607"; // get
|
||||
static get getGasStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=609"; // get
|
||||
static get requestGasRefill => "$_baseUrl/GazRefill/AddGazRefill"; // get
|
||||
static get updateGasRefill => "$_baseUrl/GazRefill/UpdateGazRefill"; // get
|
||||
static get getGasRefill => "$_baseUrl/GazRefill/GetGazRefills"; // get
|
||||
|
||||
//device transfer
|
||||
static const requestDeviceTransfer = "/create/transfer/asset"; // get
|
||||
static const updateDeviceTransfer = "/update/transfer/asset"; // get
|
||||
static const getDeviceTransfer = "/search/transfer/asset"; // get
|
||||
static get requestDeviceTransfer => "$_baseUrl/AssetTransfer/AddAssetTransfer"; // get
|
||||
static get updateDeviceTransfer => "$_baseUrl/AssetTransfer/UpdateAssetTransfer"; // get
|
||||
static get getDeviceTransfer => "$_baseUrl/AssetTransfer/GetAssetTransfers"; // get
|
||||
|
||||
// employee
|
||||
static const getEmployees = "/return/assigned/employee"; // get
|
||||
static get getEmployees => "$_baseUrl/Lookups/GetLookup?lookupEnum=33"; // get
|
||||
static get getEngineers => "$_baseUrl/Account/GetUserByRoleValue?value=R-6"; // get
|
||||
|
||||
// pentry
|
||||
static const getPentry = "/return/pentry/details"; // get
|
||||
static const updatePentry = "/update/pentry/details"; // get
|
||||
static const getPentryTaskStatus = "/return/pentry/task/status"; // get
|
||||
static const getPentryVisitStatus = "/return/pentry/visit/status/list"; // get
|
||||
static const getPentryStatus = "/return/pentry/status/list"; // get
|
||||
static get getPentry => "$_baseUrl/return/pentry/details"; // get
|
||||
static get updatePentry => "$_baseUrl/Visit/UpdateVisit"; // get
|
||||
static get getPentryTaskStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=403"; // get
|
||||
static get getPentryVisitStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=402"; // get
|
||||
static get getPentryStatus => "$_baseUrl/Lookups/GetLookup?lookupEnum=401"; // get
|
||||
// contacts
|
||||
static const getPentryContacts = "/handle/return/all/contacts"; // get
|
||||
static get getPentryContacts => "$_baseUrl/handle/return/all/contacts"; // get
|
||||
|
||||
}
|
||||
@ -0,0 +1,73 @@
|
||||
import 'dart:convert';
|
||||
|
||||
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';
|
||||
import 'package:test_sa/models/lookup.dart';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:http/http.dart';
|
||||
|
||||
class EngineersProvider extends ChangeNotifier{
|
||||
|
||||
//reset provider data
|
||||
void reset(){
|
||||
_items = 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> _items;
|
||||
List<Engineer> get items => _items;
|
||||
|
||||
// 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> getData ({String host,User user}) async {
|
||||
if(_loading == true) return -2;
|
||||
_loading = true;
|
||||
notifyListeners();
|
||||
Response response;
|
||||
try{
|
||||
response = await ApiManager.instance.get(
|
||||
URLs.getEngineers,
|
||||
);
|
||||
_stateCode = response.statusCode;
|
||||
if(response.statusCode >= 200 && response.statusCode < 300) {
|
||||
// client's request was successfully received
|
||||
List categoriesListJson = json.decode(response.body);
|
||||
_items = categoriesListJson.map((type) => Engineer.fromJson(type)).toList();
|
||||
}
|
||||
_loading = false;
|
||||
notifyListeners();
|
||||
return response.statusCode;
|
||||
} catch(error) {
|
||||
_loading = false;
|
||||
_stateCode = -1;
|
||||
notifyListeners();
|
||||
return -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,74 @@
|
||||
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';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
|
||||
class GasCylinderTypesProvider extends ChangeNotifier{
|
||||
|
||||
//reset provider data
|
||||
void reset(){
|
||||
_items = 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> _items;
|
||||
List<Lookup> get items => _items;
|
||||
|
||||
// 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> getData ({String host,User user,}) async {
|
||||
if(_loading == true)
|
||||
return -2;
|
||||
_loading = true;
|
||||
notifyListeners();
|
||||
Response response;
|
||||
try{
|
||||
response = await ApiManager.instance.get(
|
||||
URLs.getGasCylinderType,
|
||||
);
|
||||
_stateCode = response.statusCode;
|
||||
if(response.statusCode >= 200 && response.statusCode < 300) {
|
||||
// client's request was successfully received
|
||||
List categoriesListJson = json.decode(response.body)["data"];
|
||||
_items = categoriesListJson.map((item) => Lookup.fromJson(item)).toList();
|
||||
}
|
||||
_loading = false;
|
||||
notifyListeners();
|
||||
return response.statusCode;
|
||||
} catch(error) {
|
||||
_loading = false;
|
||||
_stateCode = -1;
|
||||
notifyListeners();
|
||||
return -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,74 @@
|
||||
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';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
|
||||
class ServiceRequestStatusProvider extends ChangeNotifier{
|
||||
|
||||
//reset provider data
|
||||
void reset(){
|
||||
_statuses = 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> _statuses;
|
||||
List<Lookup> get items => _statuses;
|
||||
|
||||
// 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> getData ({String host,User user}) async {
|
||||
if(_loading == true)
|
||||
return -2;
|
||||
_loading = true;
|
||||
notifyListeners();
|
||||
Response response;
|
||||
try{
|
||||
response = await ApiManager.instance.get(
|
||||
URLs.getServiceRequestStatus,
|
||||
);
|
||||
_stateCode = response.statusCode;
|
||||
if(response.statusCode >= 200 && response.statusCode < 300) {
|
||||
// client's request was successfully received
|
||||
List categoriesListJson = json.decode(response.body)["data"];
|
||||
_statuses = categoriesListJson.map((e) => Lookup.fromJson(e)).toList();
|
||||
|
||||
}
|
||||
_loading = false;
|
||||
notifyListeners();
|
||||
return response.statusCode;
|
||||
} catch(error) {
|
||||
_loading = false;
|
||||
_stateCode = -1;
|
||||
notifyListeners();
|
||||
return -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,74 @@
|
||||
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';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
|
||||
class ServiceRequestedThroughProvider extends ChangeNotifier{
|
||||
|
||||
//reset provider data
|
||||
void reset(){
|
||||
_statuses = 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> _statuses;
|
||||
List<Lookup> get items => _statuses;
|
||||
|
||||
// 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> getData ({String host,User user}) async {
|
||||
if(_loading == true)
|
||||
return -2;
|
||||
_loading = true;
|
||||
notifyListeners();
|
||||
Response response;
|
||||
try{
|
||||
response = await ApiManager.instance.get(
|
||||
URLs.getServiceRequestThrough,
|
||||
);
|
||||
_stateCode = response.statusCode;
|
||||
if(response.statusCode >= 200 && response.statusCode < 300) {
|
||||
// client's request was successfully received
|
||||
List categoriesListJson = json.decode(response.body)["data"];
|
||||
_statuses = categoriesListJson.map((e) => Lookup.fromJson(e)).toList();
|
||||
|
||||
}
|
||||
_loading = false;
|
||||
notifyListeners();
|
||||
return response.statusCode;
|
||||
} catch(error) {
|
||||
_loading = false;
|
||||
_stateCode = -1;
|
||||
notifyListeners();
|
||||
return -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,74 @@
|
||||
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';
|
||||
import 'package:test_sa/models/user.dart';
|
||||
|
||||
class ServiceRequestTypeProvider extends ChangeNotifier{
|
||||
|
||||
//reset provider data
|
||||
void reset(){
|
||||
_statuses = 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> _statuses;
|
||||
List<Lookup> get items => _statuses;
|
||||
|
||||
// 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> getData ({String host,User user}) async {
|
||||
if(_loading == true)
|
||||
return -2;
|
||||
_loading = true;
|
||||
notifyListeners();
|
||||
Response response;
|
||||
try{
|
||||
response = await ApiManager.instance.get(
|
||||
URLs.getServiceRequestTypes,
|
||||
);
|
||||
_stateCode = response.statusCode;
|
||||
if(response.statusCode >= 200 && response.statusCode < 300) {
|
||||
// client's request was successfully received
|
||||
List categoriesListJson = json.decode(response.body)["data"];
|
||||
_statuses = categoriesListJson.map((e) => Lookup.fromJson(e)).toList();
|
||||
|
||||
}
|
||||
_loading = false;
|
||||
notifyListeners();
|
||||
return response.statusCode;
|
||||
} catch(error) {
|
||||
_loading = false;
|
||||
_stateCode = -1;
|
||||
notifyListeners();
|
||||
return -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,47 @@
|
||||
class ModelDefinition {
|
||||
int id;
|
||||
String assetName;
|
||||
String modelDefCode;
|
||||
String modelName;
|
||||
String manufacturerName;
|
||||
String supplierName;
|
||||
String replacementDate;
|
||||
int lifeSpan;
|
||||
|
||||
ModelDefinition(
|
||||
{this.id,
|
||||
this.assetName,
|
||||
this.modelDefCode,
|
||||
this.modelName,
|
||||
this.manufacturerName,
|
||||
this.supplierName,
|
||||
this.replacementDate,
|
||||
this.lifeSpan,});
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = <String, dynamic>{};
|
||||
data['id'] = id;
|
||||
data['assetName'] = assetName;
|
||||
data['modelDefCode'] = modelDefCode;
|
||||
data['modelName'] = modelName;
|
||||
data['manufacturerName'] = manufacturerName;
|
||||
data['supplierName'] = supplierName;
|
||||
data['replacementDate'] = replacementDate;
|
||||
data['lifeSpan'] = lifeSpan;
|
||||
return data;
|
||||
}
|
||||
|
||||
factory ModelDefinition.fromJson(Map<String, dynamic> map) {
|
||||
if(map == null) return null;
|
||||
return ModelDefinition(
|
||||
id: map['id'] as int,
|
||||
assetName: map['assetName'] as String,
|
||||
modelDefCode: map['modelDefCode'] as String,
|
||||
modelName: map['modelName'] as String,
|
||||
manufacturerName: map['manufacturerName'] as String,
|
||||
supplierName: map['supplierName'] as String,
|
||||
replacementDate: map['replacementDate'] as String,
|
||||
lifeSpan: map['lifeSpan'] as int,
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,41 @@
|
||||
class Engineer{
|
||||
String id;
|
||||
String name;
|
||||
|
||||
Engineer({
|
||||
this.id,
|
||||
this.name,
|
||||
});
|
||||
|
||||
|
||||
|
||||
factory Engineer.fromJson(Map<String,dynamic> parsedJson){
|
||||
return Engineer(
|
||||
id: parsedJson["userId"] ?? parsedJson["id"],
|
||||
name: parsedJson["userName"] ?? parsedJson["name"],
|
||||
);
|
||||
}
|
||||
factory Engineer.fromEngineer(Engineer department){
|
||||
return Engineer(
|
||||
id: department?.id,
|
||||
name: department?.name,
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
bool operator == (Object other) =>
|
||||
identical(this, other) || other is Engineer &&
|
||||
id == other.id;
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => id.hashCode;
|
||||
|
||||
Map<String, dynamic> toMap() {
|
||||
return {
|
||||
'id': id,
|
||||
'name': name,
|
||||
};
|
||||
}
|
||||
|
||||
}
|
||||
@ -1,47 +0,0 @@
|
||||
class Lookup{
|
||||
|
||||
final String label;
|
||||
final String key;
|
||||
final int id;
|
||||
|
||||
const Lookup({
|
||||
this.label,
|
||||
this.key,
|
||||
this.id,
|
||||
});
|
||||
|
||||
@override
|
||||
bool operator == (Object other) =>
|
||||
identical(this, other) || other is Lookup &&
|
||||
key == other.key &&
|
||||
id == other.id;
|
||||
|
||||
|
||||
@override
|
||||
int get hashCode => id.hashCode;
|
||||
|
||||
factory Lookup.fromStatus(Lookup old){
|
||||
return Lookup(
|
||||
label: old.label,
|
||||
id: old.id,
|
||||
key: old.key,
|
||||
);
|
||||
}
|
||||
|
||||
factory Lookup.fromJson(Map<String,dynamic> parsedJson){
|
||||
if(parsedJson["id"] == null && parsedJson["uid"] == null) return null;
|
||||
return Lookup(
|
||||
label: parsedJson["value"],
|
||||
id: parsedJson["id"] is int
|
||||
? parsedJson["id"]
|
||||
: int.tryParse(parsedJson["id"] ?? parsedJson["uid"]),
|
||||
);
|
||||
}
|
||||
|
||||
factory Lookup.fromIntIdJson(Map<String,dynamic> parsedJson){
|
||||
return Lookup(
|
||||
label: parsedJson["value"],
|
||||
id: parsedJson["id"],
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -1,26 +1,40 @@
|
||||
import 'package:test_sa/models/lookup.dart';
|
||||
|
||||
class CalibrationTool{
|
||||
int id;
|
||||
Lookup assetsNumber;
|
||||
DateTime dataOfTesting;
|
||||
|
||||
CalibrationTool({
|
||||
this.id,
|
||||
this.assetsNumber,
|
||||
this.dataOfTesting,
|
||||
});
|
||||
|
||||
Map<String, String> toMap() {
|
||||
Map<String, dynamic> toMap(int visitId) {
|
||||
return {
|
||||
if(assetsNumber != null) 'assetsSN': (assetsNumber?.id).toString(),
|
||||
if(dataOfTesting != null) 'dataOfTesting': (dataOfTesting.millisecondsSinceEpoch ~/ 1000).toString(),
|
||||
"id":id ?? 0,
|
||||
"visitId": visitId,
|
||||
if(assetsNumber != null) 'assetId': (assetsNumber?.id).toString(),
|
||||
if(dataOfTesting != null) 'calibrationDateOfTesters': dataOfTesting.toIso8601String(),
|
||||
};
|
||||
}
|
||||
|
||||
factory CalibrationTool.fromMap(Map<String, dynamic> map) {
|
||||
return CalibrationTool(
|
||||
assetsNumber: Lookup.fromJson(map['assetsSN']),
|
||||
dataOfTesting: map['dataOfTesting'] == null || map['dataOfTesting'] == "" ? null :
|
||||
DateTime.fromMillisecondsSinceEpoch(int.tryParse(map['dataOfTesting']) * 1000),
|
||||
assetsNumber: Lookup(id: map["assetId"],name: map['assetSerialNo']),
|
||||
dataOfTesting: DateTime.tryParse(map['calibrationDateOfTesters'] ?? ""),
|
||||
);
|
||||
}
|
||||
|
||||
CalibrationTool copyWith({
|
||||
Lookup assetsNumber,
|
||||
DateTime dataOfTesting,
|
||||
}) {
|
||||
return CalibrationTool(
|
||||
id: id,
|
||||
assetsNumber: assetsNumber ?? this.assetsNumber,
|
||||
dataOfTesting: dataOfTesting ?? this.dataOfTesting,
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -1,33 +1,54 @@
|
||||
import 'package:test_sa/models/lookup.dart';
|
||||
|
||||
class PPMCheckList{
|
||||
int id;
|
||||
Lookup status;
|
||||
String title;
|
||||
String comment;
|
||||
String measuredValue;
|
||||
|
||||
PPMCheckList({
|
||||
this.id,
|
||||
this.title,
|
||||
this.status,
|
||||
this.comment,
|
||||
this.measuredValue,
|
||||
});
|
||||
|
||||
Map<String, String> toMap() {
|
||||
Map<String, dynamic> toMap(int visitId) {
|
||||
return {
|
||||
if(status != null) 'status': status?.id.toString(),
|
||||
if(title != null) 'title': title,
|
||||
if(comment != null) 'comment': comment,
|
||||
'id': id ?? 0,
|
||||
"visitId": visitId,
|
||||
if(status != null) 'taskStatusId': status?.id.toString(),
|
||||
if(title != null) 'task': title,
|
||||
if(comment != null) 'taskComment': comment,
|
||||
if(measuredValue != null) 'measuredValue': measuredValue,
|
||||
};
|
||||
}
|
||||
|
||||
factory PPMCheckList.fromMap(Map<String, dynamic> map) {
|
||||
return PPMCheckList(
|
||||
status: Lookup.fromJson(map['status']),
|
||||
title: map['title'] as String,
|
||||
comment: map['comment'] as String,
|
||||
id: map['id'] as int,
|
||||
status: Lookup(id: map["taskStatusId"],name: map["taskStatusName"]),
|
||||
title: map['task'] as String,
|
||||
comment: map['taskComment'] as String,
|
||||
measuredValue: map['measuredValue'] as String,
|
||||
);
|
||||
}
|
||||
|
||||
PPMCheckList copyWith({
|
||||
int id,
|
||||
Lookup status,
|
||||
String title,
|
||||
String comment,
|
||||
String measuredValue,
|
||||
}) {
|
||||
return PPMCheckList(
|
||||
id: id ?? this.id,
|
||||
status: status ?? this.status,
|
||||
title: title ?? this.title,
|
||||
comment: comment ?? this.comment,
|
||||
measuredValue: measuredValue ?? this.measuredValue,
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -1,23 +1,37 @@
|
||||
class Part{
|
||||
String id;
|
||||
int id;
|
||||
int reportPartID;
|
||||
String code;
|
||||
String name;
|
||||
int quantity;
|
||||
|
||||
Part({
|
||||
this.id,
|
||||
this.reportPartID,
|
||||
this.code,
|
||||
this.name,
|
||||
this.quantity = 1,
|
||||
});
|
||||
|
||||
factory Part.fromJson(Map<String,dynamic> parsedJson){
|
||||
Map<String,dynamic> toJson(){
|
||||
return {
|
||||
"id": reportPartID ?? 0,
|
||||
"sparePart":{
|
||||
"id":id,
|
||||
"partNo": code,
|
||||
"partName":name
|
||||
},
|
||||
"qty":quantity
|
||||
};
|
||||
}
|
||||
|
||||
factory Part.fromJson(Map<String,dynamic> parsedJson,{Map<String,dynamic> reportJson}){
|
||||
return Part(
|
||||
id: parsedJson["nid"] ?? parsedJson["id"],
|
||||
code: parsedJson["part_code"] ?? parsedJson["name"],
|
||||
name: parsedJson["part_name"],
|
||||
quantity: parsedJson["qty"] == null
|
||||
? 1 : int.tryParse(parsedJson["qty"].toString()) ?? 1,
|
||||
id: parsedJson["id"],
|
||||
reportPartID: reportJson != null ? reportJson["id"] : null,
|
||||
code: parsedJson["partNo"],
|
||||
name: parsedJson["partName"],
|
||||
quantity: reportJson != null ? (reportJson["qty"] ?? 1).toInt() : 1,
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,90 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_typeahead/flutter_typeahead.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:test_sa/controllers/providers/api/devices_provider.dart';
|
||||
import 'package:test_sa/controllers/providers/api/user_provider.dart';
|
||||
import 'package:test_sa/controllers/providers/settings/setting_provider.dart';
|
||||
import 'package:test_sa/models/lookup.dart';
|
||||
import 'package:test_sa/views/app_style/colors.dart';
|
||||
import 'package:test_sa/views/app_style/sizing.dart';
|
||||
class AutoCompleteModelField extends StatefulWidget {
|
||||
final Lookup initialValue;
|
||||
final Function(Lookup) onPick;
|
||||
|
||||
const AutoCompleteModelField({Key key, this.initialValue, this.onPick,}) : super(key: key);
|
||||
|
||||
@override
|
||||
_AutoCompleteModelFieldState createState() => _AutoCompleteModelFieldState();
|
||||
}
|
||||
|
||||
class _AutoCompleteModelFieldState extends State<AutoCompleteModelField> {
|
||||
|
||||
SettingProvider _settingProvider;
|
||||
DevicesProvider _devicesProvider;
|
||||
UserProvider _userProvider;
|
||||
TextEditingController _controller;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
_controller = TextEditingController(text: widget.initialValue?.name);
|
||||
super.initState();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
_controller.dispose();
|
||||
super.dispose();
|
||||
}
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
_settingProvider = Provider.of<SettingProvider>(context);
|
||||
_userProvider = Provider.of<UserProvider>(context);
|
||||
_devicesProvider = Provider.of<DevicesProvider>(context);
|
||||
//Subtitle _subtitle = AppLocalization.of(context).subtitle;
|
||||
return Container(
|
||||
padding: const EdgeInsets.symmetric(
|
||||
horizontal: 16
|
||||
),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
border: Border.all(color:AColors.black),
|
||||
borderRadius: BorderRadius.circular(
|
||||
AppStyle.borderRadius * AppStyle.getScaleFactor(context)
|
||||
),
|
||||
boxShadow: [
|
||||
AppStyle.boxShadow
|
||||
]
|
||||
),
|
||||
child: TypeAheadField<Lookup>(
|
||||
textFieldConfiguration: TextFieldConfiguration(
|
||||
style: Theme.of(context).textTheme.headline6,
|
||||
controller: _controller,
|
||||
textAlign: TextAlign.center,
|
||||
|
||||
decoration: const InputDecoration(
|
||||
hintText: "Model",
|
||||
border: InputBorder.none,
|
||||
disabledBorder: InputBorder.none,
|
||||
focusedBorder: InputBorder.none,
|
||||
enabledBorder: InputBorder.none,
|
||||
),
|
||||
textInputAction: TextInputAction.search,
|
||||
),
|
||||
suggestionsCallback: (value) async {
|
||||
return await _devicesProvider.getModels(
|
||||
code: value,
|
||||
);
|
||||
},
|
||||
itemBuilder: (context, lookup) {
|
||||
return ListTile(
|
||||
title: Text(lookup.name),
|
||||
);
|
||||
},
|
||||
onSuggestionSelected: (lookup) {
|
||||
_controller.text = lookup.name;
|
||||
widget.onPick(lookup);
|
||||
},
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue