add support for custom "internal" module and theme templates. fix package installer issue related to absolute paths
This commit is contained in:
		| @ -181,9 +181,18 @@ namespace Oqtane.Controllers | ||||
|                 DirectoryInfo rootFolder = Directory.GetParent(_environment.ContentRootPath); | ||||
|                 string templatePath = Utilities.PathCombine(_environment.WebRootPath, "Modules", "Templates", moduleDefinition.Template,Path.DirectorySeparatorChar.ToString()); | ||||
|  | ||||
|                 rootPath = Utilities.PathCombine(rootFolder.Parent.FullName , moduleDefinition.Owner + "." + moduleDefinition.Name,Path.DirectorySeparatorChar.ToString()); | ||||
|                 moduleDefinition.ModuleDefinitionName = moduleDefinition.Owner + "." + moduleDefinition.Name + ", " + moduleDefinition.Owner + "." + moduleDefinition.Name + ".Client.Oqtane";                     | ||||
|                 moduleDefinition.ServerManagerType = moduleDefinition.Owner + "." + moduleDefinition.Name + ".Manager." + moduleDefinition.Name + "Manager, " + moduleDefinition.Owner + "." + moduleDefinition.Name + ".Server.Oqtane"; | ||||
|                 if (moduleDefinition.Template.ToLower().Contains("internal")) | ||||
|                 { | ||||
|                     rootPath = Utilities.PathCombine(rootFolder.FullName, Path.DirectorySeparatorChar.ToString()); | ||||
|                     moduleDefinition.ModuleDefinitionName = moduleDefinition.Owner + "." + moduleDefinition.Name + ", Oqtane.Client"; | ||||
|                     moduleDefinition.ServerManagerType = moduleDefinition.Owner + "." + moduleDefinition.Name + ".Manager." + moduleDefinition.Name + "Manager, Oqtane.Server"; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     rootPath = Utilities.PathCombine(rootFolder.Parent.FullName, moduleDefinition.Owner + "." + moduleDefinition.Name, Path.DirectorySeparatorChar.ToString()); | ||||
|                     moduleDefinition.ModuleDefinitionName = moduleDefinition.Owner + "." + moduleDefinition.Name + ", " + moduleDefinition.Owner + "." + moduleDefinition.Name + ".Client.Oqtane"; | ||||
|                     moduleDefinition.ServerManagerType = moduleDefinition.Owner + "." + moduleDefinition.Name + ".Manager." + moduleDefinition.Name + "Manager, " + moduleDefinition.Owner + "." + moduleDefinition.Name + ".Server.Oqtane"; | ||||
|                 } | ||||
|  | ||||
|                 ProcessTemplatesRecursively(new DirectoryInfo(templatePath), rootPath, rootFolder.Name, templatePath, moduleDefinition); | ||||
|                 _logger.Log(LogLevel.Information, this, LogFunction.Create, "Module Definition Created {ModuleDefinition}", moduleDefinition); | ||||
|  | ||||
| @ -111,8 +111,16 @@ namespace Oqtane.Controllers | ||||
|                 DirectoryInfo rootFolder = Directory.GetParent(_environment.ContentRootPath); | ||||
|                 string templatePath = Utilities.PathCombine(_environment.WebRootPath, "Themes", "Templates", theme.Template, Path.DirectorySeparatorChar.ToString()); | ||||
|  | ||||
|                 rootPath = Utilities.PathCombine(rootFolder.Parent.FullName, theme.Owner + "." + theme.Name, Path.DirectorySeparatorChar.ToString()); | ||||
|                 theme.ThemeName = theme.Owner + "." + theme.Name + ", " + theme.Owner + "." + theme.Name + ".Client.Oqtane"; | ||||
|                 if (theme.Template.ToLower().Contains("internal")) | ||||
|                 { | ||||
|                     rootPath = Utilities.PathCombine(rootFolder.FullName, Path.DirectorySeparatorChar.ToString()); | ||||
|                     theme.ThemeName = theme.Owner + "." + theme.Name + ", Oqtane.Client"; | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     rootPath = Utilities.PathCombine(rootFolder.Parent.FullName, theme.Owner + "." + theme.Name, Path.DirectorySeparatorChar.ToString()); | ||||
|                     theme.ThemeName = theme.Owner + "." + theme.Name + ", " + theme.Owner + "." + theme.Name + ".Client.Oqtane"; | ||||
|                 } | ||||
|  | ||||
|                 ProcessTemplatesRecursively(new DirectoryInfo(templatePath), rootPath, rootFolder.Name, templatePath, theme); | ||||
|                 _logger.Log(LogLevel.Information, this, LogFunction.Create, "Theme Created {Theme}", theme); | ||||
|  | ||||
| @ -6,6 +6,7 @@ using System.IO.Compression; | ||||
| using System.Linq; | ||||
| using System.Reflection; | ||||
| using System.Text.Json; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Xml; | ||||
| using Microsoft.AspNetCore.Hosting; | ||||
| using Microsoft.Extensions.Hosting; | ||||
| @ -122,7 +123,9 @@ namespace Oqtane.Infrastructure | ||||
|  | ||||
|                             if (filename != "") | ||||
|                             { | ||||
|                                 assets.Add(filename.Replace(contentRootPath, "")); | ||||
|                                 // ContentRootPath does not use different case for folder names as other framework methods   | ||||
|                                 filename = Regex.Replace(filename, Regex.Escape(contentRootPath), "", RegexOptions.IgnoreCase); | ||||
|                                 assets.Add(filename); | ||||
|                                 if (!manifest && Path.GetFileName(filename) == name + ".log") | ||||
|                                 { | ||||
|                                     manifest = true; | ||||
| @ -142,7 +145,7 @@ namespace Oqtane.Infrastructure | ||||
|                             { | ||||
|                                 Directory.CreateDirectory(Path.GetDirectoryName(manifestpath)); | ||||
|                             } | ||||
|                             File.WriteAllText(manifestpath, JsonSerializer.Serialize(assets)); | ||||
|                             File.WriteAllText(manifestpath, JsonSerializer.Serialize(assets, new JsonSerializerOptions { WriteIndented = true })); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker