cleanup and ensure site level scripts work properly
This commit is contained in:
parent
43bcfb9a4e
commit
86fbdced1b
@ -77,7 +77,7 @@ namespace Oqtane.Modules
|
|||||||
{
|
{
|
||||||
if (PageState.Page.Resources != null)
|
if (PageState.Page.Resources != null)
|
||||||
{
|
{
|
||||||
resources = PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Script && item.Namespace == type.Namespace).ToList();
|
resources = PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Script && item.Level != ResourceLevel.Site && item.Namespace == type.Namespace).ToList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // modulecontrolbase
|
else // modulecontrolbase
|
||||||
|
@ -40,7 +40,7 @@ namespace Oqtane.Themes
|
|||||||
{
|
{
|
||||||
if (PageState.Page.Resources != null)
|
if (PageState.Page.Resources != null)
|
||||||
{
|
{
|
||||||
resources = PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Script && item.Namespace == type.Namespace).ToList();
|
resources = PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Script && item.Level != ResourceLevel.Site && item.Namespace == type.Namespace).ToList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // themecontrolbase, containerbase
|
else // themecontrolbase, containerbase
|
||||||
|
@ -512,6 +512,8 @@
|
|||||||
if (resources != null)
|
if (resources != null)
|
||||||
{
|
{
|
||||||
foreach (var resource in resources)
|
foreach (var resource in resources)
|
||||||
|
{
|
||||||
|
if (resource.Level != ResourceLevel.Site)
|
||||||
{
|
{
|
||||||
if (resource.Url.StartsWith("~"))
|
if (resource.Url.StartsWith("~"))
|
||||||
{
|
{
|
||||||
@ -531,6 +533,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return pageresources;
|
return pageresources;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,13 +42,6 @@
|
|||||||
}
|
}
|
||||||
headcontent += $"<link id=\"app-favicon\" rel=\"shortcut icon\" type=\"image/{favicontype}\" href=\"{favicon}\" />\n";
|
headcontent += $"<link id=\"app-favicon\" rel=\"shortcut icon\" type=\"image/{favicontype}\" href=\"{favicon}\" />\n";
|
||||||
|
|
||||||
// stylesheets
|
|
||||||
//foreach (Resource resource in PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Stylesheet))
|
|
||||||
//{
|
|
||||||
// var url = (resource.Url.Contains("://")) ? resource.Url : PageState.Alias.BaseUrl + resource.Url;
|
|
||||||
// headcontent += "<link rel=\"stylesheet\" href=\"" + url + "\"" + (!string.IsNullOrEmpty(resource.Integrity) ? " integrity=\"" + resource.Integrity + "\"" : "") + (!string.IsNullOrEmpty(resource.CrossOrigin) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") + " type=\"text/css\"/>" + "\n";
|
|
||||||
//}
|
|
||||||
|
|
||||||
// head content
|
// head content
|
||||||
AddHeadContent(headcontent, PageState.Site.HeadContent);
|
AddHeadContent(headcontent, PageState.Site.HeadContent);
|
||||||
if (!string.IsNullOrEmpty(PageState.Site.HeadContent))
|
if (!string.IsNullOrEmpty(PageState.Site.HeadContent))
|
||||||
@ -103,9 +96,8 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (PageState.Page.Resources != null)
|
// style sheets
|
||||||
{
|
if (PageState.Page.Resources != null && PageState.Page.Resources.Exists(item => item.ResourceType == ResourceType.Stylesheet))
|
||||||
if (PageState.Page.Resources.Exists(item => item.ResourceType == ResourceType.Stylesheet))
|
|
||||||
{
|
{
|
||||||
var interop = new Interop(JSRuntime);
|
var interop = new Interop(JSRuntime);
|
||||||
string batch = DateTime.UtcNow.ToString("yyyyMMddHHmmssfff");
|
string batch = DateTime.UtcNow.ToString("yyyyMMddHHmmssfff");
|
||||||
@ -123,30 +115,6 @@
|
|||||||
await interop.RemoveElementsById("app-stylesheet-page-", "", "app-stylesheet-page-" + batch + "-00");
|
await interop.RemoveElementsById("app-stylesheet-page-", "", "app-stylesheet-page-" + batch + "-00");
|
||||||
await interop.RemoveElementsById("app-stylesheet-module-", "", "app-stylesheet-module-" + batch + "-00");
|
await interop.RemoveElementsById("app-stylesheet-module-", "", "app-stylesheet-module-" + batch + "-00");
|
||||||
}
|
}
|
||||||
|
|
||||||
//if (PageState.Page.Resources.Exists(item => item.ResourceType == ResourceType.Script))
|
|
||||||
//{
|
|
||||||
// var scripts = new List<object>();
|
|
||||||
// var inline = 0;
|
|
||||||
// foreach (Resource resource in PageState.Page.Resources.Where(item => item.ResourceType == ResourceType.Script && item.Level != ResourceLevel.Site))
|
|
||||||
// {
|
|
||||||
// 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())
|
|
||||||
// {
|
|
||||||
// await interop.IncludeScripts(scripts.ToArray());
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task InjectScripts(string content, ResourceLocation location)
|
private async Task InjectScripts(string content, ResourceLocation location)
|
||||||
|
@ -9,8 +9,8 @@
|
|||||||
<script src="js/app.js"></script>
|
<script src="js/app.js"></script>
|
||||||
<script src="js/loadjs.min.js"></script>
|
<script src="js/loadjs.min.js"></script>
|
||||||
<link rel="stylesheet" href="css/app.css" />
|
<link rel="stylesheet" href="css/app.css" />
|
||||||
<link id="app-stylesheet-page" rel="stylesheet" href="css/empty.css" disabled />
|
<link id="app-stylesheet-page" />
|
||||||
<link id="app-stylesheet-module" rel="stylesheet" href="css/empty.css" disabled />
|
<link id="app-stylesheet-module" />
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
@ -15,8 +15,8 @@
|
|||||||
{
|
{
|
||||||
<link id="app-manifest" rel="manifest" />
|
<link id="app-manifest" rel="manifest" />
|
||||||
}
|
}
|
||||||
<style id="app-stylesheet-page"></style>
|
<link id="app-stylesheet-page" />
|
||||||
<style id="app-stylesheet-module"></style>
|
<link id="app-stylesheet-module" />
|
||||||
<component type="typeof(Oqtane.Head)" render-mode="@((RenderMode)Enum.Parse(typeof(RenderMode), Model.RenderMode, true))" />
|
<component type="typeof(Oqtane.Head)" render-mode="@((RenderMode)Enum.Parse(typeof(RenderMode), Model.RenderMode, true))" />
|
||||||
@Html.Raw(Model.HeadResources)
|
@Html.Raw(Model.HeadResources)
|
||||||
</head>
|
</head>
|
||||||
|
@ -475,8 +475,8 @@ namespace Oqtane.Pages
|
|||||||
{
|
{
|
||||||
var url = (resource.Url.Contains("://")) ? resource.Url : alias.BaseUrl + resource.Url;
|
var url = (resource.Url.Contains("://")) ? resource.Url : alias.BaseUrl + resource.Url;
|
||||||
return "<script src=\"" + url + "\"" +
|
return "<script src=\"" + url + "\"" +
|
||||||
((!string.IsNullOrEmpty(resource.CrossOrigin)) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") +
|
|
||||||
((!string.IsNullOrEmpty(resource.Integrity)) ? " integrity=\"" + resource.Integrity + "\"" : "") +
|
((!string.IsNullOrEmpty(resource.Integrity)) ? " integrity=\"" + resource.Integrity + "\"" : "") +
|
||||||
|
((!string.IsNullOrEmpty(resource.CrossOrigin)) ? " crossorigin=\"" + resource.CrossOrigin + "\"" : "") +
|
||||||
"></script>";
|
"></script>";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Reference in New Issue
Block a user