mirror of
				https://github.com/SillyTavern/SillyTavern.git
				synced 2025-06-05 21:59:27 +02:00 
			
		
		
		
	Resolve conflict
This commit is contained in:
		@@ -1,6 +1,6 @@
 | 
			
		||||
import { event_types, eventSource, main_api, saveSettingsDebounced } from '../../../script.js';
 | 
			
		||||
import { extension_settings, renderExtensionTemplateAsync } from '../../extensions.js';
 | 
			
		||||
import { callGenericPopup, Popup, POPUP_TYPE } from '../../popup.js';
 | 
			
		||||
import { callGenericPopup, Popup, POPUP_RESULT, POPUP_TYPE } from '../../popup.js';
 | 
			
		||||
import { SlashCommand } from '../../slash-commands/SlashCommand.js';
 | 
			
		||||
import { SlashCommandAbortController } from '../../slash-commands/SlashCommandAbortController.js';
 | 
			
		||||
import { ARGUMENT_TYPE, SlashCommandArgument, SlashCommandNamedArgument } from '../../slash-commands/SlashCommandArgument.js';
 | 
			
		||||
@@ -136,6 +136,7 @@ const profilesProvider = () => [
 | 
			
		||||
 * @property {string} [context] Context Template
 | 
			
		||||
 * @property {string} [instruct-state] Instruct Mode
 | 
			
		||||
 * @property {string} [tokenizer] Tokenizer
 | 
			
		||||
 * @property {string[]} [exclude] Commands to exclude
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -172,8 +173,13 @@ function findProfileByName(value) {
 | 
			
		||||
async function readProfileFromCommands(mode, profile, cleanUp = false) {
 | 
			
		||||
    const commands = mode === 'cc' ? CC_COMMANDS : TC_COMMANDS;
 | 
			
		||||
    const opposingCommands = mode === 'cc' ? TC_COMMANDS : CC_COMMANDS;
 | 
			
		||||
    const excludeList = Array.isArray(profile.exclude) ? profile.exclude : [];
 | 
			
		||||
    for (const command of commands) {
 | 
			
		||||
        try {
 | 
			
		||||
            if (excludeList.includes(command)) {
 | 
			
		||||
                continue;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            const args = getNamedArguments();
 | 
			
		||||
            const result = await SlashCommandParser.commands[command].callback(args, '');
 | 
			
		||||
            if (result) {
 | 
			
		||||
@@ -209,15 +215,37 @@ async function readProfileFromCommands(mode, profile, cleanUp = false) {
 | 
			
		||||
async function createConnectionProfile(forceName = null) {
 | 
			
		||||
    const mode = main_api === 'openai' ? 'cc' : 'tc';
 | 
			
		||||
    const id = uuidv4();
 | 
			
		||||
    /** @type {ConnectionProfile} */
 | 
			
		||||
    const profile = {
 | 
			
		||||
        id,
 | 
			
		||||
        mode,
 | 
			
		||||
        exclude: [],
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    await readProfileFromCommands(mode, profile);
 | 
			
		||||
 | 
			
		||||
    const profileForDisplay = makeFancyProfile(profile);
 | 
			
		||||
    const template = await renderExtensionTemplateAsync(MODULE_NAME, 'profile', { profile: profileForDisplay });
 | 
			
		||||
    const template = $(await renderExtensionTemplateAsync(MODULE_NAME, 'profile', { profile: profileForDisplay }));
 | 
			
		||||
    template.find('input[name="exclude"]').on('input', function () {
 | 
			
		||||
        const fancyName = String($(this).val());
 | 
			
		||||
        const keyName = Object.entries(FANCY_NAMES).find(x => x[1] === fancyName)?.[0];
 | 
			
		||||
        if (!keyName) {
 | 
			
		||||
            console.warn('Key not found for fancy name:', fancyName);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (!Array.isArray(profile.exclude)) {
 | 
			
		||||
            profile.exclude = [];
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        const excludeState = !$(this).prop('checked');
 | 
			
		||||
        if (excludeState) {
 | 
			
		||||
            profile.exclude.push(keyName);
 | 
			
		||||
        } else {
 | 
			
		||||
            const index = profile.exclude.indexOf(keyName);
 | 
			
		||||
            index !== -1 && profile.exclude.splice(index, 1);
 | 
			
		||||
        }
 | 
			
		||||
    });
 | 
			
		||||
    const isNameTaken = (n) => extension_settings.connectionManager.profiles.some(p => p.name === n);
 | 
			
		||||
    const suggestedName = getUniqueName(collapseSpaces(`${profile.api ?? ''} ${profile.model ?? ''} - ${profile.preset ?? ''}`), isNameTaken);
 | 
			
		||||
    const name = forceName ?? await callGenericPopup(template, POPUP_TYPE.INPUT, suggestedName, { rows: 2 });
 | 
			
		||||
@@ -231,7 +259,13 @@ async function createConnectionProfile(forceName = null) {
 | 
			
		||||
        return null;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    profile.name = name;
 | 
			
		||||
    if (Array.isArray(profile.exclude)) {
 | 
			
		||||
        for (const command of profile.exclude) {
 | 
			
		||||
            delete profile[command];
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    profile.name = String(name);
 | 
			
		||||
    return profile;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -358,7 +392,11 @@ async function renderDetailsContent(detailsContent) {
 | 
			
		||||
    const profile = extension_settings.connectionManager.profiles.find(p => p.id === selectedProfile);
 | 
			
		||||
    if (profile) {
 | 
			
		||||
        const profileForDisplay = makeFancyProfile(profile);
 | 
			
		||||
        const template = await renderExtensionTemplateAsync(MODULE_NAME, 'view', { profile: profileForDisplay });
 | 
			
		||||
        const templateParams = { profile: profileForDisplay };
 | 
			
		||||
        if (Array.isArray(profile.exclude) && profile.exclude.length > 0) {
 | 
			
		||||
            templateParams.omitted = profile.exclude.map(e => FANCY_NAMES[e]).join(', ');
 | 
			
		||||
        }
 | 
			
		||||
        const template = await renderExtensionTemplateAsync(MODULE_NAME, 'view', templateParams);
 | 
			
		||||
        detailsContent.innerHTML = template;
 | 
			
		||||
    } else {
 | 
			
		||||
        detailsContent.textContent = t`No profile selected`;
 | 
			
		||||
@@ -473,29 +511,71 @@ async function renderDetailsContent(detailsContent) {
 | 
			
		||||
        await eventSource.emit(event_types.CONNECTION_PROFILE_LOADED, NONE);
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    const renameButton = document.getElementById('rename_connection_profile');
 | 
			
		||||
    renameButton.addEventListener('click', async () => {
 | 
			
		||||
    const editButton = document.getElementById('edit_connection_profile');
 | 
			
		||||
    editButton.addEventListener('click', async () => {
 | 
			
		||||
        const selectedProfile = extension_settings.connectionManager.selectedProfile;
 | 
			
		||||
        const profile = extension_settings.connectionManager.profiles.find(p => p.id === selectedProfile);
 | 
			
		||||
        if (!profile) {
 | 
			
		||||
            console.log('No profile selected');
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        if (!Array.isArray(profile.exclude)) {
 | 
			
		||||
            profile.exclude = [];
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        let saveChanges = false;
 | 
			
		||||
        const sortByViewOrder = (a, b) => Object.keys(FANCY_NAMES).indexOf(a) - Object.keys(FANCY_NAMES).indexOf(b);
 | 
			
		||||
        const commands = profile.mode === 'cc' ? CC_COMMANDS : TC_COMMANDS;
 | 
			
		||||
        const settings = commands.slice().sort(sortByViewOrder).reduce((acc, command) => {
 | 
			
		||||
            const fancyName = FANCY_NAMES[command];
 | 
			
		||||
            acc[fancyName] = !profile.exclude.includes(command);
 | 
			
		||||
            return acc;
 | 
			
		||||
        }, {});
 | 
			
		||||
        const template = $(await renderExtensionTemplateAsync(MODULE_NAME, 'edit', { name: profile.name, settings }));
 | 
			
		||||
        const newName = await callGenericPopup(template, POPUP_TYPE.INPUT, profile.name, {
 | 
			
		||||
            customButtons: [{
 | 
			
		||||
                text: t`Save and Update`,
 | 
			
		||||
                classes: ['popup-button-ok'],
 | 
			
		||||
                result: POPUP_RESULT.AFFIRMATIVE,
 | 
			
		||||
                action: () => {
 | 
			
		||||
                    saveChanges = true;
 | 
			
		||||
                },
 | 
			
		||||
            }],
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        const newName = await Popup.show.input(t`Enter a new name`, null, profile.name, { rows: 2 });
 | 
			
		||||
        if (!newName) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (extension_settings.connectionManager.profiles.some(p => p.name === newName)) {
 | 
			
		||||
        if (profile.name !== newName && extension_settings.connectionManager.profiles.some(p => p.name === newName)) {
 | 
			
		||||
            toastr.error('A profile with the same name already exists.');
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        profile.name = newName;
 | 
			
		||||
        const newExcludeList = template.find('input[name="exclude"]:not(:checked)').map(function () {
 | 
			
		||||
            return Object.entries(FANCY_NAMES).find(x => x[1] === String($(this).val()))?.[0];
 | 
			
		||||
        }).get();
 | 
			
		||||
 | 
			
		||||
        if (newExcludeList.length !== profile.exclude.length || !newExcludeList.every(e => profile.exclude.includes(e))) {
 | 
			
		||||
            profile.exclude = newExcludeList;
 | 
			
		||||
            for (const command of newExcludeList) {
 | 
			
		||||
                delete profile[command];
 | 
			
		||||
            }
 | 
			
		||||
            if (saveChanges) {
 | 
			
		||||
                await updateConnectionProfile(profile);
 | 
			
		||||
            } else {
 | 
			
		||||
                toastr.info('Press "Update" to record them into the profile.', 'Included settings list updated');
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (profile.name !== newName) {
 | 
			
		||||
            toastr.success('Connection profile renamed.');
 | 
			
		||||
            profile.name = String(newName);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        saveSettingsDebounced();
 | 
			
		||||
        renderConnectionProfiles(profiles);
 | 
			
		||||
        toastr.success('Connection profile renamed', '', { timeOut: 1500 });
 | 
			
		||||
        await renderDetailsContent(detailsContent);
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    /** @type {HTMLElement} */
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user