Skip to content

Commit

Permalink
Set head content with javascript
Browse files Browse the repository at this point in the history
  • Loading branch information
danheron committed Nov 4, 2023
1 parent 328ba82 commit 55c6c4a
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 16 deletions.
10 changes: 10 additions & 0 deletions Heron.MudCalendar.UnitTests.Viewer/Shared/MainLayout.razor
Original file line number Diff line number Diff line change
@@ -1,7 +1,17 @@
@inherits LayoutComponentBase

<HeadContent>
<meta name="description" content="@_description" />
</HeadContent>

<MudThemeProvider/>
<MudDialogProvider/>
<MudSnackbarProvider/>

@Body

@code {

private string _description = "Description set by code";

}
18 changes: 2 additions & 16 deletions Heron.MudCalendar/Components/MudCalendar.razor
Original file line number Diff line number Diff line change
@@ -1,32 +1,18 @@
@namespace Heron.MudCalendar
@inherits MudComponentBase
@using CategoryTypes = Heron.MudCalendar.Attributes.CategoryTypes
@using Microsoft.JSInterop
@inject IJSRuntime JsRuntime

@Render

@code {

/// <summary>
/// Renders the html page head element.
/// </summary>
protected virtual RenderFragment RenderHead =>
@<HeadContent>
@RenderHeaderContent
</HeadContent>;

/// <summary>
/// Renders the contents of the head element.
/// </summary>
protected virtual RenderFragment RenderHeaderContent =>
@<link href="_content/Heron.MudCalendar/Heron.MudCalendar.min.css" rel="stylesheet"/>;

/// <summary>
/// Renders the component.
/// </summary>
protected virtual RenderFragment Render => __builder =>
{
RenderHead(__builder);

<CascadingValue IsFixed="false" Value="this">
<div class="@Classname" style="@Styles">

Expand Down
16 changes: 16 additions & 0 deletions Heron.MudCalendar/Components/MudCalendar.razor.cs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using Heron.MudCalendar.Services;
using Microsoft.AspNetCore.Components;
using MudBlazor.Utilities;
using MudBlazor;
Expand All @@ -8,6 +9,8 @@ namespace Heron.MudCalendar;

public partial class MudCalendar : MudComponentBase
{
private JsService? _jsService;

/// <summary>
/// The higher the number, the heavier the drop-shadow. 0 for no shadow.
/// </summary>
Expand Down Expand Up @@ -255,6 +258,8 @@ protected override async Task OnAfterRenderAsync(bool firstRender)
{
//await DateRangeChanged.InvokeAsync(new CalendarDateRange(CurrentDay, View));
await ChangeDateRange();

await SetLinks();
}
}

Expand Down Expand Up @@ -305,6 +310,17 @@ protected virtual Task OnPreviousClicked()
return ChangeDateRange();
}

private async Task SetLinks()
{
// Check if link is already set
_jsService ??= new JsService(JsRuntime);
var head = await _jsService.GetHeadContent();
if (!string.IsNullOrEmpty(head) && head.Contains("Heron.MudCalendar.min.css")) return;

// Add link
await _jsService.AddLink("_content/Heron.MudCalendar/Heron.MudCalendar.min.css", "stylesheet");
}

private Task DatePickerDateChanged(DateTime? dateTime)
{
PickerDate = dateTime;
Expand Down
13 changes: 13 additions & 0 deletions Heron.MudCalendar/Services/JsService.cs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using System.Runtime.InteropServices;
using Microsoft.AspNetCore.Components;
using Microsoft.JSInterop;

Expand All @@ -18,6 +19,18 @@ public async Task Scroll(ElementReference element, int top)
var module = await _moduleTask.Value;
await module.InvokeVoidAsync("scroll", element, top);
}

public async Task<string> GetHeadContent()
{
var module = await _moduleTask.Value;
return await module.InvokeAsync<string>("getHeadContent");
}

public async Task AddLink(string href, string rel)
{
var module = await _moduleTask.Value;
await module.InvokeVoidAsync("addLink", href, rel);
}

public async ValueTask DisposeAsync()
{
Expand Down
11 changes: 11 additions & 0 deletions Heron.MudCalendar/wwwroot/Heron.MudCalendar.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,14 @@
export function scroll(element, top) {
element.scrollTo(0, top);
}

export function getHeadContent() {
return document.head.innerHTML;
}

export function addLink(href, rel) {
const link = document.createElement("link");
link.href = href;
link.rel = rel;
document.head.appendChild(link);
}

0 comments on commit 55c6c4a

Please sign in to comment.