Merge branch 'master' into 'majd_development'

# Conflicts:
#   lib/views/widgets/loaders/loading_manager.dart
merge-requests/7/head
Sikander Saleem 3 years ago
commit 4100950a42

@ -42,10 +42,7 @@ class DevicesProvider extends ChangeNotifier {
/// return state code if request complete may be 200, 404 or 403 /// return state code if request complete may be 200, 404 or 403
/// for more details check http state manager /// for more details check http state manager
/// lib\controllers\http_status_manger\http_status_manger.dart /// lib\controllers\http_status_manger\http_status_manger.dart
Future<int> getEquipment( Future<int> getEquipment({required String host, required User user, required String hospitalId}) async {
{required String host,
required User user,
required String hospitalId}) async {
if (_loading == true) { if (_loading == true) {
return -2; return -2;
} }
@ -67,8 +64,7 @@ class DevicesProvider extends ChangeNotifier {
if (response.statusCode >= 200 && response.statusCode < 300) { if (response.statusCode >= 200 && response.statusCode < 300) {
// client's request was successfully received // client's request was successfully received
List equipmentListJson = json.decode(utf8.decode(response.bodyBytes)); List equipmentListJson = json.decode(utf8.decode(response.bodyBytes));
_devices = _devices = equipmentListJson.map((device) => Device.fromJson(device)).toList();
equipmentListJson.map((device) => Device.fromJson(device)).toList();
} }
_loading = false; _loading = false;
notifyListeners(); notifyListeners();
@ -98,9 +94,7 @@ class DevicesProvider extends ChangeNotifier {
if (response.statusCode >= 200 && response.statusCode < 300) { if (response.statusCode >= 200 && response.statusCode < 300) {
// client's request was successfully received // client's request was successfully received
List categoriesListJson = json.decode(utf8.decode(response.bodyBytes)); List categoriesListJson = json.decode(utf8.decode(response.bodyBytes));
page = categoriesListJson page = categoriesListJson.map((device) => Device.fromJson(device)).toList();
.map((device) => Device.fromJson(device))
.toList();
} }
return page; return page;
} catch (error) { } catch (error) {
@ -122,8 +116,7 @@ class DevicesProvider extends ChangeNotifier {
Response response; Response response;
try { try {
response = await get( response = await get(
Uri.parse( Uri.parse("$host${URLs.getEquipment}?client=$hospitalId${sn.isEmpty ? "" : "&serial_qr=$sn"}"),
"$host${URLs.getEquipment}?client=$hospitalId${sn.isEmpty ? "" : "&serial_qr=$sn"}"),
); );
_stateCode = response.statusCode; _stateCode = response.statusCode;
@ -131,9 +124,7 @@ class DevicesProvider extends ChangeNotifier {
if (response.statusCode >= 200 && response.statusCode < 300) { if (response.statusCode >= 200 && response.statusCode < 300) {
// client's request was successfully received // client's request was successfully received
List categoriesListJson = json.decode(utf8.decode(response.bodyBytes)); List categoriesListJson = json.decode(utf8.decode(response.bodyBytes));
page = categoriesListJson page = categoriesListJson.map((device) => Device.fromJson(device)).toList();
.map((device) => Device.fromJson(device))
.toList();
} }
return page; return page;
} catch (error) { } catch (error) {

@ -30,7 +30,6 @@ import '../../../widgets/status/service_request/service_request_defect_types_mun
import '../../../widgets/status/service_request/service_request_priority_mune.dart'; import '../../../widgets/status/service_request/service_request_priority_mune.dart';
import '../../../widgets/titles/app_sub_title.dart'; import '../../../widgets/titles/app_sub_title.dart';
class CreateRequestPage extends StatefulWidget { class CreateRequestPage extends StatefulWidget {
static final String id = "/create-request"; static final String id = "/create-request";
@ -46,7 +45,7 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
ServiceRequest _serviceRequest = ServiceRequest(); ServiceRequest _serviceRequest = ServiceRequest();
List<File> _deviceImages = []; List<File> _deviceImages = [];
bool _isLoading = false; bool _isLoading = false;
late Device _device; Device? _device;
late Subtitle _subtitle; late Subtitle _subtitle;
final GlobalKey<FormState> _formKey = GlobalKey<FormState>(); final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>(); final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
@ -101,7 +100,12 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
padding: const EdgeInsets.all(8.0), padding: const EdgeInsets.all(8.0),
child: Text( child: Text(
_subtitle.newServiceRequest, _subtitle.newServiceRequest,
style: Theme.of(context).textTheme.headline5?.copyWith(color: AColors.cyan, fontWeight: FontWeight.w600), style: Theme.of(context)
.textTheme
.headline5
?.copyWith(
color: AColors.cyan,
fontWeight: FontWeight.w600),
), ),
), ),
), ),
@ -113,7 +117,9 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
? SizedBox.shrink() ? SizedBox.shrink()
: ATextFormField( : ATextFormField(
enable: false, enable: false,
initialValue: _userProvider.user?.hospital?.name ?? _subtitle.noHospitalFound, initialValue:
_userProvider.user?.hospital?.name ??
_subtitle.noHospitalFound,
hintText: _subtitle.hospital, hintText: _subtitle.hospital,
prefixIconData: FontAwesomeIcons.hospital, prefixIconData: FontAwesomeIcons.hospital,
style: Theme.of(context).textTheme.subtitle1, style: Theme.of(context).textTheme.subtitle1,
@ -123,7 +129,9 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
? SizedBox.shrink() ? SizedBox.shrink()
: ATextFormField( : ATextFormField(
enable: false, enable: false,
initialValue: _userProvider.user?.department?.name ?? _subtitle.noUniteFound, initialValue:
_userProvider.user?.department?.name ??
_subtitle.noUniteFound,
hintText: _subtitle.unite, hintText: _subtitle.unite,
prefixIconData: FontAwesomeIcons.hospitalUser, prefixIconData: FontAwesomeIcons.hospitalUser,
style: Theme.of(context).textTheme.subtitle1, style: Theme.of(context).textTheme.subtitle1,
@ -136,21 +144,29 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
setState(() {}); setState(() {});
}, },
), ),
const SizedBox(height: 8,), const SizedBox(
height: 8,
),
const ASubTitle("Priority"), const ASubTitle("Priority"),
const SizedBox(height: 4,), const SizedBox(
height: 4,
),
ServiceRequestPriorityMenu( ServiceRequestPriorityMenu(
initialValue: _serviceRequest.priority, initialValue: _serviceRequest.priority,
onSelect: (status){ onSelect: (status) {
_serviceRequest.priority = status; _serviceRequest.priority = status;
}, },
), ),
const SizedBox(height: 8,), const SizedBox(
height: 8,
),
const ASubTitle("Defect Type"), const ASubTitle("Defect Type"),
const SizedBox(height: 4,), const SizedBox(
height: 4,
),
ServiceRequestDefectTypesMenu( ServiceRequestDefectTypesMenu(
initialValue: _serviceRequest.defectType, initialValue: _serviceRequest.defectType,
onSelect: (status){ onSelect: (status) {
_serviceRequest.defectType = status; _serviceRequest.defectType = status;
}, },
), ),
@ -169,7 +185,9 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
prefixIconData: FontAwesomeIcons.triangleExclamation, prefixIconData: FontAwesomeIcons.triangleExclamation,
style: Theme.of(context).textTheme.headline6, style: Theme.of(context).textTheme.headline6,
textInputType: TextInputType.multiline, textInputType: TextInputType.multiline,
validator: (value) => Validator.hasValue(value!) ? '' : _subtitle.maintenanceIssueRequired, validator: (value) => Validator.hasValue(value!)
? ''
: _subtitle.maintenanceIssueRequired,
onSaved: (value) { onSaved: (value) {
_serviceRequest.maintenanceIssue = value; _serviceRequest.maintenanceIssue = value;
}, },
@ -186,19 +204,24 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
child: AButton( child: AButton(
text: _subtitle.submit, text: _subtitle.submit,
onPressed: () async { onPressed: () async {
if (!(_formKey.currentState?.validate()??false)) return; if (!(_formKey.currentState?.validate() ?? false))
return;
_formKey.currentState?.save(); _formKey.currentState?.save();
_serviceRequest.deviceId = _device?.id ?? ""; _serviceRequest.deviceId = _device?.id ?? "";
_isLoading = true; _isLoading = true;
setState(() {}); setState(() {});
_serviceRequest.devicePhotos = _deviceImages.map((e) => base64Encode(e.readAsBytesSync())).toList(); _serviceRequest.devicePhotos = _deviceImages
.map((e) => base64Encode(e.readAsBytesSync()))
.toList();
if (_serviceRequest.audio != null) { if (_serviceRequest.audio != null) {
final file = File(_serviceRequest.audio!); final file = File(_serviceRequest.audio!);
_serviceRequest.audio = base64Encode(file.readAsBytesSync()); _serviceRequest.audio =
base64Encode(file.readAsBytesSync());
} }
int status = await _serviceRequestsProvider.createRequest( int status =
await _serviceRequestsProvider.createRequest(
user: _userProvider.user!, user: _userProvider.user!,
host: _settingProvider.host??"", host: _settingProvider.host ?? "",
serviceRequest: _serviceRequest, serviceRequest: _serviceRequest,
); );
_isLoading = false; _isLoading = false;
@ -209,7 +232,9 @@ class _CreateRequestPageState extends State<CreateRequestPage> {
); );
Navigator.of(context).pop(); Navigator.of(context).pop();
} else { } else {
String errorMessage = HttpStatusManger.getStatusMessage(status: status, subtitle: _subtitle); String errorMessage =
HttpStatusManger.getStatusMessage(
status: status, subtitle: _subtitle);
ScaffoldMessenger.of(context).showSnackBar(SnackBar( ScaffoldMessenger.of(context).showSnackBar(SnackBar(
content: Text(errorMessage), content: Text(errorMessage),
)); ));

@ -8,18 +8,18 @@ import '../../app_style/sizing.dart';
import 'single_department_picker.dart'; import 'single_department_picker.dart';
class DepartmentButton extends StatelessWidget { class DepartmentButton extends StatelessWidget {
final Function(Department)? onDepartmentPick; final Function(Department) onDepartmentPick;
final Department? department; final Department? department;
const DepartmentButton({Key? key, this.department, this.onDepartmentPick}) : super(key: key); const DepartmentButton({Key? key, this.department, required this.onDepartmentPick}) : super(key: key);
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
Subtitle? _subtitle = AppLocalization.of(context)?.subtitle; Subtitle? subtitle = AppLocalization.of(context)?.subtitle;
return ElevatedButton( return ElevatedButton(
style: ElevatedButton.styleFrom( style: ElevatedButton.styleFrom(
elevation: 0, elevation: 0,
padding: EdgeInsets.symmetric(horizontal: 8, vertical: 8), padding: const EdgeInsets.symmetric(horizontal: 8, vertical: 8),
shape: RoundedRectangleBorder( shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(AppStyle.borderRadius * AppStyle.getScaleFactor(context)), borderRadius: BorderRadius.circular(AppStyle.borderRadius * AppStyle.getScaleFactor(context)),
), ),
@ -32,7 +32,7 @@ class DepartmentButton extends StatelessWidget {
child: Padding( child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 8), padding: const EdgeInsets.symmetric(horizontal: 8),
child: Text( child: Text(
department?.name ?? _subtitle?.pickUnite??"", department?.name ?? subtitle?.pickUnite ?? "",
style: Theme.of(context).textTheme.bodyText1, style: Theme.of(context).textTheme.bodyText1,
textScaleFactor: AppStyle.getScaleFactor(context), textScaleFactor: AppStyle.getScaleFactor(context),
textDirection: TextDirection.rtl, textDirection: TextDirection.rtl,
@ -44,8 +44,8 @@ class DepartmentButton extends StatelessWidget {
], ],
), ),
onPressed: () async { onPressed: () async {
Department _department = await Navigator.of(context).pushNamed(SingleDepartmentPicker.id) as Department; Department department = await Navigator.of(context).pushNamed(SingleDepartmentPicker.id) as Department;
onDepartmentPick!(_department); onDepartmentPick(department);
}); });
} }
} }

@ -8,11 +8,10 @@ import '../../app_style/sizing.dart';
import 'single_device_picker.dart'; import 'single_device_picker.dart';
class DeviceButton extends StatelessWidget { class DeviceButton extends StatelessWidget {
final Function(Device)? onDevicePick; final Function(Device?) onDevicePick;
final Device? device; final Device? device;
const DeviceButton({Key? key, required this.device, this.onDevicePick}) const DeviceButton({Key? key, required this.device, required this.onDevicePick}) : super(key: key);
: super(key: key);
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
@ -20,11 +19,9 @@ class DeviceButton extends StatelessWidget {
return ElevatedButton( return ElevatedButton(
style: ElevatedButton.styleFrom( style: ElevatedButton.styleFrom(
elevation: 0, elevation: 0,
padding: EdgeInsets.symmetric( padding: EdgeInsets.symmetric(horizontal: 16, vertical: device == null ? 12 : 8),
horizontal: 16, vertical: device == null ? 12 : 8),
shape: RoundedRectangleBorder( shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular( borderRadius: BorderRadius.circular(AppStyle.borderRadius * AppStyle.getScaleFactor(context)),
AppStyle.borderRadius * AppStyle.getScaleFactor(context)),
), ),
foregroundColor: AColors.primaryColor, foregroundColor: AColors.primaryColor,
backgroundColor: AColors.inputFieldBackgroundColor, backgroundColor: AColors.inputFieldBackgroundColor,
@ -71,14 +68,12 @@ class DeviceButton extends StatelessWidget {
], ],
), ),
)), )),
const Icon(Icons.keyboard_arrow_down, const Icon(Icons.keyboard_arrow_down, size: 28, color: AColors.grey3A),
size: 28, color: AColors.grey3A),
], ],
), ),
onPressed: () async { onPressed: () async {
Device _device = await Navigator.of(context) Device? device = await Navigator.of(context).pushNamed(SingleDevicePicker.id) as Device?;
.pushNamed(SingleDevicePicker.id) as Device; onDevicePick(device);
onDevicePick!(_device);
}); });
} }
} }

