2023-08-30 02:15:03 -04:00
|
|
|
import Component from "@glimmer/component";
|
2024-05-14 03:54:54 -04:00
|
|
|
import { tracked } from "@glimmer/tracking";
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
import { hash } from "@ember/helper";
|
2024-05-14 03:54:54 -04:00
|
|
|
import { next } from "@ember/runloop";
|
2023-08-30 02:15:03 -04:00
|
|
|
import { inject as service } from "@ember/service";
|
2023-11-21 02:02:27 -05:00
|
|
|
import KeyValueStore from "discourse/lib/key-value-store";
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
import DropdownSelectBox from "select-kit/components/dropdown-select-box";
|
2023-08-30 02:15:03 -04:00
|
|
|
|
|
|
|
function isBotMessage(composer, currentUser) {
|
|
|
|
if (
|
|
|
|
composer &&
|
|
|
|
composer.targetRecipients &&
|
|
|
|
currentUser.ai_enabled_chat_bots
|
|
|
|
) {
|
|
|
|
const reciepients = composer.targetRecipients.split(",");
|
|
|
|
|
2024-06-19 09:16:00 -04:00
|
|
|
return currentUser.ai_enabled_chat_bots
|
2024-10-24 15:24:53 -04:00
|
|
|
.filter((bot) => bot.username)
|
2024-06-19 09:16:00 -04:00
|
|
|
.any((bot) => reciepients.any((username) => username === bot.username));
|
2023-08-30 02:15:03 -04:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class BotSelector extends Component {
|
|
|
|
static shouldRender(args, container) {
|
|
|
|
return (
|
|
|
|
container?.currentUser?.ai_enabled_personas &&
|
|
|
|
isBotMessage(args.model, container.currentUser)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
@service currentUser;
|
2024-05-14 03:54:54 -04:00
|
|
|
@service siteSettings;
|
|
|
|
@tracked llm;
|
2024-10-15 16:20:31 -04:00
|
|
|
@tracked allowLLMSelector = true;
|
2023-11-21 02:02:27 -05:00
|
|
|
|
|
|
|
STORE_NAMESPACE = "discourse_ai_persona_selector_";
|
2024-05-14 03:54:54 -04:00
|
|
|
LLM_STORE_NAMESPACE = "discourse_ai_llm_selector_";
|
|
|
|
|
2023-11-21 02:02:27 -05:00
|
|
|
preferredPersonaStore = new KeyValueStore(this.STORE_NAMESPACE);
|
2024-05-14 03:54:54 -04:00
|
|
|
preferredLlmStore = new KeyValueStore(this.LLM_STORE_NAMESPACE);
|
2023-11-21 02:02:27 -05:00
|
|
|
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
constructor() {
|
|
|
|
super(...arguments);
|
2023-11-21 02:02:27 -05:00
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
if (this.botOptions && this.botOptions.length && this.composer) {
|
2023-11-24 02:08:08 -05:00
|
|
|
let personaId = this.preferredPersonaStore.getObject("id");
|
|
|
|
|
|
|
|
this._value = this.botOptions[0].id;
|
2023-11-21 02:02:27 -05:00
|
|
|
if (personaId) {
|
2023-11-24 02:08:08 -05:00
|
|
|
personaId = parseInt(personaId, 10);
|
|
|
|
if (this.botOptions.any((bot) => bot.id === personaId)) {
|
|
|
|
this._value = personaId;
|
|
|
|
}
|
2023-11-21 02:02:27 -05:00
|
|
|
}
|
|
|
|
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
this.composer.metaData = { ai_persona_id: this._value };
|
2024-10-15 16:20:31 -04:00
|
|
|
this.setAllowLLMSelector();
|
2024-05-14 03:54:54 -04:00
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
if (this.hasLlmSelector) {
|
|
|
|
let llm = this.preferredLlmStore.getObject("id");
|
2024-10-21 20:16:02 -04:00
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
const llmOption =
|
|
|
|
this.llmOptions.find((innerLlmOption) => innerLlmOption.id === llm) ||
|
|
|
|
this.llmOptions[0];
|
2024-10-21 20:16:02 -04:00
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
if (llmOption) {
|
|
|
|
llm = llmOption.id;
|
|
|
|
} else {
|
|
|
|
llm = "";
|
|
|
|
}
|
2024-10-21 20:16:02 -04:00
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
if (llm) {
|
|
|
|
next(() => {
|
|
|
|
this.currentLlm = llm;
|
|
|
|
});
|
|
|
|
}
|
2024-05-14 03:54:54 -04:00
|
|
|
}
|
2024-10-24 15:24:53 -04:00
|
|
|
|
|
|
|
next(() => {
|
|
|
|
this.resetTargetRecipients();
|
|
|
|
});
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
}
|
|
|
|
}
|
2023-08-30 02:15:03 -04:00
|
|
|
|
|
|
|
get composer() {
|
|
|
|
return this.args?.outletArgs?.model;
|
|
|
|
}
|
|
|
|
|
2024-10-24 15:24:53 -04:00
|
|
|
get hasLlmSelector() {
|
|
|
|
return this.currentUser.ai_enabled_chat_bots.any((bot) => !bot.is_persona);
|
|
|
|
}
|
|
|
|
|
2023-08-30 02:15:03 -04:00
|
|
|
get botOptions() {
|
|
|
|
if (this.currentUser.ai_enabled_personas) {
|
2024-10-24 15:24:53 -04:00
|
|
|
let enabledPersonas = this.currentUser.ai_enabled_personas;
|
|
|
|
|
|
|
|
if (!this.hasLlmSelector) {
|
|
|
|
enabledPersonas = enabledPersonas.filter((persona) => persona.username);
|
|
|
|
}
|
|
|
|
|
|
|
|
return enabledPersonas.map((persona) => {
|
2023-08-30 02:15:03 -04:00
|
|
|
return {
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
id: persona.id,
|
2023-08-30 02:15:03 -04:00
|
|
|
name: persona.name,
|
|
|
|
description: persona.description,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-30 16:29:10 -05:00
|
|
|
get filterable() {
|
|
|
|
return this.botOptions.length > 4;
|
|
|
|
}
|
|
|
|
|
2023-08-30 02:15:03 -04:00
|
|
|
get value() {
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
return this._value;
|
2023-08-30 02:15:03 -04:00
|
|
|
}
|
|
|
|
|
2023-11-21 02:02:27 -05:00
|
|
|
set value(newValue) {
|
|
|
|
this._value = newValue;
|
|
|
|
this.preferredPersonaStore.setObject({ key: "id", value: newValue });
|
|
|
|
this.composer.metaData = { ai_persona_id: newValue };
|
2024-10-15 16:20:31 -04:00
|
|
|
this.setAllowLLMSelector();
|
2024-10-21 20:16:02 -04:00
|
|
|
this.resetTargetRecipients();
|
2024-10-15 16:20:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
setAllowLLMSelector() {
|
2024-10-24 15:24:53 -04:00
|
|
|
if (!this.hasLlmSelector) {
|
|
|
|
this.allowLLMSelector = false;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-10-15 16:20:31 -04:00
|
|
|
const persona = this.currentUser.ai_enabled_personas.find(
|
|
|
|
(innerPersona) => innerPersona.id === this._value
|
|
|
|
);
|
|
|
|
|
|
|
|
this.allowLLMSelector = !persona?.force_default_llm;
|
2023-08-30 02:15:03 -04:00
|
|
|
}
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
|
2024-05-14 03:54:54 -04:00
|
|
|
get currentLlm() {
|
|
|
|
return this.llm;
|
|
|
|
}
|
|
|
|
|
|
|
|
set currentLlm(newValue) {
|
|
|
|
this.llm = newValue;
|
|
|
|
this.preferredLlmStore.setObject({ key: "id", value: newValue });
|
2024-10-21 20:16:02 -04:00
|
|
|
|
|
|
|
this.resetTargetRecipients();
|
|
|
|
}
|
|
|
|
|
|
|
|
resetTargetRecipients() {
|
2024-10-15 16:20:31 -04:00
|
|
|
if (this.allowLLMSelector) {
|
2024-10-21 20:16:02 -04:00
|
|
|
const botUsername = this.currentUser.ai_enabled_chat_bots.find(
|
|
|
|
(bot) => bot.model_name === this.llm
|
|
|
|
).username;
|
2024-10-15 16:20:31 -04:00
|
|
|
this.composer.set("targetRecipients", botUsername);
|
|
|
|
} else {
|
|
|
|
const persona = this.currentUser.ai_enabled_personas.find(
|
|
|
|
(innerPersona) => innerPersona.id === this._value
|
|
|
|
);
|
|
|
|
this.composer.set("targetRecipients", persona.username || "");
|
|
|
|
}
|
2024-05-14 03:54:54 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
get llmOptions() {
|
2024-06-18 13:32:14 -04:00
|
|
|
const availableBots = this.currentUser.ai_enabled_chat_bots
|
2024-06-19 09:16:00 -04:00
|
|
|
.filter((bot) => !bot.is_persona)
|
2024-06-18 13:32:14 -04:00
|
|
|
.filter(Boolean);
|
|
|
|
|
|
|
|
return availableBots.map((bot) => {
|
|
|
|
return {
|
|
|
|
id: bot.model_name,
|
|
|
|
name: bot.display_name,
|
|
|
|
};
|
|
|
|
});
|
2024-05-14 03:54:54 -04:00
|
|
|
}
|
|
|
|
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
<template>
|
2024-05-14 03:54:54 -04:00
|
|
|
<div class="persona-llm-selector">
|
|
|
|
<div class="gpt-persona">
|
|
|
|
<DropdownSelectBox
|
|
|
|
class="persona-llm-selector__persona-dropdown"
|
|
|
|
@value={{this.value}}
|
|
|
|
@content={{this.botOptions}}
|
|
|
|
@options={{hash icon="robot" filterable=this.filterable}}
|
|
|
|
/>
|
|
|
|
</div>
|
2024-10-15 16:20:31 -04:00
|
|
|
{{#if this.allowLLMSelector}}
|
|
|
|
<div class="llm-selector">
|
|
|
|
<DropdownSelectBox
|
|
|
|
class="persona-llm-selector__llm-dropdown"
|
|
|
|
@value={{this.currentLlm}}
|
|
|
|
@content={{this.llmOptions}}
|
|
|
|
@options={{hash icon="globe"}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
{{/if}}
|
FEATURE: UI to update ai personas on admin page (#290)
Introduces a UI to manage customizable personas (admin only feature)
Part of the change was some extensive internal refactoring:
- AIBot now has a persona set in the constructor, once set it never changes
- Command now takes in bot as a constructor param, so it has the correct persona and is not generating AIBot objects on the fly
- Added a .prettierignore file, due to the way ALE is configured in nvim it is a pre-req for prettier to work
- Adds a bunch of validations on the AIPersona model, system personas (artist/creative etc...) are all seeded. We now ensure
- name uniqueness, and only allow certain properties to be touched for system personas.
- (JS note) the client side design takes advantage of nested routes, the parent route for personas gets all the personas via this.store.findAll("ai-persona") then child routes simply reach into this model to find a particular persona.
- (JS note) data is sideloaded into the ai-persona model the meta property supplied from the controller, resultSetMeta
- This removes ai_bot_enabled_personas and ai_bot_enabled_chat_commands, both should be controlled from the UI on a per persona basis
- Fixes a long standing bug in token accounting ... we were doing to_json.length instead of to_json.to_s.length
- Amended it so {commands} are always inserted at the end unconditionally, no need to add it to the template of the system message as it just confuses things
- Adds a concept of required_commands to stock personas, these are commands that must be configured for this stock persona to show up.
- Refactored tests so we stop requiring inference_stubs, it was very confusing to need it, added to plugin.rb for now which at least is clearer
- Migrates the persona selector to gjs
---------
Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
Co-authored-by: Martin Brennan <martin@discourse.org>
2023-11-21 00:56:43 -05:00
|
|
|
</div>
|
|
|
|
</template>
|
2023-08-30 02:15:03 -04:00
|
|
|
}
|