flutter_timeline 0.0.4+5 copy "flutter_timeline: ^0.0.4+5" to clipboard
flutter_timeline: ^0.0.4+5 copied to clipboard

outdated

a fully customizable & general timeline widget, based on real-world application references

example/lib/main.dart

import 'package:example/screen/cms_comments_demo.dart';
import 'package:example/screen/github_activity_demo.dart';
import 'package:example/screen/plain_timeline_demo.dart';
import 'package:flutter/material.dart';
import 'package:flutter_timeline/flutter_timeline.dart';

void main() {
  runApp(TimelineDemoApp());
}

class TimelineDemoApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Timeline',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.blue,
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      routes: {
        PlainTimelineDemoScreen.routeName: (c) => PlainTimelineDemoScreen(),
        DeskTimelineDemoScreen.routeName: (c) => DeskTimelineDemoScreen(),
        GithubActivityDemo.routeName: (c) => GithubActivityDemo(),
      },
      home: DemoHomePage(title: 'Flutter Timeline Demo'),
    );
  }
}

List<DemoScreen> demos = [
  DemoScreen(
      name: "plain timeline",
      description: "simplest timeline demo",
      cover: null,
      route: PlainTimelineDemoScreen.routeName),
  DemoScreen(
      name: "github activity",
      description: "github's activity timeline demo",
      cover: null,
      route: GithubActivityDemo.routeName),
  DemoScreen(
      name: "genoplan desk",
      description: "genoplan's desk crm app timeline demo",
      cover: null,
      route: DeskTimelineDemoScreen.routeName),
  DemoScreen(
      name: "shopify",
      description: "timeline demo from shopify admin",
      cover: null,
      route: PlainTimelineDemoScreen.routeName),
];

class DemoHomePage extends StatefulWidget {
  DemoHomePage({Key key, this.title}) : super(key: key);
  final String title;

  @override
  _DemoHomePageState createState() => _DemoHomePageState();
}

class _DemoHomePageState extends State<DemoHomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: _buildBody(),
    );
  }

  Widget _buildDemoEntries() {
    return ListView.builder(
      itemBuilder: (c, i) {
        var data = demos[i];
        return ListTile(
          title: Text(data.name),
          subtitle: Text(data.description),
          onTap: () {
            Navigator.of(context).pushNamed(data.route);
          },
        );
      },
      itemCount: demos.length,
    );
  }

  Widget _buildBody() {
    return _buildDemoEntries();
  }
}

class DemoScreen {
  DemoScreen(
      {@required this.name,
      @required this.description,
      @required this.cover,
      @required this.route});

  final String name;
  final String description;
  final String cover;
  final String route;
}
135
likes
0
pub points
86%
popularity

Publisher

verified publishergrida.co

a fully customizable & general timeline widget, based on real-world application references

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter

More

Packages that depend on flutter_timeline