From b9870b77b35aeef21811bd292286f822c04c5c1b Mon Sep 17 00:00:00 2001 From: King Date: Tue, 30 Sep 2025 13:39:40 +0330 Subject: [PATCH] Update --- src/BackOffice/BackOffice/BackOffice.csproj | 10 ++ .../Common/Configure/ConfigureService.cs | 13 ++- .../Common/Utilities/RouteConstance.cs | 5 + .../Pages/AutoComplete/RoleAutoComplete.razor | 14 +++ .../AutoComplete/RoleAutoComplete.razor.cs | 75 +++++++++++++++ .../Package/Components/PackageDataTable.razor | 14 +++ .../Components/PackageDataTable.razor.cs | 7 ++ .../Pages/Role/Components/CreateDialog.razor | 22 +++++ .../Role/Components/CreateDialog.razor.cs | 67 +++++++++++++ .../Pages/Role/Components/RoleDataTable.razor | 39 ++++++++ .../Role/Components/RoleDataTable.razor.cs | 74 +++++++++++++++ .../Pages/Role/Components/UpdateDialog.razor | 23 +++++ .../Role/Components/UpdateDialog.razor.cs | 58 ++++++++++++ .../BackOffice/Pages/Role/RoleMainPage.razor | 36 +++++++ .../Pages/User/Components/UserDataTable.razor | 71 ++++++++++++++ .../User/Components/UserDataTable.razor.cs | 94 +++++++++++++++++++ .../User/Components/UserRoleDialog.razor | 28 ++++++ .../User/Components/UserRoleDialog.razor.cs | 68 ++++++++++++++ .../BackOffice/Pages/User/UserMainPage.razor | 22 +++++ .../UserAddress/Components/CreateDialog.razor | 29 ++++++ .../Components/CreateDialog.razor.cs | 63 +++++++++++++ .../UserAddress/Components/UpdateDialog.razor | 29 ++++++ .../Components/UpdateDialog.razor.cs | 63 +++++++++++++ .../Components/UserAddressDataTable.razor | 39 ++++++++ .../Components/UserAddressDataTable.razor.cs | 77 +++++++++++++++ .../UserAddress/UserAddressMainPage.razor | 36 +++++++ .../Components/UserOrderDataTable.razor | 51 ++++++++++ .../Components/UserOrderDataTable.razor.cs | 62 ++++++++++++ .../Pages/UserOrder/UserOrderMainPage.razor | 23 +++++ .../UserRole/Components/CreateDialog.razor | 21 +++++ .../UserRole/Components/CreateDialog.razor.cs | 47 ++++++++++ .../UserRole/Components/RoleTitleColumn.razor | 17 ++++ .../Components/RoleTitleColumn.razor.cs | 30 ++++++ .../UserRole/Components/UpdateDialog.razor | 21 +++++ .../UserRole/Components/UpdateDialog.razor.cs | 50 ++++++++++ .../Components/UserRoleDataTable.razor | 39 ++++++++ .../Components/UserRoleDataTable.razor.cs | 76 +++++++++++++++ .../Pages/UserRole/UserRoleMainPage.razor | 37 ++++++++ .../BackOffice/Shared/NavMenu.razor | 2 + 39 files changed, 1551 insertions(+), 1 deletion(-) create mode 100644 src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor create mode 100644 src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/Role/RoleMainPage.razor create mode 100644 src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor create mode 100644 src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/User/UserMainPage.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserAddress/UserAddressMainPage.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserOrder/UserOrderMainPage.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor.cs create mode 100644 src/BackOffice/BackOffice/Pages/UserRole/UserRoleMainPage.razor diff --git a/src/BackOffice/BackOffice/BackOffice.csproj b/src/BackOffice/BackOffice/BackOffice.csproj index 34aaa22..88eec3f 100644 --- a/src/BackOffice/BackOffice/BackOffice.csproj +++ b/src/BackOffice/BackOffice/BackOffice.csproj @@ -22,6 +22,16 @@ + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Common/Configure/ConfigureService.cs b/src/BackOffice/BackOffice/Common/Configure/ConfigureService.cs index a62e1ba..de8bd70 100644 --- a/src/BackOffice/BackOffice/Common/Configure/ConfigureService.cs +++ b/src/BackOffice/BackOffice/Common/Configure/ConfigureService.cs @@ -1,5 +1,11 @@  +using BackOffice.BFF.Otp.Protobuf.Protos.Otp; using BackOffice.BFF.Package.Protobuf.Protos.Package; +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using BackOffice.BFF.User.Protobuf.Protos.User; +using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress; +using BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder; +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; using BackOffice.Common.Utilities; using Blazored.LocalStorage; using Google.Protobuf.Reflection; @@ -54,8 +60,13 @@ public static class ConfigureServices + services.AddTransient(sp => new OtpContract.OtpContractClient(channel)); services.AddTransient(sp => new PackageContract.PackageContractClient(channel)); - //services.AddTransient(sp => new OtpContract.OtpContractClient(channel)); + services.AddTransient(sp => new RoleContract.RoleContractClient(channel)); + services.AddTransient(sp => new UserContract.UserContractClient(channel)); + services.AddTransient(sp => new UserAddressContract.UserAddressContractClient(channel)); + services.AddTransient(sp => new UserOrderContract.UserOrderContractClient(channel)); + services.AddTransient(sp => new UserRoleContract.UserRoleContractClient(channel)); return services; } diff --git a/src/BackOffice/BackOffice/Common/Utilities/RouteConstance.cs b/src/BackOffice/BackOffice/Common/Utilities/RouteConstance.cs index 32de4da..5906b3b 100644 --- a/src/BackOffice/BackOffice/Common/Utilities/RouteConstance.cs +++ b/src/BackOffice/BackOffice/Common/Utilities/RouteConstance.cs @@ -6,4 +6,9 @@ public static class RouteConstance public const string Login = "/Login/"; public const string VerifyCodePage = "/VerifyCodePage/"; public const string Package = "/PackagePage/"; + public const string Role = "/RolePage/"; + public const string UserPage = "/UserPage/"; + public const string UserOrder = "/UserOrderPage/"; + public const string UserRole = "/UserRolePage/"; + public const string UserAddress = "/UserAddressPage/"; } diff --git a/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor b/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor new file mode 100644 index 0000000..e15b00a --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor @@ -0,0 +1,14 @@ +@using BackOffice.BFF.Role.Protobuf.Protos.Role + + \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor.cs b/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor.cs new file mode 100644 index 0000000..7aafde4 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/AutoComplete/RoleAutoComplete.razor.cs @@ -0,0 +1,75 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Microsoft.AspNetCore.Components; + +using Microsoft.JSInterop; + +namespace BackOffice.Pages.AutoComplete; + +public partial class RoleAutoComplete +{ + [Inject] public RoleContract.RoleContractClient RoleService { get; set; } + [Parameter] public long? Value { get; set; } + [Parameter] public string? Label { get; set; } = "نقش"; + [Parameter] public EventCallback ValueChanged { get; set; } + private List _items = new(); + private GetAllRoleByFilterResponseModel _item; + protected override async void OnParametersSet() + { + await base.OnParametersSetAsync(); + if (Value > 0) + { + var getAll = await RoleService.GetAllRoleByFilterAsync(new() + { + Filter = new() + { + Id = Value + }, + PaginationState = new() + { + PageNumber = 1, + PageSize = 1 + } + }); + if (getAll != null && getAll.Models != null && getAll.Models.Any()) + { + _item = getAll.Models.First(); + StateHasChanged(); + } + + } + } + private async Task OnSelected(GetAllRoleByFilterResponseModel? model) + { + if (model == null) + { + _item = null; + await ValueChanged.InvokeAsync(null); + } + else + { + + _item = model; + await ValueChanged.InvokeAsync(model.Id); + } + } + private async Task> Search(string value, CancellationToken token) + { + var getAll = await RoleService.GetAllRoleByFilterAsync(new() + { + Filter = new() + { + Title = value + }, + PaginationState = new() + { + PageNumber = 1, + PageSize = 9 + } + }); + if (getAll != null && getAll.Models != null) + _items = getAll.Models.ToList(); + + return _items; + + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor b/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor index cab0cbf..14ad96d 100644 --- a/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor +++ b/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor @@ -2,6 +2,20 @@ @using BackOffice.Common.BaseComponents @using DataModel = BackOffice.BFF.Package.Protobuf.Protos.Package.GetAllPackageByFilterResponseModel + + + + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor.cs index 18124bb..f333d93 100644 --- a/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor.cs +++ b/src/BackOffice/BackOffice/Pages/Package/Components/PackageDataTable.razor.cs @@ -70,5 +70,12 @@ public partial class PackageDataTable if (_gridData != null) await _gridData.ReloadServerData(); } + private async Task SearchTitle(string? title) + { + _request.Filter ??= new(); + _request.Filter.Title = string.IsNullOrWhiteSpace(title) ? default : title; + ReLoadData(); + } + } \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor b/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor new file mode 100644 index 0000000..98ba619 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor @@ -0,0 +1,22 @@ +@using BackOffice.BFF.Package.Protobuf.Protos.Package +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor.cs new file mode 100644 index 0000000..aa0aa4e --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/CreateDialog.razor.cs @@ -0,0 +1,67 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Google.Protobuf; +using Grpc.Core; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.Role.Components; + +public partial class CreateDialog +{ + [Inject] public RoleContract.RoleContractClient RoleContract { get; set; } + [Parameter] public CreateNewRoleRequest Model { get; set; } = new(); + [CascadingParameter] MudDialogInstance MudDialog { get; set; } + + private bool _isLoading = false; + private string _srcImage = ""; + private IBrowserFile? _imageFile; + private long _maxAllowedSize = (1024 * 1024) * 200; + + private async Task OnImageFileSelect(IBrowserFile? file) + { + _imageFile = file; + var buffer = new byte[file.Size]; + await file.OpenReadStream().ReadAsync(buffer); + _srcImage = $"data:{file.ContentType};base64," + Convert.ToBase64String(buffer); + StateHasChanged(); + } + public async void CallCreateMethod() + { + _isLoading = true; + StateHasChanged(); + + if (string.IsNullOrWhiteSpace(Model.Title)) + { + Snackbar.Add("لطفا عنوان را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.Name)) + { + Snackbar.Add("لطفا عنوان لاتین را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + + + try + { + await RoleContract.CreateNewRoleAsync(Model); + Submit(); + + } + catch (RpcException ex) + { + Console.WriteLine(ex); + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor b/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor new file mode 100644 index 0000000..859becc --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor @@ -0,0 +1,39 @@ +@using BackOffice.BFF.Role.Protobuf.Protos.Role +@using BackOffice.Common.BaseComponents +@using DataModel = BackOffice.BFF.Role.Protobuf.Protos.Role.GetAllRoleByFilterResponseModel + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor.cs new file mode 100644 index 0000000..cc62718 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/RoleDataTable.razor.cs @@ -0,0 +1,74 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Google.Protobuf.WellKnownTypes; +using HtmlAgilityPack; +using Mapster; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using static Google.Rpc.Context.AttributeContext.Types; +using DataModel = BackOffice.BFF.Role.Protobuf.Protos.Role.GetAllRoleByFilterResponseModel; + +namespace BackOffice.Pages.Role.Components; + +public partial class RoleDataTable +{ + + [Inject] public RoleContract.RoleContractClient RoleContract { get; set; } + private bool _isLoading = true; + private MudDataGrid _gridData; + + private GetAllRoleByFilterRequest _request = new() { Filter = new() }; + private async Task> ServerReload(GridState state) + { + _request.Filter ??= new(); + _request.PaginationState ??= new(); + _request.PaginationState.PageNumber = state.Page + 1; + _request.PaginationState.PageSize = state.PageSize; + + var result = await RoleContract.GetAllRoleByFilterAsync(_request); + if (result != null && result.Models != null && result.Models.Any()) + { + return new GridData() { Items = result.Models.ToList(), TotalItems = (int)result.MetaData.TotalCount }; + } + + return new GridData(); + } + public async Task Update(DataModel model) + { + var parameters = new DialogParameters { { x => x.Model, model.Adapt() } }; + + var dialog = await DialogService.ShowAsync($"ویرایش نقش", parameters, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + + if (!result.Canceled) + { + ReLoadData(); + //Reload Data + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + + } + } + private async Task OnDelete(DataModel model) + { + var options = new DialogOptions { CloseOnEscapeKey = true, MaxWidth = MaxWidth.Small }; + bool? result = await DialogService.ShowMessageBox( + "اخطار", + "آیا از حذف این مورد مطمئن هستید؟", + yesText: "حذف", cancelText: "لغو", + options: options); + if (result != null && result.Value) + { + await RoleContract.DeleteRoleAsync(new() + { + Id = model.Id + }); + ReLoadData(); + } + StateHasChanged(); + } + public async void ReLoadData() + { + if (_gridData != null) + await _gridData.ReloadServerData(); + } + +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor b/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor new file mode 100644 index 0000000..2e71175 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor @@ -0,0 +1,23 @@ +@using BackOffice.BFF.Package.Protobuf.Protos.Package +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor.cs new file mode 100644 index 0000000..152800c --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/Components/UpdateDialog.razor.cs @@ -0,0 +1,58 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Google.Protobuf; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.Role.Components +{ + public partial class UpdateDialog + { + private bool _isLoading = false; + [Inject] public RoleContract.RoleContractClient RoleContract { get; set; } + + [Parameter] + public UpdateRoleRequest Model { get; set; } = new(); + + [CascadingParameter] + MudDialogInstance MudDialog { get; set; } + + public async void CallUpdateMethod() + { + _isLoading = true; + StateHasChanged(); + if (string.IsNullOrWhiteSpace(Model.Title)) + { + Snackbar.Add("لطفا عنوان را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.Name)) + { + Snackbar.Add("لطفا عنوان لاتین را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + + + try + { + await RoleContract.UpdateRoleAsync(Model); + Submit(); + + } + catch (Exception) + { + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/Role/RoleMainPage.razor b/src/BackOffice/BackOffice/Pages/Role/RoleMainPage.razor new file mode 100644 index 0000000..c06d768 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/Role/RoleMainPage.razor @@ -0,0 +1,36 @@ +@attribute [Route(RouteConstance.Role)] + +@using BackOffice.BFF.Role.Protobuf.Protos.Role +@using BackOffice.Pages.Role.Components + + + + + مدیریت نقش + + افزودن + + + + + + + +@code { + + private RoleDataTable _table; + + public async Task CreateNew() + { + var dialog = await DialogService.ShowAsync($"افزودن نقش", new DialogParameters() { { x => x.Model, new CreateNewRoleRequest() } }, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + if (!result.Canceled) + { + _table.ReLoadData(); + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + } + } + +} + + diff --git a/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor b/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor new file mode 100644 index 0000000..d4762e5 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor @@ -0,0 +1,71 @@ +@using BackOffice.BFF.User.Protobuf.Protos.User +@using BackOffice.Common.BaseComponents +@using DataModel = BackOffice.BFF.User.Protobuf.Protos.User.GetAllUserByFilterResponseModel + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @($"{context.Item.FirstName} {context.Item.LastName}") + + + + + + + + + + + + فاکتور ها + آدرس ها + مدیریت نقش + آرشیو + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor.cs new file mode 100644 index 0000000..647ce7e --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/User/Components/UserDataTable.razor.cs @@ -0,0 +1,94 @@ +using BackOffice.BFF.User.Protobuf.Protos.User; +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; +using Google.Protobuf.WellKnownTypes; +using HtmlAgilityPack; +using Mapster; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using static Google.Rpc.Context.AttributeContext.Types; +using static MudBlazor.CategoryTypes; +using DataModel = BackOffice.BFF.User.Protobuf.Protos.User.GetAllUserByFilterResponseModel; + +namespace BackOffice.Pages.User.Components; + +public partial class UserDataTable +{ + + [Inject] public UserContract.UserContractClient UserContract { get; set; } + private bool _isLoading = true; + private MudDataGrid _gridData; + + private GetAllUserByFilterRequest _request = new() { Filter = new() }; + private async Task> ServerReload(GridState state) + { + _request.Filter ??= new(); + _request.PaginationState ??= new(); + _request.PaginationState.PageNumber = state.Page + 1; + _request.PaginationState.PageSize = state.PageSize; + + var result = await UserContract.GetAllUserByFilterAsync(_request); + if (result != null && result.Models != null && result.Models.Any()) + { + return new GridData() { Items = result.Models.ToList(), TotalItems = (int)result.MetaData.TotalCount }; + } + + return new GridData(); + } + private async Task OnDelete(DataModel model) + { + var options = new DialogOptions { CloseOnEscapeKey = true, MaxWidth = MaxWidth.Small }; + bool? result = await DialogService.ShowMessageBox( + "اخطار", + "آیا از حذف این مورد مطمئن هستید؟", + yesText: "حذف", cancelText: "لغو", + options: options); + if (result != null && result.Value) + { + await UserContract.DeleteUserAsync(new() + { + Id = model.Id + }); + ReLoadData(); + } + StateHasChanged(); + } + public async void ReLoadData() + { + if (_gridData != null) + await _gridData.ReloadServerData(); + } + private async Task Searchfirstname(string? firstname) + { + _request.Filter ??= new(); + _request.Filter.FirstName = string.IsNullOrWhiteSpace(firstname) ? default : firstname; + ReLoadData(); + } + private async Task Searchlastname(string? lastname) + { + _request.Filter ??= new(); + _request.Filter.LastName = string.IsNullOrWhiteSpace(lastname) ? default : lastname; + ReLoadData(); + } + private async Task SearchNationalCode(string? nationalcode) + { + _request.Filter ??= new(); + _request.Filter.NationalCode = string.IsNullOrWhiteSpace(nationalcode) ? default : nationalcode; + ReLoadData(); + } + private async Task SearchMobile(string? mobile) + { + _request.Filter ??= new(); + _request.Filter.Mobile = string.IsNullOrWhiteSpace(mobile) ? default : mobile; + ReLoadData(); + } + public async Task OnclickUserRoleDialog(long userid) + { + var dialog = await DialogService.ShowAsync($"نقش های کاربر", new DialogParameters() { { x => x.UserId, userid } }, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + if (!result.Canceled) + { + ReLoadData(); + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + } + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor b/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor new file mode 100644 index 0000000..12a873b --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor @@ -0,0 +1,28 @@ +@using BackOffice.BFF.Role.Protobuf.Protos.Role + + + @if (_isFirstLoad) + { + + + + + } + else + { + + @foreach (var item in _roleresponse.Models.OrderBy(x=>x.Name).ToList()) + { + + + } + + } + + + + بستن + ثبت + + + \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor.cs b/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor.cs new file mode 100644 index 0000000..e212b36 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/User/Components/UserRoleDialog.razor.cs @@ -0,0 +1,68 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using BackOffice.BFF.User.Protobuf.Protos.User; +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; + +namespace BackOffice.Pages.User.Components; +public partial class UserRoleDialog +{ + [Parameter] public long UserId { get; set; } + [CascadingParameter] MudDialogInstance MudDialog { get; set; } + MudForm _form; + private bool _isLoading; + private bool _isFirstLoad = true; + [Inject] public RoleContract.RoleContractClient RoleService { get; set; } + [Inject] public UserRoleContract.UserRoleContractClient UserRoleService { get; set; } + private GetAllUserRoleByFilterResponse _userRoleresponse = new(); + private GetAllRoleByFilterResponse _roleresponse = new(); + private List _selectedRole = new(); + protected override async Task OnInitializedAsync() + { + await base.OnInitializedAsync(); + + _roleresponse = await RoleService.GetAllRoleByFilterAsync(new()); + _userRoleresponse = await UserRoleService.GetAllUserRoleByFilterAsync(new() { Filter = new() { UserId = UserId } }); + + _selectedRole.AddRange(_userRoleresponse.Models.Select(s => s.RoleId)); + + _isFirstLoad = false; + } + private async Task AddItem() + { + _isLoading = true; + StateHasChanged(); + if (_userRoleresponse != null && _userRoleresponse.Models != null && _userRoleresponse.Models.Any()) + { + foreach (var item in _userRoleresponse.Models) + { + await UserRoleService.DeleteUserRoleAsync(new() { Id = item.Id }); + + } + } + foreach (var item in _selectedRole) + { + await UserRoleService.CreateNewUserRoleAsync(new() { UserId = UserId, RoleId = item }); + + } + + _isLoading = false; + StateHasChanged(); + + MudDialog.Close(DialogResult.Ok(true)); + } + private void OnChackedChange(bool check, long id) + { + if (check) + { + if (!_selectedRole.Any(x => x == id)) + _selectedRole.Add(id); + } + else + { + if (_selectedRole.Any(x => x == id)) + _selectedRole.Remove(id); + } + } + void Cancel() => MudDialog.Cancel(); +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/User/UserMainPage.razor b/src/BackOffice/BackOffice/Pages/User/UserMainPage.razor new file mode 100644 index 0000000..910a9c9 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/User/UserMainPage.razor @@ -0,0 +1,22 @@ +@attribute [Route(RouteConstance.UserPage)] + +@using BackOffice.BFF.User.Protobuf.Protos.User +@using BackOffice.Pages.User.Components + + + + + مدیریت کاربر + + + + + + +@code { + + private UserDataTable _table; + +} + + diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor b/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor new file mode 100644 index 0000000..6dd1948 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor @@ -0,0 +1,29 @@ +@using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor.cs new file mode 100644 index 0000000..d2142c7 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/CreateDialog.razor.cs @@ -0,0 +1,63 @@ +using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress; +using Google.Protobuf; +using Grpc.Core; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.UserAddress.Components; + +public partial class CreateDialog +{ + [Inject] public UserAddressContract.UserAddressContractClient UserAddressContract { get; set; } + [Parameter] public CreateNewUserAddressRequest Model { get; set; } = new(); + [CascadingParameter] MudDialogInstance MudDialog { get; set; } + + private bool _isLoading = false; + + public async void CallCreateMethod() + { + _isLoading = true; + StateHasChanged(); + + if (string.IsNullOrWhiteSpace(Model.Title)) + { + Snackbar.Add("لطفا عنوان را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.Address)) + { + Snackbar.Add("لطفا ادرس را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.PostalCode)) + { + Snackbar.Add("لطفا کد پستی را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + + + try + { + await UserAddressContract.CreateNewUserAddressAsync(Model); + Submit(); + + } + catch (RpcException ex) + { + Console.WriteLine(ex); + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor new file mode 100644 index 0000000..86c2d5a --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor @@ -0,0 +1,29 @@ +@using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor.cs new file mode 100644 index 0000000..212edaa --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UpdateDialog.razor.cs @@ -0,0 +1,63 @@ +using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress; +using Google.Protobuf; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.UserAddress.Components +{ + public partial class UpdateDialog + { + private bool _isLoading = false; + [Inject] public UserAddressContract.UserAddressContractClient UserAddressContract { get; set; } + + [Parameter] + public UpdateUserAddressRequest Model { get; set; } = new(); + + [CascadingParameter] + MudDialogInstance MudDialog { get; set; } + public async void CallUpdateMethod() + { + _isLoading = true; + StateHasChanged(); + if (string.IsNullOrWhiteSpace(Model.Title)) + { + Snackbar.Add("لطفا عنوان را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.Address)) + { + Snackbar.Add("لطفا ادرس را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + if (string.IsNullOrWhiteSpace(Model.PostalCode)) + { + Snackbar.Add("لطفا کد پستی را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + + try + { + await UserAddressContract.UpdateUserAddressAsync(Model); + Submit(); + + } + catch (Exception) + { + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor new file mode 100644 index 0000000..e2396f6 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor @@ -0,0 +1,39 @@ +@using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress +@using BackOffice.Common.BaseComponents +@using DataModel = BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress.GetAllUserAddressByFilterResponseModel + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor.cs new file mode 100644 index 0000000..f5b295a --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/Components/UserAddressDataTable.razor.cs @@ -0,0 +1,77 @@ +using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress; +using Google.Protobuf.WellKnownTypes; +using HtmlAgilityPack; +using Mapster; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using static Google.Rpc.Context.AttributeContext.Types; +using DataModel = BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress.GetAllUserAddressByFilterResponseModel; + +namespace BackOffice.Pages.UserAddress.Components; + +public partial class UserAddressDataTable +{ + [Parameter] public long UserId { get; set; } + [Inject] public UserAddressContract.UserAddressContractClient UserAddressContract { get; set; } + private bool _isLoading = true; + private MudDataGrid _gridData; + + private GetAllUserAddressByFilterRequest _request = new() { Filter = new() }; + private async Task> ServerReload(GridState state) + { + _request.Filter ??= new(); + _request.PaginationState ??= new(); + _request.PaginationState.PageNumber = state.Page + 1; + _request.PaginationState.PageSize = state.PageSize; + + _request.Filter.UserId = UserId; + + + var result = await UserAddressContract.GetAllUserAddressByFilterAsync(_request); + if (result != null && result.Models != null && result.Models.Any()) + { + return new GridData() { Items = result.Models.ToList(), TotalItems = (int)result.MetaData.TotalCount }; + } + + return new GridData(); + } + public async Task Update(DataModel model) + { + var parameters = new DialogParameters { { x => x.Model, model.Adapt() } }; + + var dialog = await DialogService.ShowAsync($"ویرایش آدرس", parameters, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + + if (!result.Canceled) + { + ReLoadData(); + //Reload Data + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + + } + } + private async Task OnDelete(DataModel model) + { + var options = new DialogOptions { CloseOnEscapeKey = true, MaxWidth = MaxWidth.Small }; + bool? result = await DialogService.ShowMessageBox( + "اخطار", + "آیا از حذف این مورد مطمئن هستید؟", + yesText: "حذف", cancelText: "لغو", + options: options); + if (result != null && result.Value) + { + await UserAddressContract.DeleteUserAddressAsync(new() + { + Id = model.Id + }); + ReLoadData(); + } + StateHasChanged(); + } + public async void ReLoadData() + { + if (_gridData != null) + await _gridData.ReloadServerData(); + } + +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserAddress/UserAddressMainPage.razor b/src/BackOffice/BackOffice/Pages/UserAddress/UserAddressMainPage.razor new file mode 100644 index 0000000..c66240c --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserAddress/UserAddressMainPage.razor @@ -0,0 +1,36 @@ +@attribute [Route(RouteConstance.UserAddress+"{UserId:long}")] + +@using BackOffice.BFF.UserAddress.Protobuf.Protos.UserAddress +@using BackOffice.Pages.UserAddress.Components + + + + + مدیریت آدرس + + افزودن + + + + + + + +@code { + [Parameter] public long UserId { get; set; } + private UserAddressDataTable _table; + + public async Task CreateNew() + { + var dialog = await DialogService.ShowAsync($"افزودن آدرس", new DialogParameters() { { x => x.Model, new CreateNewUserAddressRequest() { UserId = UserId } } }, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + if (!result.Canceled) + { + _table.ReLoadData(); + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + } + } + +} + + diff --git a/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor b/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor new file mode 100644 index 0000000..17ae14d --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor @@ -0,0 +1,51 @@ +@using BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder +@using BackOffice.Common.BaseComponents +@using DataModel = BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder.GetAllUserOrderByFilterResponseModel + + + + + + + + + + + + + + + @if (context.Item.PaymentStatus) + { + پرداخت شده + } + else + { + پرداخت نشده + } + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor.cs new file mode 100644 index 0000000..dea0d1e --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserOrder/Components/UserOrderDataTable.razor.cs @@ -0,0 +1,62 @@ +using BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder; +using Google.Protobuf.WellKnownTypes; +using HtmlAgilityPack; +using Mapster; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using static Google.Rpc.Context.AttributeContext.Types; +using DataModel = BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder.GetAllUserOrderByFilterResponseModel; + +namespace BackOffice.Pages.UserOrder.Components; + +public partial class UserOrderDataTable +{ + [Parameter] public long UserId { get; set; } + + [Inject] public UserOrderContract.UserOrderContractClient UserOrderContract { get; set; } + private bool _isLoading = true; + private MudDataGrid _gridData; + + private GetAllUserOrderByFilterRequest _request = new() { Filter = new() }; + private async Task> ServerReload(GridState state) + { + _request.Filter ??= new(); + _request.PaginationState ??= new(); + _request.PaginationState.PageNumber = state.Page + 1; + _request.PaginationState.PageSize = state.PageSize; + + _request.Filter.UserId = UserId; + + var result = await UserOrderContract.GetAllUserOrderByFilterAsync(_request); + if (result != null && result.Models != null && result.Models.Any()) + { + return new GridData() { Items = result.Models.ToList(), TotalItems = (int)result.MetaData.TotalCount }; + } + + return new GridData(); + } + private async Task OnDelete(DataModel model) + { + var options = new DialogOptions { CloseOnEscapeKey = true, MaxWidth = MaxWidth.Small }; + bool? result = await DialogService.ShowMessageBox( + "اخطار", + "آیا از حذف این مورد مطمئن هستید؟", + yesText: "حذف", cancelText: "لغو", + options: options); + if (result != null && result.Value) + { + await UserOrderContract.DeleteUserOrderAsync(new() + { + Id = model.Id + }); + ReLoadData(); + } + StateHasChanged(); + } + public async void ReLoadData() + { + if (_gridData != null) + await _gridData.ReloadServerData(); + } + +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserOrder/UserOrderMainPage.razor b/src/BackOffice/BackOffice/Pages/UserOrder/UserOrderMainPage.razor new file mode 100644 index 0000000..6a2ed7a --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserOrder/UserOrderMainPage.razor @@ -0,0 +1,23 @@ +@attribute [Route(RouteConstance.UserOrder + "{UserId:long}")] + +@using BackOffice.BFF.UserOrder.Protobuf.Protos.UserOrder +@using BackOffice.Pages.UserOrder.Components + + + + + فاکتور + + + + + + +@code { + [Parameter] public long UserId { get; set; } + + private UserOrderDataTable _table; + +} + + diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor b/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor new file mode 100644 index 0000000..6995bdf --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor @@ -0,0 +1,21 @@ +@using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor.cs new file mode 100644 index 0000000..4bd7a3d --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/CreateDialog.razor.cs @@ -0,0 +1,47 @@ +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; +using Google.Protobuf; +using Grpc.Core; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.UserRole.Components; + +public partial class CreateDialog +{ + [Inject] public UserRoleContract.UserRoleContractClient UserRoleContract { get; set; } + [Parameter] public CreateNewUserRoleRequest Model { get; set; } = new(); + [CascadingParameter] MudDialogInstance MudDialog { get; set; } + + private bool _isLoading = false; + + public async void CallCreateMethod() + { + _isLoading = true; + StateHasChanged(); + + if (Model.RoleId <= 0) + { + Snackbar.Add("لطفا نقش را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + try + { + await UserRoleContract.CreateNewUserRoleAsync(Model); + Submit(); + + } + catch (RpcException ex) + { + Console.WriteLine(ex); + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor b/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor new file mode 100644 index 0000000..7e906d1 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor @@ -0,0 +1,17 @@ +@if (getRoleResponse == null || getRoleResponse.Id < 0) +{ + if (_isLoading) + { + + } + else + { + - + } +} +else +{ + + @($"{getRoleResponse.Title}") + +} diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor.cs b/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor.cs new file mode 100644 index 0000000..5367f89 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/RoleTitleColumn.razor.cs @@ -0,0 +1,30 @@ +using BackOffice.BFF.Role.Protobuf.Protos.Role; +using Microsoft.AspNetCore.Components; + +namespace BackOffice.Pages.UserRole.Components; +public partial class RoleTitleColumn +{ + [Parameter] + public long RoleId { get; set; } + + [Inject] public RoleContract.RoleContractClient RoleService { get; set; } + + private GetRoleResponse getRoleResponse = new(); + private bool _isLoading = true; + + protected override async Task OnAfterRenderAsync(bool firstRender) + { + await base.OnAfterRenderAsync(firstRender); + if (firstRender) + { + + getRoleResponse = await RoleService.GetRoleAsync(new() + { + Id = RoleId + }); + + _isLoading = false; + StateHasChanged(); + } + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor b/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor new file mode 100644 index 0000000..103001c --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor @@ -0,0 +1,21 @@ +@using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole +@using BackOffice.Common.BaseComponents +@using Microsoft.AspNetCore.Components.Forms +@using Tizzani.MudBlazor.HtmlEditor + + + + + + + + + + + + + لغو + ثبت + + + diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor.cs b/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor.cs new file mode 100644 index 0000000..baebcdd --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/UpdateDialog.razor.cs @@ -0,0 +1,50 @@ +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; +using Google.Protobuf; +using Microsoft.AspNetCore.Components; +using Microsoft.AspNetCore.Components.Forms; +using MudBlazor; + +namespace BackOffice.Pages.UserRole.Components +{ + public partial class UpdateDialog + { + private bool _isLoading = false; + [Inject] public UserRoleContract.UserRoleContractClient UserRoleContract { get; set; } + + [Parameter] + public UpdateUserRoleRequest Model { get; set; } = new(); + + [CascadingParameter] + MudDialogInstance MudDialog { get; set; } + + public async void CallUpdateMethod() + { + _isLoading = true; + StateHasChanged(); + if (Model.RoleId <= 0) + { + Snackbar.Add("لطفا نقش را وارد کنید!", Severity.Warning); + _isLoading = false; + StateHasChanged(); + return; + } + + try + { + await UserRoleContract.UpdateUserRoleAsync(Model); + Submit(); + + } + catch (Exception) + { + Snackbar.Add("خطای سرور", Severity.Error); + } + + _isLoading = false; + StateHasChanged(); + } + + void Submit() => MudDialog.Close(DialogResult.Ok(true)); + void Cancel() => MudDialog.Cancel(); + } +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor b/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor new file mode 100644 index 0000000..c197683 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor @@ -0,0 +1,39 @@ +@using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole +@using BackOffice.Common.BaseComponents +@using DataModel = BackOffice.BFF.UserRole.Protobuf.Protos.UserRole.GetAllUserRoleByFilterResponseModel + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor.cs b/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor.cs new file mode 100644 index 0000000..507fb21 --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/Components/UserRoleDataTable.razor.cs @@ -0,0 +1,76 @@ +using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole; +using Google.Protobuf.WellKnownTypes; +using HtmlAgilityPack; +using Mapster; +using Microsoft.AspNetCore.Components; +using MudBlazor; +using static Google.Rpc.Context.AttributeContext.Types; +using DataModel = BackOffice.BFF.UserRole.Protobuf.Protos.UserRole.GetAllUserRoleByFilterResponseModel; + +namespace BackOffice.Pages.UserRole.Components; + +public partial class UserRoleDataTable +{ + [Parameter] public long UserId { get; set; } + [Inject] public UserRoleContract.UserRoleContractClient UserRoleContract { get; set; } + private bool _isLoading = true; + private MudDataGrid _gridData; + + private GetAllUserRoleByFilterRequest _request = new() { Filter = new() }; + private async Task> ServerReload(GridState state) + { + _request.Filter ??= new(); + _request.PaginationState ??= new(); + _request.PaginationState.PageNumber = state.Page + 1; + _request.PaginationState.PageSize = state.PageSize; + + _request.Filter.UserId = UserId; + + var result = await UserRoleContract.GetAllUserRoleByFilterAsync(_request); + if (result != null && result.Models != null && result.Models.Any()) + { + return new GridData() { Items = result.Models.ToList(), TotalItems = (int)result.MetaData.TotalCount }; + } + + return new GridData(); + } + public async Task Update(DataModel model) + { + var parameters = new DialogParameters { { x => x.Model, model.Adapt() } }; + + var dialog = await DialogService.ShowAsync($"ویرایش کاربر", parameters, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + + if (!result.Canceled) + { + ReLoadData(); + //Reload Data + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + + } + } + private async Task OnDelete(DataModel model) + { + var options = new DialogOptions { CloseOnEscapeKey = true, MaxWidth = MaxWidth.Small }; + bool? result = await DialogService.ShowMessageBox( + "اخطار", + "آیا از حذف این مورد مطمئن هستید؟", + yesText: "حذف", cancelText: "لغو", + options: options); + if (result != null && result.Value) + { + await UserRoleContract.DeleteUserRoleAsync(new() + { + Id = model.Id + }); + ReLoadData(); + } + StateHasChanged(); + } + public async void ReLoadData() + { + if (_gridData != null) + await _gridData.ReloadServerData(); + } + +} \ No newline at end of file diff --git a/src/BackOffice/BackOffice/Pages/UserRole/UserRoleMainPage.razor b/src/BackOffice/BackOffice/Pages/UserRole/UserRoleMainPage.razor new file mode 100644 index 0000000..8ade2ea --- /dev/null +++ b/src/BackOffice/BackOffice/Pages/UserRole/UserRoleMainPage.razor @@ -0,0 +1,37 @@ +@attribute [Route(RouteConstance.UserRole + "{UserId:long}")] + +@using BackOffice.BFF.UserRole.Protobuf.Protos.UserRole +@using BackOffice.Pages.UserRole.Components + + + + + مدیریت نقش های کاربر + + افزودن + + + + + + + +@code { + [Parameter] public long UserId { get; set; } + + private UserRoleDataTable _table; + + public async Task CreateNew() + { + var dialog = await DialogService.ShowAsync($"افزودن نقش های کاربر", new DialogParameters() { { x => x.Model, new CreateNewUserRoleRequest() { UserId = UserId } } }, new DialogOptions() { CloseButton = true, FullWidth = true, MaxWidth = MaxWidth.Small }); + var result = await dialog.Result; + if (!result.Canceled) + { + _table.ReLoadData(); + Snackbar.Add("عملیات با موفقیت انجام شد", Severity.Success); + } + } + +} + + diff --git a/src/BackOffice/BackOffice/Shared/NavMenu.razor b/src/BackOffice/BackOffice/Shared/NavMenu.razor index 9796d16..a89e1eb 100644 --- a/src/BackOffice/BackOffice/Shared/NavMenu.razor +++ b/src/BackOffice/BackOffice/Shared/NavMenu.razor @@ -6,6 +6,8 @@ مدیریت پکیج + مدیریت کاربر + مدیریت نقش