mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-06-05 21:59:27 +02:00
Fix preset migration
This commit is contained in:
@ -6,26 +6,25 @@ import {power_user} from "./power-user.js";
|
|||||||
* Register migrations for the prompt manager when settings are loaded or an Open AI preset is loaded.
|
* Register migrations for the prompt manager when settings are loaded or an Open AI preset is loaded.
|
||||||
*/
|
*/
|
||||||
const registerPromptManagerMigration = (saveSettingsCallback) => {
|
const registerPromptManagerMigration = (saveSettingsCallback) => {
|
||||||
const migrate = (settings) => {
|
const migrate = (settings, preset) => {
|
||||||
// If any of the specified settings exist, run the migration
|
// If any of the specified settings exist, run the migration
|
||||||
if (settings.main_prompt || settings.nsfw_prompt || settings.jailbreak_prompt) {
|
if (preset.main_prompt || preset.nsfw_prompt || preset.jailbreak_prompt) {
|
||||||
console.log('Running one-time configuration migration for prompt manager.')
|
console.log('Running one-time configuration migration for prompt manager.')
|
||||||
if (settings.prompts === undefined || settings.prompts.length === 0) settings.prompts = chatCompletionDefaultPrompts.prompts;
|
if (settings.prompts === undefined || settings.prompts.length === 0) settings.prompts = chatCompletionDefaultPrompts.prompts;
|
||||||
|
|
||||||
const findPrompt = (identifier) => settings.prompts.find(prompt => identifier === prompt.identifier);
|
const findPrompt = (identifier) => settings.prompts.find(prompt => identifier === prompt.identifier);
|
||||||
|
if (preset.main_prompt) {
|
||||||
if (settings.main_prompt) {
|
findPrompt('main').content = preset.main_prompt
|
||||||
findPrompt('main').content = settings.main_prompt
|
|
||||||
delete settings.main_prompt;
|
delete settings.main_prompt;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (settings.nsfw_prompt) {
|
if (preset.nsfw_prompt) {
|
||||||
findPrompt('nsfw').content = settings.nsfw_prompt
|
findPrompt('nsfw').content = preset.nsfw_prompt
|
||||||
delete settings.nsfw_prompt;
|
delete settings.nsfw_prompt;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (settings.jailbreak_prompt) {
|
if (preset.jailbreak_prompt) {
|
||||||
findPrompt('jailbreak').content = settings.jailbreak_prompt
|
findPrompt('jailbreak').content = preset.jailbreak_prompt
|
||||||
delete settings.jailbreak_prompt;
|
delete settings.jailbreak_prompt;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,8 +32,14 @@ const registerPromptManagerMigration = (saveSettingsCallback) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
eventSource.on(event_types.SETTINGS_LOADED_BEFORE, settings => migrate(settings));
|
const migrateSettings = (settings) => migrate(settings, settings);
|
||||||
eventSource.on(event_types.OAI_PRESET_CHANGED, settings => migrate(settings));
|
const migratePreset = (event) => {
|
||||||
|
migrate(event.settings, event.preset);
|
||||||
|
event.callback(event.presetName, event.settings, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
eventSource.on(event_types.SETTINGS_LOADED_BEFORE, settings => migrateSettings(settings));
|
||||||
|
eventSource.on(event_types.OAI_PRESET_CHANGED, settings => migratePreset(settings));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user