mirror of
https://github.com/mudler/LocalAI.git
synced 2025-02-22 01:56:38 +00:00
* feat(ui): allow to set system prompt for chat Make also the models in the index clickable, and display as table Fixes #2257 Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * feat(vision): support also png with base64 input Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * feat(ui): support vision and upload of files Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * display the processed image Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * make trust remote code stand out Signed-off-by: mudler <mudler@localai.io> * feat(ui): track in progress job across index/model gallery Signed-off-by: mudler <mudler@localai.io> * minor fixups Signed-off-by: mudler <mudler@localai.io> --------- Signed-off-by: Ettore Di Giacinto <mudler@localai.io> Signed-off-by: mudler <mudler@localai.io>
115 lines
6.3 KiB
HTML
115 lines
6.3 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="header text-center py-12">
|
|
<h1 class="text-5xl font-bold text-gray-100">Welcome to <i>your</i> LocalAI instance!</h1>
|
|
<p class="mt-4 text-lg">The FOSS alternative to OpenAI, Claude, ...</p>
|
|
<a href="https://localai.io" target="_blank" class="mt-4 inline-block bg-blue-500 text-white py-2 px-4 rounded-lg shadow transition duration-300 ease-in-out hover:bg-blue-700 hover:shadow-lg">
|
|
<i class="fas fa-book-reader pr-2"></i>Documentation
|
|
</a>
|
|
</div>
|
|
|
|
<div class="models mt-4">
|
|
|
|
<!-- Show in progress operations-->
|
|
{{ if .ProcessingModels }}
|
|
<h3
|
|
class="mt-4 mb-4 text-center text-3xl font-semibold text-gray-100">Operations in progress</h2>
|
|
{{end}}
|
|
{{$taskType:=.TaskTypes}}
|
|
{{ range $key,$value:=.ProcessingModels }}
|
|
{{ $op := index $taskType $key}}
|
|
{{$parts := split "@" $key}}
|
|
<div class="flex items-center justify-between bg-slate-600 p-2 mb-2 rounded-md">
|
|
<div class="flex items center">
|
|
<span class="text-gray-300"><a href="/browse?term={{$parts._1}}"
|
|
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"
|
|
>{{$parts._1}}</a> (from the '{{$parts._0}}' repository)</span>
|
|
</div>
|
|
<div hx-get="/browse/job/{{$value}}" hx-swap="innerHTML" hx-target="this" hx-trigger="done">
|
|
<h3 role="status" id="pblabel" >{{$op}}
|
|
<div hx-get="/browse/job/progress/{{$value}}" hx-trigger="every 600ms" hx-target="this"
|
|
hx-swap= "innerHTML" ></div></h3>
|
|
</div>
|
|
</div>
|
|
{{ end }}
|
|
<!-- END Show in progress operations-->
|
|
|
|
{{ if eq (len .ModelsConfig) 0 }}
|
|
<h2 class="text-center text-3xl font-semibold text-gray-100"> <i class="text-yellow-200 ml-2 fa-solid fa-triangle-exclamation animate-pulse"></i> Ouch! seems you don't have any models installed!</h2>
|
|
<p class="text-center mt-4 text-xl">..install something from the <a class="text-gray-400 hover:text-white ml-1 px-3 py-2 rounded" href="/browse">🖼️ Gallery</a> or check the <a href="https://localai.io/basics/getting_started/" class="text-gray-400 hover:text-white ml-1 px-3 py-2 rounded"> <i class="fa-solid fa-book"></i> Getting started documentation </a></p>
|
|
{{ else }}
|
|
<h2 class="text-center text-3xl font-semibold text-gray-100">Installed models</h2>
|
|
<p class="text-center mt-4 text-xl">We have {{len .ModelsConfig}} pre-loaded models available.</p>
|
|
<table class="table-auto mt-4 w-full text-left text-gray-200">
|
|
<thead class="text-xs text-gray-400 uppercase bg-gray-700">
|
|
<tr>
|
|
<th class="px-4 py-2"></th>
|
|
<th class="px-4 py-2">Model Name</th>
|
|
<th class="px-4 py-2">Backend</th>
|
|
<th class="px-4 py-2 float-right">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{{$galleryConfig:=.GalleryConfig}}
|
|
{{$noicon:="https://upload.wikimedia.org/wikipedia/commons/6/65/No-Image-Placeholder.svg"}}
|
|
{{ range .ModelsConfig }}
|
|
{{ $cfg:= index $galleryConfig .Name}}
|
|
<tr class="bg-gray-800 border-b border-gray-700">
|
|
<td class="px-4 py-3">
|
|
{{ with $cfg }}
|
|
<img {{ if $cfg.Icon }}
|
|
src="{{$cfg.Icon}}"
|
|
{{ else }}
|
|
src="{{$noicon}}"
|
|
{{ end }}
|
|
class="rounded-t-lg max-h-24 max-w-24 object-cover mt-3"
|
|
>
|
|
{{ else}}
|
|
<img src="{{$noicon}}" class="rounded-t-lg max-h-24 max-w-24 object-cover mt-3">
|
|
{{ end }}
|
|
</td>
|
|
<td class="px-4 py-3 font-bold">
|
|
<p class="font-bold text-white flex items-center"><i class="fas fa-brain pr-2"></i><a href="/browse?term={{.Name}}">{{.Name}}</a></p>
|
|
</td>
|
|
<td class="px-4 py-3 font-bold">
|
|
{{ if .Backend }}
|
|
<!-- Badge for Backend -->
|
|
<span class="inline-block bg-blue-500 text-white py-1 px-3 rounded-full text-xs">
|
|
{{.Backend}}
|
|
</span>
|
|
{{ else }}
|
|
<span class="inline-block bg-yellow-500 text-white py-1 px-3 rounded-full text-xs">
|
|
auto
|
|
</span>
|
|
{{ end }}
|
|
</td>
|
|
|
|
<td class="px-4 py-3">
|
|
<button
|
|
class="float-right inline-block rounded bg-red-800 px-6 pb-2.5 mb-3 pt-2.5 text-xs font-medium uppercase leading-normal text-white shadow-primary-3 transition duration-150 ease-in-out hover:bg-red-accent-300 hover:shadow-red-2 focus:bg-red-accent-300 focus:shadow-primary-2 focus:outline-none focus:ring-0 active:bg-red-600 active:shadow-primary-2 dark:shadow-black/30 dark:hover:shadow-dark-strong dark:focus:shadow-dark-strong dark:active:shadow-dark-strong"
|
|
data-twe-ripple-color="light" data-twe-ripple-init="" hx-confirm="Are you sure you wish to delete the model?" hx-post="/browse/delete/model/{{.Name}}" hx-swap="outerHTML"><i class="fa-solid fa-cancel pr-2"></i>Delete</button>
|
|
</td>
|
|
{{ end }}
|
|
</tbody>
|
|
</table>
|
|
{{ end }}
|
|
|
|
|
|
|
|
</div>
|
|
</div>
|
|
|
|
{{template "views/partials/footer" .}}
|
|
</div>
|
|
|
|
</body>
|
|
</html>
|