mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-01-23 07:51:18 +01:00
Add /profile-get command
This commit is contained in:
parent
065daa7599
commit
4fd7828a9b
@ -74,6 +74,31 @@ const escapeArgument = (a) => a.replace(/"/g, '\\"').replace(/\|/g, '\\|');
|
|||||||
const collapseSpaces = (s) => s.replace(/\s+/g, ' ').trim();
|
const collapseSpaces = (s) => s.replace(/\s+/g, ' ').trim();
|
||||||
const makeUnique = (s, f, i) => { if (!f(s)) { return s; } else { while (f(`${s} (${i})`)) { i++; } return `${s} (${i})`; } };
|
const makeUnique = (s, f, i) => { if (!f(s)) { return s; } else { while (f(`${s} (${i})`)) { i++; } return `${s} (${i})`; } };
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finds the best match for the search value.
|
||||||
|
* @param {string} value Search value
|
||||||
|
* @returns {ConnectionProfile|null} Best match or null
|
||||||
|
*/
|
||||||
|
function findProfileByName(value) {
|
||||||
|
// Try to find exact match
|
||||||
|
const profile = extension_settings.connectionManager.profiles.find(p => p.name === value);
|
||||||
|
|
||||||
|
if (profile) {
|
||||||
|
return profile;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to find fuzzy match
|
||||||
|
const fuse = new Fuse(extension_settings.connectionManager.profiles, { keys: ['name'] });
|
||||||
|
const results = fuse.search(value);
|
||||||
|
|
||||||
|
if (results.length === 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
const bestMatch = results[0];
|
||||||
|
return bestMatch.item;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reads the connection profile from the commands.
|
* Reads the connection profile from the commands.
|
||||||
* @param {string} mode Mode of the connection profile
|
* @param {string} mode Mode of the connection profile
|
||||||
@ -374,27 +399,16 @@ async function renderDetailsContent(details, detailsContent) {
|
|||||||
return NONE;
|
return NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try to find exact match
|
const profile = findProfileByName(value);
|
||||||
const profile = extension_settings.connectionManager.profiles.find(p => p.name === value);
|
|
||||||
|
|
||||||
if (profile) {
|
if (!profile) {
|
||||||
profiles.selectedIndex = Array.from(profiles.options).findIndex(o => o.value === profile.id);
|
|
||||||
profiles.dispatchEvent(new Event('change'));
|
|
||||||
return profile.name;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Try to find fuzzy match
|
|
||||||
const fuse = new Fuse(extension_settings.connectionManager.profiles, { keys: ['name'] });
|
|
||||||
const results = fuse.search(value);
|
|
||||||
|
|
||||||
if (results.length === 0) {
|
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
const bestMatch = results[0];
|
profiles.selectedIndex = Array.from(profiles.options).findIndex(o => o.value === profile.id);
|
||||||
profiles.value = bestMatch.item.id;
|
|
||||||
profiles.dispatchEvent(new Event('change'));
|
profiles.dispatchEvent(new Event('change'));
|
||||||
return bestMatch.item.name;
|
|
||||||
|
return profiles.name;
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@ -448,4 +462,33 @@ async function renderDetailsContent(details, detailsContent) {
|
|||||||
saveSettingsDebounced();
|
saveSettingsDebounced();
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
SlashCommandParser.addCommandObject(SlashCommand.fromProps({
|
||||||
|
name: 'profile-get',
|
||||||
|
helpString: 'Get the details of the connection profile. Returns the selected profile if no argument is provided.',
|
||||||
|
returns: 'object of the selected profile',
|
||||||
|
unnamedArgumentList: [
|
||||||
|
SlashCommandArgument.fromProps({
|
||||||
|
description: 'Name of the connection profile',
|
||||||
|
enumProvider: profilesProvider,
|
||||||
|
isRequired: false,
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
callback: async (_args, value) => {
|
||||||
|
if (!value || typeof value !== 'string') {
|
||||||
|
const selectedProfile = extension_settings.connectionManager.selectedProfile;
|
||||||
|
const profile = extension_settings.connectionManager.profiles.find(p => p.id === selectedProfile);
|
||||||
|
if (!profile) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
return JSON.stringify(profile);
|
||||||
|
}
|
||||||
|
|
||||||
|
const profile = findProfileByName(value);
|
||||||
|
if (!profile) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
return JSON.stringify(profile);
|
||||||
|
},
|
||||||
|
}));
|
||||||
})();
|
})();
|
||||||
|
Loading…
Reference in New Issue
Block a user