Revert "Fix for Tabpanel is not updating the UI. #4778"
This commit is contained in:
		| @ -10,7 +10,7 @@ | ||||
| @if (_initialized) | ||||
| { | ||||
|     <form @ref="form" class="@(validated ? "was-validated" : "needs-validation")" novalidate> | ||||
|         <TabStrip Refresh="@_refresh" ActiveTab="@_activetab"> | ||||
|         <TabStrip Refresh="@_refresh"> | ||||
|             <TabPanel Name="Settings" ResourceKey="Settings" Heading="Settings"> | ||||
|                 <div class="container"> | ||||
|                     <div class="row mb-1 align-items-center"> | ||||
| @ -246,7 +246,6 @@ | ||||
|     private string _iconresources = ""; | ||||
|     private DateTime? _effectivedate = null; | ||||
|     private DateTime? _expirydate = null; | ||||
|     private string _activetab = ""; | ||||
|  | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
| @ -336,7 +335,6 @@ | ||||
|  | ||||
|     private async Task SavePage() | ||||
|     { | ||||
|         _activetab = "Settings"; | ||||
|         validated = true; | ||||
|         var interop = new Interop(JSRuntime); | ||||
|         if (await interop.FormValid(form)) | ||||
|  | ||||
| @ -16,7 +16,7 @@ | ||||
|     <form @ref="form" class="@(validated ? "was-validated" : "needs-validation")" novalidate> | ||||
|         @if (_page.UserId == null) | ||||
|         { | ||||
|             <TabStrip Refresh="@_refresh" ActiveTab="@_activetab"> | ||||
|             <TabStrip Refresh="@_refresh"> | ||||
|                 <TabPanel Name="Settings" ResourceKey="Settings" Heading="Settings"> | ||||
|                     <div class="container"> | ||||
|                         <div class="row mb-1 align-items-center"> | ||||
| @ -30,16 +30,16 @@ | ||||
|                             <div class="row mb-1 align-items-center"> | ||||
|                                 <Label Class="col-sm-3" For="parent" HelpText="Select the parent for the page in the site hierarchy" ResourceKey="Parent">Parent: </Label> | ||||
|                                 <div class="col-sm-9"> | ||||
|                                     <select id="parent" class="form-select" value="@_parentid" @onchange="(e => ParentChanged(e))" required> | ||||
|                                         <option value="-1"><@Localizer["SiteRoot"]></option> | ||||
|                                         @foreach (Page page in _pages) | ||||
|                                         { | ||||
|                                             if (UserSecurity.IsAuthorized(PageState.User, PermissionNames.View, page.PermissionList) && page.PageId != _pageId) | ||||
|                                         <select id="parent" class="form-select" value="@_parentid" @onchange="(e => ParentChanged(e))" required> | ||||
|                                             <option value="-1"><@Localizer["SiteRoot"]></option> | ||||
|                                             @foreach (Page page in _pages) | ||||
|                                             { | ||||
|                                                 <option value="@(page.PageId)">@(new string('-', page.Level * 2))@(page.Name)</option> | ||||
|                                                 if (UserSecurity.IsAuthorized(PageState.User, PermissionNames.View, page.PermissionList) && page.PageId != _pageId) | ||||
|                                                 { | ||||
|                                                     <option value="@(page.PageId)">@(new string('-', page.Level * 2))@(page.Name)</option> | ||||
|                                                 } | ||||
|                                             } | ||||
|                                         } | ||||
|                                     </select> | ||||
|                                         </select> | ||||
|                                 </div> | ||||
|                             </div> | ||||
|                             <div class="row mb-1 align-items-center"> | ||||
| @ -230,10 +230,10 @@ | ||||
|                 <TabPanel Name="PageModules" Heading="Modules" ResourceKey="PageModules"> | ||||
|                     <Pager Items="_pageModules"> | ||||
|                         <Header> | ||||
|                             <th style="width: 1px;"> </th> | ||||
|                             <th style="width: 1px;"> </th> | ||||
|                             <th>@Localizer["ModuleTitle"]</th> | ||||
|                             <th>@Localizer["ModuleDefinition"]</th> | ||||
|                         <th style="width: 1px;"> </th> | ||||
|                         <th style="width: 1px;"> </th> | ||||
|                         <th>@Localizer["ModuleTitle"]</th> | ||||
|                         <th>@Localizer["ModuleDefinition"]</th> | ||||
|                         </Header> | ||||
|                         <Row> | ||||
|                             <td><ActionLink Action="Settings" Text="Edit" Path="@_actualpath" ModuleId="@context.ModuleId" Security="SecurityAccessLevel.Edit" PermissionList="@context.PermissionList" ResourceKey="ModuleSettings" /></td> | ||||
| @ -356,7 +356,6 @@ | ||||
|     private string _iconresources = ""; | ||||
|     private DateTime? _effectivedate = null; | ||||
|     private DateTime? _expirydate = null; | ||||
|     private string _activetab = ""; | ||||
|  | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
| @ -467,7 +466,7 @@ | ||||
|             _parentid = (string)e.Value; | ||||
|             _children = new List<Page>(); | ||||
|             foreach (Page p in _pages.Where(item => (_parentid == "-1" && item.ParentId == null) || (item.ParentId == int.Parse(_parentid)))) | ||||
|             { | ||||
|         { | ||||
|                 if (p.PageId != _pageId && UserSecurity.IsAuthorized(PageState.User, PermissionNames.View, p.PermissionList)) | ||||
|                 { | ||||
|                     _children.Add(p); | ||||
| @ -513,7 +512,7 @@ | ||||
|                     builder.OpenComponent(0, _themeSettingsType); | ||||
|                     builder.AddAttribute(1, "RenderModeBoundary", RenderModeBoundary); | ||||
|                     builder.AddComponentReferenceCapture(2, inst => { _themeSettings = Convert.ChangeType(inst, _themeSettingsType); }); | ||||
|  | ||||
|                      | ||||
|                     builder.CloseComponent(); | ||||
|                 }; | ||||
|             } | ||||
| @ -523,7 +522,6 @@ | ||||
|  | ||||
|     private async Task SavePage() | ||||
|     { | ||||
|         _activetab = "Settings"; | ||||
|         validated = true; | ||||
|         var interop = new Interop(JSRuntime); | ||||
|         if (await interop.FormValid(form)) | ||||
| @ -672,7 +670,7 @@ | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     AddModuleMessage(Localizer["Message.Required.PageInfo"], MessageType.Warning);                     | ||||
|                     AddModuleMessage(Localizer["Message.Required.PageInfo"], MessageType.Warning); | ||||
|                 } | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|  | ||||
| @ -30,8 +30,6 @@ else | ||||
|     [Parameter] | ||||
|     public SecurityAccessLevel? Security { get; set; } // optional - can be used to specify SecurityAccessLevel | ||||
|  | ||||
|     public bool IsActive { get; set; } | ||||
|  | ||||
|     protected override void OnParametersSet() | ||||
|     { | ||||
|         base.OnParametersSet(); | ||||
|  | ||||
| @ -8,9 +8,18 @@ | ||||
|                 @foreach (TabPanel tabPanel in _tabPanels) | ||||
|                 { | ||||
|                     <li class="nav-item" @key="tabPanel.Name"> | ||||
|                         <a class="nav-link @(tabPanel.IsActive ? "active" : "")" data-bs-toggle="tab" href="#@(Id + tabPanel.Name)" role="tab" @onclick:preventDefault="true" @onclick="() => SetActiveTab(tabPanel.Name)"> | ||||
|                             @tabPanel.DisplayHeading() | ||||
|                         </a> | ||||
|                         @if (tabPanel.Name.ToLower() == ActiveTab.ToLower()) | ||||
|                         { | ||||
|                             <a class="nav-link active" data-bs-toggle="tab" href="#@(Id + tabPanel.Name)" role="tab" @onclick:preventDefault="true"> | ||||
|                                 @tabPanel.DisplayHeading() | ||||
|                             </a> | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
| 							<a class="nav-link" data-bs-toggle="tab" href="#@(Id + tabPanel.Name)" role="tab" @onclick:preventDefault="true"> | ||||
|                                 @tabPanel.DisplayHeading() | ||||
|                             </a> | ||||
|                         } | ||||
|                     </li> | ||||
|                 } | ||||
|             </ul> | ||||
| @ -50,43 +59,16 @@ | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
|     protected override void OnParametersSet() | ||||
| 	protected override void OnParametersSet() | ||||
|     { | ||||
|         base.OnParametersSet(); | ||||
|  | ||||
|         if (PageState.QueryString.ContainsKey("tab")) | ||||
|         { | ||||
|             ActiveTab = PageState.QueryString["tab"]; | ||||
|         } | ||||
|  | ||||
|         if (_tabPanels == null || Refresh) | ||||
|         { | ||||
|             _tabPanels = new List<TabPanel>(); | ||||
|         } | ||||
|  | ||||
|         // Ensure the active tab is valid and exists | ||||
|         if (!string.IsNullOrEmpty(ActiveTab) && _tabPanels.Any()) | ||||
|         { | ||||
|             var activeTabExists = _tabPanels.Any(tp => tp.Name.Equals(ActiveTab, StringComparison.OrdinalIgnoreCase)); | ||||
|             if (!activeTabExists) | ||||
|             { | ||||
|                 ActiveTab = _tabPanels[0].Name; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Update the active tab in the UI | ||||
|         UpdateActiveTab(); | ||||
|     } | ||||
|  | ||||
|     private void UpdateActiveTab() | ||||
|     { | ||||
|         if (!string.IsNullOrEmpty(ActiveTab) && _tabPanels != null) | ||||
|         { | ||||
|             foreach (var tabPanel in _tabPanels) | ||||
|             { | ||||
|                 tabPanel.IsActive = tabPanel.Name.Equals(ActiveTab, StringComparison.OrdinalIgnoreCase); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     internal void AddTabPanel(TabPanel tabPanel) | ||||
| @ -94,20 +76,12 @@ | ||||
|         if (!_tabPanels.Exists(item => item.Name == tabPanel.Name) && IsAuthorized(tabPanel)) | ||||
|         { | ||||
|             _tabPanels.Add(tabPanel); | ||||
|             if (string.IsNullOrEmpty(ActiveTab)) | ||||
|             { | ||||
|                 ActiveTab = tabPanel.Name; | ||||
|             } | ||||
|             UpdateActiveTab(); | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void SetActiveTab(string tabName) | ||||
|     { | ||||
|         ActiveTab = tabName; | ||||
|         UpdateActiveTab(); | ||||
|         StateHasChanged(); | ||||
|         if (string.IsNullOrEmpty(ActiveTab)) | ||||
|         { | ||||
|             ActiveTab = tabPanel.Name; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private bool IsAuthorized(TabPanel tabPanel) | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker