mirror of
https://github.com/MarginaliaSearch/MarginaliaSearch.git
synced 2025-02-24 21:29:00 +00:00
data:image/s3,"s3://crabby-images/c765d/c765d5283f4176ac41b612e7ae83ed62e7ddf9a1" alt="Viktor Lofgren"
Still missing is a proper build, we're currently pulling in tailwind from a CDN, which is no bueno in prod. There's also a lot of polish remaining everywhere, dead links, etc.
60 lines
3.2 KiB
Plaintext
60 lines
3.2 KiB
Plaintext
@import nu.marginalia.search.model.SearchFilters
|
|
@import java.util.List
|
|
|
|
@param SearchFilters filters
|
|
|
|
<aside class="md:w-64 py-4 shrink-0 hidden sm:block">
|
|
<div class="space-y-6 sticky top-4">
|
|
<div class="bg-white p-4 border border-gray-300">
|
|
<h2 class="font-medium mb-3 flex items-center font-serif hidden md:block">
|
|
<i class="fas fa-filter text-sm mr-2"></i> Filter
|
|
</h2>
|
|
<div class="space-y-2">
|
|
@for (List<SearchFilters.Filter> filterGroup : filters.getFilterGroups())
|
|
@for (SearchFilters.Filter filter : filterGroup)
|
|
<label class="flex items-center">
|
|
<button title="${filter.displayName}" onclick="document.location='$unsafe{filter.url}'" class="flex-1 py-2 pl-2 rounded flex space-x-2 has-[:checked]:bg-gray-100 has-[:checked]:text-slate-900 hover:bg-gray-50 bg-white text-margeblue">
|
|
@if (filter.current)
|
|
<input type="checkbox" checked class="sr-only" aria-checked="true" />
|
|
@else
|
|
<input type="checkbox" class="sr-only" aria-checked="false" />
|
|
@endif
|
|
|
|
|
|
<a tabindex="-1" href="$unsafe{filter.url}" class="text-sm" href="#">
|
|
<i class="fas ${filter.icon} text-sm mr-3"></i>
|
|
<span class="hidden md:inline">${filter.displayName}</span></a>
|
|
</button>
|
|
</label>
|
|
@endfor
|
|
<div class="[&:not(:last-child)]:border-b hidden md:block"></div>
|
|
@endfor
|
|
</div>
|
|
</div>
|
|
<div class="bg-white p-4 border border-gray-300">
|
|
<h2 class="font-medium mb-3 flex items-center font-serif hidden md:block">
|
|
<i class="fas fa-cog text-sm mr-2"></i> Advanced Settings
|
|
</h2>
|
|
<div class="space-y-2">
|
|
@for (SearchFilters.SearchOption option : filters.searchOptions())
|
|
<label class="flex items-center">
|
|
<button title="${option.name()}" onclick="document.location='$unsafe{option.getUrl()}'" class="flex-1 py-2 pl-2 rounded flex space-x-2 has-[:checked]:bg-gray-100 has-[:checked]:text-slate-900 hover:bg-gray-50 bg-white text-margeblue">
|
|
@if (option.isSet())
|
|
<input type="checkbox" checked class="sr-only" aria-checked="true" />
|
|
@else
|
|
<input type="checkbox" class="sr-only" aria-checked="false" />
|
|
@endif
|
|
|
|
|
|
<a href="$unsafe{option.getUrl()}" class="text-sm" href="#">
|
|
<i class="fas ${option.icon()} text-sm mr-3"></i>
|
|
<span class="hidden md:inline">${option.name()}</span>
|
|
</a>
|
|
</button>
|
|
</label>
|
|
@endfor
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</aside>
|