summaryrefslogtreecommitdiff
path: root/Pages/Gallery.razor
blob: 8b1954fa1e0a6f8ae7a3cb11d0a4d956608adb32 (plain)
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
@page "/"
@page "/Gallery"
@inject IDbContextFactory<HBContext> dbFactory
@inject ISearchService searchService

<PageTitle>@Title</PageTitle>

<link rel="stylesheet" href="@(nameof(HyperBooru)).styles.css"/>

<form id="upload" action="/media" method="post" enctype="multipart/form-data">
    <input type="file" id="myFile" name="filename"/>
    <input type="submit" />
</form>

@foreach(var media in Media) {
    <a href="/ViewMedia?m=@(media.Guid)">
        <img src="/media/thumb/@(media.Guid)?h=200" />
    </a>
}

@code {
    [Parameter]
    [SupplyParameterFromQuery(Name = "q")]
    public string? Query { get; set; }

    [Parameter]
    [SupplyParameterFromQuery]
    public bool? Ingest { get; set; }

    private string Title {
        get {
            if(Query is null)
                return Ingest ? "Ingest Feed" : "Gallery";
            else
                return "Search Results";
        }
    }

    private Media[] Media;

    protected override void OnParametersSet() => LoadMedia();

    private void LoadMedia() {
        using var db = dbFactory.CreateDbContext();

        if(Ingest is not null && Ingest == true) {
            Media = db.Media
                .OrderByDescending(m => m.ObjectId)
                .ToArray()
                .Where(m => m.IsIngest)
                .ToArray();
        } else {
            if(Query is null)
                Media = db.Media
                    .OrderByDescending(m => m.ObjectId)
                    .ToArray();
            else
                Media = searchService.Search(Query);
        }
    }
}