This commit is contained in:
Saifeddine ALOUI 2023-06-16 21:13:12 +02:00
commit 4ea5d28dd4
3 changed files with 146 additions and 22 deletions

View File

@ -19,7 +19,7 @@
</p> --> </p> -->
</div> </div>
<div class="text-sm text-gray-400 font-thin" v-if="message.created_at" :title="message.created_at"> <div class="text-sm text-gray-400 font-thin" v-if="message.created_at" :title="'Created at: '+created_at_parsed">
{{ created_at }} {{ created_at }}
</div> </div>
@ -105,6 +105,8 @@
<p v-if="message.binding">Binding: <span class="font-thin">{{ message.binding }}</span></p> <p v-if="message.binding">Binding: <span class="font-thin">{{ message.binding }}</span></p>
<p v-if="message.model">Model: <span class="font-thin">{{ message.model }}</span></p> <p v-if="message.model">Model: <span class="font-thin">{{ message.model }}</span></p>
<p v-if="message.seed">Seed: <span class="font-thin">{{ message.seed }}</span></p> <p v-if="message.seed">Seed: <span class="font-thin">{{ message.seed }}</span></p>
<p v-if="message.finished_generating_at">Time spent: <span class="font-thin"
:title="'Finished generating: '+finished_generating_at_parsed">{{ time_spent }}</span></p>
</div> </div>
</div> </div>
@ -174,7 +176,7 @@ export default {
this.expanded = !this.expanded; this.expanded = !this.expanded;
}, },
copyContentToClipboard() { copyContentToClipboard() {
this.$emit('copy', this.message.content) this.$emit('copy', this)
}, },
deleteMsg() { deleteMsg() {
@ -307,6 +309,54 @@ export default {
created_at() { created_at() {
return this.prettyDate(this.message.created_at) return this.prettyDate(this.message.created_at)
},
created_at_parsed() {
return new Date(Date.parse(this.message.created_at)).toLocaleString()
},
finished_generating_at_parsed() {
return new Date(Date.parse(this.message.finished_generating_at)).toLocaleString()
},
time_spent() {
const startTime = new Date(Date.parse(this.message.created_at))
const endTime = new Date(Date.parse(this.message.finished_generating_at))
//const spentTime = new Date(endTime - startTime)
let timeDiff = endTime.getTime() - startTime.getTime();
const hours = Math.floor(timeDiff / (1000 * 60 * 60));
timeDiff -= hours * (1000 * 60 * 60);
const mins = Math.floor(timeDiff / (1000 * 60));
timeDiff -= mins * (1000 * 60);
const secs = Math.floor(timeDiff / 1000)
timeDiff -= secs * 1000;
// let spentTime = Math.floor((endTime.getTime() - startTime.getTime()) / 1000);
// const result = spentTime.getSeconds();
function addZero(i) {
if (i < 10) { i = "0" + i }
return i;
}
// const d = new Date();
// let h = addZero(spentTime.getHours());
// let m = addZero(spentTime.getMinutes());
// let s = addZero(spentTime.getSeconds());
const time = addZero(hours) + "h:" + addZero(mins) + "m:" + addZero(secs)+'s';
return time
} }
} }

View File

@ -168,7 +168,7 @@
:class="isDragOverChat ? 'pointer-events-none' : ''"> :class="isDragOverChat ? 'pointer-events-none' : ''">
<!-- CHAT AREA --> <!-- CHAT AREA -->
<div class=" container pt-4 pb-10 mb-16" > <div class=" container pt-4 pb-10 mb-16">
<TransitionGroup v-if="discussionArr.length > 0" name="list"> <TransitionGroup v-if="discussionArr.length > 0" name="list">
<Message v-for="(msg, index) in discussionArr" :key="msg.id" :message="msg" :id="'msg-' + msg.id" <Message v-for="(msg, index) in discussionArr" :key="msg.id" :message="msg" :id="'msg-' + msg.id"
ref="messages" @copy="copyToClipBoard" @delete="deleteMessage" @rankUp="rankUpMessage" ref="messages" @copy="copyToClipBoard" @delete="deleteMessage" @rankUp="rankUpMessage"
@ -496,7 +496,7 @@ export default {
nextTick(() => { nextTick(() => {
const discussionitem =document.getElementById('dis-'+this.currentDiscussion.id) const discussionitem = document.getElementById('dis-' + this.currentDiscussion.id)
//this.scrollToElement(discussionitem) //this.scrollToElement(discussionitem)
@ -517,7 +517,7 @@ export default {
} }
}, },
scrollToElementInContainer(el, containerId) { scrollToElementInContainer(el, containerId) {
const topPos = el.offsetTop ; //+ el.clientHeight const topPos = el.offsetTop; //+ el.clientHeight
const container = document.getElementById(containerId) const container = document.getElementById(containerId)
// console.log(el.offsetTop , el.clientHeight, container.clientHeight) // console.log(el.offsetTop , el.clientHeight, container.clientHeight)
@ -560,12 +560,14 @@ export default {
}, },
createUserMsg(msgObj) { createUserMsg(msgObj) {
let usrMessage = { let usrMessage = {
content: msgObj.message, content: msgObj.message,
id: msgObj.id, id: msgObj.id,
//parent: 10, //parent: 10,
rank: 0, rank: 0,
sender: msgObj.user sender: msgObj.user,
created_at: msgObj.created_at
//type: 0 //type: 0
} }
this.discussionArr.push(usrMessage) this.discussionArr.push(usrMessage)
@ -601,12 +603,14 @@ export default {
if (msgObj["status"] == "generation_started") { if (msgObj["status"] == "generation_started") {
this.updateLastUserMsg(msgObj) this.updateLastUserMsg(msgObj)
// Create response message // Create response message
let responseMessage = { let responseMessage = {
content: "✍ please stand by ...",//msgObj.message, content: "✍ please stand by ...",//msgObj.message,
id: msgObj.ai_message_id, id: msgObj.ai_message_id,
parent: msgObj.user_message_id, parent: msgObj.user_message_id,
rank: 0, rank: 0,
sender: msgObj.bot, sender: msgObj.bot,
created_at: new Date().toLocaleString(),
//type: msgObj.type //type: msgObj.type
} }
this.discussionArr.push(responseMessage) this.discussionArr.push(responseMessage)
@ -653,7 +657,9 @@ export default {
message: msg, message: msg,
id: 0, id: 0,
rank: 0, rank: 0,
user: "user" user: "user",
created_at: new Date().toLocaleString(),
}; };
this.createUserMsg(usrMessage); this.createUserMsg(usrMessage);
@ -887,7 +893,7 @@ export default {
this.setDiscussionLoading(this.currentDiscussion.id, this.isGenerating); this.setDiscussionLoading(this.currentDiscussion.id, this.isGenerating);
axios.get('/get_generation_status', {}).then((res) => { axios.get('/get_generation_status', {}).then((res) => {
if (res) { if (res) {
//console.log(res.data.status); console.log(res);
if (!res.data.status) { if (!res.data.status) {
socket.emit('generate_msg_from', { prompt: msg, id: msgId }); socket.emit('generate_msg_from', { prompt: msg, id: msgId });
@ -934,9 +940,43 @@ export default {
this.setDiscussionLoading(this.currentDiscussion.id, this.isGenerating) this.setDiscussionLoading(this.currentDiscussion.id, this.isGenerating)
this.chime.play() this.chime.play()
}, },
copyToClipBoard(content) { copyToClipBoard(messageEntry) {
this.$refs.toast.showToast("Copied to clipboard successfully", 4, true) this.$refs.toast.showToast("Copied to clipboard successfully", 4, true)
navigator.clipboard.writeText(content);
let binding =""
if(messageEntry.message.binding){
binding= `Binding: ${messageEntry.message.binding}`
}
let personality=""
if(messageEntry.message.personality){
personality= `\nPersonality: ${messageEntry.message.personality}`
}
let time=""
if(messageEntry.created_at_parsed){
time= `\nCreated: ${messageEntry.created_at_parsed}`
}
let content=""
if(messageEntry.message.content){
content= messageEntry.message.content
}
let model=""
if(messageEntry.message.model){
model= `Model: ${messageEntry.message.model}`
}
let seed=""
if(messageEntry.message.seed){
seed= `Seed: ${messageEntry.message.seed}`
}
let time_spent=""
if(messageEntry.time_spent){
time_spent= `\nTime spent: ${messageEntry.time_spent}`
}
let bottomRow = ''
bottomRow = `${binding} ${model} ${seed} ${time_spent}`.trim()
const result = `${messageEntry.message.sender}${personality}${time}\n\n${content}\n\n${bottomRow}`
navigator.clipboard.writeText(result);
nextTick(() => { nextTick(() => {
feather.replace() feather.replace()
@ -1151,7 +1191,7 @@ export default {
}, },
async activated() { async activated() {
console.log('settings changed',this.$store.state.mountedPersonalities) //console.log('settings changed', this.$store.state.mountedPersonalities)
// This lifecycle hook runs every time you switch from other page back to this page (vue-router) // This lifecycle hook runs every time you switch from other page back to this page (vue-router)
// To fix scrolling back to last message, this hook is needed. // To fix scrolling back to last message, this hook is needed.
// If anyone knows hor to fix scroll issue when changing pages, please do fix it :D // If anyone knows hor to fix scroll issue when changing pages, please do fix it :D

View File

@ -162,7 +162,8 @@
<div class="flex gap-1 items-center"> <div class="flex gap-1 items-center">
<img :src="imgBinding" class="w-8 h-8 rounded-full object-fill text-blue-700"> <img :src="imgBinding" class="w-8 h-8 rounded-full object-fill text-blue-700">
<h3 class="font-bold font-large text-lg line-clamp-1"> <h3 class="font-bold font-large text-lg line-clamp-1">
{{ configFile.binding_name }} <!-- {{ configFile.binding_name }} -->
{{binding_name}}
</h3> </h3>
</div> </div>
</div> </div>
@ -329,6 +330,11 @@
<div v-if="configFile.personalities" class="mr-2">|</div> <div v-if="configFile.personalities" class="mr-2">|</div>
<!-- LIST OF MOUNTED PERSONALITIES --> <!-- LIST OF MOUNTED PERSONALITIES -->
<div class="mr-2 font-bold font-large text-lg line-clamp-1">
{{active_pesonality }}
</div>
<div v-if="configFile.personalities" class="mr-2">|</div>
<div v-if="configFile.personalities" <div v-if="configFile.personalities"
class=" text-base font-semibold cursor-pointer select-none items-center flex flex-row"> class=" text-base font-semibold cursor-pointer select-none items-center flex flex-row">
<!-- LIST --> <!-- LIST -->
@ -1380,7 +1386,7 @@ export default {
const res = await this.mount_personality(pers.personality) const res = await this.mount_personality(pers.personality)
console.log('mount_personality res', res) console.log('mount_personality res', res)
if (res.status) { if (res && res.status) {
this.configFile.personalities = res.personalities this.configFile.personalities = res.personalities
this.$refs.toast.showToast("Personality mounted", 4, true) this.$refs.toast.showToast("Personality mounted", 4, true)
pers.isMounted = true pers.isMounted = true
@ -1609,6 +1615,34 @@ export default {
return defaultModelImgPlaceholder return defaultModelImgPlaceholder
} }
}, },
binding_name(){
if (!this.isMounted) {
return
}
const index =this.bindingsArr.findIndex(item=>item.folder === this.configFile.binding_name)
if(index>-1){
return this.bindingsArr[index].name
}else{
return
}
},
active_pesonality(){
if (!this.isMounted) {
return
}
const index =this.personalities.findIndex(item => item.full_path ===this.configFile.personalities[this.configFile.active_personality_id])
if (index>-1){
return this.personalities[index].name
}else{
return
}
}
// imgPersonality() { // imgPersonality() {
// if (!this.isMounted) { // if (!this.isMounted) {
// return // return