mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-06-05 21:59:27 +02:00
#2192 Fix order of events in TTS/translate interaction
This commit is contained in:
@@ -42,6 +42,46 @@ EventEmitter.prototype.on = function (event, listener) {
|
|||||||
this.events[event].push(listener);
|
this.events[event].push(listener);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes the listener the last to be called when the event is emitted
|
||||||
|
* @param {string} event Event name
|
||||||
|
* @param {function} listener Event listener
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.makeLast = function (event, listener) {
|
||||||
|
if (typeof this.events[event] !== 'object') {
|
||||||
|
this.events[event] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
const events = this.events[event];
|
||||||
|
const idx = events.indexOf(listener);
|
||||||
|
|
||||||
|
if (idx > -1) {
|
||||||
|
events.splice(idx, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
events.push(listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes the listener the first to be called when the event is emitted
|
||||||
|
* @param {string} event Event name
|
||||||
|
* @param {function} listener Event listener
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.makeFirst = function (event, listener) {
|
||||||
|
if (typeof this.events[event] !== 'object') {
|
||||||
|
this.events[event] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
const events = this.events[event];
|
||||||
|
const idx = events.indexOf(listener);
|
||||||
|
|
||||||
|
if (idx > -1) {
|
||||||
|
events.splice(idx, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
events.unshift(listener);
|
||||||
|
}
|
||||||
|
|
||||||
EventEmitter.prototype.removeListener = function (event, listener) {
|
EventEmitter.prototype.removeListener = function (event, listener) {
|
||||||
var idx;
|
var idx;
|
||||||
|
|
||||||
|
@@ -642,9 +642,9 @@ jQuery(() => {
|
|||||||
|
|
||||||
loadSettings();
|
loadSettings();
|
||||||
|
|
||||||
eventSource.on(event_types.CHARACTER_MESSAGE_RENDERED, handleIncomingMessage);
|
eventSource.makeFirst(event_types.CHARACTER_MESSAGE_RENDERED, handleIncomingMessage);
|
||||||
|
eventSource.makeFirst(event_types.USER_MESSAGE_RENDERED, handleOutgoingMessage);
|
||||||
eventSource.on(event_types.MESSAGE_SWIPED, handleIncomingMessage);
|
eventSource.on(event_types.MESSAGE_SWIPED, handleIncomingMessage);
|
||||||
eventSource.on(event_types.USER_MESSAGE_RENDERED, handleOutgoingMessage);
|
|
||||||
eventSource.on(event_types.IMPERSONATE_READY, handleImpersonateReady);
|
eventSource.on(event_types.IMPERSONATE_READY, handleImpersonateReady);
|
||||||
eventSource.on(event_types.MESSAGE_EDITED, handleMessageEdit);
|
eventSource.on(event_types.MESSAGE_EDITED, handleMessageEdit);
|
||||||
|
|
||||||
|
@@ -1063,8 +1063,8 @@ $(document).ready(function () {
|
|||||||
eventSource.on(event_types.CHAT_CHANGED, onChatChanged);
|
eventSource.on(event_types.CHAT_CHANGED, onChatChanged);
|
||||||
eventSource.on(event_types.MESSAGE_DELETED, onMessageDeleted);
|
eventSource.on(event_types.MESSAGE_DELETED, onMessageDeleted);
|
||||||
eventSource.on(event_types.GROUP_UPDATED, onChatChanged);
|
eventSource.on(event_types.GROUP_UPDATED, onChatChanged);
|
||||||
eventSource.on(event_types.MESSAGE_SENT, onMessageEvent);
|
eventSource.makeLast(event_types.CHARACTER_MESSAGE_RENDERED, onMessageEvent);
|
||||||
eventSource.on(event_types.MESSAGE_RECEIVED, onMessageEvent);
|
eventSource.makeLast(event_types.USER_MESSAGE_RENDERED, onMessageEvent);
|
||||||
SlashCommandParser.addCommandObject(SlashCommand.fromProps({ name: 'speak',
|
SlashCommandParser.addCommandObject(SlashCommand.fromProps({ name: 'speak',
|
||||||
callback: onNarrateText,
|
callback: onNarrateText,
|
||||||
aliases: ['narrate', 'tts'],
|
aliases: ['narrate', 'tts'],
|
||||||
|
Reference in New Issue
Block a user