Improvements to themes, layouts, and CSS styling
This commit is contained in:
		| @ -19,7 +19,7 @@ | ||||
|  | ||||
| @if (packages != null) | ||||
| { | ||||
|     <hr /> | ||||
|     <hr class="app-rule" /> | ||||
|     <div class="mx-auto text-center"><h2>Available Modules</h2></div> | ||||
|  | ||||
|     <Pager Items="@packages"> | ||||
|  | ||||
| @ -88,7 +88,7 @@ | ||||
|             <label for="Name" class="control-label">Theme: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@themetype"> | ||||
|             <select class="form-control" @onchange="(e => ThemeChanged(e))"> | ||||
|                 <option value=""><Select Theme></option> | ||||
|                 @foreach (KeyValuePair<string, string> item in themes) | ||||
|                 { | ||||
| @ -161,9 +161,9 @@ | ||||
|             children = PageState.Pages.Where(item => item.ParentId == null).ToList(); | ||||
|  | ||||
|             themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|  | ||||
|             themetype = PageState.Site.DefaultThemeType; | ||||
|  | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|             layouttype = PageState.Site.DefaultLayoutType; | ||||
|  | ||||
|             List<PermissionString> permissionstrings = new List<PermissionString>(); | ||||
| @ -198,78 +198,106 @@ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void ThemeChanged(ChangeEventArgs e) | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             themetype = (string)e.Value; | ||||
|             if (themetype != "") | ||||
|             { | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 panelayouts = new Dictionary<string, string>(); | ||||
|             } | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SavePage() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             Page page = new Page(); | ||||
|             page.SiteId = PageState.Page.SiteId; | ||||
|             page.Name = name; | ||||
|             if (path == "") | ||||
|             if (name != "" && !string.IsNullOrEmpty(themetype) && (panelayouts.Count == 0 || !string.IsNullOrEmpty(layouttype))) | ||||
|             { | ||||
|                 path = name; | ||||
|             } | ||||
|             if (path.Contains("/")) | ||||
|             { | ||||
|                 path = path.Substring(path.LastIndexOf("/") + 1); | ||||
|             } | ||||
|             if (string.IsNullOrEmpty(parentid)) | ||||
|             { | ||||
|                 page.ParentId = null; | ||||
|                 page.Path = Utilities.GetFriendlyUrl(path); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 page.ParentId = Int32.Parse(parentid); | ||||
|                 Page parent = PageState.Pages.Where(item => item.PageId == page.ParentId).FirstOrDefault(); | ||||
|                 if (parent.Path == "") | ||||
|                 Page page = new Page(); | ||||
|                 page.SiteId = PageState.Page.SiteId; | ||||
|                 page.Name = name; | ||||
|                 if (path == "") | ||||
|                 { | ||||
|                     page.Path = Utilities.GetFriendlyUrl(parent.Name) + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     path = name; | ||||
|                 } | ||||
|                 if (path.Contains("/")) | ||||
|                 { | ||||
|                     path = path.Substring(path.LastIndexOf("/") + 1); | ||||
|                 } | ||||
|                 if (string.IsNullOrEmpty(parentid)) | ||||
|                 { | ||||
|                     page.ParentId = null; | ||||
|                     page.Path = Utilities.GetFriendlyUrl(path); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     page.Path = parent.Path + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     page.ParentId = Int32.Parse(parentid); | ||||
|                     Page parent = PageState.Pages.Where(item => item.PageId == page.ParentId).FirstOrDefault(); | ||||
|                     if (parent.Path == "") | ||||
|                     { | ||||
|                         page.Path = Utilities.GetFriendlyUrl(parent.Name) + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         page.Path = parent.Path + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             Page child; | ||||
|             switch (insert) | ||||
|             { | ||||
|                 case "<<": | ||||
|                     page.Order = 0; | ||||
|                     break; | ||||
|                 case "<": | ||||
|                     child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                     page.Order = child.Order - 1; | ||||
|                     break; | ||||
|                 case ">": | ||||
|                     child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                     page.Order = child.Order + 1; | ||||
|                     break; | ||||
|                 case ">>": | ||||
|                     page.Order = int.MaxValue; | ||||
|                     break; | ||||
|             } | ||||
|             page.IsNavigation = (isnavigation == null ? true : Boolean.Parse(isnavigation)); | ||||
|             page.EditMode = (mode == "edit" ? true : false); | ||||
|             page.ThemeType = themetype; | ||||
|             page.LayoutType = (layouttype == null ? "" : layouttype); | ||||
|             page.Icon = (icon == null ? "" : icon); | ||||
|             Type type; | ||||
|             if (!string.IsNullOrEmpty(layouttype)) | ||||
|             { | ||||
|                 type = Type.GetType(layouttype); | ||||
|                 Page child; | ||||
|                 switch (insert) | ||||
|                 { | ||||
|                     case "<<": | ||||
|                         page.Order = 0; | ||||
|                         break; | ||||
|                     case "<": | ||||
|                         child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                         page.Order = child.Order - 1; | ||||
|                         break; | ||||
|                     case ">": | ||||
|                         child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                         page.Order = child.Order + 1; | ||||
|                         break; | ||||
|                     case ">>": | ||||
|                         page.Order = int.MaxValue; | ||||
|                         break; | ||||
|                 } | ||||
|                 page.IsNavigation = (isnavigation == null ? true : Boolean.Parse(isnavigation)); | ||||
|                 page.EditMode = (mode == "edit" ? true : false); | ||||
|                 page.ThemeType = themetype; | ||||
|                 page.LayoutType = (layouttype == null ? "" : layouttype); | ||||
|                 page.Icon = (icon == null ? "" : icon); | ||||
|                 page.Permissions = permissiongrid.GetPermissions(); | ||||
|  | ||||
|                 if (page.ThemeType == PageState.Site.DefaultThemeType) | ||||
|                 { | ||||
|                     page.ThemeType = ""; | ||||
|                 } | ||||
|                 if (page.LayoutType == PageState.Site.DefaultLayoutType) | ||||
|                 { | ||||
|                     page.LayoutType = ""; | ||||
|                 } | ||||
|  | ||||
|                 await PageService.AddPageAsync(page); | ||||
|                 await PageService.UpdatePageOrderAsync(page.SiteId, page.ParentId); | ||||
|  | ||||
|                 NavigationManager.NavigateTo(NavigateUrl(page.Path, Reload.Site)); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 type = Type.GetType(themetype); | ||||
|                 AddModuleMessage("You Must Provide Page Name And Theme", MessageType.Warning); | ||||
|             } | ||||
|             System.Reflection.PropertyInfo property = type.GetProperty("Panes"); | ||||
|             page.Panes = (string)property.GetValue(Activator.CreateInstance(type), null); | ||||
|             page.Permissions = permissiongrid.GetPermissions(); | ||||
|             await PageService.AddPageAsync(page); | ||||
|             await PageService.UpdatePageOrderAsync(page.SiteId, page.ParentId); | ||||
|  | ||||
|             NavigationManager.NavigateTo(NavigateUrl(page.Path, Reload.Site)); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|  | ||||
| @ -66,7 +66,14 @@ | ||||
|                     <option value=""><Select Theme></option> | ||||
|                     @foreach (KeyValuePair<string, string> item in themes) | ||||
|                     { | ||||
|                         <option value="@item.Key">@item.Value</option> | ||||
|                         if (item.Key == themetype) | ||||
|                         { | ||||
|                             <option value="@item.Key" selected>@item.Value</option> | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             <option value="@item.Key">@item.Value</option> | ||||
|                         } | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
| @ -140,7 +147,6 @@ | ||||
|         try | ||||
|         { | ||||
|             themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|  | ||||
|             PageId = Int32.Parse(PageState.QueryString["id"]); | ||||
|             Page page = PageState.Pages.Where(item => item.PageId == PageId).FirstOrDefault(); | ||||
| @ -151,6 +157,7 @@ | ||||
|                 isnavigation = page.IsNavigation.ToString(); | ||||
|                 mode = (page.EditMode) ? "edit" : "view"; | ||||
|                 themetype = page.ThemeType; | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|                 layouttype = page.LayoutType; | ||||
|                 icon = page.Icon; | ||||
|                 permissions = page.Permissions; | ||||
|  | ||||
| @ -99,11 +99,18 @@ | ||||
|                 <label for="Name" class="control-label">Theme: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@themetype"> | ||||
|                 <select class="form-control" @onchange="(e => ThemeChanged(e))"> | ||||
|                     <option value=""><Select Theme></option> | ||||
|                     @foreach (KeyValuePair<string, string> item in themes) | ||||
|                     { | ||||
|                         <option value="@item.Key">@item.Value</option> | ||||
|                         if (item.Key == themetype) | ||||
|                         { | ||||
|                             <option value="@item.Key" selected>@item.Value</option> | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             <option value="@item.Key">@item.Value</option> | ||||
|                         } | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
| @ -195,7 +202,6 @@ | ||||
|             children = PageState.Pages.Where(item => item.ParentId == null).ToList(); | ||||
|  | ||||
|             themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|  | ||||
|             PageId = Int32.Parse(PageState.QueryString["id"]); | ||||
|             Page page = PageState.Pages.Where(item => item.PageId == PageId).FirstOrDefault(); | ||||
| @ -219,6 +225,7 @@ | ||||
|                 isnavigation = page.IsNavigation.ToString(); | ||||
|                 mode = (page.EditMode) ? "edit" : "view"; | ||||
|                 themetype = page.ThemeType; | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|                 layouttype = page.LayoutType; | ||||
|                 icon = page.Icon; | ||||
|                 permissions = page.Permissions; | ||||
| @ -266,102 +273,128 @@ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void ThemeChanged(ChangeEventArgs e) | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             themetype = (string)e.Value; | ||||
|             if (themetype != "") | ||||
|             { | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 panelayouts = new Dictionary<string, string>(); | ||||
|             } | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SavePage() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             Page page = PageState.Pages.Where(item => item.PageId == PageId).FirstOrDefault(); | ||||
|             string currentpath = page.Path; | ||||
|             if (name != "" && !string.IsNullOrEmpty(themetype) && (panelayouts.Count == 0 || !string.IsNullOrEmpty(layouttype))) | ||||
|             { | ||||
|                 Page page = PageState.Pages.Where(item => item.PageId == PageId).FirstOrDefault(); | ||||
|                 string currentpath = page.Path; | ||||
|  | ||||
|             page.Name = name; | ||||
|             if (path == "") | ||||
|             { | ||||
|                 path = name; | ||||
|             } | ||||
|             if (path.Contains("/")) | ||||
|             { | ||||
|                 path = path.Substring(path.LastIndexOf("/") + 1); | ||||
|             } | ||||
|             if (string.IsNullOrEmpty(parentid)) | ||||
|             { | ||||
|                 page.ParentId = null; | ||||
|                 page.Path = Utilities.GetFriendlyUrl(path); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 page.ParentId = Int32.Parse(parentid); | ||||
|                 Page parent = PageState.Pages.Where(item => item.PageId == page.ParentId).FirstOrDefault(); | ||||
|                 if (parent.Path == "") | ||||
|                 page.Name = name; | ||||
|                 if (path == "" && name.ToLower() != "home") | ||||
|                 { | ||||
|                     page.Path = Utilities.GetFriendlyUrl(parent.Name) + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     path = name; | ||||
|                 } | ||||
|                 if (path.Contains("/")) | ||||
|                 { | ||||
|                     path = path.Substring(path.LastIndexOf("/") + 1); | ||||
|                 } | ||||
|                 if (string.IsNullOrEmpty(parentid)) | ||||
|                 { | ||||
|                     page.ParentId = null; | ||||
|                     page.Path = Utilities.GetFriendlyUrl(path); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     page.Path = parent.Path + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     page.ParentId = Int32.Parse(parentid); | ||||
|                     Page parent = PageState.Pages.Where(item => item.PageId == page.ParentId).FirstOrDefault(); | ||||
|                     if (parent.Path == "") | ||||
|                     { | ||||
|                         page.Path = Utilities.GetFriendlyUrl(parent.Name) + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         page.Path = parent.Path + "/" + Utilities.GetFriendlyUrl(path); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if (insert != "=") | ||||
|             { | ||||
|                 Page child; | ||||
|                 switch (insert) | ||||
|                 if (insert != "=") | ||||
|                 { | ||||
|                     case "<<": | ||||
|                         page.Order = 0; | ||||
|                         break; | ||||
|                     case "<": | ||||
|                         child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                         page.Order = child.Order - 1; | ||||
|                         break; | ||||
|                     case ">": | ||||
|                         child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                         page.Order = child.Order + 1; | ||||
|                         break; | ||||
|                     case ">>": | ||||
|                         page.Order = int.MaxValue; | ||||
|                         break; | ||||
|                     Page child; | ||||
|                     switch (insert) | ||||
|                     { | ||||
|                         case "<<": | ||||
|                             page.Order = 0; | ||||
|                             break; | ||||
|                         case "<": | ||||
|                             child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                             page.Order = child.Order - 1; | ||||
|                             break; | ||||
|                         case ">": | ||||
|                             child = PageState.Pages.Where(item => item.PageId == childid).FirstOrDefault(); | ||||
|                             page.Order = child.Order + 1; | ||||
|                             break; | ||||
|                         case ">>": | ||||
|                             page.Order = int.MaxValue; | ||||
|                             break; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             page.IsNavigation = (isnavigation == null ? true : Boolean.Parse(isnavigation)); | ||||
|             page.EditMode = (mode == "edit" ? true : false); | ||||
|             page.ThemeType = themetype; | ||||
|             page.LayoutType = (layouttype == null ? "" : layouttype); | ||||
|             page.Icon = (icon == null ? "" : icon); | ||||
|             Type type; | ||||
|             if (!string.IsNullOrEmpty(layouttype)) | ||||
|             { | ||||
|                 type = Type.GetType(layouttype); | ||||
|                 page.IsNavigation = (isnavigation == null ? true : Boolean.Parse(isnavigation)); | ||||
|                 page.EditMode = (mode == "edit" ? true : false); | ||||
|                 page.ThemeType = themetype; | ||||
|                 page.LayoutType = (layouttype == null ? "" : layouttype); | ||||
|                 page.Icon = (icon == null ? "" : icon); | ||||
|                 page.Permissions = permissiongrid.GetPermissions(); | ||||
|                 page.IsDeleted = (isdeleted == null ? true : Boolean.Parse(isdeleted)); | ||||
|  | ||||
|                 if (page.ThemeType == PageState.Site.DefaultThemeType) | ||||
|                 { | ||||
|                     page.ThemeType = ""; | ||||
|                 } | ||||
|                 if (page.LayoutType == PageState.Site.DefaultLayoutType) | ||||
|                 { | ||||
|                     page.LayoutType = ""; | ||||
|                 } | ||||
|  | ||||
|                 await PageService.UpdatePageAsync(page); | ||||
|                 await PageService.UpdatePageOrderAsync(page.SiteId, page.ParentId); | ||||
|                 if (currentparentid == "") | ||||
|                 { | ||||
|                     await PageService.UpdatePageOrderAsync(page.SiteId, null); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     await PageService.UpdatePageOrderAsync(page.SiteId, int.Parse(currentparentid)); | ||||
|                 } | ||||
|  | ||||
|                 // update child paths | ||||
|                 if (parentid != currentparentid) | ||||
|                 { | ||||
|                     foreach (Page p in PageState.Pages.Where(item => item.Path.StartsWith(currentpath))) | ||||
|                     { | ||||
|                         p.Path = p.Path.Replace(currentpath, page.Path); | ||||
|                         await PageService.UpdatePageAsync(p); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 NavigationManager.NavigateTo(NavigateUrl(page.Path, Reload.Site)); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 type = Type.GetType(themetype); | ||||
|                 AddModuleMessage("You Must Provide Page Name And Theme", MessageType.Warning); | ||||
|             } | ||||
|             System.Reflection.PropertyInfo property = type.GetProperty("Panes"); | ||||
|             page.Panes = (string)property.GetValue(Activator.CreateInstance(type), null); | ||||
|             page.Permissions = permissiongrid.GetPermissions(); | ||||
|             page.IsDeleted = (isdeleted == null ? true : Boolean.Parse(isdeleted)); | ||||
|  | ||||
|             await PageService.UpdatePageAsync(page); | ||||
|             await PageService.UpdatePageOrderAsync(page.SiteId, page.ParentId); | ||||
|             if (currentparentid == "") | ||||
|             { | ||||
|                 await PageService.UpdatePageOrderAsync(page.SiteId, null); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 await PageService.UpdatePageOrderAsync(page.SiteId, int.Parse(currentparentid)); | ||||
|             } | ||||
|  | ||||
|             // update child paths | ||||
|             if (parentid != currentparentid) | ||||
|             { | ||||
|                 foreach (Page p in PageState.Pages.Where(item => item.Path.StartsWith(currentpath))) | ||||
|                 { | ||||
|                     p.Path = p.Path.Replace(currentpath, page.Path); | ||||
|                     await PageService.UpdatePageAsync(p); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             NavigationManager.NavigateTo(NavigateUrl(page.Path, Reload.Site)); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|  | ||||
| @ -57,7 +57,7 @@ else | ||||
|             <label for="Name" class="control-label">Default Theme: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@themetype"> | ||||
|             <select class="form-control" @onchange="(e => ThemeChanged(e))"> | ||||
|                 <option value=""><Select Theme></option> | ||||
|                 @foreach (KeyValuePair<string, string> item in themes) | ||||
|                 { | ||||
| @ -80,6 +80,20 @@ else | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Container: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@containertype"> | ||||
|                 <option value=""><Select Container></option> | ||||
|                 @foreach (KeyValuePair<string, string>container in containers) | ||||
|                 { | ||||
|                     <option value="@container.Key">@container.Value</option> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     @if (!isinitialized) | ||||
|     { | ||||
|         <tr> | ||||
| @ -109,6 +123,7 @@ else | ||||
|  | ||||
|     Dictionary<string, string> themes = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> panelayouts = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> containers = new Dictionary<string, string>(); | ||||
|  | ||||
|     List<Tenant> tenants; | ||||
|     string tenantid = "-1"; | ||||
| @ -117,6 +132,7 @@ else | ||||
|     string logo = ""; | ||||
|     string themetype = ""; | ||||
|     string layouttype = ""; | ||||
|     string containertype = ""; | ||||
|     bool isinitialized = true; | ||||
|     string username = ""; | ||||
|     string password = ""; | ||||
| @ -126,7 +142,7 @@ else | ||||
|         tenants = await TenantService.GetTenantsAsync(); | ||||
|         urls = PageState.Alias.Name; | ||||
|         themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|         panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|         containers = ThemeService.GetContainerTypes(PageState.Themes); | ||||
|         username = PageState.User.Username; | ||||
|     } | ||||
|  | ||||
| @ -151,9 +167,30 @@ else | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void ThemeChanged(ChangeEventArgs e) | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             themetype = (string)e.Value; | ||||
|             if (themetype != "") | ||||
|             { | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 panelayouts = new Dictionary<string, string>(); | ||||
|             } | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SaveSite() | ||||
|     { | ||||
|         if (tenantid != "-1" && name != "" && urls != "" && themetype != "") | ||||
|         if (tenantid != "-1" && name != "" && urls != "" && !string.IsNullOrEmpty(themetype) && (panelayouts.Count == 0 || !string.IsNullOrEmpty(layouttype)) && !string.IsNullOrEmpty(containertype)) | ||||
|         { | ||||
|             bool isvalid = true; | ||||
|  | ||||
| @ -187,6 +224,7 @@ else | ||||
|                 site.Logo = (logo == null ? "" : logo); | ||||
|                 site.DefaultThemeType = themetype; | ||||
|                 site.DefaultLayoutType = (layouttype == null ? "" : layouttype); | ||||
|                 site.DefaultContainerType = containertype; | ||||
|                 site = await SiteService.AddSiteAsync(site, aliases[0]); | ||||
|  | ||||
|                 foreach(Alias alias in aliases) | ||||
| @ -223,7 +261,7 @@ else | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             AddModuleMessage("You Must Provide A Tenant, Site Name, Alias, And Default Theme", MessageType.Warning); | ||||
|             AddModuleMessage("You Must Provide A Tenant, Site Name, Alias, And Default Theme/Container", MessageType.Warning); | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
| @ -10,71 +10,92 @@ | ||||
| } | ||||
| else | ||||
| { | ||||
|     <table class="table table-borderless"> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Name: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <input class="form-control" @bind="@name" disabled /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Aliases: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <textarea class="form-control" @bind="@urls" rows="3" disabled /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Logo: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <input class="form-control" @bind="@logo" disabled /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Default Theme: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@themetype" disabled> | ||||
|                     <option value=""><Select Theme></option> | ||||
|                     @foreach (KeyValuePair<string, string> item in themes) | ||||
| <table class="table table-borderless"> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Name: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <input class="form-control" @bind="@name" disabled /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Aliases: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <textarea class="form-control" @bind="@urls" rows="3" disabled /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Logo: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <input class="form-control" @bind="@logo" disabled /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Theme: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@themetype" disabled> | ||||
|                 <option value=""><Select Theme></option> | ||||
|                 @foreach (KeyValuePair<string, string> item in themes) | ||||
|                 { | ||||
|                     if (item.Key == themetype) | ||||
|                     { | ||||
|                         <option value="@item.Key" selected>@item.Value</option> | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         <option value="@item.Key">@item.Value</option> | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Default Layout: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@layouttype" disabled> | ||||
|                     <option value=""><Select Layout></option> | ||||
|                     @foreach (KeyValuePair<string, string> panelayout in panelayouts) | ||||
|                     { | ||||
|                         <option value="@panelayout.Key">@panelayout.Value</option> | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Is Deleted? </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@isdeleted" disabled> | ||||
|                     <option value="True">Yes</option> | ||||
|                     <option value="False">No</option> | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|     </table> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Layout: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@layouttype" disabled> | ||||
|                 <option value=""><Select Layout></option> | ||||
|                 @foreach (KeyValuePair<string, string> panelayout in panelayouts) | ||||
|                 { | ||||
|                     <option value="@panelayout.Key">@panelayout.Value</option> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Container: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@containertype" disabled> | ||||
|                 <option value=""><Select Container></option> | ||||
|                 @foreach (KeyValuePair<string, string> container in containers) | ||||
|                 { | ||||
|                     <option value="@container.Key">@container.Value</option> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Is Deleted? </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@isdeleted" disabled> | ||||
|                 <option value="True">Yes</option> | ||||
|                 <option value="False">No</option> | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
| </table> | ||||
|     <button type="button" class="btn btn-success" @onclick="DeleteSite">Delete</button> | ||||
|     <NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink> | ||||
|     <br /> | ||||
| @ -87,6 +108,7 @@ else | ||||
|  | ||||
|     Dictionary<string, string> themes = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> panelayouts = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> containers = new Dictionary<string, string>(); | ||||
|  | ||||
|     Alias Alias; | ||||
|     int siteid; | ||||
| @ -96,6 +118,8 @@ else | ||||
|     string logo = ""; | ||||
|     string themetype; | ||||
|     string layouttype; | ||||
|     string containertype; | ||||
|  | ||||
|     string createdby; | ||||
|     DateTime createdon; | ||||
|     string modifiedby; | ||||
| @ -109,7 +133,7 @@ else | ||||
|         try | ||||
|         { | ||||
|             themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|             containers = ThemeService.GetContainerTypes(PageState.Themes); | ||||
|             Alias = PageState.Aliases.Where(item => item.AliasId == Int32.Parse(PageState.QueryString["id"])).FirstOrDefault(); | ||||
|  | ||||
|             siteid = Alias.SiteId; | ||||
| @ -124,7 +148,9 @@ else | ||||
|                 } | ||||
|                 logo = site.Logo; | ||||
|                 themetype = site.DefaultThemeType; | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|                 layouttype = site.DefaultLayoutType; | ||||
|                 containertype = site.DefaultContainerType; | ||||
|  | ||||
|                 createdby = site.CreatedBy; | ||||
|                 createdon = site.CreatedOn; | ||||
|  | ||||
| @ -11,71 +11,92 @@ | ||||
| } | ||||
| else | ||||
| { | ||||
|     <table class="table table-borderless"> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Name: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <input class="form-control" @bind="@name" /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Aliases: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <textarea class="form-control" @bind="@urls" rows="3" /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Logo: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <input class="form-control" @bind="@logo" /> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Default Theme: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@themetype"> | ||||
|                     <option value=""><Select Theme></option> | ||||
|                     @foreach (KeyValuePair<string, string> item in themes) | ||||
| <table class="table table-borderless"> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Name: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <input class="form-control" @bind="@name" /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Aliases: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <textarea class="form-control" @bind="@urls" rows="3" /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Logo: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <input class="form-control" @bind="@logo" /> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Theme: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @onchange="(e => ThemeChanged(e))"> | ||||
|                 <option value=""><Select Theme></option> | ||||
|                 @foreach (KeyValuePair<string, string> item in themes) | ||||
|                 { | ||||
|                     if (item.Key == themetype) | ||||
|                     { | ||||
|                         <option value="@item.Key" selected>@item.Value</option> | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         <option value="@item.Key">@item.Value</option> | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Default Layout: </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@layouttype"> | ||||
|                     <option value=""><Select Layout></option> | ||||
|                     @foreach (KeyValuePair<string, string> panelayout in panelayouts) | ||||
|                     { | ||||
|                         <option value="@panelayout.Key">@panelayout.Value</option> | ||||
|                     } | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|         <tr> | ||||
|             <td> | ||||
|                 <label for="Name" class="control-label">Is Deleted? </label> | ||||
|             </td> | ||||
|             <td> | ||||
|                 <select class="form-control" @bind="@isdeleted"> | ||||
|                     <option value="True">Yes</option> | ||||
|                     <option value="False">No</option> | ||||
|                 </select> | ||||
|             </td> | ||||
|         </tr> | ||||
|     </table> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Layout: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@layouttype"> | ||||
|                 <option value=""><Select Layout></option> | ||||
|                 @foreach (KeyValuePair<string, string> panelayout in panelayouts) | ||||
|                 { | ||||
|                     <option value="@panelayout.Key">@panelayout.Value</option> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Default Container: </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@containertype"> | ||||
|                 <option value=""><Select Container></option> | ||||
|                 @foreach (KeyValuePair<string, string> container in containers) | ||||
|                 { | ||||
|                     <option value="@container.Key">@container.Value</option> | ||||
|                 } | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td> | ||||
|             <label for="Name" class="control-label">Is Deleted? </label> | ||||
|         </td> | ||||
|         <td> | ||||
|             <select class="form-control" @bind="@isdeleted"> | ||||
|                 <option value="True">Yes</option> | ||||
|                 <option value="False">No</option> | ||||
|             </select> | ||||
|         </td> | ||||
|     </tr> | ||||
| </table> | ||||
|     <button type="button" class="btn btn-success" @onclick="SaveSite">Save</button> | ||||
|     <NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink> | ||||
|     <br /> | ||||
| @ -88,6 +109,7 @@ else | ||||
|  | ||||
|     Dictionary<string, string> themes = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> panelayouts = new Dictionary<string, string>(); | ||||
|     Dictionary<string, string> containers = new Dictionary<string, string>(); | ||||
|  | ||||
|     Alias Alias; | ||||
|     int siteid; | ||||
| @ -97,6 +119,7 @@ else | ||||
|     string logo = ""; | ||||
|     string themetype; | ||||
|     string layouttype; | ||||
|     string containertype; | ||||
|  | ||||
|     string createdby; | ||||
|     DateTime createdon; | ||||
| @ -111,7 +134,7 @@ else | ||||
|         try | ||||
|         { | ||||
|             themes = ThemeService.GetThemeTypes(PageState.Themes); | ||||
|             panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes); | ||||
|             containers = ThemeService.GetContainerTypes(PageState.Themes); | ||||
|             Alias = PageState.Aliases.Where(item => item.AliasId == Int32.Parse(PageState.QueryString["id"])).FirstOrDefault(); | ||||
|  | ||||
|             siteid = Alias.SiteId; | ||||
| @ -126,7 +149,9 @@ else | ||||
|                 } | ||||
|                 logo = site.Logo; | ||||
|                 themetype = site.DefaultThemeType; | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|                 layouttype = site.DefaultLayoutType; | ||||
|                 containertype = site.DefaultContainerType; | ||||
|  | ||||
|                 createdby = site.CreatedBy; | ||||
|                 createdon = site.CreatedOn; | ||||
| @ -143,11 +168,32 @@ else | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void ThemeChanged(ChangeEventArgs e) | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             themetype = (string)e.Value; | ||||
|             if (themetype != "") | ||||
|             { | ||||
|                 panelayouts = ThemeService.GetPaneLayoutTypes(PageState.Themes, themetype); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 panelayouts = new Dictionary<string, string>(); | ||||
|             } | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SaveSite() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             if (name != "" && urls != "" && themetype != "") | ||||
|             if (name != "" && urls != "" && !string.IsNullOrEmpty(themetype) && (panelayouts.Count == 0 || !string.IsNullOrEmpty(layouttype)) && !string.IsNullOrEmpty(containertype)) | ||||
|             { | ||||
|                 Site site = await SiteService.GetSiteAsync(siteid, Alias); | ||||
|                 if (site != null) | ||||
| @ -156,6 +202,7 @@ else | ||||
|                     site.Logo = (logo == null ? "" : logo); | ||||
|                     site.DefaultThemeType = themetype; | ||||
|                     site.DefaultLayoutType = (layouttype == null ? "" : layouttype); | ||||
|                     site.DefaultContainerType = containertype; | ||||
|                     site.IsDeleted = (isdeleted == null ? true : Boolean.Parse(isdeleted)); | ||||
|  | ||||
|                     site = await SiteService.UpdateSiteAsync(site, Alias); | ||||
| @ -181,12 +228,12 @@ else | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
|                     NavigationManager.NavigateTo(NavigateUrl()); | ||||
|                     NavigationManager.NavigateTo(NavigateUrl(Reload.Site)); | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 AddModuleMessage("You Must Provide A Site Name, Alias, And Default Theme", MessageType.Warning); | ||||
|                 AddModuleMessage("You Must Provide A Site Name, Alias, And Default Theme/Container", MessageType.Warning); | ||||
|             } | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|  | ||||
| @ -40,6 +40,20 @@ | ||||
|     string connectionstring = ""; | ||||
|     string schema = ""; | ||||
|  | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             List<Tenant> tenants = await TenantService.GetTenantsAsync(); | ||||
|             connectionstring = tenants.FirstOrDefault().DBConnectionString; | ||||
|             schema = tenants.FirstOrDefault().DBSchema; | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SaveTenant() | ||||
|     { | ||||
|         ShowProgressIndicator(); | ||||
|  | ||||
| @ -58,6 +58,7 @@ | ||||
|             AddModuleMessage(ex.Message, MessageType.Error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private async Task SaveTenant() | ||||
|     { | ||||
|         connectionstring = connectionstring.Replace("\\\\", "\\"); | ||||
|  | ||||
| @ -19,7 +19,7 @@ | ||||
|  | ||||
| @if (packages != null) | ||||
| { | ||||
|     <hr /> | ||||
|     <hr class="app-rule" /> | ||||
|     <div class="mx-auto text-center"><h2>Available Themes</h2></div> | ||||
|  | ||||
|     <Pager Items="@packages"> | ||||
|  | ||||
| @ -26,7 +26,7 @@ else | ||||
|  | ||||
| @if (upgradeavailable) | ||||
| { | ||||
|     <hr /> | ||||
|     <hr class="app-rule" /> | ||||
|     <div class="mx-auto text-center"><h2>Upgrade Available</h2></div> | ||||
|  | ||||
|     <button type="button" class="btn btn-success" @onclick=@(async () => await Download(Constants.PackageId, Constants.Version))>Upgrade Framework</button> | ||||
|  | ||||
| @ -44,7 +44,7 @@ else | ||||
|     <button type="button" class="btn btn-success" @onclick="SaveUserRole">Save</button> | ||||
|     <NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink> | ||||
|  | ||||
|     <hr /> | ||||
|     <hr class="app-rule" /> | ||||
|     <p align="center"> | ||||
|         <Pager Items="@userroles"> | ||||
|             <Header> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker