Add search functionality to Sidebar and create Input component
This commit is contained in:
+35
-13
@@ -1,10 +1,11 @@
|
|||||||
'use client'
|
'use client'
|
||||||
|
|
||||||
import React, { useRef } from 'react'
|
import React, { useRef, useState } from 'react'
|
||||||
import { useDrag } from 'react-dnd'
|
import { useDrag } from 'react-dnd'
|
||||||
import { Button } from "@/components/ui/button"
|
import { Button } from "@/components/ui/button"
|
||||||
import { roboto } from '../app/fonts'
|
import { roboto } from '../app/fonts'
|
||||||
import { useElements } from '../context/ElementsContext'
|
import { useElements } from '../context/ElementsContext'
|
||||||
|
import { Input } from "@/components/ui/input"
|
||||||
|
|
||||||
interface DraggableElementProps {
|
interface DraggableElementProps {
|
||||||
type: string
|
type: string
|
||||||
@@ -40,20 +41,41 @@ const DraggableElement: React.FC<DraggableElementProps> = ({ type, content }) =>
|
|||||||
|
|
||||||
export const Sidebar: React.FC = () => {
|
export const Sidebar: React.FC = () => {
|
||||||
const { elements, getElementContent } = useElements()
|
const { elements, getElementContent } = useElements()
|
||||||
|
const [searchQuery, setSearchQuery] = useState('')
|
||||||
|
|
||||||
|
const filteredElements = Array.from(elements.values()).filter(element =>
|
||||||
|
getElementContent(element.type).toLowerCase().includes(searchQuery.toLowerCase())
|
||||||
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="w-64 h-full bg-gray-100 p-4 overflow-y-auto fixed top-0 right-0">
|
<div className="w-[350px] h-full flex flex-col fixed top-0 right-0 border-l-2 border-l-rgb(200,200,200)">
|
||||||
<h2 className="text-xl font-bold mb-4">Elements</h2>
|
<div className="flex-1 overflow-y-auto p-4">
|
||||||
<div className="flex flex-wrap gap-2">
|
<div className="flex flex-wrap gap-2">
|
||||||
{Array.from(elements.values()).map((element) => (
|
{filteredElements.map((element) => (
|
||||||
<DraggableElement
|
<DraggableElement
|
||||||
key={element.type}
|
key={element.type}
|
||||||
type={element.type}
|
type={element.type}
|
||||||
content={getElementContent(element.type)}
|
content={getElementContent(element.type)}
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div className="border-t">
|
||||||
|
{/* <div className="flex w-full">
|
||||||
|
<Button variant="ghost" className="w-1/2 rounded-none border-r">
|
||||||
|
Discoveries
|
||||||
|
</Button>
|
||||||
|
<Button variant="ghost" className="w-1/2 rounded-none">
|
||||||
|
Sort by Time
|
||||||
|
</Button>
|
||||||
|
</div> */}
|
||||||
|
<Input
|
||||||
|
className="w-full px-4 py-3 rounded-none"
|
||||||
|
placeholder="Search..."
|
||||||
|
value={searchQuery}
|
||||||
|
onChange={(e) => setSearchQuery(e.target.value)}
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
import * as React from "react"
|
||||||
|
|
||||||
|
import { cn } from "@/lib/utils"
|
||||||
|
|
||||||
|
const Input = React.forwardRef<HTMLInputElement, React.ComponentProps<"input">>(
|
||||||
|
({ className, type, ...props }, ref) => {
|
||||||
|
return (
|
||||||
|
<input
|
||||||
|
type={type}
|
||||||
|
className={cn(
|
||||||
|
"flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-base shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",
|
||||||
|
className
|
||||||
|
)}
|
||||||
|
ref={ref}
|
||||||
|
{...props}
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
Input.displayName = "Input"
|
||||||
|
|
||||||
|
export { Input }
|
||||||
Reference in New Issue
Block a user