// Copyright 2014 The Flutter Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // Template: dev/snippets/config/templates/stateless_widget_material.tmpl // // Comment lines marked with "▼▼▼" and "▲▲▲" are used for authoring // of samples, and may be ignored if you are just exploring the sample. // Flutter code sample for Scaffold.of // //*************************************************************************** //* ▼▼▼▼▼▼▼▼ description ▼▼▼▼▼▼▼▼ (do not modify or remove section marker) // When the [Scaffold] is actually created in the same `build` function, the // `context` argument to the `build` function can't be used to find the // [Scaffold] (since it's "above" the widget being returned in the widget // tree). In such cases, the following technique with a [Builder] can be used // to provide a new scope with a [BuildContext] that is "under" the // [Scaffold]: //* ▲▲▲▲▲▲▲▲ description ▲▲▲▲▲▲▲▲ (do not modify or remove section marker) //*************************************************************************** import 'package:flutter/material.dart'; void main() => runApp(const MyApp()); /// This is the main application widget. class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); static const String _title = 'Flutter Code Sample'; @override Widget build(BuildContext context) { return const MaterialApp( title: _title, home: MyStatelessWidget(), ); } } /// This is the stateless widget that the main application instantiates. class MyStatelessWidget extends StatelessWidget { const MyStatelessWidget({Key? key}) : super(key: key); @override //******************************************************************** //* ▼▼▼▼▼▼▼▼ code ▼▼▼▼▼▼▼▼ (do not modify or remove section marker) Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: const Text('Demo')), body: Builder( // Create an inner BuildContext so that the onPressed methods // can refer to the Scaffold with Scaffold.of(). builder: (BuildContext context) { return Center( child: ElevatedButton( child: const Text('SHOW BOTTOM SHEET'), onPressed: () { Scaffold.of(context).showBottomSheet<void>( (BuildContext context) { return Container( alignment: Alignment.center, height: 200, color: Colors.amber, child: Center( child: Column( mainAxisSize: MainAxisSize.min, children: <Widget>[ const Text('BottomSheet'), ElevatedButton( child: const Text('Close BottomSheet'), onPressed: () { Navigator.pop(context); }, ) ], ), ), ); }, ); }, ), ); }, ), ); } //* ▲▲▲▲▲▲▲▲ code ▲▲▲▲▲▲▲▲ (do not modify or remove section marker) //******************************************************************** }