C#/Blazor

[Blazor] BlazorComponentUtilities 의 CssBuilder, StyleBuilder 사용하기

kjun.kr 2023. 8. 3. 22:33
728x90

BlazorComponentUtilities 의 CssBuilder, StyleBuilder 사용하면 내가 원하는 스타일을 코드로 지정할 수 있습니다.

1. BlazorComponentUtilities Nuget package 설치

_Imports.razor 에 @using BlazorComponentUtilities 추가합니다.

2. 간단한 Style 적용 예시

@page "/"

<PageTitle>Index</PageTitle>

<button style="@testButtonStyle" onclick="@Onclick">
    test
    </button>

@code
{
    private bool isTest {get;set;} = false;

    private string testButtonStyle => new StyleBuilder()
                                    .AddStyle("width", "100%", isTest)
                                    .AddStyle("color", "red", isTest)
                                    .Build();

    private void Onclick(MouseEventArgs e)
    {
        isTest = !isTest;
    }
}

위처럼 StyleBuilder 를 통해 어떤 조건에 부합되는 경우 style 을 적용할 수 있습니다.

isTest 가 true 인 경우 width:100% 가 적용되며

isTest 가 false 인 경우 color:red 가 적용됩니다.

[결과 화면]

3. Component 를 이용한 적용 예시

ButtonStyle.cs

namespace Blazor.ComponentUtiitiesTest.Shared
{
    public enum ButtonStyle
    {
        Primary, Secondary, Outlined
    }
}

TestButton.razor

<button class="@buttonClass" style="@buttonStyle @Style" disabled="@IsDisabled" @onclick="OnClick">
    @Text 
</button>

@code {

    /// <summary>
    /// 적용할 Style
    /// </summary>
    [Parameter]
    public ButtonStyle ButtonStyle { get; set; } = ButtonStyle.Primary;

    /// <summary>
    /// 버튼에 표시될 Text
    /// </summary>
    [Parameter]
    public string? Text { get; set; }

    /// <summary>
    /// 너비 100% 로 할것인지 여부
    /// </summary>
    [Parameter]
    public bool IsFullWidth { get; set; }

    /// <summary>
    /// Disable 여부
    /// </summary>
    [Parameter]
    public bool IsDisabled { get; set; }

    /// <summary>
    /// 클릭 이벤트
    /// </summary>
    [Parameter]
    public EventCallback<MouseEventArgs> OnClick { get; set; }

    /// <summary>
    /// Class
    /// </summary>
    [Parameter]
    public string? Class { get; set; }

    /// <summary>
    /// Style
    /// </summary>
    [Parameter]
    public string? Style { get; set; }

    private string buttonClass => new CssBuilder()
                                .AddClass("button")
                                .AddClass("primary", ButtonStyle == ButtonStyle.Primary) // ButtonStyle 이 Primary 인 경우 primary 적용
                                .AddClass("secondary", ButtonStyle == ButtonStyle.Secondary) // ButtonStyle 이 Secondary 인 경우 secondary 적용
                                .AddClass("outlined", ButtonStyle == ButtonStyle.Outlined) // ButtonStyle 이 Outlined 인 경우 outlined 적용
                                .AddClass("disabled", IsDisabled)
                                .AddClass("Class", !string.IsNullOrWhiteSpace(Class))
                                .Build();

    private string buttonStyle => new StyleBuilder()
                                .AddStyle("width", "100%", IsFullWidth)
                                .AddStyle("color", "red", IsFullWidth)
                                .Build();
}

TestButton.razor.css

.button {
    border: none;
    padding: 10px 40px;
    margin : 5px;
    font-size: 20px;
    transition: 0.3s;
    cursor: pointer;
}

    .button:hover:enabled {
        background-color: #CCCCCC;
    }

.primary {
    background-color: #302D83;
    color: white;
}

.secondary {
    background-color: #7362D8;
    color: lightgray;
}

.outlined {
    background-color: transparent;
    color: black;
    border: 1px solid black;
}

.disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

Index.razor

@page "/"

<PageTitle>Index</PageTitle>
<TestButton Text="First Button" ButtonStyle="ButtonStyle.Primary" />
<TestButton Text="Secondary Button" ButtonStyle="ButtonStyle.Secondary" />
<TestButton Text="Outlined Button" ButtonStyle="ButtonStyle.Outlined" OnClick="Onclick" />
<TestButton Text="Disabled FullWidth Button"
            Style="border: 3px solid blue;" Class="mt-4" IsDisabled="true" IsFullWidth="true" />

<button style="@testButtonStyle" onclick="@Onclick">
    test
</button>

@code
{
    private bool isTest {get;set;} = false;

    private string testButtonStyle => new StyleBuilder()
                                    .AddStyle("width", "100%", isTest)
                                    .AddStyle("color", "red", !isTest)
                                    .Build();

    private void Onclick(MouseEventArgs e)
    {
        isTest = !isTest;
    }
}

위 코드를 보면 알수 있듯이 CssBuilder 를 이용하여 css 에 정의된 내용을 선택하여 적용할 수 있으며 사용자가 정의한 Style 도 적용가능합니다.

실행결과

[Source]

https://github.com/kei-soft/Blazor.AppTest/tree/master/Blazor.ComponentUtiitiesTest

 

728x90