Update to 1.24.2 (#166)

# PR Checklist
- [ ] Did you check if it works normally in all models? *ignore this
when it dosen't uses models*
- [ ] Did you check if it works normally in all of web, local and node
hosted versions? if it dosen't, did you blocked it in those versions?
- [ ] Did you added a type def?

# Description
This commit is contained in:
kwaroran
2023-06-08 09:03:02 +09:00
committed by GitHub
12 changed files with 158 additions and 30 deletions

View File

@@ -8,7 +8,7 @@
}, },
"package": { "package": {
"productName": "RisuAI", "productName": "RisuAI",
"version": "1.24.1" "version": "1.24.2"
}, },
"tauri": { "tauri": {
"allowlist": { "allowlist": {

View File

@@ -303,4 +303,6 @@ export const languageChinese = {
tags: "标签", tags: "标签",
copied: "已复制", copied: "已复制",
useChatCopy: "使用聊天复制", useChatCopy: "使用聊天复制",
autoTranslateInput: "使用自动翻译输入",
enterMessageForTranslateToEnglish: "输入要翻译为英语的消息",
} }

View File

@@ -307,4 +307,10 @@ export const languageEnglish = {
backgroundHTML: "Background Embedding", backgroundHTML: "Background Embedding",
copied: "Copied", copied: "Copied",
useChatCopy: "Use Chat Message Copy", useChatCopy: "Use Chat Message Copy",
autoTranslateInput: "Auto Translate Input",
enterMessageForTranslateToEnglish: "Enter Message for Translate to English",
recent: 'Recent',
downloads: 'Downloads',
trending: "Trending"
} }

View File

@@ -279,4 +279,6 @@ export const languageKorean = {
backgroundHTML: "백그라운드 임베딩", backgroundHTML: "백그라운드 임베딩",
copied: "복사됨", copied: "복사됨",
useChatCopy: "채팅 메시지 복사 사용", useChatCopy: "채팅 메시지 복사 사용",
autoTranslateInput: "입력 자동 번역",
enterMessageForTranslateToEnglish: "영어로 번역할 메시지를 입력해주세요",
} }

View File

@@ -11,7 +11,7 @@
function checkUpdate(){ function checkUpdate(){
if(selectedId > 0 && lastdb){ if(selectedId > 0 && lastdb){
if(lastdb.characters[selectedId].backgroundHTML !== backgroundHTML){ if(lastdb.characters[selectedId] && lastdb.characters[selectedId].backgroundHTML !== backgroundHTML){
backgroundHTML = lastdb.characters[selectedId].backgroundHTML backgroundHTML = lastdb.characters[selectedId].backgroundHTML
currentChar = lastdb.characters[selectedId] currentChar = lastdb.characters[selectedId]
} }

View File

@@ -16,8 +16,10 @@
import CreatorQuote from "./CreatorQuote.svelte"; import CreatorQuote from "./CreatorQuote.svelte";
import { stopTTS } from "src/ts/process/tts"; import { stopTTS } from "src/ts/process/tts";
import MainMenu from '../UI/MainMenu.svelte'; import MainMenu from '../UI/MainMenu.svelte';
import Help from '../Others/Help.svelte';
let messageInput = '' let messageInput:string = ''
let messageInputTranslate:string = ''
let openMenu = false let openMenu = false
export let openChatList = false export let openChatList = false
let loadPages = 30 let loadPages = 30
@@ -26,6 +28,7 @@
let rerollid = -1 let rerollid = -1
let lastCharId = -1 let lastCharId = -1
let doingChatInputTranslate = false let doingChatInputTranslate = false
async function send() { async function send() {
let selectedChar = $selectedCharID let selectedChar = $selectedCharID
console.log('send') console.log('send')
@@ -67,10 +70,11 @@
} }
} }
messageInput = '' messageInput = ''
messageInputTranslate = ''
$DataBase.characters[selectedChar].chats[$DataBase.characters[selectedChar].chatPage].message = cha $DataBase.characters[selectedChar].chats[$DataBase.characters[selectedChar].chatPage].message = cha
rerolls = [] rerolls = []
await sleep(10) await sleep(10)
updateInputSize() updateInputSizeAll()
await sendChatMain() await sendChatMain()
} }
@@ -170,7 +174,21 @@
export let customStyle = '' export let customStyle = ''
let inputHeight = "44px" let inputHeight = "44px"
let inputEle:HTMLTextAreaElement let inputEle:HTMLTextAreaElement
let inputTranslateHeight = "44px"
let inputTranslateEle:HTMLTextAreaElement
function updateInputSizeAll() {
updateInputSize()
updateInputTranslateSize()
}
function updateInputTranslateSize() {
if(inputTranslateEle) {
inputTranslateEle.style.height = "0";
inputTranslateHeight = (inputTranslateEle.scrollHeight) + "px";
inputTranslateEle.style.height = inputTranslateHeight
}
}
function updateInputSize() { function updateInputSize() {
if(inputEle){ if(inputEle){
inputEle.style.height = "0"; inputEle.style.height = "0";
@@ -179,7 +197,26 @@
} }
} }
$: updateInputSize() $: updateInputSizeAll()
function updateInputTransateMessage(reverse: boolean) {
if(reverse && messageInputTranslate === '') {
messageInput = ''
return
}
if(!reverse && messageInput === '') {
messageInputTranslate = ''
return
}
translate(reverse ? messageInputTranslate : messageInput, reverse).then((translatedMessage) => {
if(translatedMessage){
if(reverse)
messageInput = translatedMessage
else
messageInputTranslate = translatedMessage
}
})
}
</script> </script>
<!-- svelte-ignore a11y-click-events-have-key-events --> <!-- svelte-ignore a11y-click-events-have-key-events -->
<div class="w-full h-full" style={customStyle} on:click={() => { <div class="w-full h-full" style={customStyle} on:click={() => {
@@ -211,7 +248,7 @@
e.preventDefault() e.preventDefault()
} }
}} }}
on:input={updateInputSize} on:input={()=>{updateInputSizeAll();updateInputTransateMessage(false)}}
style:height={inputHeight} style:height={inputHeight}
/> />
@@ -234,6 +271,33 @@
class="mr-2 bg-gray-500 flex justify-center items-center text-white w-12 h-12 rounded-md hover:bg-green-500 transition-colors"><MenuIcon /> class="mr-2 bg-gray-500 flex justify-center items-center text-white w-12 h-12 rounded-md hover:bg-green-500 transition-colors"><MenuIcon />
</div> </div>
</div> </div>
{#if $DataBase.useAutoTranslateInput && $DataBase.useExperimental}
<div class="flex items-center mt-2 mb-2 w-full">
<label for='messageInputTranslate' class="text-neutral-200 ml-4">
<LanguagesIcon />
</label>
<textarea id = 'messageInputTranslate' class="text-neutral-200 p-2 min-w-0 bg-transparent input-text text-xl flex-grow ml-4 mr-2 border-gray-700 resize-none focus:bg-selected overflow-y-hidden overflow-x-hidden max-w-full"
bind:value={messageInputTranslate}
bind:this={inputTranslateEle}
on:keydown={(e) => {
if(e.key.toLocaleLowerCase() === "enter" && (!e.shiftKey)){
if($DataBase.sendWithEnter){
send()
e.preventDefault()
}
}
if(e.key.toLocaleLowerCase() === "m" && (e.ctrlKey)){
reroll()
e.preventDefault()
}
}}
on:input={()=>{updateInputSizeAll();updateInputTransateMessage(true)}}
placeholder={language.enterMessageForTranslateToEnglish}
style:height={inputTranslateHeight}
/>
</div>
{/if}
{#if $DataBase.useAutoSuggestions} {#if $DataBase.useAutoSuggestions}
<Suggestion messageInput={(msg)=>messageInput=msg} {send}/> <Suggestion messageInput={(msg)=>messageInput=msg} {send}/>
{/if} {/if}
@@ -362,7 +426,18 @@
<LanguagesIcon /> <LanguagesIcon />
<span class="ml-2">{language.translateInput}</span> <span class="ml-2">{language.translateInput}</span>
</div> </div>
{#if $DataBase.useExperimental}
<div class={"flex items-center cursor-pointer "+ ($DataBase.useAutoTranslateInput ? 'text-green-500':'lg:hover:text-green-500')} on:click={() => {
$DataBase.useAutoTranslateInput = !$DataBase.useAutoTranslateInput
}}>
<LanguagesIcon />
<span class="ml-2">{language.autoTranslateInput}</span>
<Help key="experimental" />
</div>
{/if}
{/if} {/if}
<div class={"flex items-center cursor-pointer "+ ($DataBase.useAutoSuggestions ? 'text-green-500':'lg:hover:text-green-500')} on:click={async () => { <div class={"flex items-center cursor-pointer "+ ($DataBase.useAutoSuggestions ? 'text-green-500':'lg:hover:text-green-500')} on:click={async () => {
$DataBase.useAutoSuggestions = !$DataBase.useAutoSuggestions $DataBase.useAutoSuggestions = !$DataBase.useAutoSuggestions
}}> }}>

View File

@@ -11,6 +11,7 @@
import { onDestroy } from 'svelte'; import { onDestroy } from 'svelte';
import { processScript } from "src/ts/process/scripts"; import { processScript } from "src/ts/process/scripts";
import { get } from "svelte/store"; import { get } from "svelte/store";
import { ParseMarkdown } from "src/ts/parser";
export let send: () => any; export let send: () => any;
export let messageInput:(string:string) => any; export let messageInput:(string:string) => any;
@@ -68,10 +69,9 @@
role:'system', role:'system',
content: replacePlaceholders($DataBase.autoSuggestPrompt, currentChar.name) content: replacePlaceholders($DataBase.autoSuggestPrompt, currentChar.name)
} }
, ,{
{
role: 'user', role: 'user',
content: lastMessages.map(b=>(b.role==='char'? 'assistant' : 'user')+":"+b.data).reduce((a,b)=>a+','+b) content: lastMessages.map(b=>(b.role==='char'? currentChar.name : $DataBase.username)+":"+b.data).reduce((a,b)=>a+','+b)
} }
] ]
@@ -118,16 +118,18 @@
<div>{language.creatingSuggestions}</div> <div>{language.creatingSuggestions}</div>
</div> </div>
{:else if !$doingChat} {:else if !$doingChat}
<div class="flex mr-2 mb-2"> {#if $DataBase.translator !== ''}
<button class={"bg-gray-500 hover:bg-gray-700 font-bold py-2 px-4 rounded " + (toggleTranslate ? 'text-green-500' : 'text-white')} <div class="flex mr-2 mb-2">
on:click={() => { <button class={"bg-gray-500 hover:bg-gray-700 font-bold py-2 px-4 rounded " + (toggleTranslate ? 'text-green-500' : 'text-white')}
toggleTranslate = !toggleTranslate on:click={() => {
// translateSuggest(toggleTranslate, suggestMessages) toggleTranslate = !toggleTranslate
}} }}
> >
<LanguagesIcon/> <LanguagesIcon/>
</button> </button>
</div> </div>
{/if}
<div class="flex mr-2 mb-2"> <div class="flex mr-2 mb-2">
<button class="bg-gray-500 hover:bg-gray-700 font-bold py-2 px-4 rounded text-white" <button class="bg-gray-500 hover:bg-gray-700 font-bold py-2 px-4 rounded text-white"
@@ -151,11 +153,9 @@
messageInput(suggest) messageInput(suggest)
send() send()
}}> }}>
{#if toggleTranslate && suggestMessagesTranslated && suggestMessagesTranslated.length > 0} {#await ParseMarkdown(($DataBase.translator !== '' && toggleTranslate && suggestMessagesTranslated && suggestMessagesTranslated.length > 0) ? suggestMessagesTranslated[i]??suggest : suggest) then md}
{suggestMessagesTranslated[i]??suggest} {@html md}
{:else} {/await}
{suggest}
{/if}
</button> </button>
<button class="bg-gray-500 hover:bg-gray-700 text-white font-bold py-2 px-4 rounded ml-1" on:click={() => { <button class="bg-gray-500 hover:bg-gray-700 text-white font-bold py-2 px-4 rounded ml-1" on:click={() => {
messageInput(suggest) messageInput(suggest)

View File

@@ -3,6 +3,7 @@
import { changeLanguage, language } from "src/lang"; import { changeLanguage, language } from "src/lang";
import { DataBase } from "src/ts/storage/database"; import { DataBase } from "src/ts/storage/database";
import { sleep } from "src/ts/util"; import { sleep } from "src/ts/util";
import Help from "src/lib/Others/Help.svelte";
let langChanged = false let langChanged = false
</script> </script>
<h2 class="mb-2 text-2xl font-bold mt-2">{language.language}</h2> <h2 class="mb-2 text-2xl font-bold mt-2">{language.language}</h2>
@@ -39,4 +40,11 @@ import { changeLanguage, language } from "src/lang";
<Check bind:check={$DataBase.autoTranslate} /> <Check bind:check={$DataBase.autoTranslate} />
<span>{language.autoTranslation}</span> <span>{language.autoTranslation}</span>
</div> </div>
{#if $DataBase.useExperimental}
<div class="flex items-center mt-2">
<Check bind:check={$DataBase.useAutoTranslateInput} />
<span>{language.autoTranslateInput}</span>
<Help key="experimental" />
</div>
{/if}
{/if} {/if}

View File

@@ -3,6 +3,7 @@
import { ArrowLeft, ArrowRight, DownloadIcon, FlagIcon, MenuIcon, SearchIcon, XIcon } from "lucide-svelte"; import { ArrowLeft, ArrowRight, DownloadIcon, FlagIcon, MenuIcon, SearchIcon, XIcon } from "lucide-svelte";
import { alertConfirm, alertInput, alertNormal } from "src/ts/alert"; import { alertConfirm, alertInput, alertNormal } from "src/ts/alert";
import { parseMarkdownSafe } from "src/ts/parser"; import { parseMarkdownSafe } from "src/ts/parser";
import { language } from "src/lang";
let openedData:null|{ let openedData:null|{
name:string name:string
@@ -23,14 +24,18 @@
}[] = [] }[] = []
let page = 0 let page = 0
let sort = ''
let search = '' let search = ''
let menuOpen = false let menuOpen = false
let nsfw = false
async function getHub(){ async function getHub(){
charas = await getRisuHub({ charas = await getRisuHub({
search: search, search: search,
page: page page: page,
nsfw: nsfw,
sort: sort
}) })
} }
@@ -38,7 +43,7 @@
</script> </script>
<div class="w-full flex justify-center mt-4 mb-3"> <div class="w-full flex justify-center mt-4">
<div class="flex w-2xl max-w-full items-center"> <div class="flex w-2xl max-w-full items-center">
<input class="flex-grow text-xl pl-3 pr-3 rounded-lg bg-darkbg h-16 min-w-0" placeholder="Search" bind:value={search}> <input class="flex-grow text-xl pl-3 pr-3 rounded-lg bg-darkbg h-16 min-w-0" placeholder="Search" bind:value={search}>
<button class="bg-darkbg h-14 w-14 min-w-14 rounded-lg ml-2 flex justify-center items-center hover:ring transition-shadow" on:click={() => { <button class="bg-darkbg h-14 w-14 min-w-14 rounded-lg ml-2 flex justify-center items-center hover:ring transition-shadow" on:click={() => {
@@ -54,6 +59,33 @@
</button> </button>
</div> </div>
</div> </div>
<div class="w-full mt-2 flex justify-center mb-3 items-center">
<button class="bg-darkbg p-2 rounded-lg ml-2 flex justify-center items-center hover:bg-selected transition-shadow" class:ring={nsfw} on:click={() => {
nsfw = !nsfw
getHub()
}}>
{nsfw ? 'NSFW ON': 'NSFW OFF'}
</button>
<div class="ml-2 mr-2 h-full border-r border-r-selected"></div>
<button class="bg-darkbg p-2 rounded-lg ml-2 flex justify-center items-center hover:bg-selected transition-shadow" class:ring={sort === ''} on:click={() => {
sort = ''
getHub()
}}>
{language.recent}
</button>
<button class="bg-darkbg p-2 rounded-lg ml-2 flex justify-center items-center hover:bg-selected transition-shadow" class:ring={sort === 'trending'} on:click={() => {
sort = 'trending'
getHub()
}}>
{language.trending}
</button>
<button class="bg-darkbg p-2 rounded-lg ml-2 flex justify-center items-center hover:bg-selected transition-shadow" class:ring={sort === 'downloads'} on:click={() => {
sort = 'downloads'
getHub()
}}>
{language.downloads}
</button>
</div>
<div class="w-full flex gap-4 p-2 flex-wrap justify-center"> <div class="w-full flex gap-4 p-2 flex-wrap justify-center">
{#key charas} {#key charas}
{#each charas as chara} {#each charas as chara}

View File

@@ -654,7 +654,9 @@ export async function shareRisuHub(char:character, arg:{
export async function getRisuHub(arg?:{ export async function getRisuHub(arg?:{
search?:string, search?:string,
page?:number page?:number,
nsfw?:boolean
sort?:string
}):Promise<{ }):Promise<{
name:string name:string
desc: string desc: string

View File

@@ -8,7 +8,7 @@ import { defaultAutoSuggestPrompt, defaultJailbreak, defaultMainPrompt } from '.
export const DataBase = writable({} as any as Database) export const DataBase = writable({} as any as Database)
export const loadedStore = writable(false) export const loadedStore = writable(false)
export let appVer = '1.24.1' export let appVer = '1.24.2'
export function setDatabase(data:Database){ export function setDatabase(data:Database){
if(checkNullish(data.characters)){ if(checkNullish(data.characters)){
@@ -502,8 +502,9 @@ export interface Database{
useAutoSuggestions:boolean useAutoSuggestions:boolean
autoSuggestPrompt:string, autoSuggestPrompt:string,
claudeAPIKey:string, claudeAPIKey:string,
novellistAPI:string
useChatCopy:boolean, useChatCopy:boolean,
novellistAPI:string,
useAutoTranslateInput:boolean
} }
interface hordeConfig{ interface hordeConfig{

View File

@@ -1 +1 @@
{"version":"1.24.1"} {"version":"1.24.2"}