MT.MudBlazor.Extensions 1.0.2

dotnet add package MT.MudBlazor.Extensions --version 1.0.2                
NuGet\Install-Package MT.MudBlazor.Extensions -Version 1.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="MT.MudBlazor.Extensions" Version="1.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MT.MudBlazor.Extensions --version 1.0.2                
#r "nuget: MT.MudBlazor.Extensions, 1.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install MT.MudBlazor.Extensions as a Cake Addin
#addin nuget:?package=MT.MudBlazor.Extensions&version=1.0.2

// Install MT.MudBlazor.Extensions as a Cake Tool
#tool nuget:?package=MT.MudBlazor.Extensions&version=1.0.2                

MT.MudBlazor.Extensions

Extensions to MudBlazor component library

Nuget

Installing

You can install from Nuget using the following command:

Install-Package MT.MudBlazor.Extensions

Or via the Visual Studio package manger.

Basic Usage

The extensions have been built within the MudBlazor namespace so as long as you're importing that in your _Imports.razor file you're good to go.

As per the MudBlazor Getting Started docs, add the following using statement in your _Imports.razor

@using MudBlazor

DrawerService

A MudDrawer is a panel that is overlaid on top of a page and slides in from the side. This provides another great option for rendering forms or just informational content.

Generally, drawers are used for navigation but it's just another container for any type of content just like the MudDialog.
Unlike the MudDialog, however, the drawer can currently only be inline, embedded in the page from where it is to be triggered.

This poses a problem when you want to abstract the content of a drawer for say a form in it's own component and show ad-hoc when a button is clicked the way dialogs work with the IDialogService

IDrawerService provides IDialogService like functionality but for drawers!

Register DrawerService in ServiceProvider

In your Program.cs or wherever you configure your services

using Microsoft.AspNetCore.Components.WebAssembly.Hosting;

var builder = await WebAssemblyHostBuilder.CreateDefault(args);

builder.Services
    .AddMudServices()
    .AddMudBlazorDrawerService();

Add MudDrawerProvider component to layout

In your Layout.razor

<MudLayout>
    <MudDrawerProvider Width="600px" />
</MudLayout>

A subset of original Drawer options can be configured globally as default options for all drawers that are opened with the IDrawerService

Create drawer content component

Create a component, e.g., DrawerPane.razor, that contains content of your drawer pane

<MudContainer>
    This is some content in the pane.  The message passed here is <strong>@Message</strong>
</MudContainer>

<MudDivider Class="my-5" />

<MudContainer>
    <MudStack Row="true" Justify="Justify.SpaceBetween">
        <MudButton OnClick="Close" Variant="Variant.Filled">Close</MudButton>
        <MudButton Color="Color.Primary" OnClick="Submit" Variant="Variant.Filled">Submit</MudButton>
    </MudStack>
</MudContainer>

@code {
    [CascadingParameter] 
    private MudDrawerInstance DrawerPane { get; set; }
    
    [Parameter] 
    public string Message { get; set; }

    private void Submit()
    {
        DrawerPane.Close();
    }

    private void Close()
    {
        DrawerPane.Cancel();
    }
}

Trigger the drawer from a page

In a page, e.g., DrawerTestPage.razor, show the drawer with your content by using the IDrawerService

@page "/DrawerTest"

@inject IDialogService DialogService

<MudPaper Height="1200px">
    <MudStack>
        <MudPaper Class="pa-3">
            Click <MudButton Variant="Variant.Outlined" OnClick="OpenServiceDrawer">here</MudButton> to trigger a test DrawerService drawer.
        </MudPaper>
        <MudPaper Class="pa-3">
            Click <MudButton Variant="Variant.Outlined" OnClick="OpenInlineDrawer">here</MudButton> to trigger a test inline drawer on this page.
        </MudPaper>
    </MudStack>

    <MudDrawer Open="@DrawerOpen" OpenChanged="v => DrawerOpen = v" Anchor="Anchor.Right" ClipMode="DrawerClipMode.Never" Width="600px" Variant="DrawerVariant.Temporary">
        <MudDrawerHeader>
            <MudText Typo="Typo.h6">Inline Test Drawer</MudText>
        </MudDrawerHeader>
        <MudContainer>
            This is an inline temporary drawer to demonstrate difference with the one with drawer service
        </MudContainer>
    </MudDrawer>
</MudPaper>

@code {
    private bool DrawerOpen { get; set; }
    
    private async Task OpenServiceDrawer()
    {
        var drawer = DrawerService.Show<DrawerContent>("Test Drawer", new DrawerParameters().Add("Message", "Hello world!"), new DrawerOptions());

        var result = await drawer.Result;

        if (!result.Cancelled)
        {
            SnackBar.Add("Drawer was closed on action", Severity.Success);
        }
    }

    private void OpenInlineDrawer()
    {
        DrawerOpen = !DrawerOpen;
    }
}

Change Log

  • 0.0.1 Pre-release
  • 1.0.0 Initial release
  • 1.0.1 Documentation update

Github Repository | Nuget Package

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 5,032 8/20/2022
1.0.1 430 8/19/2022
1.0.0 422 8/18/2022
0.0.1 429 8/18/2022