Search results

Customize ColorPicker

Custom Palette

By default, the Palette will be rendered with default colors. To load custom colors in the palette, specify the colors in the PresetColors property. To customize the color palette, add a custom class to palette tiles using OnTileRender event.

@using Syncfusion.EJ2.Blazor.Inputs
@using Newtonsoft.Json.Linq;

<div id="preview" style="@StyleValue"></div>
<h4>Select a color</h4>
<EjsColorPicker Mode="Syncfusion.EJ2.Blazor.Inputs.ColorPickerMode.Palette" CssClass="circle-palette" ModeSwitcher="false" Inline="true" ShowButtons="false" Columns="4" PresetColors="@CustomValues[0]" OnTileRender="BeforeCircleTileRender" ValueChange="OnChange"></EjsColorPicker>

@code{
    public string StyleValue = "background-color:#008000";
    public GetCurrentValue ColorValue { get; set; }
    public void OnChange(ColorPickerEventArgs args)
    {
        this.ColorValue = ((JObject)args.CurrentValue).ToObject<GetCurrentValue>();
        this.StyleValue = "background-color:" + this.ColorValue.hex;
        this.StateHasChanged();
    }
    public class GetCurrentValue
    {
        public string hex { get; set; }
        public string rgba { get; set; }
    }
    public void BeforeCircleTileRender(PaletteTileEventArgs args)
    {
        args.Element.AddClass(new string[] { "e-circle-palette" });
    }
    public List<object> CustomValues = new List<object> {
    new{
        Custom = new string[] {"#ef9a9a", "#e57373", "#ef5350", "#f44336", "#f48fb1", "#f06292",
                    "#ec407a", "#e91e63", "#ce93d8", "#ba68c8", "#ab47bc", "#9c27b0", "#b39ddb","#9575cd",
                    "#7e57c2", "#673AB7", "#9FA8DA", "#7986CB", "#5C6BC0", "#3F51B5", "#90CAF9", "#64B5F6",
                    "#42A5F5","#2196F3", "#81D4FA", "#4FC3F7", "#29B6F6", "#03A9F4", "#80DEEA", "#4DD0E1",
                    "#26C6DA", "#00BCD4", "#80CBC4", "#4DB6AC", "#26A69A", "#009688","#A5D6A7", "#81C784",
                    "#66BB6A", "#4CAF50", "#C5E1A5", "#AED581", "#9CCC65", "#8BC34A", "#E6EE9C","#DCE775",
                    "#D4E157", "#CDDC39" }
        }
   };
}

<style>
     #preview {
        height: 50px;
        width: 50%;
     }

    .e-container .e-palette .e-circle-palette {
        border: 0;
        height: 32px;
        width: 32px;
        border-radius: 20px;
        margin: 4px;
    }

    .circle-palette .e-container {
        background-color: transparent;
        border-color: transparent;
        box-shadow: none;
    }

    .e-container .e-palette .e-circle-palette.e-selected {
        outline: none;
    }
</style>

Output be like color-picker

Hide input area from picker

By default, the input area will be rendered in ColorPicker. To hide the input area from it, add e-hide-value class to ColorPicker using the CssClass property.

In the following sample, the ColorPicker is rendered without input area.

@using Syncfusion.EJ2.Blazor.Inputs

<h4>Choose a color</h4>
<EjsColorPicker ModeSwitcher="false" CssClass="e-hide-value"></EjsColorPicker>

Output be like color-picker

Custom Handle

ColorPicker handle shape and UI can be customized. Here, we have customized the handle as svg icon. The same way you can customize the handle based on your requirement.

The following sample show the customized color picker handle.

@using Syncfusion.EJ2.Blazor.Inputs

<EjsColorPicker Value="#344aae" CssClass="e-custom-picker" ModeSwitcher="false"></EjsColorPicker>

<style>
    .e-color-picker-tooltip.e-popup.e-popup-open {
    display: none;
    }
    .e-custom-picker .e-container .e-handler {
    background: transparent url('');
    font-size: 16px;
    height: 16px;
    line-height: 16px;
    margin-left: -8px;
    margin-top: -8px;
    border: none;
    box-shadow: none;
    width: 16px;
    }
</style>

Output be like color-picker