page_selector_demo.dart 3.03 KB
Newer Older
1 2 3 4 5 6
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'package:flutter/material.dart';

Hans Muller's avatar
Hans Muller committed
7
class _PageSelector extends StatelessWidget {
8
  const _PageSelector({ this.icons });
9

10
  final List<Icon> icons;
11

12
  void _handleArrowButtonPress(BuildContext context, int delta) {
13
    final TabController controller = DefaultTabController.of(context);
Hans Muller's avatar
Hans Muller committed
14
    if (!controller.indexIsChanging)
15
      controller.animateTo((controller.index + delta).clamp(0, icons.length - 1));
16 17
  }

18
  @override
Hans Muller's avatar
Hans Muller committed
19 20 21
  Widget build(BuildContext context) {
    final TabController controller = DefaultTabController.of(context);
    final Color color = Theme.of(context).accentColor;
22 23 24 25 26 27 28 29 30 31 32 33 34 35
    return new SafeArea(
      top: false,
      bottom: false,
      child: new Column(
        children: <Widget>[
          new Container(
            margin: const EdgeInsets.only(top: 16.0),
            child: new Row(
              children: <Widget>[
                new IconButton(
                  icon: const Icon(Icons.chevron_left),
                  color: color,
                  onPressed: () { _handleArrowButtonPress(context, -1); },
                  tooltip: 'Page back'
Hans Muller's avatar
Hans Muller committed
36
                ),
37 38 39 40 41 42 43 44 45 46 47 48
                new TabPageSelector(controller: controller),
                new IconButton(
                  icon: const Icon(Icons.chevron_right),
                  color: color,
                  onPressed: () { _handleArrowButtonPress(context, 1); },
                  tooltip: 'Page forward'
                )
              ],
              mainAxisAlignment: MainAxisAlignment.spaceBetween
            )
          ),
          new Expanded(
49 50 51 52 53 54 55 56 57 58 59 60 61
            child: new IconTheme(
              data: new IconThemeData(
                size: 128.0,
                color: color,
              ),
              child: new TabBarView(
                children: icons.map((Icon icon) {
                  return new Container(
                    padding: const EdgeInsets.all(12.0),
                    child: new Card(
                      child: new Center(
                        child: icon,
                      ),
62
                    ),
63 64 65
                  );
                }).toList()
              ),
66
            ),
Hans Muller's avatar
Hans Muller committed
67
          ),
68 69
        ],
      ),
Hans Muller's avatar
Hans Muller committed
70 71 72
    );
  }
}
73

Hans Muller's avatar
Hans Muller committed
74
class PageSelectorDemo extends StatelessWidget {
75
  static const String routeName = '/material/page-selector';
76 77 78 79 80 81 82
  static final List<Icon> icons = <Icon>[
    const Icon(Icons.event, semanticLabel: 'Event'),
    const Icon(Icons.home, semanticLabel: 'Home'),
    const Icon(Icons.android, semanticLabel: 'Android'),
    const Icon(Icons.alarm, semanticLabel: 'Alarm'),
    const Icon(Icons.face, semanticLabel: 'Face'),
    const Icon(Icons.language, semanticLabel: 'Language'),
Hans Muller's avatar
Hans Muller committed
83 84 85 86
  ];

  @override
  Widget build(BuildContext context) {
87
    return new Scaffold(
88
      appBar: new AppBar(title: const Text('Page selector')),
Hans Muller's avatar
Hans Muller committed
89 90 91 92
      body: new DefaultTabController(
        length: icons.length,
        child: new _PageSelector(icons: icons),
      ),
93 94 95
    );
  }
}