KDialogs

Implementation of common, useful dialogs for displaying loading indicators, confirmation messages, content, error messages, and more. This README provides an overview of the project.

  • Strives to adhere to the design principles defined in Material 3.

Implementations:

  • showKDialogWithLoadingMessage:

    Displays a spinner with message and provides a function to stop the indicator.

        final close = await showKDialogWithLoadingMessage(context,message: "Loading Please Wait...");
        await Future.delayed(const Duration(seconds: 2));
        close();
    
  • showKDialogWithLoadingIndicator:

    Displays a spinner and provides a function to stop the indicator.

        final close = await showKDialogWithLoadingIndicator(context)
        await Future.delayed(const Duration(seconds: 2));
        close();
    
  • showBottomAlertKDialog:

    Displays a bottom modal that can show an error message, along with an option to retry, which returns a boolean 'true' if the retry action is taken.

        await showBottomAlertKDialog(context, message: "This is an error message", retryable: true);
    
  • showKDialogContent:

    Enables the display of content within a dialog and provides various additional operations.

       await showKDialogContent(
                context,
                closeOnOutsideTab: false,
                builder: (context) {
                return Column(
                    children: [
                    const Text("Hello there!!!"),
                    Container(
                        color: Colors.green,
                        width: 100.0,
                        height: 100.0,
                    )
                    ],
                );
                },
            );
    
  • showConfirmationKDialog:

    Displays a dialog with the option to cancel or accept, returning 'true' if the accept option is chosen.

      final response = await showConfirmationKDialog(context, title: "Confirm Message");
    
  • showAsyncProgressKDialog:

    Combines the various dialog implementations, enabling the ability to request confirmation, display loading indicators, show error dialogs, and present the retry option.

        // simple
     final resultvalue = await showAsyncProgressKDialog<String>(
                context,
                doProcess: () async {
                    await Future.delayed(const Duration(seconds: 2)); // process
                    return "value";
                    },
                showSuccessSnackBar: true,
            );
    
    // retryable and  confirmationRequired
    final resultvalue = await showAsyncProgressKDialog<String>(
                context,
                doProcess: () async {
                    await Future.delayed(const Duration(seconds: 2));
                    throw "This is an error indicating that the process could not be completed";
                },
                confirmationRequired: true,
                showSuccessSnackBar: true,
                loadingMessage: "Procesing...",
                retryable: true,
            );
    

Examples:

Example

Libraries

kdialogs