mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2024-12-12 09:26:33 +01:00
Add Tabby model selection
This commit is contained in:
parent
1c421cc117
commit
42fa3c79d7
@ -15,8 +15,13 @@
|
|||||||
z-index: 40000;
|
z-index: 40000;
|
||||||
}
|
}
|
||||||
|
|
||||||
.select2-selection__clear {
|
.select2-container .select2-selection .select2-selection__clear {
|
||||||
color: var(--SmartThemeBodyColor);
|
color: var(--SmartThemeBodyColor);
|
||||||
|
font-size: 24px;
|
||||||
|
padding: 0;
|
||||||
|
position: absolute;
|
||||||
|
right: 5px;
|
||||||
|
top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.select2-container .select2-search__field {
|
.select2-container .select2-search__field {
|
||||||
|
@ -2335,8 +2335,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="flex1">
|
<div class="flex1">
|
||||||
<h4>
|
<h4>
|
||||||
<span data-i18n="Ollama Model">Ollama Model
|
<span data-i18n="Ollama Model">Ollama Model</span>
|
||||||
</h4>
|
|
||||||
</h4>
|
</h4>
|
||||||
<select id="ollama_model">
|
<select id="ollama_model">
|
||||||
<option data-i18n="-- Connect to the API --">
|
<option data-i18n="-- Connect to the API --">
|
||||||
@ -2373,7 +2372,19 @@
|
|||||||
<h4>
|
<h4>
|
||||||
<span data-i18n="Tabby Model">Tabby Model</span>
|
<span data-i18n="Tabby Model">Tabby Model</span>
|
||||||
</h4>
|
</h4>
|
||||||
</h4>
|
<select id="tabby_model">
|
||||||
|
<option data-i18n="-- Connect to the API --">
|
||||||
|
-- Connect to the API --
|
||||||
|
</option>
|
||||||
|
</select>
|
||||||
|
<small>
|
||||||
|
<i class="fa-solid fa-lightbulb"></i>
|
||||||
|
|
||||||
|
<code>inline_model_loading: true</code>
|
||||||
|
<span data-i18n="must be set in Tabby's config.yml to switch models.">
|
||||||
|
must be set in Tabby's config.yml to switch models.
|
||||||
|
</span>
|
||||||
|
</small>
|
||||||
<div id="tabby_download_model" class="menu_button menu_button_icon">
|
<div id="tabby_download_model" class="menu_button menu_button_icon">
|
||||||
<i class="fa-solid fa-download"></i>
|
<i class="fa-solid fa-download"></i>
|
||||||
<span data-i18n="Download">Download</span>
|
<span data-i18n="Download">Download</span>
|
||||||
|
@ -224,7 +224,7 @@ import {
|
|||||||
import { getBackgrounds, initBackgrounds, loadBackgroundSettings, background_settings } from './scripts/backgrounds.js';
|
import { getBackgrounds, initBackgrounds, loadBackgroundSettings, background_settings } from './scripts/backgrounds.js';
|
||||||
import { hideLoader, showLoader } from './scripts/loader.js';
|
import { hideLoader, showLoader } from './scripts/loader.js';
|
||||||
import { BulkEditOverlay, CharacterContextMenu } from './scripts/BulkEditOverlay.js';
|
import { BulkEditOverlay, CharacterContextMenu } from './scripts/BulkEditOverlay.js';
|
||||||
import { loadFeatherlessModels, loadMancerModels, loadOllamaModels, loadTogetherAIModels, loadInfermaticAIModels, loadOpenRouterModels, loadVllmModels, loadAphroditeModels, loadDreamGenModels, initTextGenModels } from './scripts/textgen-models.js';
|
import { loadFeatherlessModels, loadMancerModels, loadOllamaModels, loadTogetherAIModels, loadInfermaticAIModels, loadOpenRouterModels, loadVllmModels, loadAphroditeModels, loadDreamGenModels, initTextGenModels, loadTabbyModels } from './scripts/textgen-models.js';
|
||||||
import { appendFileContent, hasPendingFileAttachment, populateFileAttachment, decodeStyleTags, encodeStyleTags, isExternalMediaAllowed, getCurrentEntityId } from './scripts/chats.js';
|
import { appendFileContent, hasPendingFileAttachment, populateFileAttachment, decodeStyleTags, encodeStyleTags, isExternalMediaAllowed, getCurrentEntityId } from './scripts/chats.js';
|
||||||
import { initPresetManager } from './scripts/preset-manager.js';
|
import { initPresetManager } from './scripts/preset-manager.js';
|
||||||
import { MacrosParser, evaluateMacros, getLastMessageId } from './scripts/macros.js';
|
import { MacrosParser, evaluateMacros, getLastMessageId } from './scripts/macros.js';
|
||||||
@ -1214,6 +1214,9 @@ async function getStatusTextgen() {
|
|||||||
} else if (textgen_settings.type === FEATHERLESS) {
|
} else if (textgen_settings.type === FEATHERLESS) {
|
||||||
loadFeatherlessModels(data?.data);
|
loadFeatherlessModels(data?.data);
|
||||||
setOnlineStatus(textgen_settings.featherless_model);
|
setOnlineStatus(textgen_settings.featherless_model);
|
||||||
|
} else if (textgen_settings.type === TABBY) {
|
||||||
|
loadTabbyModels(data?.data);
|
||||||
|
setOnlineStatus(textgen_settings.tabby_model || data?.result);
|
||||||
} else {
|
} else {
|
||||||
setOnlineStatus(data?.result);
|
setOnlineStatus(data?.result);
|
||||||
}
|
}
|
||||||
|
@ -338,6 +338,7 @@ class PresetManager {
|
|||||||
'max_tokens_second',
|
'max_tokens_second',
|
||||||
'openrouter_providers',
|
'openrouter_providers',
|
||||||
'openrouter_allow_fallbacks',
|
'openrouter_allow_fallbacks',
|
||||||
|
'tabby_model',
|
||||||
];
|
];
|
||||||
const settings = Object.assign({}, getSettingsByApiId(this.apiId));
|
const settings = Object.assign({}, getSettingsByApiId(this.apiId));
|
||||||
|
|
||||||
|
@ -3426,6 +3426,7 @@ function getModelOptions(quiet) {
|
|||||||
{ id: 'vllm_model', api: 'textgenerationwebui', type: textgen_types.VLLM },
|
{ id: 'vllm_model', api: 'textgenerationwebui', type: textgen_types.VLLM },
|
||||||
{ id: 'aphrodite_model', api: 'textgenerationwebui', type: textgen_types.APHRODITE },
|
{ id: 'aphrodite_model', api: 'textgenerationwebui', type: textgen_types.APHRODITE },
|
||||||
{ id: 'ollama_model', api: 'textgenerationwebui', type: textgen_types.OLLAMA },
|
{ id: 'ollama_model', api: 'textgenerationwebui', type: textgen_types.OLLAMA },
|
||||||
|
{ id: 'tabby_model', api: 'textgenerationwebui', type: textgen_types.TABBY },
|
||||||
{ id: 'model_openai_select', api: 'openai', type: chat_completion_sources.OPENAI },
|
{ id: 'model_openai_select', api: 'openai', type: chat_completion_sources.OPENAI },
|
||||||
{ id: 'model_claude_select', api: 'openai', type: chat_completion_sources.CLAUDE },
|
{ id: 'model_claude_select', api: 'openai', type: chat_completion_sources.CLAUDE },
|
||||||
{ id: 'model_windowai_select', api: 'openai', type: chat_completion_sources.WINDOWAI },
|
{ id: 'model_windowai_select', api: 'openai', type: chat_completion_sources.WINDOWAI },
|
||||||
|
@ -12,6 +12,7 @@ let dreamGenModels = [];
|
|||||||
let vllmModels = [];
|
let vllmModels = [];
|
||||||
let aphroditeModels = [];
|
let aphroditeModels = [];
|
||||||
let featherlessModels = [];
|
let featherlessModels = [];
|
||||||
|
let tabbyModels = [];
|
||||||
export let openRouterModels = [];
|
export let openRouterModels = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -66,6 +67,30 @@ export async function loadOllamaModels(data) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function loadTabbyModels(data) {
|
||||||
|
if (!Array.isArray(data)) {
|
||||||
|
console.error('Invalid Tabby models data', data);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
tabbyModels = data;
|
||||||
|
tabbyModels.sort((a, b) => a.id.localeCompare(b.id));
|
||||||
|
tabbyModels.unshift({ id: '' });
|
||||||
|
|
||||||
|
if (!tabbyModels.find(x => x.id === textgen_settings.tabby_model)) {
|
||||||
|
textgen_settings.tabby_model = tabbyModels[0]?.id || '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#tabby_model').empty();
|
||||||
|
for (const model of tabbyModels) {
|
||||||
|
const option = document.createElement('option');
|
||||||
|
option.value = model.id;
|
||||||
|
option.text = model.id;
|
||||||
|
option.selected = model.id === textgen_settings.tabby_model;
|
||||||
|
$('#tabby_model').append(option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export async function loadTogetherAIModels(data) {
|
export async function loadTogetherAIModels(data) {
|
||||||
if (!Array.isArray(data)) {
|
if (!Array.isArray(data)) {
|
||||||
console.error('Invalid Together AI models data', data);
|
console.error('Invalid Together AI models data', data);
|
||||||
@ -310,6 +335,12 @@ function onOllamaModelSelect() {
|
|||||||
$('#api_button_textgenerationwebui').trigger('click');
|
$('#api_button_textgenerationwebui').trigger('click');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onTabbyModelSelect() {
|
||||||
|
const modelId = String($('#tabby_model').val());
|
||||||
|
textgen_settings.tabby_model = modelId;
|
||||||
|
$('#api_button_textgenerationwebui').trigger('click');
|
||||||
|
}
|
||||||
|
|
||||||
function onOpenRouterModelSelect() {
|
function onOpenRouterModelSelect() {
|
||||||
const modelId = String($('#openrouter_model').val());
|
const modelId = String($('#openrouter_model').val());
|
||||||
textgen_settings.openrouter_model = modelId;
|
textgen_settings.openrouter_model = modelId;
|
||||||
@ -641,6 +672,7 @@ export function initTextGenModels() {
|
|||||||
$('#aphrodite_model').on('change', onAphroditeModelSelect);
|
$('#aphrodite_model').on('change', onAphroditeModelSelect);
|
||||||
$('#featherless_model').on('change', onFeatherlessModelSelect);
|
$('#featherless_model').on('change', onFeatherlessModelSelect);
|
||||||
$('#tabby_download_model').on('click', downloadTabbyModel);
|
$('#tabby_download_model').on('click', downloadTabbyModel);
|
||||||
|
$('#tabby_model').on('change', onTabbyModelSelect);
|
||||||
|
|
||||||
const providersSelect = $('.openrouter_providers');
|
const providersSelect = $('.openrouter_providers');
|
||||||
for (const provider of OPENROUTER_PROVIDERS) {
|
for (const provider of OPENROUTER_PROVIDERS) {
|
||||||
@ -671,6 +703,13 @@ export function initTextGenModels() {
|
|||||||
searchInputCssClass: 'text_pole',
|
searchInputCssClass: 'text_pole',
|
||||||
width: '100%',
|
width: '100%',
|
||||||
});
|
});
|
||||||
|
$('#tabby_model').select2({
|
||||||
|
placeholder: '[Currently loaded]',
|
||||||
|
searchInputPlaceholder: 'Search models...',
|
||||||
|
searchInputCssClass: 'text_pole',
|
||||||
|
width: '100%',
|
||||||
|
allowClear: true,
|
||||||
|
});
|
||||||
$('#model_infermaticai_select').select2({
|
$('#model_infermaticai_select').select2({
|
||||||
placeholder: 'Select a model',
|
placeholder: 'Select a model',
|
||||||
searchInputPlaceholder: 'Search models...',
|
searchInputPlaceholder: 'Search models...',
|
||||||
|
@ -180,6 +180,7 @@ const settings = {
|
|||||||
vllm_model: '',
|
vllm_model: '',
|
||||||
aphrodite_model: '',
|
aphrodite_model: '',
|
||||||
dreamgen_model: 'opus-v1-xl/text',
|
dreamgen_model: 'opus-v1-xl/text',
|
||||||
|
tabby_model: '',
|
||||||
legacy_api: false,
|
legacy_api: false,
|
||||||
sampler_order: KOBOLDCPP_ORDER,
|
sampler_order: KOBOLDCPP_ORDER,
|
||||||
logit_bias: [],
|
logit_bias: [],
|
||||||
@ -1047,6 +1048,11 @@ export function getTextGenModel() {
|
|||||||
return settings.featherless_model;
|
return settings.featherless_model;
|
||||||
case HUGGINGFACE:
|
case HUGGINGFACE:
|
||||||
return 'tgi';
|
return 'tgi';
|
||||||
|
case TABBY:
|
||||||
|
if (settings.tabby_model) {
|
||||||
|
return settings.tabby_model;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user