Jinget.Blazor
6.2.5
Prefix Reserved
See the version list below for details.
dotnet add package Jinget.Blazor --version 6.2.5
NuGet\Install-Package Jinget.Blazor -Version 6.2.5
<PackageReference Include="Jinget.Blazor" Version="6.2.5" />
paket add Jinget.Blazor --version 6.2.5
#r "nuget: Jinget.Blazor, 6.2.5"
// Install Jinget.Blazor as a Cake Addin #addin nuget:?package=Jinget.Blazor&version=6.2.5 // Install Jinget.Blazor as a Cake Tool #tool nuget:?package=Jinget.Blazor&version=6.2.5
Jinget Blazor
Blazor components optimised for RTL languaged such as Farsi, Arabic etc.
Components list:
- Captcha
- Date Picker
- Date Range Picker
- Message Box
- Modal
- List
- Table
- Dynamic Form
How to Use:
Download the package from NuGet using Package Manager:
Install-Package Jinget.Blazor
You can also use other methods supported by NuGet. Check Here for more information.
Configuration
References:
Add reference to jinget.core.css
in your _Host.razor
or App.razor
files.
<link href="_content/Jinget.Blazor/css/jinget.core.css" rel="stylesheet" />
Install MudBlazor
and add reference to MudBlazor.min.js
in your _Host.razor
or App.razor
files.
<script src="_content/MudBlazor/MudBlazor.min.js"></script>
Install Texnomic.Blazor.JsonViewer
and add reference to jsonViewer.js
in your _Host.razor
or App.razor
files.
<script src="_content/Texnomic.Blazor.JsonViewer/scripts/jsonViewer.js"></script>
Add reference to jinget.core.js
in your _Host.razor
or App.razor
files.
<script src="_content/Jinget.Blazor/js/jinget.core.js" id="jinget"></script>
Jinget Captcha component
Add the JingetCaptcha
to your page and start using it;-)
<JingetCaptcha Width="200"
Height="50"
CharCount="5"
CharSetType="CharSetTypeOptions.EnglishCharsPlusDigit"
ContentCaseSensitivity="CharSetCaseSensitivityOptions.IgnoreCase"
CaseSesitiveComparison=false>
</JingetCaptcha>
Parameters:
Width
: Captcha image box width. Default is 170.
Height
: Captcha image box height. Default is 40.
CharCount
: Total number of characters to be rendered in image. Default value is 5. The value should be greater than 0 otherwise it will be replaced by 5
CharSetType
: Set the character set used for rendering the image. Default is DigitOnly. Supported values are: DigitOnly, EnglishCharsOnly, FarsiCharsOnly, EnglishCharsPlusDigit, FarsiCharsPlusDigit, EnglishCharsPlusFarsiChars, BlendAll, Custom
ContentCaseSensitivity
: Set the character set case sensitivity used for rendering the image. This property is only applied to the English characters. Default value is IgnoreCase. Supported values are: UpperCaseOnly, LowerCaseOnly, IgnoreCase
CaseSesitiveComparison
: Check if the input captcha text validation should be done in case sensitive or case insensitive manner.
CustomCharSet
: If ContentCharsType is set to Custom then characters provided by CustomCharSet will be used to render the image.
IsRtlCharSet
: If RTL language's character set is being used(such as Farsi, Arabic, etc), this property should be set to true.
FontFamilies
: Sets the Font families used for drawing the text inside the image. Default Values are: Arial, Tahoma and Times New Roman
Callbacks:
CaptchaChanged
: Fires a callback whenever the captcha image is changed
Methods:
IsValid
: Checks if the given input text is equal to the image's text
GetNewCaptchaAsync
: Draw a new captcha image
Jinget DatePicker component
Add the JingetDatePicker
to your page and start using it;-)
<JingetDatePicker
Value=selectedDate_1
DateChanged="OnDateChanged_1">
</JingetDatePicker>
...
@code {
DateTime? selectedDate_1;
void OnDateChanged_1(DateTime? selectedDate) => selectedDate_1 = selectedDate;
}
Parameters:
Value
: Defines the picker's value
Culture
: Defines the date picker culture. For Jalali calendar you can set this to fa-IR, for Hijri calendar you can set this to arabic cultures such as ar-SA, for gregorian calendar you can set this to an appropriate calendar such as en-US. Other cultures are also supported such as chinese: zh-Hans
Disabled
: If set to true, then the calendar will be disabled.
ReadOnly
: If set to true, then the calendar will be rendered in readonly mode.
Editable
: If set to true, user can select date using keyboard.(Default is true. for fa-IR and ar-SA cultures this property is set to false)
Clearable
: If set ti true, clear button will be shown for clearing the selected date.
MinDate
: Defines the minimum acceptable date.
MaxDate
: Defines the maximum acceptable date.
Required
: Defines whether the input is required or optional.
RequiredError
: Error message used to show when the input is required and remained empty or unselected.
EnglishNumber
: Defines whether the numbers in calendar should be rendred as English numbers or not.
Label
: Label for the component.
DisabledDateFunc
: Defines a Func delegate to disable the specific date(s)
CustomDateStyleFunc
: Defines a Func delegate to use custom styles for decorating cusotm dates
Callbacks:
DateChanged
: Fires a callback whenever the selected date is changed
Jinget DateRangePicker component
Add the JingetDateRangePicker
to your page and start using it;-)
<JingetDateRangePicker
Value=selectedDateRange_1.DateRange
DateRangeChanged="OnDateRangeChanged_1">
</JingetDateRangePicker>
...
@code {
SelectedDateRangeModel selectedDateRange_1 = new();
void OnDateRangeChanged_1(SelectedDateRangeModel selectedDateRange) => selectedDateRange_1 = selectedDateRange;
}
Parameters:
Value
: Defines the picker's value
Culture
: Defines the date picker culture. For Jalali calendar you can set this to fa-IR, for Hijri calendar you can set this to arabic cultures such as ar-SA, for gregorian calendar you can set this to an appropriate calendar such as en-US. Other cultures are also supported such as chinese: zh-Hans
Disabled
: If set to true, then the calendar will be disabled.
ReadOnly
: If set to true, then the calendar will be rendered in readonly mode.
Editable
: If set to true, user can select date using keyboard.(Default is true. for fa-IR and ar-SA cultures this property is set to false)
Clearable
: If set ti true, clear button will be shown for clearing the selected date.
MinDate
: Defines the minimum acceptable date.
MaxDate
: Defines the maximum acceptable date.
Required
: Defines whether the input is required or optional.
RequiredError
: Error message used to show when the input is required and remained empty or unselected.
EnglishNumber
: Defines whether the numbers in calendar should be rendred as English numbers or not.
Label
: Label for the component.
DisabledDateFunc
: Defines a Func delegate to disable the specific date(s)
CustomDateStyleFunc
: Defines a Func delegate to use custom styles for decorating cusotm dates
Callbacks:
DateRangeChanged
: Fires a callback whenever the selected date range is changed.
Jinget Modal component
Add the JingetModal
to your page and start using it;-)
<JingetModal @ref="@modal1"
Title="Sample Header"
ShowFooter=true
ShowHeader=true
Rtl=false
CloseButtonText="Close">
<ChildContent>
<div class="alert alert-secondary" role="alert">
This is a sample modal
</div>
</ChildContent>
</JingetModal>
...
@code {
JingetModal? modal1 { get; set; }
async Task ShowModal1() => await modal1?.OpenAsync();
}
Parameters:
ShowHeader
: Defines whether to show the header or not.
ShowFooter
: Defines whether to show the footer or not.
Title
: Dfines the modal title.
ChildContent
: Defines the content which should be rendered as component's child.
FooterContent
: Defines the content which should be rendered as component's footer.
Rtl
: If set to true, the the modal content will be rendred Right-to-Left.
CloseButtonText
: Defines the close button text.
Callbacks:
OnOpen
: Fires a callback whenever the modal is being opened.
OnClose
: Fires a callback whenever the modal is being closed.
Jinget MessageBox component
Add the JingetMessageBox
to your page and start using it;-)
<JingetMessageBox @ref=@messageBox OnOpen=Opened>
</JingetMessageBox>
...
@code {
void Opened() => messageBox.CloseButtonText = messageBox.Rtl ? "بستن" : "Close";
}
Parameters:
ShowVerboseFuncAsync
: Defines a Func delegate to show the verbose content
Rtl
: If set to true, the the modal content will be rendred Right-to-Left.
CloseButtonText
: Defines the close button text.
Callbacks:(shared with JingetMessageBox Component)
OnOpen
: Fires a callback whenever the modal is being opened.
OnClose
: Fires a callback whenever the modal is being closed.
Methods:
OpenAsync
: Opens the message box.
CloseAsync
: Closes the message box.
ShowErrorAsync
: Opens the message box using Error theme.
ShowWarningAsync
: Opens the message box using Warning theme.
ShowInfoAsync
: Opens the message box using Info theme.
Jinget List component
Add the JingetList
to your page and start using it;-)
<JingetList
Model=@Model
Title="Sample List"
HeaderCssClass="list-group-item-action active">
</JingetList>
...
@code {
IList<ListItem> Model = new List<ListItem>
{
new ListItem("Item 1","list-group-item-info"),
new ListItem("Item 2","list-group-item-secondary"),
new ListItem("Item 3"),
};
}
Parameters:
Model
: Model used to bind to the component.
Title
: If ShowTitle
is set to true, then Title
will be rendered as list's header text.
ShowTitle
: Defines whether to show the Title
or not.
HeaderCssClass
: Defines a custom css class used to decorate the list's header.
Jinget Table component
Add the JingetTable
to your page and start using it;-)
<JingetTable
Model=@ModelRtl
SearchProviderAsync=@SearchAsyncRtl
ShowPagination=true
ShowSearchBar=true>
<ActionContent>
<MudButton
OnClick=@(async ()=> await ShowDetailFarsi((SampleDataFarsi)context))
ButtonType="ButtonType.Reset"
Color="Color.Warning">جزئیات...
</MudButton>
</ActionContent>
</JingetTable>
...
@code {
JingetMessageBox messageBox;
TableData<SampleDataFarsi> ModelRtl;
protected override void OnInitialized() {
ModelRtl = GetDataFarsi();
}
async Task ShowDetailFarsi(SampleDataFarsi data){
messageBox.CloseButtonText = "بستن";
await messageBox.ShowInfoAsync(
data.Id.ToString(),
$"{data.Name} {data.LastName}",
System.Text.Json.JsonSerializer.Serialize(data), rtl:true);
}
async Task<TableData<SampleDataFarsi>> SearchAsyncRtl(TableState state, string? searchString = null)
{
try
{
IQueryable<SampleDataFarsi> data;
if (searchString == null)
data=GetDataFarsi().Items.AsQueryable();
else
data = GetDataFarsi().Items
.Where(x =>
x.Name.Contains(searchString, StringComparison.InvariantCultureIgnoreCase) ||
x.LastName.Contains(searchString, StringComparison.InvariantCultureIgnoreCase)).AsQueryable();
int totalCount =data==null?0: data.Count();
if(!string.IsNullOrWhiteSpace(state.SortLabel)){
var sortDirection = state.SortDirection == SortDirection.Ascending ?
OrderByDirection.Ascending:
OrderByDirection.Descending;
data = data.OrderByDynamic(state.SortLabel,sortDirection);
}
var response= data
.Skip(state.Page*state.PageSize)
.Take(state.PageSize).ToList();
if (response == null || response.Count==0)
return JingetObjectFactory<SampleDataFarsi>.EmptyTableData.Instance;
return await Task.FromResult(
new TableData<SampleDataFarsi>
{
Items = response,
TotalItems = totalCount
});
}
catch (Exception ex)
{
await messageBox.ShowErrorAsync("Error", "Unable to search data", ex.Message);
}
return JingetObjectFactory<SampleDataFarsi>.EmptyTableData.Instance;
}
TableData<SampleDataFarsi> GetDataFarsi()
{
var data = new List<SampleDataFarsi>
{
new SampleDataFarsi(1,"وحید","فرهمندیان",34,true),
new SampleDataFarsi(2,"علی","احمدی",40,true),
new SampleDataFarsi(3,"محسن","نوروزی",18,true),
new SampleDataFarsi(4,"قانعی","مریم",24,false),
new SampleDataFarsi(5,"سارا","حسین زاده",37,false),
new SampleDataFarsi(6,"امیر","رحمانی",29,true),
new SampleDataFarsi(7,"سید رحمان","رئوفی اصل",54,true),
new SampleDataFarsi(8,"سامان","صادقی",41,true),
new SampleDataFarsi(9,"ابوالفضل","بهنام پور",19,true),
new SampleDataFarsi(10,"ژاله","علیزاده",38,false),
new SampleDataFarsi(11,"سیدرضا","ابوالفتحی",47,false),
new SampleDataFarsi(12,"مهتاب","آسمانی",26,true),
new SampleDataFarsi(13,"ستاره","فضائی",71,true),
new SampleDataFarsi(14,"امیررضا","عسکری",30,false),
new SampleDataFarsi(15,"عرفان","طباطبائی",25,true),
new SampleDataFarsi(16,"پانته آ","قوام",31,false),
new SampleDataFarsi(17,"یحیی","فرهمند",18,false),
new SampleDataFarsi(18,"ناصر","ملک زاده",24,true),
};
return new TableData<SampleDataFarsi>
{
Items = data,
TotalItems = data.Count
};
}
[JingetTable]
class SampleDataFarsi
{
public SampleDataFarsi(int id, string name, string lastname,int age, bool isActive)
{
Id=id;
Name=name;
LastName=lastname;
Age = age;
IsActive = isActive;
}
[JingetTableMember(DisplayName = "#")]
public int Id { get; set; }
[JingetTableMember(DisplayName = "نام")]
public string Name{get;set;}
[JingetTableMember(DisplayName = "نام خانوادگی")]
public string LastName{get;set;}
[JingetTableMember(DisplayName = "سن", Sortable=true)]
public int Age{get;set;}
[JingetTableMember(DisplayName = "وضعیت")]
public bool IsActive{get;set;}
}
}
Parameters:
Model
: Model used to bind to the component. Class defining the model should have JingetTable
attributes. Also each property used to rendered as table's column should have JingetTableMember
attribute.
ShowSearchBar
: Defines whether to show the search bar or not
Rtl
: If set to true, the the modal content will be rendred Right-to-Left. Default is true
ShowPagination
: Defines whether to show the pagination bar or not
ActionContent
: Defines the content which should be rendered in each rows as custom actions.
SearchBarContent
: Defines the custom content which should be rendered in search bar.
SearchProviderAsync
: Defines a Func delegate to do the search action.
PaginationSetting
: Settings used for table's pagination section.
NoRecordText
: Text used to show when there is no data to display in table.
SearchPlaceHolderText
: Text used to shown in search bar input box.
Methods:
Reload
: Used to reload the data into the table.
Jinget DynamicForm component
Add the JingetDynamicForm
to your page and start using it;-)
<JingetDynamicForm Model=@Model Rtl=true></JingetDynamicForm>
...
@code {
public SampleModel Model { get; set; }
protected override void OnInitialized() => Model = new();
public record SampleModel
{
public SampleModel() { }
public SampleModel(IServiceProvider serviceProvider) { }
[JingetTextBox(DisplayName = "نام", HelperText = "نام خود را منطبق با اطلاعات کارت ملی وارد نمایید", Order =1)]
public string Name { get; set; }
[JingetPasswordBox(DisplayName = "رمز عبور", Order =3)]
public string Password { get; init; }
[JingetEmailBox(DisplayName = "پست الکترونیکی",Order =4)]
public string EMail { get; init; }
[JingetDatePicker(DisplayName = "تاریخ تولد",Culture ="fa-IR", Order =5)]
public string DoB { get; init; }
[JingetDateRangePicker(DisplayName = "بازه زمانی سفر",Culture ="fa-IR", Order =6)]
public DateRange TravelDate { get; init; }
[JingetLabel(DisplayName = "امتیاز اکتسابی", HasLabel = false)]
public int Score { get; init; } = 1850;
[JingetTextArea(DisplayName = "اطلاعات بیشتر", Rows =3)]
public string Description { get; init; }
[JingetNumberBox(DisplayName = "سن", Order =7)]
public int Age { get; set; }
[JingetComboBox(DisplayName = "وضعیت", BindingFunction = nameof(GetStatusAsync),
Searchable =true,DefaultText ="---انتخاب کنید---",HasLabel =true, LabelCssClass = "overlayed-label", Order =8)]
public int? Status { get; init; }
public async Task<List<DropDownItemModel>> GetStatusAsync()
=> await new JingetComboBox().BindAsync<StatusModel>(async () =>
{
return await Task.FromResult(new List<StatusModel>
{
new StatusModel{Code= 1,Title= "فعال" },
new StatusModel{Code= 2,Title= "غیرفعال" },
new StatusModel{Code= 3,Title= "نامشخص" }
});
});
class StatusModel : BaseTypeModel
{
}
}
}
Parameters:
Model
: Model used to decorate the form. two-way binding is also supported.
Rtl
: If set to true, the the form will be rendred Right-to-Left. Default is true
.
Callbacks:
OnModelChanged
: Fires a callback whenever the model is changed.
Attributes:
JingetTextBox
: Render a textbox on the page.
JingetTextArea
: Render a textarea on the page. Using Rows
property you can set the textarea rows.
JingetEmailBox
: Render an email input on the page.
JingetNumberBox
: Render a number input on the page.
JingetPasswordBox
: Render a password input on the page.
JingetTelephoneBox
: Render a tel input on the page.
JingetDatePicker
: Render a JingetDatePicker on the page. You can set Culture
and EnglishNumber
properties.
JingetDateRangePicker
: Render a JingetDateRangePicker on the page. You can set Culture
and EnglishNumber
properties.
JingetComboBox
: Render a select input on the page. If Searchable
is set to true, then the user can do search among combobox items. Using BindingFunction
user can define a method to bind data into combobox.
JingetLabel
: Render a label on the page.
JingetList
: Render a JingetList on the page. List's items are defined using BodyMember
property. items should be passed as json string to this property.
JingetTable
: Render a JingetTable on the page.(Used in JingetTable component, for more info go to JingetTable component section)
How to install
In order to install Jinget Blazor please refer to nuget.org
Contact Me
👨💻 Twitter: https://twitter.com/_jinget
📧 Email: farahmandian2011@gmail.com
📣 Instagram: https://www.instagram.com/vahidfarahmandian
Product | Versions 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. |
-
net6.0
- Jinget.Core (>= 6.2.5)
- MudBlazor (>= 6.19.1)
- SkiaSharp (>= 2.88.8)
- Texnomic.Blazor.JsonViewer (>= 0.1.0)
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 |
---|---|---|
6.2.19-preview037 | 76 | 10/14/2024 |
6.2.19-preview036 | 65 | 9/30/2024 |
6.2.19-preview035 | 94 | 9/10/2024 |
6.2.19-preview034 | 82 | 9/9/2024 |
6.2.19-preview033 | 84 | 9/1/2024 |
6.2.19-preview032 | 78 | 9/1/2024 |
6.2.19-preview031 | 80 | 8/31/2024 |
6.2.19-preview029 | 94 | 8/26/2024 |
6.2.19-preview028 | 102 | 8/26/2024 |
6.2.19-preview027 | 92 | 8/26/2024 |
6.2.19-preview026 | 109 | 8/21/2024 |
6.2.19-preview025 | 103 | 8/21/2024 |
6.2.19-preview024 | 104 | 8/19/2024 |
6.2.19-preview023 | 99 | 8/8/2024 |
6.2.19-preview022 | 100 | 8/8/2024 |
6.2.19-preview021 | 98 | 8/5/2024 |
6.2.19-preview020 | 79 | 8/5/2024 |
6.2.19-preview019 | 80 | 8/5/2024 |
6.2.19-preview018 | 72 | 8/3/2024 |
6.2.19-preview017 | 52 | 7/30/2024 |
6.2.19-preview016 | 60 | 7/29/2024 |
6.2.19-preview015 | 61 | 7/29/2024 |
6.2.19-preview014 | 75 | 7/26/2024 |
6.2.19-preview013 | 79 | 7/20/2024 |
6.2.19-preview012 | 78 | 7/20/2024 |
6.2.19-preview011 | 103 | 6/15/2024 |
6.2.19-preview010 | 96 | 6/14/2024 |
6.2.19-preview009 | 89 | 6/14/2024 |
6.2.19-preview008 | 94 | 6/13/2024 |
6.2.19-preview007 | 91 | 6/13/2024 |
6.2.19-preview006 | 85 | 6/13/2024 |
6.2.19-preview005 | 84 | 6/13/2024 |
6.2.19-preview004 | 90 | 6/13/2024 |
6.2.19-preview003 | 96 | 6/11/2024 |
6.2.19-preview002 | 96 | 6/8/2024 |
6.2.19-preview001 | 88 | 6/8/2024 |
6.2.18 | 138 | 6/6/2024 |
6.2.18-preview020 | 75 | 6/6/2024 |
6.2.18-preview019 | 97 | 6/6/2024 |
6.2.18-preview018 | 99 | 6/6/2024 |
6.2.18-preview017 | 108 | 6/2/2024 |
6.2.18-preview016 | 109 | 6/1/2024 |
6.2.18-preview015 | 96 | 5/28/2024 |
6.2.18-preview014 | 101 | 5/28/2024 |
6.2.18-preview013 | 108 | 5/28/2024 |
6.2.18-preview012 | 108 | 5/28/2024 |
6.2.18-preview011 | 94 | 5/26/2024 |
6.2.18-preview010 | 96 | 5/26/2024 |
6.2.18-preview009 | 95 | 5/26/2024 |
6.2.18-preview008 | 93 | 5/26/2024 |
6.2.18-preview007 | 109 | 5/22/2024 |
6.2.18-preview006 | 97 | 5/22/2024 |
6.2.18-preview005 | 101 | 5/19/2024 |
6.2.18-preview004 | 101 | 5/19/2024 |
6.2.18-preview003 | 102 | 5/19/2024 |
6.2.18-preview002 | 102 | 5/19/2024 |
6.2.17 | 120 | 5/19/2024 |
6.2.16 | 121 | 5/18/2024 |
6.2.15 | 108 | 5/18/2024 |
6.2.14 | 112 | 5/18/2024 |
6.2.13 | 105 | 5/17/2024 |
6.2.10 | 122 | 5/17/2024 |
6.2.9 | 105 | 5/12/2024 |
6.2.8 | 118 | 5/9/2024 |
6.2.7 | 117 | 5/9/2024 |
6.2.6 | 110 | 5/7/2024 |
6.2.5 | 119 | 4/24/2024 |
6.2.4 | 157 | 2/1/2024 |
6.2.3 | 88 | 2/1/2024 |
6.2.2 | 117 | 1/31/2024 |
6.2.1 | 138 | 1/23/2024 |
6.2.0 | 113 | 1/23/2024 |
6.2.0-preview013 | 101 | 1/19/2024 |
6.2.0-preview012 | 101 | 1/19/2024 |
6.2.0-preview011 | 120 | 1/18/2024 |
6.2.0-preview010 | 117 | 1/14/2024 |
6.2.0-preview009 | 120 | 1/11/2024 |
6.2.0-preview008 | 127 | 1/1/2024 |
6.2.0-preview007 | 97 | 1/1/2024 |
6.2.0-preview006 | 87 | 1/1/2024 |
6.2.0-preview005 | 111 | 1/1/2024 |
6.2.0-preview001 | 135 | 12/30/2023 |
6.1.0 | 216 | 12/2/2023 |