-
Taha Tesser authored
Add ability to customize `NavigationBar` indicator overlay and fix indicator shape for the overlay (#138901) fixes [Provide ability to override `NavigationBar` indicator ink response overlay](https://github.com/flutter/flutter/issues/138850) fixes [`NavigationBar.indicatorShape` is ignored, `NavigationBarThemeData.indicatorShape` is applied to the indicator inkwell](https://github.com/flutter/flutter/issues/138900) ### Code sample <details> <summary>expand to view the code sample</summary> ```dart import 'package:flutter/material.dart'; void main() => runApp(const MyApp()); class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return const MaterialApp( debugShowCheckedModeBanner: false, home: Scaffold( bottomNavigationBar: NavigationBarExample(), ), ); } } class NavigationBarExample extends StatefulWidget { const NavigationBarExample({super.key}); @override State<NavigationBarExample> createState() => _NavigationBarExampleState(); } class _NavigationBarExampleState extends State<NavigationBarExample> { int index = 0; @override Widget build(BuildContext context) { return NavigationBar( elevation: 0, overlayColor: const MaterialStatePropertyAll<Color>(Colors.transparent), // indicatorShape: RoundedRectangleBorder( // borderRadius: BorderRadius.circular(4.0), // ), indicatorColor: Colors.transparent, selectedIndex: index, onDestinationSelected: (int index) { setState(() { this.index = index; }); }, destinations: const <Widget>[ NavigationDestination( selectedIcon: Icon(Icons.home_filled), icon: Icon(Icons.home_outlined), label: 'Home', ), NavigationDestination( selectedIcon: Icon(Icons.favorite), icon: Icon(Icons.favorite_outline), label: 'Favorites', ), ], ); } } ``` </details> ### Before #### Cannot override `NavigationBar` Indicator ink well overlay data:image/s3,"s3://crabby-images/1782f/1782f3e9921c683519c826ef14fbc747271ac1b5" alt="Screenshot 2023-11-22 at 18 22 48" #### Indicator shape is ignored for the indicator overlay data:image/s3,"s3://crabby-images/35e52/35e52ce5c30a863db9e36cf24d0f145e6fe3880b" alt="Screenshot 2023-11-22 at 15 29 52" ### After #### Can use `NavigationBar.overlayColor` or `NavigationBarThemeData.NavigationBar` to override default indicator overlay `overlayColor: MaterialStatePropertyAll<Color>(Colors.red.withOpacity(0.33)),` data:image/s3,"s3://crabby-images/97eb5/97eb5dfb5623fb80966374d5ee7396678e5bac5a" alt="Screenshot 2023-11-22 at 18 22 08" `overlayColor: MaterialStatePropertyAll<Color>(Colors.transparent),` data:image/s3,"s3://crabby-images/8f63e/8f63ef73904bb45ef2e8508ac7704b8c1adfde6e" alt="Screenshot 2023-11-22 at 18 22 25" #### Indicator shape is respected for the indicator overlay data:image/s3,"s3://crabby-images/f5e9e/f5e9eae075a746b2d05dc67f445104d6153122f7" alt="Screenshot 2023-11-22 at 15 30 36"