添加整体复制按钮
This commit is contained in:
parent
87f629bb37
commit
5b231e0170
2
main.py
2
main.py
@ -266,7 +266,7 @@ def main():
|
|||||||
cookies.update({'uuid': uuid.uuid4()})
|
cookies.update({'uuid': uuid.uuid4()})
|
||||||
return cookies
|
return cookies
|
||||||
demo.load(init_cookie, inputs=[cookies, chatbot], outputs=[cookies])
|
demo.load(init_cookie, inputs=[cookies, chatbot], outputs=[cookies])
|
||||||
demo.load(lambda: 0, inputs=None, outputs=None, _js='()=>{ChatBotHeight();}')
|
demo.load(lambda: 0, inputs=None, outputs=None, _js='()=>{GptAcademicJavaScriptInit();}')
|
||||||
|
|
||||||
# gradio的inbrowser触发不太稳定,回滚代码到原始的浏览器打开函数
|
# gradio的inbrowser触发不太稳定,回滚代码到原始的浏览器打开函数
|
||||||
def auto_opentab_delay():
|
def auto_opentab_delay():
|
||||||
|
@ -125,6 +125,7 @@ model_info = {
|
|||||||
"tokenizer": tokenizer_gpt4,
|
"tokenizer": tokenizer_gpt4,
|
||||||
"token_cnt": get_token_num_gpt4,
|
"token_cnt": get_token_num_gpt4,
|
||||||
},
|
},
|
||||||
|
|
||||||
"gpt-4-32k": {
|
"gpt-4-32k": {
|
||||||
"fn_with_ui": chatgpt_ui,
|
"fn_with_ui": chatgpt_ui,
|
||||||
"fn_without_ui": chatgpt_noui,
|
"fn_without_ui": chatgpt_noui,
|
||||||
@ -133,6 +134,7 @@ model_info = {
|
|||||||
"tokenizer": tokenizer_gpt4,
|
"tokenizer": tokenizer_gpt4,
|
||||||
"token_cnt": get_token_num_gpt4,
|
"token_cnt": get_token_num_gpt4,
|
||||||
},
|
},
|
||||||
|
|
||||||
# azure openai
|
# azure openai
|
||||||
"azure-gpt-3.5":{
|
"azure-gpt-3.5":{
|
||||||
"fn_with_ui": chatgpt_ui,
|
"fn_with_ui": chatgpt_ui,
|
||||||
|
@ -23,4 +23,30 @@
|
|||||||
/* status bar height */
|
/* status bar height */
|
||||||
.min.svelte-1yrv54 {
|
.min.svelte-1yrv54 {
|
||||||
min-height: var(--size-12);
|
min-height: var(--size-12);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* copy btn */
|
||||||
|
.message-btn-row {
|
||||||
|
width: 19px;
|
||||||
|
height: 19px;
|
||||||
|
position: absolute;
|
||||||
|
left: calc(100% + 3px);
|
||||||
|
top: 0;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
/* .message-btn-row-leading, .message-btn-row-trailing {
|
||||||
|
display: inline-flex;
|
||||||
|
gap: 4px;
|
||||||
|
} */
|
||||||
|
.message-btn-row button {
|
||||||
|
font-size: 18px;
|
||||||
|
align-self: center;
|
||||||
|
align-items: center;
|
||||||
|
flex-wrap: nowrap;
|
||||||
|
white-space: nowrap;
|
||||||
|
display: inline-flex;
|
||||||
|
flex-direction: row;
|
||||||
|
gap: 4px;
|
||||||
|
padding-block: 2px !important;
|
||||||
|
}
|
||||||
|
@ -1,4 +1,85 @@
|
|||||||
function ChatBotHeight() {
|
function gradioApp() {
|
||||||
|
// https://github.com/GaiZhenbiao/ChuanhuChatGPT/tree/main/web_assets/javascript
|
||||||
|
const elems = document.getElementsByTagName('gradio-app');
|
||||||
|
const elem = elems.length == 0 ? document : elems[0];
|
||||||
|
if (elem !== document) {
|
||||||
|
elem.getElementById = function(id) {
|
||||||
|
return document.getElementById(id);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return elem.shadowRoot ? elem.shadowRoot : elem;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const copiedIcon = '<span><svg stroke="currentColor" fill="none" stroke-width="2" viewBox="0 0 24 24" stroke-linecap="round" stroke-linejoin="round" height=".8em" width=".8em" xmlns="http://www.w3.org/2000/svg"><polyline points="20 6 9 17 4 12"></polyline></svg></span>';
|
||||||
|
const copyIcon = '<span><svg stroke="currentColor" fill="none" stroke-width="2" viewBox="0 0 24 24" stroke-linecap="round" stroke-linejoin="round" height=".8em" width=".8em" xmlns="http://www.w3.org/2000/svg"><rect x="9" y="9" width="13" height="13" rx="2" ry="2"></rect><path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"></path></svg></span>';
|
||||||
|
|
||||||
|
|
||||||
|
function addCopyButton(botElement) {
|
||||||
|
// https://github.com/GaiZhenbiao/ChuanhuChatGPT/tree/main/web_assets/javascript
|
||||||
|
// Copy bot button
|
||||||
|
const messageBtnColumnElement = botElement.querySelector('.message-btn-row');
|
||||||
|
if (messageBtnColumnElement) {
|
||||||
|
// Do something if .message-btn-column exists, for example, remove it
|
||||||
|
// messageBtnColumnElement.remove();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var copyButton = document.createElement('button');
|
||||||
|
copyButton.classList.add('copy-bot-btn');
|
||||||
|
copyButton.setAttribute('aria-label', 'Copy');
|
||||||
|
copyButton.innerHTML = copyIcon;
|
||||||
|
copyButton.addEventListener('click', async () => {
|
||||||
|
const textToCopy = botElement.innerText;
|
||||||
|
try {
|
||||||
|
if ("clipboard" in navigator) {
|
||||||
|
await navigator.clipboard.writeText(textToCopy);
|
||||||
|
copyButton.innerHTML = copiedIcon;
|
||||||
|
setTimeout(() => {
|
||||||
|
copyButton.innerHTML = copyIcon;
|
||||||
|
}, 1500);
|
||||||
|
} else {
|
||||||
|
const textArea = document.createElement("textarea");
|
||||||
|
textArea.value = textToCopy;
|
||||||
|
document.body.appendChild(textArea);
|
||||||
|
textArea.select();
|
||||||
|
try {
|
||||||
|
document.execCommand('copy');
|
||||||
|
copyButton.innerHTML = copiedIcon;
|
||||||
|
setTimeout(() => {
|
||||||
|
copyButton.innerHTML = copyIcon;
|
||||||
|
}, 1500);
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Copy failed: ", error);
|
||||||
|
}
|
||||||
|
document.body.removeChild(textArea);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Copy failed: ", error);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var messageBtnColumn = document.createElement('div');
|
||||||
|
messageBtnColumn.classList.add('message-btn-row');
|
||||||
|
messageBtnColumn.appendChild(copyButton);
|
||||||
|
botElement.appendChild(messageBtnColumn);
|
||||||
|
}
|
||||||
|
|
||||||
|
function chatbotContentChanged(attempt = 1, force = false) {
|
||||||
|
// https://github.com/GaiZhenbiao/ChuanhuChatGPT/tree/main/web_assets/javascript
|
||||||
|
for (var i = 0; i < attempt; i++) {
|
||||||
|
setTimeout(() => {
|
||||||
|
gradioApp().querySelectorAll('#gpt-chatbot .message-wrap .message.bot').forEach(addCopyButton);
|
||||||
|
}, i === 0 ? 0 : 200);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function GptAcademicJavaScriptInit() {
|
||||||
|
chatbotIndicator = gradioApp().querySelector('#gpt-chatbot > div.wrap');
|
||||||
|
var chatbotObserver = new MutationObserver(() => {
|
||||||
|
chatbotContentChanged(1);
|
||||||
|
});
|
||||||
|
chatbotObserver.observe(chatbotIndicator, { attributes: true, childList: true, subtree: true });
|
||||||
|
|
||||||
function update_height(){
|
function update_height(){
|
||||||
var { panel_height_target, chatbot_height, chatbot } = get_elements(true);
|
var { panel_height_target, chatbot_height, chatbot } = get_elements(true);
|
||||||
if (panel_height_target!=chatbot_height)
|
if (panel_height_target!=chatbot_height)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user