lazy_paginated_data_table 1.0.2 lazy_paginated_data_table: ^1.0.2 copied to clipboard
Lazy paginated data table.
This a PaginatedDataTable wrapper that allows it to support lazy loading
Features #
Allows lazy loading for PaginatedDataTable
Getting started #
Start by adding lazy_paginated_data_table to your pubspec.yaml or by running the following command
flutter pub get lazy_paginated_data_table
Usage #
import 'package:flutter/material.dart';
import 'package:lazy_paginated_data_table/lazy_paginated_data_table.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({Key? key}) : super(key: key);
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("Table"),
),
body: SingleChildScrollView(
child: LazyPaginatedDataTable<Person>(
getData: getData,
getTotal: () => Future.value(115),
availableRowsPerPage: [5, 10, 15, 20],
columns: [
DataColumn(label: Text("First name")),
DataColumn(label: Text("Last name")),
DataColumn(label: Text("Age")),
],
dataToRow: (data, indexInCurrentPage) {
return DataRow(cells: [
DataCell(Text(data.firstName)),
DataCell(Text(data.lastName)),
DataCell(Text("${data.age}")),
]);
},
),
),
);
}
Future<List<Person>> getData(PageInfo info) {
var result = <Person>[];
for (int i = 0; i < info.pageSize; i++) {
result.add(Person(
firstName: "firstName_${info.pageIndex * info.pageSize + 1}",
lastName: "lastName_${info.pageIndex * info.pageSize + 1}",
age: info.pageSize * info.pageIndex + i));
}
print("getting data {size: ${info.pageSize}, index: ${info.pageIndex}}");
return Future.delayed(Duration(milliseconds: 300), () => result);
}
}
class Person {
final String firstName;
final String lastName;
final int age;
Person({
required this.firstName,
required this.lastName,
required this.age,
});
}