Skip to content

Latest commit

 

History

History
 
 

responsive_scaffold

responsive_scaffold

On mobile it shows a list and pushes to details and on tablet it shows the List and the selected item.

Getting Started

  • You can use this in two modes ResponsiveScaffold and ResponsiveScaffold.builder.
  • On Mobile the ListView will push to the details screen

mobile

push

  • On Tablet it will show a Master Detail View.

tablet

  • You can add additional Slivers to the Scrollview and the AppBar is optional.

Example

import 'package:flutter/material.dart';

import 'package:responsive_scaffold/responsive_scaffold.dart';

void main() => runApp(MyApp());

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: ResponsiveScaffold.builder(
        detailBuilder: (BuildContext context, int index) {
          return DetailsScreen(
            appBar: AppBar(
              elevation: 0.0,
              title: Text("Details"),
              actions: [
                IconButton(
                  icon: Icon(Icons.share),
                  onPressed: () {},
                ),
              ],
            ),
            body: Container(
              child: Center(
                child: Text("Item: $index"),
              ),
            ),
          );
        },
        slivers: <Widget>[
          SliverAppBar(
            title: Text("App Bar"),
          ),
        ],
        itemCount: 100,
        itemBuilder: (BuildContext context, int index) {
          return ListTile(
            leading: Text(index.toString()),
          );
        },
      ),
    );
  }
}