Filter Requests DONE
parent
cc089d917f
commit
dbb26d8cd4
@ -0,0 +1,72 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:test_sa/extensions/int_extensions.dart';
|
||||||
|
import 'package:test_sa/extensions/text_extensions.dart';
|
||||||
|
import 'package:test_sa/extensions/widget_extensions.dart';
|
||||||
|
|
||||||
|
import '../../../app_style/app_color.dart';
|
||||||
|
|
||||||
|
class RequestsTypeFilter extends StatefulWidget {
|
||||||
|
final Function(List<int>) onSelect;
|
||||||
|
final Map<String, int> items;
|
||||||
|
final List<int> initialValues;
|
||||||
|
|
||||||
|
const RequestsTypeFilter({Key key, @required this.items, this.initialValues, this.onSelect}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<RequestsTypeFilter> createState() => _RequestsTypeFilterState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _RequestsTypeFilterState extends State<RequestsTypeFilter> {
|
||||||
|
List<int> _selected = [];
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
if (widget.initialValues != null) {
|
||||||
|
_selected.addAll(widget.initialValues);
|
||||||
|
}
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didUpdateWidget(covariant RequestsTypeFilter oldWidget) {
|
||||||
|
if (widget.initialValues != oldWidget.initialValues) {
|
||||||
|
setState(() {
|
||||||
|
_selected = widget.initialValues ?? [];
|
||||||
|
});
|
||||||
|
}
|
||||||
|
super.didUpdateWidget(oldWidget);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Wrap(
|
||||||
|
spacing: 8.toScreenWidth,
|
||||||
|
runSpacing: 8.toScreenHeight,
|
||||||
|
children: widget.items.keys
|
||||||
|
.map(
|
||||||
|
(data) => Container(
|
||||||
|
padding: EdgeInsets.symmetric(vertical: 8.toScreenHeight, horizontal: (_selected.contains(widget.items[data]) ? 12 : 8).toScreenWidth),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(7),
|
||||||
|
color: _selected.contains(widget.items[data]) ? AppColor.neutral30 : Colors.white,
|
||||||
|
border: _selected.contains(widget.items[data]) ? Border.all(width: 1, color: AppColor.primary50) : null,
|
||||||
|
boxShadow: [BoxShadow(color: Colors.black.withOpacity(0.03), blurRadius: 14)],
|
||||||
|
),
|
||||||
|
child: data.tinyFont(context).custom(color: AppColor.neutral50),
|
||||||
|
).onPress(
|
||||||
|
() {
|
||||||
|
if (_selected.contains(widget.items[data])) {
|
||||||
|
_selected.remove(widget.items[data]);
|
||||||
|
} else {
|
||||||
|
_selected.add(widget.items[data]);
|
||||||
|
}
|
||||||
|
setState(() {
|
||||||
|
widget.onSelect(_selected);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.toList(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,36 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:http/http.dart';
|
||||||
|
import 'package:test_sa/providers/loading_list_notifier.dart';
|
||||||
|
|
||||||
|
import '../../controllers/api_routes/api_manager.dart';
|
||||||
|
import '../../controllers/api_routes/urls.dart';
|
||||||
|
import '../../models/lookup.dart';
|
||||||
|
|
||||||
|
class RequestStatusProvider extends LoadingListNotifier<Lookup> {
|
||||||
|
@override
|
||||||
|
Future getDate() async {
|
||||||
|
if (loading == true) return -2;
|
||||||
|
loading = true;
|
||||||
|
notifyListeners();
|
||||||
|
loading = true;
|
||||||
|
notifyListeners();
|
||||||
|
try {
|
||||||
|
Response 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"];
|
||||||
|
items = categoriesListJson.map((item) => Lookup.fromJson(item)).toList();
|
||||||
|
}
|
||||||
|
loading = false;
|
||||||
|
notifyListeners();
|
||||||
|
return response.statusCode;
|
||||||
|
} catch (error) {
|
||||||
|
loading = false;
|
||||||
|
stateCode = -1;
|
||||||
|
notifyListeners();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue