@page "/admin/announcements" @attribute [Authorize] @using TaxBaik.Web.Services @using TaxBaik.Domain.Entities @inject IAnnouncementBrowserClient AnnouncementClient @inject NavigationManager Navigation @inject IJSRuntime JS 공지사항 관리
Homepage

공지사항 관리

홈페이지 상단에 노출되는 공지사항을 등록하고 관리합니다.

공지 등록
@if (announcements is null) { } else if (!announcements.Any()) {
등록된 공지사항이 없습니다.
} else {
@foreach (var item in announcements) { }
제목 유형 상태 게시 기간 순서
@item.Title @GetTypeLabel(item.DisplayType) @if (IsCurrentlyActive(item)) { 노출 중 } else if (!item.IsActive) { 비활성 } else { 기간 외 } @FormatPeriod(item) @item.SortOrder
}
@code { [CascadingParameter] private Task? AuthStateTask { get; set; } private List? announcements; protected override async Task OnAfterRenderAsync(bool firstRender) { if (firstRender && AuthStateTask != null) { var authState = await AuthStateTask; if (authState.User.Identity?.IsAuthenticated == true) { await LoadAsync(); StateHasChanged(); } } } private async Task LoadAsync() { try { announcements = (await AnnouncementClient.GetAllAsync()).ToList(); } catch (Exception ex) { await JS.InvokeVoidAsync("alert", $"오류: {ex.Message}"); announcements = []; } } private async Task DeleteAsync(Announcement item) { var confirmed = await JS.InvokeAsync("confirm", $"'{item.Title}' 공지를 삭제하시겠습니까?"); if (!confirmed) return; try { var success = await AnnouncementClient.DeleteAsync(item.Id); if (success) { await JS.InvokeVoidAsync("alert", "공지사항이 삭제되었습니다."); await LoadAsync(); } else { await JS.InvokeVoidAsync("alert", "삭제 실패"); } } catch (Exception ex) { await JS.InvokeVoidAsync("alert", $"오류: {ex.Message}"); } } private static bool IsCurrentlyActive(Announcement a) { if (!a.IsActive) return false; var now = DateTime.UtcNow; if (a.StartsAt.HasValue && a.StartsAt > now) return false; if (a.EndsAt.HasValue && a.EndsAt < now) return false; return true; } private static string FormatPeriod(Announcement a) { var start = a.StartsAt?.ToLocalTime().ToString("MM/dd") ?? "즉시"; var end = a.EndsAt?.ToLocalTime().ToString("MM/dd") ?? "무기한"; return $"{start} ~ {end}"; } private static string GetTypeLabel(string type) => type switch { "urgent" => "긴급", "banner" => "배너", _ => "일반" }; }