From dbb7a51aee71d956ddbbf966b1c17ca906feff63 Mon Sep 17 00:00:00 2001 From: Dele Olajide Date: Fri, 18 Oct 2024 18:40:58 +0100 Subject: [PATCH] implement chat summary with llama --- docs/index.js | 69 ++++++++++++++++++++++++++++++++++++++-- docs/manifest.json | 2 +- docs/options/manifest.js | 8 +++++ docs/options/settings.js | 1 + 4 files changed, 77 insertions(+), 3 deletions(-) diff --git a/docs/index.js b/docs/index.js index 3268d462..70b50d3f 100644 --- a/docs/index.js +++ b/docs/index.js @@ -1038,10 +1038,11 @@ function setupPadeRoot() { _converse.api.listen.on('getMessageActionButtons', (el, buttons) => { if (el.model.get('body')) { - buttons.push({'i18n_text': __('Pin'), 'handler': ev => handlePinAction(el), 'button_class': 'chat-msg__action-pin', 'icon_class': 'fa fa-paperclip', 'name': 'pade-pin'}); + buttons.push({'i18n_text': __('Pin'), 'handler': ev => handlePinAction(el), 'button_class': 'chat-msg__action-pin', 'icon_class': 'fa fa-paperclip', 'name': 'pade-pin'}); buttons.push({'i18n_text': __('Reply'), 'handler': ev => handleReplyAction(el), 'button_class': 'chat-msg__action-reply', 'icon_class': 'fas fa-arrow-left', 'name': 'pade-reply'}); buttons.push({'i18n_text': __('Like'), 'handler': ev => handleReactionAction(el.model, ':smiley:'), 'button_class': 'chat-msg__action-thumbsup', 'icon_class': 'fa fa-check', 'name': 'pade-thumbsup'}); buttons.push({'i18n_text': __('Dislike'), 'handler': ev => handleReactionAction(el.model, ':disappointed:'), 'button_class': 'chat-msg__action-thumbsdownp', 'icon_class': 'fa fa-times', 'name': 'pade-thumbsdown'}); + buttons.push({'i18n_text': __('Summarize'), 'handler': ev => handleSummarizeAction(el), 'button_class': 'chat-msg__action-summarize', 'icon_class': 'fa fa-info-circle', 'name': 'pade-summarize'}); } return buttons; }); @@ -1703,6 +1704,71 @@ function handleReplyAction(el) { replyChat(el.model, prefix + ' : ' + selectedText); } +function handleSummarizeAction(el) { + const timestamp = el.model.get('time'); + const timeAgo = timeago.format(new Date(timestamp)); + const msgId = el.model.get('msgid'); + const messages = el.model.collection.models; + console.debug('handleSummarizeAction', el.model, timestamp, timeAgo, msgId, messages); + + let firstMsg = 0; + const msg = document.querySelector('[data-msgid="' + msgId + '"]'); + + for (let i=0; i')) { + detail = detail + pretty_from + ": " + body + "\n"; + } + } + + const llama = _converse.roster.findWhere({'jid': "llama@pade.chat"}); + + if (llama) { + const llamaJid = getSetting("llamaAddress", "llama@" + _converse.connection.domain) + "/" + llama.presence.resources.models[0].get('name'); + const promptText = "summarize this:" + "\n\n" + detail; + console.debug("handleSummarizeAction summary text\n", promptText, llamaJid); + + const stanza = $iq({'to': llamaJid, 'from': _converse.connection.jid, 'type': 'get'}).c('query', { 'xmlns': "urn:xmpp:gen-ai:0"}).t(promptText); + + _converse.connection.sendIQ(stanza, function(iq) { + const response = iq.querySelector('response')?.innerHTML; + console.debug("handleSummarizeAction response", response, iq); + injectMessage(el.model.chatbox, "Summary from " + timeAgo, response); + + }, function(error){ + console.error("handleSummarizeAction error", error); + }); + } +} + +function injectMessage(model, title, body) { + const msgId = 'inject-' + Math.random().toString(36).substr(2,9); + const type = model.get("type") == "chatbox" ? "chat" : "groupchat"; + const from = model.get("jid"); + + let attrs = {message: body, body, id: msgId, msgId, type, from: _converse.jid}; + + if (type == "groupchat") { + attrs = {message: body, body, id: msgId, msgId, type, from_muc: from, from: from + '/' + title, nick: title}; + } + + model.queueMessage(attrs); +} + function handlePinAction(el) { const msgId = el.model.get('msgid'); const message = el.model.get('message'); @@ -1780,7 +1846,6 @@ function getSelectedChatBox() { return view; } - function replyInverseChat(text) { var box = getSelectedChatBox(); diff --git a/docs/manifest.json b/docs/manifest.json index f10d96ee..729b58a5 100644 --- a/docs/manifest.json +++ b/docs/manifest.json @@ -3,7 +3,7 @@ "short_name": "__MSG_manifest_shortExtensionName__", "name": "__MSG_manifest_extensionName__", "description": "__MSG_manifest_extensionDescription__", - "version": "2.1.11", + "version": "2.1.12", "homepage_url": "https://igniterealtime.github.io/openfire-pade-plugin/help/", "manifest_version": 3, "permissions": [ diff --git a/docs/options/manifest.js b/docs/options/manifest.js index 2c1e7506..52ff99dd 100644 --- a/docs/options/manifest.js +++ b/docs/options/manifest.js @@ -288,6 +288,14 @@ this.manifest = { "type": "checkbox", "label": i18n.get("Open auto-start windows minimized") }, + { + "tab": i18n.get("General"), + "group": i18n.get("Preferences"), + "name": "llamaAddress", + "type": "text", + "text": i18n.get("Enter xmpp address for LLaMA AI Assistant"), + "label": i18n.get("LLaMA Address") + }, { "tab": i18n.get("General"), "group": i18n.get("Fastpath (Workgroups)"), diff --git a/docs/options/settings.js b/docs/options/settings.js index 1c1c29f6..9ae468bd 100644 --- a/docs/options/settings.js +++ b/docs/options/settings.js @@ -505,6 +505,7 @@ function doDefaults(background) setDefaultSetting("renderMedia", true); setDefaultSetting("notifyAllMessages", true); setDefaultSetting("useUpDownCursorKeys", true); + setDefaultSetting("llamaAddress", "llama@pade.chat"); // config setDefaultSetting("startBitrate", 800);