BlazorStart/Start/Client/Components/BookmarkGroup.razor

65 lines
2 KiB
Plaintext

@using System.Drawing
<div class="card bookmarkGroup">
<div class="card-header" style="background-color: @this.Group.Color">
<h2 class="card-title h5 d-inline-block @this.ForegroundTitleColorClass">
@this.Group.Title
</h2>
<button type="button" class="addBookmarkButton btn btn-sm tooltip tooltip-left"
aria-label="Create Bookmark" data-tooltip="Create Bookmark">
<i class="icon icon-plus"></i>
</button>
</div>
<div class="card-body">
<ul class="bookmarks">
@if (this.Group.Bookmarks == null || !this.Group.Bookmarks.Any())
{
<li class="noBookmarksItem">
<div class="empty">
<div class="empty-icon">
<i class="icon icon-bookmark"></i>
</div>
<p class="empty-title h5">No Bookmarks</p>
<div class="empty-action">
<button type="button" class="btn btn-primary">
<i class="icon icon-plus"></i> Create Bookmark
</button>
</div>
</div>
</li>
}
else
{
foreach (BookmarkDto bookmark in this.Group.Bookmarks)
{
<Bookmark Model="bookmark" />
}
}
</ul>
</div>
</div>
@code
{
[Parameter]
public BookmarkGroupDto Group { get; set; } = null!;
protected string ForegroundTitleColorClass {
get {
const int threshold = 105;
Color bgColor = ColorTranslator.FromHtml(this.Group.Color);
double val = Math.Floor((bgColor.R * .299) + (bgColor.G * 0.587) + (bgColor.B * 0.114));
if ((255 - val) < threshold)
return "text-dark";
return "text-light";
}
}
protected void OnCreateBookmarkClicked()
{
// Placeholder
}
}