mirror of
https://github.com/NovaOSS/nova-betterchat.git
synced 2024-11-25 21:23:58 +01:00
fix: disable new chat during generation
This commit is contained in:
parent
dcea49d6ad
commit
17b6fc91fb
|
@ -54,9 +54,9 @@ const ShowMoreButton = () => {
|
||||||
|
|
||||||
const ChatHistoryClass = {
|
const ChatHistoryClass = {
|
||||||
normal:
|
normal:
|
||||||
'flex py-3 px-3 items-center gap-3 relative rounded-md hover:bg-[#2A2B32] break-all hover:pr-4 group',
|
'flex py-3 px-3 items-center gap-3 relative rounded-md hover:bg-[#2A2B32] break-all hover:pr-4 group transition-opacity',
|
||||||
active:
|
active:
|
||||||
'flex py-3 px-3 items-center gap-3 relative rounded-md break-all pr-14 bg-gray-800 hover:bg-gray-800 group',
|
'flex py-3 px-3 items-center gap-3 relative rounded-md break-all pr-14 bg-gray-800 hover:bg-gray-800 group transition-opacity',
|
||||||
normalGradient:
|
normalGradient:
|
||||||
'absolute inset-y-0 right-0 w-8 z-10 bg-gradient-to-l from-gray-900 group-hover:from-[#2A2B32]',
|
'absolute inset-y-0 right-0 w-8 z-10 bg-gradient-to-l from-gray-900 group-hover:from-[#2A2B32]',
|
||||||
activeGradient:
|
activeGradient:
|
||||||
|
@ -110,7 +110,11 @@ const ChatHistory = React.memo(
|
||||||
<a
|
<a
|
||||||
className={`${
|
className={`${
|
||||||
active ? ChatHistoryClass.active : ChatHistoryClass.normal
|
active ? ChatHistoryClass.active : ChatHistoryClass.normal
|
||||||
} ${generating ? 'cursor-not-allowed' : 'cursor-pointer'}`}
|
} ${
|
||||||
|
generating
|
||||||
|
? 'cursor-not-allowed opacity-40'
|
||||||
|
: 'cursor-pointer opacity-100'
|
||||||
|
}`}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
if (!generating) setCurrentChatIndex(chatIndex);
|
if (!generating) setCurrentChatIndex(chatIndex);
|
||||||
}}
|
}}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
import useStore from '@store/store';
|
||||||
|
|
||||||
import PlusIcon from '@icon/PlusIcon';
|
import PlusIcon from '@icon/PlusIcon';
|
||||||
|
|
||||||
|
@ -8,11 +9,18 @@ import useAddChat from '@hooks/useAddChat';
|
||||||
const NewChat = () => {
|
const NewChat = () => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const addChat = useAddChat();
|
const addChat = useAddChat();
|
||||||
|
const generating = useStore((state) => state.generating);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<a
|
<a
|
||||||
className='max-md:hidden flex py-3 px-3 items-center gap-3 rounded-md hover:bg-gray-500/10 transition-colors duration-200 text-white cursor-pointer text-sm md:mb-2 flex-shrink-0 md:border md:border-white/20'
|
className={`max-md:hidden flex py-3 px-3 items-center gap-3 rounded-md hover:bg-gray-500/10 transition-colors duration-200 text-white text-sm md:mb-2 flex-shrink-0 md:border md:border-white/20 transition-opacity ${
|
||||||
onClick={addChat}
|
generating
|
||||||
|
? 'cursor-not-allowed opacity-40'
|
||||||
|
: 'cursor-pointer opacity-100'
|
||||||
|
}`}
|
||||||
|
onClick={() => {
|
||||||
|
if (!generating) addChat;
|
||||||
|
}}
|
||||||
>
|
>
|
||||||
<PlusIcon />{' '}
|
<PlusIcon />{' '}
|
||||||
<span className='hidden md:inline-flex text-white text-sm'>
|
<span className='hidden md:inline-flex text-white text-sm'>
|
||||||
|
|
|
@ -5,6 +5,7 @@ import PlusIcon from '@icon/PlusIcon';
|
||||||
import useAddChat from '@hooks/useAddChat';
|
import useAddChat from '@hooks/useAddChat';
|
||||||
|
|
||||||
const MobileBar = () => {
|
const MobileBar = () => {
|
||||||
|
const generating = useStore((state) => state.generating);
|
||||||
const chatTitle = useStore((state) =>
|
const chatTitle = useStore((state) =>
|
||||||
state.chats &&
|
state.chats &&
|
||||||
state.chats.length > 0 &&
|
state.chats.length > 0 &&
|
||||||
|
@ -48,7 +49,17 @@ const MobileBar = () => {
|
||||||
</svg>
|
</svg>
|
||||||
</button>
|
</button>
|
||||||
<h1 className='flex-1 text-center text-base font-normal'>{chatTitle}</h1>
|
<h1 className='flex-1 text-center text-base font-normal'>{chatTitle}</h1>
|
||||||
<button type='button' className='px-3 text-gray-400' onClick={addChat}>
|
<button
|
||||||
|
type='button'
|
||||||
|
className={`px-3 text-gray-400 transition-opacity ${
|
||||||
|
generating
|
||||||
|
? 'cursor-not-allowed opacity-40'
|
||||||
|
: 'cursor-pointer opacity-100'
|
||||||
|
}`}
|
||||||
|
onClick={() => {
|
||||||
|
if (!generating) addChat();
|
||||||
|
}}
|
||||||
|
>
|
||||||
<PlusIcon className='h-6 w-6' />
|
<PlusIcon className='h-6 w-6' />
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue