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:
@@ -8,7 +8,7 @@
|
|||||||
},
|
},
|
||||||
"package": {
|
"package": {
|
||||||
"productName": "RisuAI",
|
"productName": "RisuAI",
|
||||||
"version": "1.24.1"
|
"version": "1.24.2"
|
||||||
},
|
},
|
||||||
"tauri": {
|
"tauri": {
|
||||||
"allowlist": {
|
"allowlist": {
|
||||||
|
|||||||
@@ -303,4 +303,6 @@ export const languageChinese = {
|
|||||||
tags: "标签",
|
tags: "标签",
|
||||||
copied: "已复制",
|
copied: "已复制",
|
||||||
useChatCopy: "使用聊天复制",
|
useChatCopy: "使用聊天复制",
|
||||||
|
autoTranslateInput: "使用自动翻译输入",
|
||||||
|
enterMessageForTranslateToEnglish: "输入要翻译为英语的消息",
|
||||||
}
|
}
|
||||||
@@ -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"
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -279,4 +279,6 @@ export const languageKorean = {
|
|||||||
backgroundHTML: "백그라운드 임베딩",
|
backgroundHTML: "백그라운드 임베딩",
|
||||||
copied: "복사됨",
|
copied: "복사됨",
|
||||||
useChatCopy: "채팅 메시지 복사 사용",
|
useChatCopy: "채팅 메시지 복사 사용",
|
||||||
|
autoTranslateInput: "입력 자동 번역",
|
||||||
|
enterMessageForTranslateToEnglish: "영어로 번역할 메시지를 입력해주세요",
|
||||||
}
|
}
|
||||||
@@ -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]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
}}>
|
}}>
|
||||||
|
|||||||
@@ -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}
|
||||||
|
{#if $DataBase.translator !== ''}
|
||||||
<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 " + (toggleTranslate ? 'text-green-500' : 'text-white')}
|
<button class={"bg-gray-500 hover:bg-gray-700 font-bold py-2 px-4 rounded " + (toggleTranslate ? 'text-green-500' : 'text-white')}
|
||||||
on:click={() => {
|
on:click={() => {
|
||||||
toggleTranslate = !toggleTranslate
|
toggleTranslate = !toggleTranslate
|
||||||
// translateSuggest(toggleTranslate, suggestMessages)
|
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<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)
|
||||||
|
|||||||
@@ -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}
|
||||||
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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{
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
{"version":"1.24.1"}
|
{"version":"1.24.2"}
|
||||||
Reference in New Issue
Block a user