Skip to content

Commit

Permalink
feat: new select component
Browse files Browse the repository at this point in the history
  • Loading branch information
ivalshamkya committed Feb 24, 2024
1 parent cfe8bf0 commit bff81a4
Show file tree
Hide file tree
Showing 3 changed files with 92 additions and 3 deletions.
25 changes: 25 additions & 0 deletions apps/www/src/components/example/SelectExample.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
'use client';
import Select from "@/components/neobruu/Select";
import { ChangeEvent, useState } from "react";

export default function SelectExample() {
const [value1, setValue1] = useState<string>("");

const handleInput1 = (e: ChangeEvent<HTMLSelectElement>) => {
setValue1(e.target.value);
};

return (
<div className="flex flex-wrap gap-3">
<Select
onChange={handleInput1}
variant="light"
rounded="md"
>
<option value="1">Option 1</option>
<option value="2">Option 2</option>
<option value="3">Option 3</option>
</Select>
</div>
);
}
56 changes: 56 additions & 0 deletions apps/www/src/components/neobruu/Select.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
import React from "react";
import { VariantProps, cva } from "class-variance-authority";
import { cn } from "@/lib/utils";

const selectVariants = cva(
"border-2 border-black py-[10px] px-[20px] shadow-[4px_4px_0px_0px_rgba(0,0,0,1)] outline-none transition-all",
{
variants: {
variant: {
primary: "focus:bg-orange-200",
secondary: "focus:bg-pink-200",
light: "focus:bg-slate-50",
dark: "focus:text-white focus:bg-zinc-900",
blue: "focus:bg-blue-200",
yellow: "focus:bg-[#f7cb46]",
green: "focus:bg-green-200",
red: "focus:bg-red-200",
},
rounded: {
none: "rounded-none",
sm: "rounded-sm",
md: "rounded-md",
lg: "rounded-lg",
xl: "rounded-xl",
full: "rounded-full",
},
},
defaultVariants: {
variant: "primary",
rounded: "none",
},
},
);

interface SelectProps
extends React.SelectHTMLAttributes<HTMLSelectElement>,
VariantProps<typeof selectVariants> {}

const Select = React.forwardRef<HTMLSelectElement, SelectProps>(
({ className, children, variant, rounded, ...props }, ref) => {
return (
<select
className={cn(selectVariants({ variant, rounded, className }))}
ref={ref}
{...props}
>
{children}
</select>
);
},
);

Select.displayName = "Select";

export default Select;

14 changes: 11 additions & 3 deletions apps/www/src/data/components.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ import AccordionExample from "@/components/example/AccordionExample";
import DrawerExample from "@/components/example/DrawerExample";
import DialogExample from "@/components/example/DialogExample";
import RadioExample from "@/components/example/RadioExample";
import Select from "@/components/neobruu/Select";
import SelectExample from "@/components/example/SelectExample";

type ComponentObj = {
name: string;
Expand Down Expand Up @@ -88,14 +90,12 @@ const components: ComponentObj[] = [
{
name: "Dialog",
sub: "Overlay component used to display important information, receive user input, or confirm actions within the application interface.",
isNew: true,
component: Dialog,
exampleComponent: DialogExample,
},
{
name: "Drawer",
sub: "Sliding panel or container typically used for navigation, displaying additional content, or providing contextual options within the application interface.",
isNew: true,
component: Drawer,
exampleComponent: DrawerExample,
},
Expand All @@ -116,6 +116,14 @@ const components: ComponentObj[] = [
sub: "Interactive element allowing users to select or deselect options within forms or lists.",
component: Radio,
exampleComponent: RadioExample,
isNew: true
},
{
name: "Select",
sub: "Interactive field for users to enter or edit text, numbers, or other data within forms or Select fields.",
component: Select,
exampleComponent: SelectExample,
isNew: true
},
{
name: "Tabs",
Expand Down Expand Up @@ -161,4 +169,4 @@ for (let i = 0; i < components.length; i++) {
}
}

export default components;
export default components;

0 comments on commit bff81a4

Please sign in to comment.