Add pagination to tasks
This commit is contained in:
parent
a55ffbf888
commit
764255e6c6
|
|
@ -35,9 +35,10 @@ class TaskRepository {
|
||||||
return taskResponse.data;
|
return taskResponse.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<BuiltList<TaskEntity>> loadList(
|
Future<BuiltList<TaskEntity>> loadList(Credentials credentials, int page,
|
||||||
Credentials credentials, int createdAt, bool filterDeleted) async {
|
int createdAt, bool filterDeleted) async {
|
||||||
final url = credentials.url + '/tasks?created_at=$createdAt';
|
final url = credentials.url +
|
||||||
|
'/tasks?per_page=$kMaxRecordsPerPage&page=$page&created_at=$createdAt';
|
||||||
|
|
||||||
/* Server is incorrect if client isn't set
|
/* Server is incorrect if client isn't set
|
||||||
if (filterDeleted) {
|
if (filterDeleted) {
|
||||||
|
|
|
||||||
|
|
@ -73,9 +73,10 @@ class LoadTaskActivity {
|
||||||
}
|
}
|
||||||
|
|
||||||
class LoadTasks {
|
class LoadTasks {
|
||||||
LoadTasks({this.completer});
|
LoadTasks({this.completer, this.page = 1});
|
||||||
|
|
||||||
final Completer completer;
|
final Completer completer;
|
||||||
|
final int page;
|
||||||
}
|
}
|
||||||
|
|
||||||
class LoadTaskRequest implements StartLoading {}
|
class LoadTaskRequest implements StartLoading {}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
// Flutter imports:
|
// Flutter imports:
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
|
import 'package:invoiceninja_flutter/constants.dart';
|
||||||
|
|
||||||
// Package imports:
|
// Package imports:
|
||||||
import 'package:redux/redux.dart';
|
import 'package:redux/redux.dart';
|
||||||
|
|
@ -284,16 +285,24 @@ Middleware<AppState> _loadTasks(TaskRepository repository) {
|
||||||
repository
|
repository
|
||||||
.loadList(
|
.loadList(
|
||||||
state.credentials,
|
state.credentials,
|
||||||
|
action.page,
|
||||||
state.createdAtLimit,
|
state.createdAtLimit,
|
||||||
state.filterDeletedClients,
|
state.filterDeletedClients,
|
||||||
)
|
)
|
||||||
.then((data) {
|
.then((data) {
|
||||||
store.dispatch(LoadTasksSuccess(data));
|
store.dispatch(LoadTasksSuccess(data));
|
||||||
|
|
||||||
if (action.completer != null) {
|
if (data.length == kMaxRecordsPerPage) {
|
||||||
action.completer.complete(null);
|
store.dispatch(LoadTasks(
|
||||||
|
completer: action.completer,
|
||||||
|
page: action.page + 1,
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
if (action.completer != null) {
|
||||||
|
action.completer.complete(null);
|
||||||
|
}
|
||||||
|
store.dispatch(LoadVendors());
|
||||||
}
|
}
|
||||||
store.dispatch(LoadVendors());
|
|
||||||
}).catchError((Object error) {
|
}).catchError((Object error) {
|
||||||
print(error);
|
print(error);
|
||||||
store.dispatch(LoadTasksFailure(error));
|
store.dispatch(LoadTasksFailure(error));
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue