mirror of
https://github.com/mudler/LocalAI.git
synced 2024-12-20 21:23:10 +00:00
fe055d4b36
* ux: change welcome when there are no models installed Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * ux: filter Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * ux: show tags in filter Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * wip Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * make tags clickable Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * allow to delete models from the list Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * ui: display icon of installed models Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * gallery: remove gallery file when removing model Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * feat(gallery): show a re-install button Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * make filter buttons, rename Gallery field Signed-off-by: mudler <mudler@localai.io> * show again buttons at end of operations Signed-off-by: mudler <mudler@localai.io> --------- Signed-off-by: Ettore Di Giacinto <mudler@localai.io> Signed-off-by: mudler <mudler@localai.io>
83 lines
4.7 KiB
HTML
83 lines
4.7 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
{{template "views/partials/head" .}}
|
|
|
|
<body class="bg-gray-900 text-gray-200">
|
|
<div class="flex flex-col min-h-screen">
|
|
|
|
{{template "views/partials/navbar" .}}
|
|
<div class="container mx-auto px-4 flex-grow">
|
|
|
|
<div class="models mt-12">
|
|
<h2 class="text-center text-3xl font-semibold text-gray-100">
|
|
🖼️ Available models from <i>{{ len .Repositories }}</i> repositories <a href="https://localai.io/models/" target="_blank" >
|
|
<i class="fas fa-circle-info pr-2"></i>
|
|
</a></h2>
|
|
|
|
<div class="text-center font-semibold text-gray-100">
|
|
<h2>Filter by type:</h2>
|
|
<button hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "tts"}'
|
|
hx-indicator=".htmx-indicator" >TTS</button>
|
|
<button hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "stablediffusion"}'
|
|
hx-indicator=".htmx-indicator" >Image generation</button>
|
|
<button hx-post="/browse/search/models" \
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "llm"}'
|
|
hx-indicator=".htmx-indicator" >Text generation</button>
|
|
<button hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "multimodal"}'
|
|
hx-indicator=".htmx-indicator" >Multimodal</button>
|
|
<button hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "embedding"}'
|
|
hx-indicator=".htmx-indicator" >Embeddings</button>
|
|
<button hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "rerank"}'
|
|
hx-indicator=".htmx-indicator" >Rerankers</button>
|
|
<button
|
|
hx-post="/browse/search/models"
|
|
class="text-white-500 inline-block bg-blue-200 rounded-full px-3 py-1 text-sm font-semibold text-gray-700 mr-2 mb-2 hover:bg-gray-300 hover:shadow-gray-2"
|
|
hx-target="#search-results"
|
|
hx-vals='{"search": "whisper"}'
|
|
hx-indicator=".htmx-indicator" >Audio transcription</button>
|
|
</div>
|
|
|
|
<div class="text-center text-xs font-semibold text-gray-100">
|
|
Filter by tags:
|
|
{{ range .AllTags }}
|
|
<button hx-post="/browse/search/models" class="text-blue-500" hx-target="#search-results"
|
|
hx-vals='{"search": "{{.}}"}'
|
|
hx-indicator=".htmx-indicator" >{{.}}</button>
|
|
{{ end }}
|
|
</div>
|
|
|
|
<span class="htmx-indicator loader"></span>
|
|
<input class="form-control appearance-none block w-full px-3 py-2 text-base font-normal text-gray-300 pb-2 mb-5 bg-gray-800 bg-clip-padding border border-solid border-gray-600 rounded transition ease-in-out m-0 focus:text-gray-300 focus:bg-gray-900 focus:border-blue-500 focus:outline-none" type="search"
|
|
name="search" placeholder="Begin Typing To Search models..."
|
|
hx-post="/browse/search/models"
|
|
hx-trigger="input changed delay:500ms, search"
|
|
hx-target="#search-results"
|
|
hx-indicator=".htmx-indicator">
|
|
|
|
<div id="search-results">{{.Models}}</div>
|
|
</div>
|
|
</div>
|
|
|
|
{{template "views/partials/footer" .}}
|
|
</div>
|
|
|
|
</body>
|
|
</html>
|