Skip to content

💡Abp RadzenUI is a UI theme built on the Abp framework and developed using the Radzen Blazor component

License

Notifications You must be signed in to change notification settings

ShaoHans/Abp.RadzenUI

Repository files navigation

Abp RadzenUI

Abp RadzenUI is a UI theme built on the Abp framework and developed using the Radzen Blazor component.

build AbpRadzen.Blazor.Server.UI AbpRadzen.Blazor.Server.UI Abp.RadzenUI

English | 简体中文

❤️Demo Site

http://49.65.124.146:20103/

UserName: test

Password: 1q2w#E*

🎨Page display

1.The login page

image

2.The list page

image

3.The other list page with datagrid filter

image

4.Theme switch

image

🌱How to use

1. Create new solution by abp cli

abp new CRM -u blazor-server -dbms PostgreSQL -m none --theme leptonx-lite -csf

2. Install AbpRadzen.Blazor.Server.UI on your CRM.Blazor project

dotnet add package AbpRadzen.Blazor.Server.UI

3. Remove the nuget packages and code associated with the leptonx-lite theme

This is mainly the code in the CRMBlazorModule class and delete files in the Pages directory

4. Config Abp RadzenUI

Add the ConfigureAbpRadzenUI method on your ConfigService method

private void ConfigureAbpRadzenUI()
{
    // Configure AbpRadzenUI
    Configure<AbpRadzenUIOptions>(options =>
    {
        // this is very imporant to set current web application's pages to the AbpRadzenUI module
        options.RouterAdditionalAssemblies = [typeof(Home).Assembly];

        // other settings
        //options.TitleBar = new TitleBarSettings
        //{
        //    ShowLanguageMenu = false,
        //    Title = "CRM"
        //};
        //options.LoginPage = new LoginPageSettings
        //{
        //    LogoPath = "xxx/xx.png"
        //};
        //options.Theme = new ThemeSettings
        //{
        //    Default = "material",
        //    EnablePremiumTheme = true,
        //};
    });

    // Configure AbpMultiTenancyOptions, this will affect login page that whether need to switch tenants
    Configure<AbpMultiTenancyOptions>(options =>
    {
        options.IsEnabled = MultiTenancyConsts.IsEnabled;
    });

    // Configure AbpLocalizationOptions
    Configure<AbpLocalizationOptions>(options =>
    {
        // set AbpRadzenUIResource as BaseTypes for your application's localization resources
        var crmResource = options.Resources.Get<CRMResource>();
        crmResource.AddBaseTypes(typeof(AbpRadzenUIResource));

        // if you don't want to use the default language list, you can clear it and add your own languages
        options.Languages.Clear();
        options.Languages.Add(new LanguageInfo("en", "en", "English"));
        options.Languages.Add(new LanguageInfo("fr", "fr", "Français"));
        options.Languages.Add(new LanguageInfo("zh-Hans", "zh-Hans", "简体中文"));
    });

    // Configure your web application's navigation menu
    Configure<AbpNavigationOptions>(options =>
    {
        options.MenuContributors.Add(new CRMMenuContributor());
    });
}

then add the following code on your OnApplicationInitialization method

app.UseRadzenUI();

yuo can refer to the sample code CRMBlazorWebModule

5. Config Menu

When you add razor page and need config menu , you should edit the CRMMenuContributor class

6. Don't forget migrate your database when you first run the app

About

💡Abp RadzenUI is a UI theme built on the Abp framework and developed using the Radzen Blazor component

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published