flex_grid 5.0.3 flex_grid: ^5.0.3 copied to clipboard
The FlexGrid display data in a tabular format. It is including frozened column/row,loading more, high performance and better experience in TabBarView/PageView.
example/lib/main.dart
import 'package:ff_annotation_route_library/ff_annotation_route_library.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:oktoast/oktoast.dart';
import 'example_route.dart';
import 'example_routes.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return OKToast(
child: MaterialApp(
title: 'FlexGrid demo',
debugShowCheckedModeBanner: false,
theme: ThemeData(
primarySwatch: Colors.blue,
),
builder: (BuildContext c, Widget w) {
if (!kIsWeb) {
final MediaQueryData data = MediaQuery.of(c);
w = MediaQuery(
data: data.copyWith(textScaleFactor: 1.0),
child: w,
);
}
return w;
},
initialRoute: Routes.fluttercandiesMainpage,
onGenerateRoute: (RouteSettings settings) {
return onGenerateRoute(
settings: settings,
getRouteSettings: getRouteSettings,
routeSettingsWrapper: (FFRouteSettings ffRouteSettings) {
if (ffRouteSettings.name == Routes.fluttercandiesMainpage ||
ffRouteSettings.name == Routes.fluttercandiesDemogrouppage) {
return ffRouteSettings;
}
return ffRouteSettings.copyWith(
builder: () => CommonWidget(
child: ffRouteSettings.builder(),
title: ffRouteSettings.routeName,
));
},
);
},
));
}
}
class CommonWidget extends StatelessWidget {
const CommonWidget({
this.child,
this.title,
});
final Widget child;
final String title;
@override
Widget build(BuildContext context) {
return SafeArea(
bottom: true,
child: Scaffold(
appBar: AppBar(
title: Text(
title,
),
),
body: child,
),
);
}
}
String get imageTestUrl => 'https://photo.tuchong.com/4870004/f/298584322.jpg';