2024-06-21 06:26:11 +00:00
|
|
|
@page "/editNow"
|
|
|
|
@inject NavigationManager Nav
|
|
|
|
@inject RestService api
|
|
|
|
@inject State State
|
|
|
|
|
|
|
|
|
|
|
|
<div class="max markdown-editor">
|
|
|
|
<MarkdownEditor @ref="Editor"
|
|
|
|
@bind-Value="@markdownValue"
|
|
|
|
Theme="material-darker"
|
|
|
|
MaxHeight="100%"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<nav>
|
2024-06-24 02:23:28 +00:00
|
|
|
<label class="checkbox" disabled="@loading">
|
|
|
|
<InputCheckbox @bind-Value="listed" disabled="@loading"></InputCheckbox>
|
2024-06-21 06:26:11 +00:00
|
|
|
<span>Include my page in the Now Garden</span>
|
|
|
|
</label>
|
|
|
|
<div class="max"></div>
|
2024-06-24 02:23:28 +00:00
|
|
|
<button class="transparent link" onclick="history.back();" disabled="@loading">Cancel</button>
|
|
|
|
<button @onclick="Save" disabled="@loading">
|
|
|
|
@if (loading) {
|
|
|
|
<span>Saving...</span>
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
<i class="fa-solid fa-floppy-disk"></i> <span>Save</span>
|
|
|
|
}
|
2024-06-21 06:26:11 +00:00
|
|
|
</button>
|
|
|
|
</nav>
|
|
|
|
|
|
|
|
@code {
|
2024-07-02 00:13:52 +00:00
|
|
|
private MarkdownEditor? Editor;
|
2024-06-24 00:40:46 +00:00
|
|
|
private bool listed;
|
2024-07-02 00:13:52 +00:00
|
|
|
private string? markdownValue;
|
2024-06-24 00:40:46 +00:00
|
|
|
|
|
|
|
private bool loading = false;
|
2024-06-21 06:26:11 +00:00
|
|
|
|
|
|
|
protected override async Task OnInitializedAsync() {
|
|
|
|
await base.OnInitializedAsync();
|
2024-07-02 00:13:52 +00:00
|
|
|
NowContentData? data = await api.GetNowPage(State.SelectedAddressName!);
|
2024-06-21 06:26:11 +00:00
|
|
|
if (data != null)
|
|
|
|
{
|
|
|
|
listed = data.Listed == 1;
|
|
|
|
markdownValue = data.Content;
|
2024-07-02 00:13:52 +00:00
|
|
|
await Editor!.SetValueAsync(markdownValue);
|
2024-06-21 06:26:11 +00:00
|
|
|
}
|
2024-07-02 00:13:52 +00:00
|
|
|
await InvokeAsync(StateHasChanged);
|
2024-06-21 06:26:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Task OnMarkdownValueChanged(string value) {
|
|
|
|
return Task.CompletedTask;
|
|
|
|
}
|
|
|
|
|
|
|
|
public async Task Save() {
|
2024-06-24 00:40:46 +00:00
|
|
|
loading = true;
|
|
|
|
await InvokeAsync(StateHasChanged);
|
2024-07-02 00:13:52 +00:00
|
|
|
var result = await api.PostNowPage(State.SelectedAddressName!, markdownValue ?? string.Empty, listed);
|
2024-06-24 00:40:46 +00:00
|
|
|
if (result != null) {
|
|
|
|
await State.RefreshNow();
|
|
|
|
await InvokeAsync(StateHasChanged);
|
|
|
|
Nav.NavigateTo($"/person/{State.SelectedAddressName}#now");
|
|
|
|
}
|
|
|
|
|
|
|
|
loading = false;
|
2024-06-21 06:26:11 +00:00
|
|
|
}
|
|
|
|
}
|