feat(Navbar): Add settings entry to navbar

This commit is contained in:
Chuck 2024-06-04 17:25:56 +08:00
parent 99fc130061
commit 23478f002c
2 changed files with 8 additions and 6 deletions

View file

@ -2,7 +2,7 @@ import { Clock, Edit, Share, Trash } from 'lucide-react';
import { Message } from './ChatWindow';
import { useEffect, useState } from 'react';
import { formatTimeDifference } from '@/lib/utils';
import ThemeSwitcher from './theme/Switcher';
import SettingsEntry from './SettingsEntry';
const Navbar = ({ messages }: { messages: Message[] }) => {
const [title, setTitle] = useState<string>('');
@ -50,9 +50,11 @@ const Navbar = ({ messages }: { messages: Message[] }) => {
</div>
<p className="hidden lg:flex">{title}</p>
<ThemeSwitcher size={17} className="lg:hidden ml-auto mr-4" />
<div className="flex flex-row items-center space-x-4">
<SettingsEntry
size={17}
className="active:scale-95 transition duration-100 cursor-pointer"
/>
<Share
size={17}
className="active:scale-95 transition duration-100 cursor-pointer"

View file

@ -1,16 +1,16 @@
import { useState } from 'react';
import { Settings } from 'lucide-react';
import type { LucideProps } from 'lucide-react';
import { cn } from '@/lib/utils';
import SettingsDialog from './SettingsDialog';
interface InputProps extends React.InputHTMLAttributes<HTMLInputElement> {}
const SettingsEntry = ({ className }: InputProps) => {
const SettingsEntry = ({ className, ...restProps }: LucideProps) => {
const [isSettingsOpen, setIsSettingsOpen] = useState(false);
return (
<>
<Settings
{...restProps}
onClick={() => setIsSettingsOpen(!isSettingsOpen)}
className={cn('cursor-pointer', className)}
/>