From 05ee49e7c4019f32c654f2f935b734ec2383bebc Mon Sep 17 00:00:00 2001 From: molvqingtai Date: Thu, 10 Oct 2024 04:54:33 +0800 Subject: [PATCH 1/6] perf: change https://github.com/weizhenye/Danmaku to https://github.com/imtaotao/danmu --- package.json | 2 +- pnpm-lock.yaml | 77 +++++++++++-------- src/app/background/index.ts | 2 +- src/app/content/App.tsx | 2 +- .../content/components/DanmakuContainer.tsx | 2 +- src/app/content/components/DanmakuMessage.tsx | 19 ++++- src/app/content/views/AppButton/index.tsx | 2 +- src/constants/config.ts | 2 +- src/constants/event.ts | 3 +- src/domain/Danmaku.ts | 16 ++-- src/domain/externs/Danmaku.ts | 6 +- src/domain/externs/Storage.ts | 3 +- src/domain/impls/Danmaku.ts | 67 +++++++--------- src/domain/impls/Storage.ts | 16 +++- 14 files changed, 121 insertions(+), 98 deletions(-) diff --git a/package.json b/package.json index 345a5b4..3be1d7c 100644 --- a/package.json +++ b/package.json @@ -65,7 +65,7 @@ "@webext-core/proxy-service": "^1.2.0", "class-variance-authority": "^0.7.0", "clsx": "^2.1.1", - "danmaku": "^2.0.7", + "danmu": "^0.12.0", "date-fns": "^4.1.0", "framer-motion": "^11.11.1", "idb-keyval": "^6.2.1", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 6fabc20..3029ebe 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -71,9 +71,9 @@ importers: clsx: specifier: ^2.1.1 version: 2.1.1 - danmaku: - specifier: ^2.0.7 - version: 2.0.7 + danmu: + specifier: ^0.12.0 + version: 0.12.0 date-fns: specifier: ^4.1.0 version: 4.1.0 @@ -136,7 +136,7 @@ importers: version: 2.5.3 trystero: specifier: ^0.20.0 - version: 0.20.0(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/proto@0.0.7)(@waku/relay@0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4) + version: 0.20.0(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/proto@0.0.7)(@waku/relay@0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4) type-fest: specifier: ^4.26.1 version: 4.26.1 @@ -1132,9 +1132,6 @@ packages: '@libp2p/interface@1.7.0': resolution: {integrity: sha512-/zFyaIaIGW0aihhsH7/93vQdpWInUzFocxF11RO/029Y6h0SVjs24HHbils+DqaFDTqN+L7oNlBx2rM2MnmTjA==} - '@libp2p/interface@2.1.2': - resolution: {integrity: sha512-uD4NapC+1qGX7RmgC1aehQm3pMs1MpO1DwuhUlAo1M6CyNxfs1Ha9jhg2T+G4u4CAJM6wffZTyPGnKnrR+M8Fw==} - '@libp2p/logger@4.0.20': resolution: {integrity: sha512-TTh2dhHsOTAlMPxSa9ncFPHa/0jTt+0AQxwHdlxg/OGLAgc9VRhnrhHUbJZp07Crcw4T/MOfS4KhjlxgqYgJRw==} @@ -2406,6 +2403,9 @@ packages: resolution: {integrity: sha512-gOsf2YwSlleG6IjRYG2A7k0HmBMEo6qVNk9Bp/EaLgAJT5ngH6PXbqa4ItvnEwCm/velL5jAnQgsHsWnjhGmvw==} engines: {node: '>=18'} + aidly@1.9.0: + resolution: {integrity: sha512-OREY4n7SkhJZpxn94Exd4MeYni1MVPpHGe8dBxkuOSjqrlOTHchgjguaX8BNd0g3idoRNrkFBrmyJ+JWK+AROw==} + ajv@6.12.6: resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==} @@ -2971,8 +2971,8 @@ packages: csstype@3.1.3: resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==} - danmaku@2.0.7: - resolution: {integrity: sha512-etJEa9tdfW6cp5pn5qLCr1oE9v+uSE7bZxeQUMFKjHNV0Z7JCIVO126NZ5KyKgeOZx3jXAXLkS4UH/CgIx4BPQ==} + danmu@0.12.0: + resolution: {integrity: sha512-29NnnQaVFJVWvfCNpt70nW9UV2ClLtryrkWvwz8Nrwe1qrd2M8LMEfEQCNdtXebn1enk6ropBfHq3S/uTiTj5A==} dargs@8.1.0: resolution: {integrity: sha512-wAV9QHOsNbwnWdNW2FYvE1P56wtgSbM+3SZcdGiWQILwVjACCXDCI3Ai8QlCjMDB8YK5zySiXZYBiwGmNY3lnw==} @@ -3834,6 +3834,9 @@ packages: hookable@5.5.3: resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==} + hooks-plugin@1.3.0: + resolution: {integrity: sha512-CuISP+7AhIca8ZoGRN4valoVwVPtOVkzA7MiVaLA2s9XNESADUI7WbLO67z17KU2onX/UA2n/ZRhMn9PdMzXVw==} + hosted-git-info@2.8.9: resolution: {integrity: sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==} @@ -5933,6 +5936,9 @@ packages: resolution: {integrity: sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==} engines: {node: '>=18'} + small-queue@1.1.2: + resolution: {integrity: sha512-K6zQPh7cRjkzv+upcwrOTbR4kU3neY3KZR2F1nc8Fuez8uJyh4BguOUs4KGKHcuzU1LJmK8yfCkMUZbconLe8Q==} + snake-case@3.0.4: resolution: {integrity: sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==} @@ -7953,16 +7959,6 @@ snapshots: progress-events: 1.0.1 uint8arraylist: 2.4.8 - '@libp2p/interface@2.1.2': - dependencies: - '@multiformats/multiaddr': 12.3.1 - it-pushable: 3.2.3 - it-stream-types: 2.0.2 - multiformats: 13.3.0 - progress-events: 1.0.1 - uint8arraylist: 2.4.8 - optional: true - '@libp2p/logger@4.0.20': dependencies: '@libp2p/interface': 1.7.0 @@ -9273,7 +9269,7 @@ snapshots: transitivePeerDependencies: - supports-color - '@waku/discovery@0.0.3(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7)': + '@waku/discovery@0.0.3(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7)': dependencies: '@waku/enr': 0.0.26(@multiformats/multiaddr@12.3.1) '@waku/proto': 0.0.7 @@ -9282,11 +9278,11 @@ snapshots: hi-base32: 0.5.1 uint8arrays: 5.1.0 optionalDependencies: - '@libp2p/interface': 2.1.2 + '@libp2p/interface': 1.7.0 transitivePeerDependencies: - supports-color - '@waku/discovery@0.0.5(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4)': + '@waku/discovery@0.0.5(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4)': dependencies: '@waku/core': 0.0.32(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4) '@waku/enr': 0.0.26(@multiformats/multiaddr@12.3.1) @@ -9298,7 +9294,7 @@ snapshots: hi-base32: 0.5.1 uint8arrays: 5.1.0 optionalDependencies: - '@libp2p/interface': 2.1.2 + '@libp2p/interface': 1.7.0 transitivePeerDependencies: - '@multiformats/multiaddr' - libp2p @@ -9337,13 +9333,13 @@ snapshots: dependencies: protons-runtime: 5.5.0 - '@waku/relay@0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4)': + '@waku/relay@0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4)': dependencies: '@noble/hashes': 1.5.0 '@waku/core': 0.0.32(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4) '@waku/interfaces': 0.0.27 '@waku/proto': 0.0.8 - '@waku/sdk': 0.0.28(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(utf-8-validate@6.0.4) + '@waku/sdk': 0.0.28(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(utf-8-validate@6.0.4) '@waku/utils': 0.0.20 chai: 4.5.0 debug: 4.3.7 @@ -9357,7 +9353,7 @@ snapshots: - supports-color - utf-8-validate - '@waku/sdk@0.0.26(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/relay@0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4)': + '@waku/sdk@0.0.26(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/relay@0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4)': dependencies: '@chainsafe/libp2p-noise': 14.1.0 '@libp2p/identify': 1.0.21 @@ -9365,10 +9361,10 @@ snapshots: '@libp2p/ping': 1.1.6 '@libp2p/websockets': 8.2.0(bufferutil@4.0.8)(utf-8-validate@6.0.4) '@noble/hashes': 1.5.0 - '@waku/discovery': 0.0.3(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7) + '@waku/discovery': 0.0.3(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7) '@waku/message-hash': 0.1.16 '@waku/proto': 0.0.7 - '@waku/relay': 0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4) + '@waku/relay': 0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4) libp2p: 1.9.4 transitivePeerDependencies: - '@libp2p/interface' @@ -9377,7 +9373,7 @@ snapshots: - supports-color - utf-8-validate - '@waku/sdk@0.0.28(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(utf-8-validate@6.0.4)': + '@waku/sdk@0.0.28(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(utf-8-validate@6.0.4)': dependencies: '@chainsafe/libp2p-noise': 15.1.2 '@libp2p/identify': 2.1.5 @@ -9386,7 +9382,7 @@ snapshots: '@libp2p/websockets': 8.2.0(bufferutil@4.0.8)(utf-8-validate@6.0.4) '@noble/hashes': 1.5.0 '@waku/core': 0.0.32(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4) - '@waku/discovery': 0.0.5(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4) + '@waku/discovery': 0.0.5(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(libp2p@1.9.4) '@waku/interfaces': 0.0.27 '@waku/message-hash': 0.1.16 '@waku/proto': 0.0.8 @@ -9465,6 +9461,10 @@ snapshots: clean-stack: 5.2.0 indent-string: 5.0.0 + aidly@1.9.0: + dependencies: + small-queue: 1.1.2 + ajv@6.12.6: dependencies: fast-deep-equal: 3.1.3 @@ -10062,7 +10062,10 @@ snapshots: csstype@3.1.3: {} - danmaku@2.0.7: {} + danmu@0.12.0: + dependencies: + aidly: 1.9.0 + hooks-plugin: 1.3.0 dargs@8.1.0: {} @@ -11181,6 +11184,10 @@ snapshots: hookable@5.5.3: {} + hooks-plugin@1.3.0: + dependencies: + aidly: 1.9.0 + hosted-git-info@2.8.9: {} hosted-git-info@7.0.2: @@ -13525,6 +13532,8 @@ snapshots: ansi-styles: 6.2.1 is-fullwidth-code-point: 5.0.0 + small-queue@1.1.2: {} + snake-case@3.0.4: dependencies: dot-case: 3.0.4 @@ -13892,13 +13901,13 @@ snapshots: trough@2.2.0: {} - trystero@0.20.0(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/proto@0.0.7)(@waku/relay@0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4): + trystero@0.20.0(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/proto@0.0.7)(@waku/relay@0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4): dependencies: '@noble/curves': 1.6.0 '@supabase/supabase-js': 2.45.4(bufferutil@4.0.8)(utf-8-validate@6.0.4) '@thaunknown/simple-peer': 10.0.10 - '@waku/discovery': 0.0.3(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7) - '@waku/sdk': 0.0.26(@libp2p/interface@2.1.2)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/relay@0.0.15(@libp2p/interface@2.1.2)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4) + '@waku/discovery': 0.0.3(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/proto@0.0.7) + '@waku/sdk': 0.0.26(@libp2p/interface@1.7.0)(@waku/enr@0.0.26(@multiformats/multiaddr@12.3.1))(@waku/message-hash@0.1.16)(@waku/relay@0.0.15(@libp2p/interface@1.7.0)(@multiformats/multiaddr@12.3.1)(bufferutil@4.0.8)(libp2p@1.9.4)(utf-8-validate@6.0.4))(bufferutil@4.0.8)(utf-8-validate@6.0.4) firebase: 10.14.0 libp2p: 1.9.4 mqtt: 5.10.1(bufferutil@4.0.8)(utf-8-validate@6.0.4) diff --git a/src/app/background/index.ts b/src/app/background/index.ts index 6248cb0..c665d54 100644 --- a/src/app/background/index.ts +++ b/src/app/background/index.ts @@ -9,7 +9,7 @@ export default defineBackground({ main() { browser.runtime.onMessage.addListener(async (event: EVENT) => { - if (event === EVENT.OPEN_OPTIONS_PAGE) { + if (event === EVENT.OPTIONS_PAGE_OPEN) { browser.runtime.openOptionsPage() } }) diff --git a/src/app/content/App.tsx b/src/app/content/App.tsx index ecc9ead..0e64338 100644 --- a/src/app/content/App.tsx +++ b/src/app/content/App.tsx @@ -52,7 +52,7 @@ export default function App() { useEffect(() => { danmakuIsEnabled && send(danmakuDomain.command.MountCommand(danmakuContainerRef.current!)) return () => { - danmakuIsEnabled && send(danmakuDomain.command.DestroyCommand()) + danmakuIsEnabled && send(danmakuDomain.command.UnmountCommand()) } }, [danmakuIsEnabled]) diff --git a/src/app/content/components/DanmakuContainer.tsx b/src/app/content/components/DanmakuContainer.tsx index 78a8434..3770cdb 100644 --- a/src/app/content/components/DanmakuContainer.tsx +++ b/src/app/content/components/DanmakuContainer.tsx @@ -8,7 +8,7 @@ export interface DanmakuContainerProps { const DanmakuContainer = forwardRef(({ className }, ref) => { return (
) diff --git a/src/app/content/components/DanmakuMessage.tsx b/src/app/content/components/DanmakuMessage.tsx index 8e5f7cf..29dd371 100644 --- a/src/app/content/components/DanmakuMessage.tsx +++ b/src/app/content/components/DanmakuMessage.tsx @@ -1,18 +1,33 @@ import { Avatar, AvatarFallback } from '@/components/ui/Avatar' import { Button } from '@/components/ui/Button' +import { APP_STATUS_STORAGE_KEY } from '@/constants/config' +import { EVENT } from '@/constants/event' +import { AppStatus } from '@/domain/AppStatus' +import { LocalStorageImpl } from '@/domain/impls/Storage' import { TextMessage } from '@/domain/Room' import { cn } from '@/utils' import { AvatarImage } from '@radix-ui/react-avatar' -import { FC } from 'react' +import { FC, MouseEvent } from 'react' export interface PromptItemProps { data: TextMessage className?: string + onMouseEnter?: (e: MouseEvent) => void + onMouseLeave?: (e: MouseEvent) => void } -const DanmakuMessage: FC = ({ data, className }) => { +const DanmakuMessage: FC = ({ data, className, onMouseEnter, onMouseLeave }) => { + const handleOpenApp = async () => { + const appStatus = await LocalStorageImpl.value.get(APP_STATUS_STORAGE_KEY) + LocalStorageImpl.value.set(APP_STATUS_STORAGE_KEY, { ...appStatus!, open: true, unread: 0 }) + dispatchEvent(new CustomEvent(EVENT.APP_OPEN)) + } + return ( + )} /> - + Date: Thu, 10 Oct 2024 05:19:43 +0800 Subject: [PATCH 3/6] fix: the text in the textarea is not visible in dark mode --- src/app/content/components/MessageInput.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/content/components/MessageInput.tsx b/src/app/content/components/MessageInput.tsx index 706845a..3546a79 100644 --- a/src/app/content/components/MessageInput.tsx +++ b/src/app/content/components/MessageInput.tsx @@ -52,7 +52,7 @@ const MessageInput = forwardRef( onKeyDown={handleKeyDown} autoFocus={autoFocus} maxLength={maxLength} - className="box-border resize-none whitespace-pre-wrap break-words border-none bg-gray-50 pb-5 [field-sizing:content] focus:ring-0 focus:ring-offset-0" + className="box-border resize-none whitespace-pre-wrap break-words border-none bg-gray-50 pb-5 text-primary [field-sizing:content] focus:ring-0 focus:ring-offset-0" rows={2} value={value} onCompositionStart={onCompositionStart} From d6652cb2a43116016af32697b52d5bba276e6d2c Mon Sep 17 00:00:00 2001 From: molvqingtai Date: Thu, 10 Oct 2024 05:30:55 +0800 Subject: [PATCH 4/6] fix: the text in the button is not visible in dark mode --- src/app/content/components/MessageInput.tsx | 2 +- src/components/ui/Button.tsx | 3 ++- src/components/ui/Textarea.tsx | 2 +- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/app/content/components/MessageInput.tsx b/src/app/content/components/MessageInput.tsx index 3546a79..706845a 100644 --- a/src/app/content/components/MessageInput.tsx +++ b/src/app/content/components/MessageInput.tsx @@ -52,7 +52,7 @@ const MessageInput = forwardRef( onKeyDown={handleKeyDown} autoFocus={autoFocus} maxLength={maxLength} - className="box-border resize-none whitespace-pre-wrap break-words border-none bg-gray-50 pb-5 text-primary [field-sizing:content] focus:ring-0 focus:ring-offset-0" + className="box-border resize-none whitespace-pre-wrap break-words border-none bg-gray-50 pb-5 [field-sizing:content] focus:ring-0 focus:ring-offset-0" rows={2} value={value} onCompositionStart={onCompositionStart} diff --git a/src/components/ui/Button.tsx b/src/components/ui/Button.tsx index 9e6473f..590b9c0 100644 --- a/src/components/ui/Button.tsx +++ b/src/components/ui/Button.tsx @@ -11,7 +11,8 @@ const buttonVariants = cva( variant: { default: 'bg-primary text-primary-foreground shadow hover:bg-primary/90', destructive: 'bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90', - outline: 'border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground', + outline: + 'border border-input text-primary bg-background shadow-sm hover:bg-accent hover:text-accent-foreground', secondary: 'bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80', ghost: 'hover:bg-accent hover:text-accent-foreground', link: 'text-primary underline-offset-4 hover:underline' diff --git a/src/components/ui/Textarea.tsx b/src/components/ui/Textarea.tsx index 151c7d2..edf1a21 100644 --- a/src/components/ui/Textarea.tsx +++ b/src/components/ui/Textarea.tsx @@ -8,7 +8,7 @@ const Textarea = React.forwardRef(({ classNa return (