Модульный монолит на Blazor? Легко! Calabonga.Blazor.AppDefinitions позволяет выделить модули (Components) в отдельные сборки (в отдельные проекты), чтобы предоставить возможность разным командам разрабатывать разные модули одного приложения. Для установки в проект достаточно установить nuget-пакет Calabonga.Blazor.AppDefinitions.
Помимо всего, эта сборка позволяет навести порядок в вашем Program.cs. Можно всё разложить "по полочкам". А еще можно реализовать систему плагинов. Чтобы воспользоваться сборкой надо просто установить nuget-пакет Calabonga.Blazor.AppDefinitions.
В сборку Calabonga.Blazor.AppDefinitions входят контракты прочие необходимые для работы системы модулей артифакты.
Сборка Calabonga.Blazor.AppDefinitions.Template является шаблоном для Visual Studio (Rider), которые позволит "на лету" создать примеры модульного приложения на Blazor.
Используя Calabonga.Blazor.AppDefinitions можно с легкостью реализовать предложенную ниже архитектуру. Модули на frontend работают с микросервисами на backend. Причем, можно позволить модулям UI "ходить" в разные сервисы на стороне backend.
- Calabonga.Blazor.AppDefinitions - nuget-пакет (этот репозиторий), который собой представляет набор контактов для использования в модулях и в основном приложении.
- Calabonga.Blazor.AppDefinitions.Template - nuget-пакет, установка которого добавит в список шаблонов новый шаблон
Calabonga.Blazor.Shell. Этот шаблон создает проект Blazor Server приложения как основа для модульного монолита (Shell). Шаблон работает и для Visual Studio, и для JetBrains Rider, и для dotnet CLI.
На видео показано превращение обыкновенного проекта WeatherForecast на Blazor, созданное из стандартного шаблона в Visual Studio, в приложение Shell с Plugins. То есть из простого шаблона создается приложение на Blazor, которое "умеет" загружать модули.
Application Definitions for Blazor application. The small but very helpful package that can help you to organize modules in Blazor application.
Обновление до NET 9.0
Обновление 1.2.0 добавило возможность сортировки модулей, а также возможность скрывать их из меню при необходимости.
-
В интерфейс
IBlazorModuleдобавлены новые свойстваOrderIndexиVisibility(OrderIndexandVisibilityproperties added intoIBlazorModulemetadata interface.)./// <summary> /// Module marker for Blazor application /// </summary> public interface IBlazorModule { + /// <summary> + /// Visibility for UI. For example, NavMenu + /// </summary> + bool IsHidden { get; } + /// <summary> + /// Order index sorting operations + /// </summary> + int OrderIndex { get; } /// <summary> /// Module title /// </summary> string Title { get; } /// <summary> /// Brief module description /// </summary> string Description { get; } /// <summary> /// Navigation Route /// </summary> string Route { get; } /// <summary> /// NavLink type match /// </summary> NavLinkMatch Match { get; } } -
Добавлен новый базовый абстрактный класс
BlazorModule, в котором заданyые значения по умолчанию для свойствOrderIndexиVisibility(Base abstract class BlazorModule created with default values for some properties.).
- Добавлен сбор метаданных от модулей для возможности формировать
NavLinkдинамически. - Добавлены методы получения списка
Assembly - Добавления расширения для формирования ссылок для навигации.
- Первый релиз сборки.