@ -14,9 +14,13 @@ import '../loaders/loading_manager.dart';
import '../loaders/no_item_found.dart'; import '../loaders/no_item_found.dart';
import '../qr/scan_qr.dart'; import '../qr/scan_qr.dart';
import 'device_item.dart'; import 'device_item.dart';
class SingleDevicePicker extends StatefulWidget { class SingleDevicePicker extends StatefulWidget {
static final String id = "/single-device-Picker"; static const String id = "/single-device-Picker";
final bool sandraChoice = true; final bool sandraChoice = true;
const SingleDevicePicker({super.key});
@override @override
_SingleDevicePickerState createState() => _SingleDevicePickerState(); _SingleDevicePickerState createState() => _SingleDevicePickerState();
} }
@ -25,28 +29,23 @@ class _SingleDevicePickerState extends State<SingleDevicePicker> {
DevicesProvider? _devicesProvider; DevicesProvider? _devicesProvider;
UserProvider? _userProvider; UserProvider? _userProvider;
SettingProvider? _settingProvider; SettingProvider? _settingProvider;
List<Device> _searchableList = []; final List<Device> _searchableList = [];
bool _firstTime = true; bool _firstTime = true;
Subtitle? _subtitle; Subtitle? _subtitle;
_getDevice(String result) async { _getDevice(String? result) async {
if(result == null) return; if (result == null) return;
showDialog( showDialog(
barrierDismissible: false, barrierDismissible: false,
context: context, context: context,
builder: (dialogContext){ builder: (dialogContext) {
return const Center(child: CircularProgressIndicator()); return const Center(child: CircularProgressIndicator());
} });
); List<Device> devices =
List<Device> devices = await _devicesProvider!.getDevicesListBySN( await _devicesProvider!.getDevicesListBySN(host: _settingProvider?.host ?? "", user: _userProvider?.user ?? User(), hospitalId: _userProvider?.user?.hospital?.id ?? "", sn: result);
host: _settingProvider?.host??"",
user: _userProvider?.user??User(),
hospitalId: _userProvider?.user?.hospital?.id??"",
sn: result
);
Navigator.of(context).pop(); Navigator.of(context).pop();
if(devices.isEmpty){ if (devices.isEmpty) {
Fluttertoast.showToast(msg: _subtitle?.noDeviceFound??""); Fluttertoast.showToast(msg: _subtitle?.noDeviceFound ?? "");
return; return;
} }
Navigator.of(context).pop(devices.first); Navigator.of(context).pop(devices.first);
@ -68,10 +67,6 @@ class _SingleDevicePickerState extends State<SingleDevicePicker> {
_userProvider = Provider.of<UserProvider>(context); _userProvider = Provider.of<UserProvider>(context);
_settingProvider = Provider.of<SettingProvider>(context); _settingProvider = Provider.of<SettingProvider>(context);
if(_firstTime && _devicesProvider?.devices != null){
_searchableList.addAll(_devicesProvider?.devices??[]);
_firstTime = false;
}
_subtitle = AppLocalization.of(context)?.subtitle; _subtitle = AppLocalization.of(context)?.subtitle;
return Scaffold( return Scaffold(
resizeToAvoidBottomInset: false, resizeToAvoidBottomInset: false,
@ -81,45 +76,39 @@ class _SingleDevicePickerState extends State<SingleDevicePicker> {
isFailedLoading: _devicesProvider?.devices == null, isFailedLoading: _devicesProvider?.devices == null,
onRefresh: () async { onRefresh: () async {
_devicesProvider?.reset(); _devicesProvider?.reset();
await _devicesProvider?.getEquipment( await _devicesProvider?.getEquipment(user: _userProvider?.user ?? User(), host: _settingProvider?.host ?? "", hospitalId: _userProvider?.user?.hospital?.id ?? "");
user: _userProvider?.user??User(), if (_firstTime) {
host: _settingProvider?.host??"", _searchableList.addAll(_devicesProvider?.devices ?? []);
hospitalId: _userProvider?.user?.hospital?.id??"" _firstTime = false;
); }
}, },
child: Column( child: Column(
children: [ children: [
const SizedBox(height: 48), const SizedBox(height: 48),
Padding( Padding(
padding: const EdgeInsets.symmetric(vertical: 8,horizontal: 16), padding: const EdgeInsets.symmetric(vertical: 8, horizontal: 16),
child: Column( child: Column(
children: [ children: [
ATextFormField( ATextFormField(
hintText: _subtitle?.searchBySn??"", hintText: _subtitle?.searchBySn ?? "",
style: Theme.of(context).textTheme.subtitle1, style: Theme.of(context).textTheme.subtitle1,
suffixIcon: const Icon(Icons.search_rounded), suffixIcon: const Icon(Icons.search_rounded),
onChange: (value){ onChange: (value) {
_searchableList.clear(); _searchableList.clear();
_searchableList.addAll(_devicesProvider!.devices!.where( _searchableList.addAll(_devicesProvider!.devices!.where((element) => element.serialNumber!.toLowerCase().contains(value.toLowerCase())).toList());
(element) => element.serialNumber!.toLowerCase().contains(
value.toLowerCase()
)
).toList());
setState(() {}); setState(() {});
}, },
), ),
const SizedBox(height: 8,), const SizedBox(
height: 8,
),
ATextFormField( ATextFormField(
hintText: "Search by Number", hintText: "Search by Number",
style: Theme.of(context).textTheme.subtitle1, style: Theme.of(context).textTheme.subtitle1,
suffixIcon: const Icon(Icons.search_rounded), suffixIcon: const Icon(Icons.search_rounded),
onChange: (value){ onChange: (value) {
_searchableList.clear(); _searchableList.clear();
_searchableList.addAll(_devicesProvider!.devices!.where( _searchableList.addAll(_devicesProvider!.devices!.where((element) => element.number!.toLowerCase().contains(value.toLowerCase())).toList());
(element) => element.number!.toLowerCase().contains(
value.toLowerCase()
)
).toList());
setState(() {}); setState(() {});
}, },
), ),
@ -127,21 +116,23 @@ class _SingleDevicePickerState extends State<SingleDevicePicker> {
), ),
), ),
Expanded( Expanded(
child: _searchableList.isEmpty ? child: _searchableList.isEmpty
NoItemFound(message: _subtitle?.noDeviceFound??"",): ? NoItemFound(
ListView.builder( message: _subtitle?.noDeviceFound ?? "",
padding: EdgeInsets.zero, )
shrinkWrap: true, : ListView.builder(
itemCount: _searchableList.length, padding: EdgeInsets.zero,
itemBuilder: (listContext,itemIndex){ shrinkWrap: true,
return DeviceItem( itemCount: _searchableList.length,
device: _searchableList[itemIndex], itemBuilder: (listContext, itemIndex) {
onPressed: (device){ return DeviceItem(
Navigator.of(context).pop(device); device: _searchableList[itemIndex],
}, onPressed: (device) {
); Navigator.of(context).pop(device);
}, },
), );
},
),
), ),
], ],
), ),
@ -151,7 +142,7 @@ class _SingleDevicePickerState extends State<SingleDevicePicker> {
child: const Icon(Icons.qr_code_scanner), child: const Icon(Icons.qr_code_scanner),
onPressed: () async { onPressed: () async {
String result = await Navigator.of(context).push( String result = await Navigator.of(context).push(
MaterialPageRoute(builder: (_)=> ScanQr()), MaterialPageRoute(builder: (_) => ScanQr()),
) as String; ) as String;
_getDevice(result); _getDevice(result);
}, },

@ -5,6 +5,7 @@ import '../../../controllers/localization/localization.dart';
import '../../../models/subtitle.dart'; import '../../../models/subtitle.dart';
import 'app_loading.dart'; import 'app_loading.dart';
import 'failed_loading.dart'; import 'failed_loading.dart';
class LoadingManager extends StatefulWidget { class LoadingManager extends StatefulWidget {
final bool? isLoading; final bool? isLoading;
final bool? isFailedLoading; final bool? isFailedLoading;
@ -15,13 +16,13 @@ class LoadingManager extends StatefulWidget {
final Future<void> Function()? onRefresh; final Future<void> Function()? onRefresh;
final Widget? child; final Widget? child;
LoadingManager({ const LoadingManager({
Key? key, Key? key,
this.isLoading, this.isLoading,
this.isFailedLoading, this.isFailedLoading,
this.stateCode, this.stateCode,
this.onRefresh, this.onRefresh,
this.child, this.child,
this.progress, this.progress,
this.isNotPage = false, this.isNotPage = false,
this.askOnBack = false, this.askOnBack = false,
@ -32,10 +33,9 @@ class LoadingManager extends StatefulWidget {
} }
class _LoadingManagerState extends State<LoadingManager> { class _LoadingManagerState extends State<LoadingManager> {
@override @override
void initState() { void initState() {
if(widget.onRefresh != null && widget.stateCode == null){ if (widget.onRefresh != null && widget.stateCode == null) {
WidgetsBinding.instance.addPostFrameCallback((timeStamp) { WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
widget.onRefresh!(); widget.onRefresh!();
}); });
@ -48,7 +48,7 @@ class _LoadingManagerState extends State<LoadingManager> {
Subtitle? subtitle = AppLocalization.of(context)?.subtitle; Subtitle? subtitle = AppLocalization.of(context)?.subtitle;
Widget? placeHolder; Widget? placeHolder;
// to load data if load not start // to load data if load not start
if(widget.isLoading == false && widget.stateCode == null){ if (widget.isLoading == false && widget.stateCode == null) {
WidgetsBinding.instance.addPostFrameCallback((timeStamp) { WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
widget.onRefresh!(); widget.onRefresh!();
}); });
@ -56,20 +56,19 @@ class _LoadingManagerState extends State<LoadingManager> {
// if loading of still not start in loading (true or null) // if loading of still not start in loading (true or null)
// return loading widget // return loading widget
if(widget.isLoading != false || widget.stateCode == null){ if (widget.isLoading != false || widget.stateCode == null) {
placeHolder = ALoading(); placeHolder = const ALoading();
}else if((widget.isFailedLoading??false) && !(widget.isNotPage)){ } else if ((widget.isFailedLoading ?? false) && !(widget.isNotPage ?? false)) {
// if failed return failed widget // if failed return failed widget
placeHolder = FailedLoading( placeHolder = FailedLoading(
message: HttpStatusManger.getStatusMessage( message: HttpStatusManger.getStatusMessage(status: widget.stateCode, subtitle: subtitle),
status: widget.stateCode, subtitle: subtitle),
onReload: widget.onRefresh, onReload: widget.onRefresh,
); );
} }
// if load end successfully return loaded widget // if load end successfully return loaded widget
return RefreshIndicator( return RefreshIndicator(
onRefresh: () async{ onRefresh: () async {
await widget.onRefresh!(); await widget.onRefresh!();
}, },
child: AnimatedSwitcher( child: AnimatedSwitcher(

Loading…
Cancel
Save