Add InputList control to select values from a dictionary of string
The control accepts a dictionary of string that can be searched using an input control. Pages Add and Edit have implemented the control to render the list of Icons found in the Oqtane Shared namespace.
This commit is contained in:
		| @ -112,7 +112,7 @@ | ||||
|                     <div class="row mb-1 align-items-center"> | ||||
|                         <Label Class="col-sm-3" For="icon" HelpText="Optionally provide an icon class name for this page which will be displayed in the site navigation" ResourceKey="Icon">Icon: </Label> | ||||
|                         <div class="col-sm-9"> | ||||
|                             <input id="icon" class="form-control" @bind="@_icon" /> | ||||
|                             <InputList Value="@_icon" ValueChanged="IconChanged" InputValues="@IconList" /> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                     <div class="row mb-1 align-items-center"> | ||||
| @ -215,7 +215,7 @@ | ||||
|     private string _url; | ||||
|     private string _ispersonalizable = "False"; | ||||
|     private string _title; | ||||
|     private string _icon = string.Empty; | ||||
|     private string _icon { get; set; } = string.Empty; | ||||
|     private string _themetype = string.Empty; | ||||
|     private string _containertype = string.Empty; | ||||
|     private string _headcontent; | ||||
| @ -227,6 +227,7 @@ | ||||
|     private RenderFragment ThemeSettingsComponent { get; set; } | ||||
|     private bool _refresh = false; | ||||
|     protected Page _parent = null; | ||||
|     protected Dictionary<string, string> IconList = new(); | ||||
|  | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
| @ -242,6 +243,20 @@ | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             Type iconsType = typeof(Icons); | ||||
|             System.Reflection.FieldInfo[] fields = iconsType.GetFields(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.GetField); | ||||
|  | ||||
|             foreach (System.Reflection.FieldInfo field in fields) | ||||
|             { | ||||
|                 if (field.FieldType == typeof(string)) | ||||
|                 { | ||||
|                     string fieldName = field.Name; | ||||
|                     string fieldValue = (string)field.GetValue(null); | ||||
|  | ||||
|                     IconList.Add(fieldName, fieldValue); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // if admin or user has edit access to parent page | ||||
|             if (UserSecurity.IsAuthorized(PageState.User, RoleNames.Admin) || (_parent != null && UserSecurity.IsAuthorized(PageState.User, PermissionNames.Edit, _parent.PermissionList))) | ||||
|             { | ||||
| @ -482,4 +497,8 @@ | ||||
|             NavigationManager.NavigateTo(NavigateUrl()); | ||||
|         } | ||||
|     } | ||||
|     private void IconChanged(string NewIcon) | ||||
|     { | ||||
|         _icon = NewIcon; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -124,7 +124,7 @@ | ||||
|                         <div class="row mb-1 align-items-center"> | ||||
|                             <Label Class="col-sm-3" For="icon" HelpText="Optionally provide an icon class name for this page which will be displayed in the site navigation" ResourceKey="Icon">Icon: </Label> | ||||
|                             <div class="col-sm-9"> | ||||
|                                 <input id="icon" class="form-control" @bind="@_icon" maxlength="50" /> | ||||
|                                 <InputList Value="@_icon" ValueChanged="IconChanged" InputValues="@IconList" /> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                         <div class="row mb-1 align-items-center"> | ||||
| @ -292,7 +292,7 @@ | ||||
|     private string _url; | ||||
|     private string _ispersonalizable; | ||||
|     private string _title; | ||||
|     private string _icon; | ||||
|     private string _icon { get; set; } | ||||
|     private string _themetype; | ||||
|     private string _containertype = "-"; | ||||
|     private Type _themeSettingsType; | ||||
| @ -312,7 +312,7 @@ | ||||
|     private bool _refresh = false; | ||||
|     protected Page _page = null; | ||||
|     protected Page _parent = null; | ||||
|  | ||||
|     protected Dictionary<string, string> IconList = new(); | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
|         try | ||||
| @ -352,6 +352,20 @@ | ||||
|                 _icon = _page.Icon; | ||||
|                 _ispersonalizable = _page.IsPersonalizable.ToString(); | ||||
|  | ||||
|                 Type iconsType = typeof(Icons); | ||||
|                 System.Reflection.FieldInfo[] fields = iconsType.GetFields(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.GetField); | ||||
|  | ||||
|                 foreach (System.Reflection.FieldInfo field in fields) | ||||
|                 { | ||||
|                     if (field.FieldType == typeof(string)) | ||||
|                     { | ||||
|                         string fieldName = field.Name; | ||||
|                         string fieldValue = (string)field.GetValue(null); | ||||
|  | ||||
|                         IconList.Add(fieldName, fieldValue); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 // appearance | ||||
|                 _title = _page.Title; | ||||
|                 _themetype = _page.ThemeType; | ||||
| @ -660,4 +674,9 @@ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void IconChanged(string NewIcon) | ||||
|     { | ||||
|         _icon = NewIcon; | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Leigh Pointer
					Leigh Pointer