flutter_easy_dialogs 1.0.8 copy "flutter_easy_dialogs: ^1.0.8" to clipboard
flutter_easy_dialogs: ^1.0.8 copied to clipboard

Easy, lightweight and flexible service for showing dialogs inside your Flutter application.

FlutterEasyDialogs #

Flutter overlay based service for easy usage of different kinds of 'dialogs'.

Features #

  • Different pre-built dialogs and animations
  • Flexible mechanism of integrating custom self-built dialogs and animations
  • Show dialogs in any place of the application

Install #

In the pubspec.yaml of your flutter project, add the following dependency:

dependencies:
  flutter_easy_dialogs: <latest_version>

In your library add the following import:

import 'package:flutter_easy_dialogs/flutter_easy_dialogs.dart'

Getting started #

Wrap your MaterialApp with FlutterEasyDialogs.builder().

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      builder: FlutterEasyDialogs.builder(),
    );
  }
}

That's it. Now you are able to call show methods from EasyDialogController like so:

 FlutterEasyDialogs.dialogsController.showBanner(
      content: ElevatedButton(
        style: ElevatedButton.styleFrom(primary: Colors.red),
        onPressed: () {},
        child: const Text(
          'BANNER',
          style: TextStyle(fontSize: 30),
        ),
      )
    );

Or

 FlutterEasyDialogs.dialogsController.showModalBanner(
   content: Container(
     height: 200.0,
     width: 200.0,
     color: Colors.red,
     child: const Icon(
       Icons.home,
       size: 60,
     ),
   ),
 );

Also you can provide your own custom dialog agent.


int? _customDialogId;

class CustomDialogAgent extends EasyDialogAgentBase {
  CustomDialogAgent({required super.overlayController});

  @override
  Future<void> hide({AgentHideParams? params}) async {
    super.overlayController.removeCustomDialog(_customDialogId!);
  }

  @override
  Future<void> show({required CustomAgentShowParams params}) async {
    _customDialogId = super.overlayController.insertCustomDialog(
          Align(
            alignment: Alignment.bottomCenter,
            child: Container(
              height: 200.0,
              width: 200.0,
              color: params.color,
              child: Center(child: params.content),
            ),
          ),
        );
  }
}

class CustomAgentShowParams extends AgentShowParams {
  final Color color;

  const CustomAgentShowParams({
    required super.theme,
    required super.content,
    required this.color,
  });
}


class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return MaterialApp(  
      builder: (context, child) {
        final builder = FlutterEasyDialogs.builder(
          /// Provide custom dialog agent
          customAgentBuilder: (overlayController) =>
              [CustomDialogAgent(overlayController: overlayController)],
        );

        return builder(context, child);
      },
    );
  }
}

Usage #

Show dialog example:

 FlutterEasyDialogs.dialogsController.showBanner(
      onDismissed: () {},
      content: ElevatedButton(
        style: ElevatedButton.styleFrom(primary: Colors.red),
        onPressed: () {},
        child: const Text(
          'BANNER',
          style: TextStyle(fontSize: 30),
        ),
      ),
      durationUntilHide: Duration(milliseconds: _autoHideDuration.toInt()),
      autoHide: true,
      position: EasyDialogPosition.top,
      animationType: EasyPositionedAnimationType.fade,
      dismissibleType: EasyPositionedDismissibleType.swipe,
    );

Theming #

It's possible to pre-configure some settings for dialogs using FlutterEasyDialogsThemeData.

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      builder: (context, child) {
        final builder = FlutterEasyDialogs.builder(
          theme: FlutterEasyDialogsThemeData(
            easyBannerTheme: EasyBannerThemeData.light(),
            easyModalBannerTheme: EasyModalBannerThemeData.light(),
          ),
        );

        return builder(context, child);
      },
    );
  }
}

Positioned dialogs #

Slide:

Slide

Fade:

Fade

Expansion:

Expansion

Fullscreen dialogs #

Modal_Banner

Special thanks to back_button_interceptor

58
likes
0
pub points
85%
popularity

Publisher

verified publisherfeduke-nukem.dev

Easy, lightweight and flexible service for showing dialogs inside your Flutter application.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

back_button_interceptor, flutter

More

Packages that depend on flutter_easy_dialogs