Merge pull request #3933 from sbwalker/dev
add support specifying RenderMode for Resources
This commit is contained in:
		| @ -96,15 +96,18 @@ namespace Oqtane.Modules | ||||
|                     var inline = 0; | ||||
|                     foreach (Resource resource in resources) | ||||
|                     { | ||||
|                         if (!string.IsNullOrEmpty(resource.Url)) | ||||
|                         if (string.IsNullOrEmpty(resource.RenderMode) || resource.RenderMode == RenderModes.Interactive) | ||||
|                         { | ||||
|                             var url = (resource.Url.Contains("://")) ? resource.Url : PageState.Alias.BaseUrl + resource.Url; | ||||
|                             scripts.Add(new { href = url, bundle = resource.Bundle ?? "", integrity = resource.Integrity ?? "", crossorigin = resource.CrossOrigin ?? "", es6module = resource.ES6Module, location = resource.Location.ToString().ToLower() }); | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             inline += 1; | ||||
|                             await interop.IncludeScript(GetType().Namespace.ToLower() + inline.ToString(), "", "", "", resource.Content, resource.Location.ToString().ToLower()); | ||||
|                             if (!string.IsNullOrEmpty(resource.Url)) | ||||
|                             { | ||||
|                                 var url = (resource.Url.Contains("://")) ? resource.Url : PageState.Alias.BaseUrl + resource.Url; | ||||
|                                 scripts.Add(new { href = url, bundle = resource.Bundle ?? "", integrity = resource.Integrity ?? "", crossorigin = resource.CrossOrigin ?? "", es6module = resource.ES6Module, location = resource.Location.ToString().ToLower() }); | ||||
|                             } | ||||
|                             else | ||||
|                             { | ||||
|                                 inline += 1; | ||||
|                                 await interop.IncludeScript(GetType().Namespace.ToLower() + inline.ToString(), "", "", "", resource.Content, resource.Location.ToString().ToLower()); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     if (scripts.Any()) | ||||
|  | ||||
| @ -62,15 +62,18 @@ namespace Oqtane.Themes | ||||
|                     var inline = 0; | ||||
|                     foreach (Resource resource in resources) | ||||
|                     { | ||||
|                         if (!string.IsNullOrEmpty(resource.Url)) | ||||
|                         if (string.IsNullOrEmpty(resource.RenderMode) || resource.RenderMode == RenderModes.Interactive) | ||||
|                         { | ||||
|                             var url = (resource.Url.Contains("://")) ? resource.Url : PageState.Alias.BaseUrl + resource.Url; | ||||
|                             scripts.Add(new { href = url, bundle = resource.Bundle ?? "", integrity = resource.Integrity ?? "", crossorigin = resource.CrossOrigin ?? "", es6module = resource.ES6Module, location = resource.Location.ToString().ToLower() }); | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             inline += 1; | ||||
|                             await interop.IncludeScript(GetType().Namespace.ToLower() + inline.ToString(), "", "", "", resource.Content, resource.Location.ToString().ToLower()); | ||||
|                             if (!string.IsNullOrEmpty(resource.Url)) | ||||
|                             { | ||||
|                                 var url = (resource.Url.Contains("://")) ? resource.Url : PageState.Alias.BaseUrl + resource.Url; | ||||
|                                 scripts.Add(new { href = url, bundle = resource.Bundle ?? "", integrity = resource.Integrity ?? "", crossorigin = resource.CrossOrigin ?? "", es6module = resource.ES6Module, location = resource.Location.ToString().ToLower() }); | ||||
|                             } | ||||
|                             else | ||||
|                             { | ||||
|                                 inline += 1; | ||||
|                                 await interop.IncludeScript(GetType().Namespace.ToLower() + inline.ToString(), "", "", "", resource.Content, resource.Location.ToString().ToLower()); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                     if (scripts.Any()) | ||||
|  | ||||
| @ -578,6 +578,7 @@ | ||||
|                             Location = resource.Location, | ||||
|                             ES6Module = resource.ES6Module, | ||||
|                             Content = resource.Content, | ||||
|                             RenderMode = resource.RenderMode, | ||||
|                             Level = level, | ||||
|                             Namespace = name | ||||
|                         }); | ||||
|  | ||||
| @ -527,10 +527,11 @@ | ||||
|         if (!string.IsNullOrEmpty(resource.Url)) | ||||
|         { | ||||
|             var url = (resource.Url.Contains("://")) ? resource.Url : alias.BaseUrl + resource.Url; | ||||
|             return "<script src=\"" + url + "\"" + | ||||
|             return "<script" + | ||||
|                 ((!string.IsNullOrEmpty(resource.Integrity)) ? " integrity=\"" + resource.Integrity + "\"" : "") + | ||||
|                 ((!string.IsNullOrEmpty(resource.CrossOrigin)) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") + | ||||
|                 "></script>"; | ||||
|                 ((resource.ES6Module) ? " type=\"module\"" : "") + | ||||
|                 " src =\"" + url + "\"></script>"; // src at end of element due to enhanced navigation patch algorithm | ||||
|         } | ||||
|         else | ||||
|         { | ||||
| @ -647,6 +648,7 @@ | ||||
|                         Location = resource.Location, | ||||
|                         ES6Module = resource.ES6Module, | ||||
|                         Content = resource.Content, | ||||
|                         RenderMode = resource.RenderMode, | ||||
|                         Level = level, | ||||
|                         Namespace = name | ||||
|                     }); | ||||
| @ -666,7 +668,10 @@ | ||||
|             { | ||||
|                 count++; | ||||
|                 string id = "id=\"app-stylesheet-" + ResourceLevel.Page.ToString().ToLower() + "-" + batch + "-" + count.ToString("00") + "\" "; | ||||
|                 _styleSheets += "<link " + id + "rel=\"stylesheet\"" + (!string.IsNullOrEmpty(resource.Integrity) ? " integrity=\"" + resource.Integrity + "\"" : "") + (!string.IsNullOrEmpty(resource.CrossOrigin) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") + " href=\"" + resource.Url + "\" type=\"text/css\"/>" + Environment.NewLine; | ||||
|                 _styleSheets += "<link " + id + "rel=\"stylesheet\"" +  | ||||
|                     (!string.IsNullOrEmpty(resource.Integrity) ? " integrity=\"" + resource.Integrity + "\"" : "") +  | ||||
|                     (!string.IsNullOrEmpty(resource.CrossOrigin) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") +  | ||||
|                     " href=\"" + resource.Url + "\" type=\"text/css\"/>" + Environment.NewLine; // href at end of element due to enhanced navigation patch algorithm | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @ -677,7 +682,10 @@ | ||||
|         { | ||||
|             foreach (var resource in resources.Where(item => item.ResourceType == ResourceType.Script)) | ||||
|             { | ||||
|                 AddScript(resource, alias); | ||||
|                 if (string.IsNullOrEmpty(resource.RenderMode) || resource.RenderMode == RenderModes.Static) | ||||
|                 { | ||||
|                     AddScript(resource, alias); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @ -62,6 +62,11 @@ namespace Oqtane.Models | ||||
|         /// </summary> | ||||
|         public string Content { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// For Scripts this defines the render mode (default is all render modes) - not applicable to Stylesheets | ||||
|         /// </summary> | ||||
|         public string RenderMode { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// The namespace of the component that declared the resource - only used in SiteRouter | ||||
|         /// </summary> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker