// 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. import 'package:flutter/material.dart'; import 'package:flutter_gallery/demo/shrine/backdrop.dart'; import 'package:flutter_gallery/demo/shrine/expanding_bottom_sheet.dart'; import 'package:flutter_gallery/demo/shrine/model/app_state_model.dart'; import 'package:flutter_gallery/demo/shrine/model/product.dart'; import 'package:flutter_gallery/demo/shrine/supplemental/asymmetric_view.dart'; import 'package:scoped_model/scoped_model.dart'; class ProductPage extends StatelessWidget { const ProductPage({Key? key, this.category = Category.all}) : super(key: key); final Category category; @override Widget build(BuildContext context) { return ScopedModelDescendant<AppStateModel>( builder: (BuildContext context, Widget? child, AppStateModel model) { return AsymmetricView(products: model.getProducts()); }); } } class HomePage extends StatelessWidget { const HomePage({ this.expandingBottomSheet, this.backdrop, Key? key, }) : super(key: key); final ExpandingBottomSheet? expandingBottomSheet; final Backdrop? backdrop; @override Widget build(BuildContext context) { return Stack( children: <Widget>[ if (backdrop != null) backdrop!, Align(alignment: Alignment.bottomRight, child: expandingBottomSheet), ], ); } }