-
-
Notifications
You must be signed in to change notification settings - Fork 93
Expand file tree
/
Copy pathShortBlogPost.razor
More file actions
106 lines (96 loc) · 2.98 KB
/
Copy pathShortBlogPost.razor
File metadata and controls
106 lines (96 loc) · 2.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
@using LinkDotNet.Blog.Domain
@using LinkDotNet.Blog.Web.Features.Bookmarks
@using LinkDotNet.Blog.Web.Features.Bookmarks.Components
@inject IBookmarkService BookmarkService
@inject IOptions<ApplicationConfiguration> AppConfiguration
<article>
<div class="blog-card @AltCssClass">
<div class="meta">
<div class="photo">
<PreviewImage PreviewImageUrl="@BlogPost.PreviewImageUrl"
PreviewImageUrlFallback="@BlogPost.PreviewImageUrlFallback"
LazyLoadImage="@LazyLoadPreviewImage"></PreviewImage>
</div>
<ul class="details">
@if (BlogPost.IsScheduled)
{
<li class="schedule">Scheduled</li>
}
else if (!BlogPost.IsPublished)
{
<li class="draft">Draft</li>
}
<li class="date me-4"><span>@BlogPost.UpdatedDate.ToShortDateString()</span></li>
@if (BlogPost.Tags.Any())
{
<li class="tags me-4">
<ul>
@foreach (var tag in BlogPost.Tags)
{
<li><a class="goto-tag" href="/searchByTag/@(Uri.EscapeDataString(tag))">@tag</a></li>
}
</ul>
</li>
}
<li class="read-time me-4">@BlogPost.ReadingTimeInMinutes minute read</li>
@if (AppConfiguration.Value.UseMultiAuthorMode && BlogPost.AuthorName is not null)
{
<li class="me-4"><i class="user-tie"></i> @BlogPost.AuthorName</li>
}
</ul>
</div>
<div class="description">
<div class="header">
<h4 class="card-title">@BlogPost.Title</h4>
<BookmarkButton IsBookmarked="isBookmarked" Bookmarked="ToggleBookmark"></BookmarkButton>
</div>
<p class="card-content">@MarkdownConverter.ToMarkupString(BlogPost.ShortDescription)</p>
<p class="read-more">
<a href="/blogPost/@BlogPost.Id/@BlogPost.Slug" aria-label="@BlogPost.Title">Read the whole article</a>
</p>
</div>
</div>
</article>
@code {
[Parameter, EditorRequired]
public required BlogPost BlogPost { get; set; }
private bool isBookmarked = false;
[Parameter]
public bool UseAlternativeStyle { get; set; }
[Parameter]
public bool LazyLoadPreviewImage { get; set; }
private string AltCssClass => UseAlternativeStyle ? "alt" : string.Empty;
private async Task ToggleBookmark()
{
isBookmarked = !isBookmarked;
await BookmarkService.SetBookmark(BlogPost.Id, isBookmarked);
StateHasChanged();
}
public override Task SetParametersAsync(ParameterView parameters)
{
foreach (var parameter in parameters)
{
switch (parameter.Name)
{
case nameof(BlogPost):
BlogPost = (BlogPost)parameter.Value;
break;
case nameof(UseAlternativeStyle):
UseAlternativeStyle = (bool)parameter.Value;
break;
case nameof(LazyLoadPreviewImage):
LazyLoadPreviewImage = (bool)parameter.Value;
break;
}
}
return base.SetParametersAsync(ParameterView.Empty);
}
protected override async Task OnAfterRenderAsync(bool firstRender)
{
if (firstRender)
{
isBookmarked = await BookmarkService.IsBookmarked(BlogPost.Id);
StateHasChanged();
}
}
}