Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
chenpangpang
open-webui
Commits
e80e4c30
Commit
e80e4c30
authored
May 24, 2024
by
Timothy J. Baek
Browse files
refac
parent
404875ca
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
49 additions
and
60 deletions
+49
-60
backend/apps/web/routers/models.py
backend/apps/web/routers/models.py
+1
-1
src/lib/apis/index.ts
src/lib/apis/index.ts
+6
-1
src/lib/apis/models/index.ts
src/lib/apis/models/index.ts
+1
-1
src/lib/components/chat/ModelSelector/Selector.svelte
src/lib/components/chat/ModelSelector/Selector.svelte
+4
-7
src/lib/components/chat/Settings/Connections.svelte
src/lib/components/chat/Settings/Connections.svelte
+3
-3
src/lib/components/chat/Settings/General.svelte
src/lib/components/chat/Settings/General.svelte
+1
-1
src/lib/components/chat/Settings/Images.svelte
src/lib/components/chat/Settings/Images.svelte
+5
-5
src/lib/components/chat/Settings/Models.svelte
src/lib/components/chat/Settings/Models.svelte
+8
-8
src/lib/components/chat/SettingsModal.svelte
src/lib/components/chat/SettingsModal.svelte
+7
-7
src/lib/components/workspace/Models.svelte
src/lib/components/workspace/Models.svelte
+5
-4
src/lib/utils/index.ts
src/lib/utils/index.ts
+0
-14
src/routes/(app)/+layout.svelte
src/routes/(app)/+layout.svelte
+4
-4
src/routes/(app)/workspace/models/create/+page.svelte
src/routes/(app)/workspace/models/create/+page.svelte
+2
-2
src/routes/(app)/workspace/models/edit/+page.svelte
src/routes/(app)/workspace/models/edit/+page.svelte
+2
-2
No files found.
backend/apps/web/routers/models.py
View file @
e80e4c30
...
...
@@ -13,7 +13,7 @@ from constants import ERROR_MESSAGES
router
=
APIRouter
()
###########################
# get
All
Models
# getModels
###########################
...
...
src/lib/apis/index.ts
View file @
e80e4c30
...
...
@@ -25,7 +25,12 @@ export const getModels = async (token: string = '') => {
throw
error
;
}
return
res
?.
data
??
[];
let
models
=
res
?.
data
??
[];
models
=
models
.
filter
((
models
)
=>
models
).
reduce
((
a
,
e
,
i
,
arr
)
=>
a
.
concat
(
e
),
[]);
console
.
log
(
models
);
return
models
;
};
export
const
getBackendConfig
=
async
()
=>
{
...
...
src/lib/apis/models/index.ts
View file @
e80e4c30
...
...
@@ -29,7 +29,7 @@ export const addNewModel = async (token: string, model: object) => {
return
res
;
};
export
const
getModels
=
async
(
token
:
string
=
''
)
=>
{
export
const
getModel
Info
s
=
async
(
token
:
string
=
''
)
=>
{
let
error
=
null
;
const
res
=
await
fetch
(
`
${
WEBUI_API_BASE_URL
}
/models/`
,
{
...
...
src/lib/components/chat/ModelSelector/Selector.svelte
View file @
e80e4c30
...
...
@@ -12,12 +12,9 @@
import { user, MODEL_DOWNLOAD_POOL, models, mobile } from '$lib/stores';
import { toast } from 'svelte-sonner';
import {
capitalizeFirstLetter,
getAllModels,
sanitizeResponseContent,
splitStream
} from '$lib/utils';
import { capitalizeFirstLetter, sanitizeResponseContent, splitStream } from '$lib/utils';
import { getModels } from '$lib/apis';
import Tooltip from '$lib/components/common/Tooltip.svelte';
const i18n = getContext('i18n');
...
...
@@ -159,7 +156,7 @@
})
);
models.set(await get
All
Models(localStorage.token));
models.set(await getModels(localStorage.token));
} else {
toast.error($i18n.t('Download canceled'));
}
...
...
src/lib/components/chat/Settings/Connections.svelte
View file @
e80e4c30
...
...
@@ -23,7 +23,7 @@
const i18n = getContext('i18n');
export let get
All
Models: Function;
export let getModels: Function;
// External
let OLLAMA_BASE_URLS = [''];
...
...
@@ -38,7 +38,7 @@
OPENAI_API_BASE_URLS = await updateOpenAIUrls(localStorage.token, OPENAI_API_BASE_URLS);
OPENAI_API_KEYS = await updateOpenAIKeys(localStorage.token, OPENAI_API_KEYS);
await models.set(await get
All
Models());
await models.set(await getModels());
};
const updateOllamaUrlsHandler = async () => {
...
...
@@ -51,7 +51,7 @@
if (ollamaVersion) {
toast.success($i18n.t('Server connection verified'));
await models.set(await get
All
Models());
await models.set(await getModels());
}
};
...
...
src/lib/components/chat/Settings/General.svelte
View file @
e80e4c30
...
...
@@ -11,7 +11,7 @@
import AdvancedParams from './Advanced/AdvancedParams.svelte';
export let saveSettings: Function;
export let get
All
Models: Function;
export let getModels: Function;
// General
let themes = ['dark', 'light', 'rose-pine dark', 'rose-pine-dawn light', 'oled-dark'];
...
...
src/lib/components/chat/Settings/Images.svelte
View file @
e80e4c30
...
...
@@ -42,7 +42,7 @@
let imageSize = '';
let steps = 50;
const get
All
Models = async () => {
const getModels = async () => {
models = await getImageGenerationModels(localStorage.token).catch((error) => {
toast.error(error);
return null;
...
...
@@ -66,7 +66,7 @@
if (res) {
COMFYUI_BASE_URL = res.COMFYUI_BASE_URL;
await get
All
Models();
await getModels();
if (models) {
toast.success($i18n.t('Server connection verified'));
...
...
@@ -85,7 +85,7 @@
if (res) {
AUTOMATIC1111_BASE_URL = res.AUTOMATIC1111_BASE_URL;
await get
All
Models();
await getModels();
if (models) {
toast.success($i18n.t('Server connection verified'));
...
...
@@ -112,7 +112,7 @@
if (enableImageGeneration) {
config.set(await getBackendConfig(localStorage.token));
get
All
Models();
getModels();
}
};
...
...
@@ -141,7 +141,7 @@
steps = await getImageSteps(localStorage.token);
if (enableImageGeneration) {
get
All
Models();
getModels();
}
}
});
...
...
src/lib/components/chat/Settings/Models.svelte
View file @
e80e4c30
...
...
@@ -22,7 +22,7 @@
const i18n = getContext('i18n');
export let get
All
Models: Function;
export let getModels: Function;
let showLiteLLM = false;
let showLiteLLMParams = false;
...
...
@@ -261,7 +261,7 @@
})
);
models.set(await get
All
Models(localStorage.token));
models.set(await getModels(localStorage.token));
} else {
toast.error($i18n.t('Download canceled'));
}
...
...
@@ -424,7 +424,7 @@
modelTransferring = false;
uploadProgress = null;
models.set(await get
All
Models());
models.set(await getModels());
};
const deleteModelHandler = async () => {
...
...
@@ -439,7 +439,7 @@
}
deleteModelTag = '';
models.set(await get
All
Models());
models.set(await getModels());
};
const cancelModelPullHandler = async (model: string) => {
...
...
@@ -488,7 +488,7 @@
liteLLMMaxTokens = '';
liteLLMModelInfo = await getLiteLLMModelInfo(localStorage.token);
models.set(await get
All
Models());
models.set(await getModels());
};
const deleteLiteLLMModelHandler = async () => {
...
...
@@ -507,7 +507,7 @@
deleteLiteLLMModelName = '';
liteLLMModelInfo = await getLiteLLMModelInfo(localStorage.token);
models.set(await get
All
Models());
models.set(await getModels());
};
const addModelInfoHandler = async () => {
...
...
@@ -534,7 +534,7 @@
toast.success(
$i18n.t('Model info for {{modelName}} added successfully', { modelName: selectedModelId })
);
models.set(await get
All
Models());
models.set(await getModels());
};
const deleteModelInfoHandler = async () => {
...
...
@@ -550,7 +550,7 @@
toast.success(
$i18n.t('Model info for {{modelName}} deleted successfully', { modelName: selectedModelId })
);
models.set(await get
All
Models());
models.set(await getModels());
};
const toggleIsVisionCapable = () => {
...
...
src/lib/components/chat/SettingsModal.svelte
View file @
e80e4c30
...
...
@@ -3,7 +3,7 @@
import { toast } from 'svelte-sonner';
import { models, settings, user } from '$lib/stores';
import { get
All
Models as _get
All
Models } from '$lib/
util
s';
import { getModels as _getModels } from '$lib/
api
s';
import Modal from '../common/Modal.svelte';
import Account from './Settings/Account.svelte';
...
...
@@ -25,12 +25,12 @@
const saveSettings = async (updated) => {
console.log(updated);
await settings.set({ ...$settings, ...updated });
await models.set(await get
All
Models());
await models.set(await getModels());
localStorage.setItem('settings', JSON.stringify($settings));
};
const get
All
Models = async () => {
return await _get
All
Models(localStorage.token);
const getModels = async () => {
return await _getModels(localStorage.token);
};
let selectedTab = 'general';
...
...
@@ -318,17 +318,17 @@
<div class="flex-1 md:min-h-[28rem]">
{#if selectedTab === 'general'}
<General
{get
All
Models}
{getModels}
{saveSettings}
on:save={() => {
toast.success($i18n.t('Settings saved successfully!'));
}}
/>
{:else if selectedTab === 'models'}
<Models {get
All
Models} />
<Models {getModels} />
{:else if selectedTab === 'connections'}
<Connections
{get
All
Models}
{getModels}
on:save={() => {
toast.success($i18n.t('Settings saved successfully!'));
}}
...
...
src/lib/components/workspace/Models.svelte
View file @
e80e4c30
...
...
@@ -6,9 +6,10 @@
import { onMount, getContext } from 'svelte';
import { WEBUI_NAME, modelfiles, models, settings, user } from '$lib/stores';
import { addNewModel, deleteModelById, getModels } from '$lib/apis/models';
import { addNewModel, deleteModelById, getModel
Info
s } from '$lib/apis/models';
import { goto } from '$app/navigation';
import { getAllModels } from '$lib/utils';
import { getModels } from '$lib/apis';
const i18n = getContext('i18n');
...
...
@@ -22,7 +23,7 @@
if (res) {
toast.success($i18n.t(`Deleted {{tagName}}`, { id }));
}
await models.set(await get
All
Models(localStorage.token));
await models.set(await getModels(localStorage.token));
};
const shareModelHandler = async (model) => {
...
...
@@ -236,7 +237,7 @@
});
}
await modelfiles.set(await getModels(localStorage.token));
await modelfiles.set(await getModel
Info
s(localStorage.token));
};
reader.readAsText(importFiles[0]);
...
...
src/lib/utils/index.ts
View file @
e80e4c30
import
{
v4
as
uuidv4
}
from
'
uuid
'
;
import
sha256
from
'
js-sha256
'
;
import
{
getModels
}
from
'
$lib/apis
'
;
export
const
getAllModels
=
async
(
token
:
string
)
=>
{
let
models
=
await
getModels
(
token
).
catch
((
error
)
=>
{
console
.
log
(
error
);
return
null
;
});
models
=
models
.
filter
((
models
)
=>
models
).
reduce
((
a
,
e
,
i
,
arr
)
=>
a
.
concat
(
e
),
[]);
console
.
log
(
models
);
return
models
;
};
//////////////////////////
// Helper functions
//////////////////////////
...
...
src/routes/(app)/+layout.svelte
View file @
e80e4c30
...
...
@@ -7,7 +7,7 @@
import { goto } from '$app/navigation';
import { get
All
Models as _get
All
Models } from '$lib/
util
s';
import { getModels as _getModels } from '$lib/
api
s';
import { getOllamaVersion } from '$lib/apis/ollama';
import { getPrompts } from '$lib/apis/prompts';
...
...
@@ -45,8 +45,8 @@
let showShortcuts = false;
const get
All
Models = async () => {
return _get
All
Models(localStorage.token);
const getModels = async () => {
return _getModels(localStorage.token);
};
onMount(async () => {
...
...
@@ -75,7 +75,7 @@
await Promise.all([
(async () => {
models.set(await get
All
Models());
models.set(await getModels());
})(),
(async () => {
prompts.set(await getPrompts(localStorage.token));
...
...
src/routes/(app)/workspace/models/create/+page.svelte
View file @
e80e4c30
...
...
@@ -8,7 +8,7 @@
import { splitStream } from '$lib/utils';
import { onMount, tick, getContext } from 'svelte';
import { createModel } from '$lib/apis/ollama';
import { addNewModel, getModelById, getModels } from '$lib/apis/models';
import { addNewModel, getModelById, getModel
Info
s } from '$lib/apis/models';
const i18n = getContext('i18n');
...
...
@@ -99,7 +99,7 @@ SYSTEM """${system}"""`.replace(/^\s*\n/gm, '');
const saveModelfile = async (modelfile) => {
await addNewModel(localStorage.token, modelfile);
await modelfiles.set(await getModels(localStorage.token));
await modelfiles.set(await getModel
Info
s(localStorage.token));
};
const submitHandler = async () => {
...
...
src/routes/(app)/workspace/models/edit/+page.svelte
View file @
e80e4c30
...
...
@@ -10,7 +10,7 @@
import { splitStream } from '$lib/utils';
import { createModel } from '$lib/apis/ollama';
import { getModels, updateModelById } from '$lib/apis/models';
import { getModel
Info
s, updateModelById } from '$lib/apis/models';
import AdvancedParams from '$lib/components/chat/Settings/Advanced/AdvancedParams.svelte';
...
...
@@ -86,7 +86,7 @@
const updateModelfile = async (modelfile) => {
await updateModelById(localStorage.token, modelfile.tagName, modelfile);
await modelfiles.set(await getModels(localStorage.token));
await modelfiles.set(await getModel
Info
s(localStorage.token));
};
const updateHandler = async () => {
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment