| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 | 'use client'import { Menu, MenuButton, MenuItem, MenuItems, Transition } from '@headlessui/react'import { Fragment } from 'react'import { GlobeAltIcon } from '@heroicons/react/24/outline'type ISelectProps = {  items: Array<{ value: string; name: string }>  value?: string  className?: string  onChange?: (value: string) => void}export default function Select({  items,  value,  onChange,}: ISelectProps) {  const item = items.filter(item => item.value === value)[0]  return (    <div className="w-56 text-right">      <Menu as="div" className="relative inline-block text-left">        <div>          <MenuButton className="h-[44px]justify-center inline-flex w-full items-center          rounded-lg border border-gray-200          px-[10px] py-[6px] text-[13px]          font-medium text-gray-900          hover:bg-gray-100">            <GlobeAltIcon className="mr-1 h-5 w-5" aria-hidden="true" />            {item?.name}          </MenuButton>        </div>        <Transition          as={Fragment}          enter="transition ease-out duration-100"          enterFrom="transform opacity-0 scale-95"          enterTo="transform opacity-100 scale-100"          leave="transition ease-in duration-75"          leaveFrom="transform opacity-100 scale-100"          leaveTo="transform opacity-0 scale-95"        >          <MenuItems className="absolute right-0 z-10 mt-2 w-[200px] origin-top-right divide-y divide-gray-100 rounded-md bg-white shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none">            <div className="px-1 py-1 ">              {items.map((item) => {                return <MenuItem key={item.value}>                  <button                    className={'group flex w-full items-center rounded-lg px-3 py-2 text-sm text-gray-700 data-[active]:bg-gray-100'}                    onClick={(evt) => {                      evt.preventDefault()                      onChange && onChange(item.value)                    }}                  >                    {item.name}                  </button>                </MenuItem>              })}            </div>          </MenuItems>        </Transition>      </Menu>    </div>  )}export function InputSelect({  items,  value,  onChange,}: ISelectProps) {  const item = items.filter(item => item.value === value)[0]  return (    <div className="w-full">      <Menu as="div" className="w-full">        <div>          <MenuButton className="block h-[38px] w-full appearance-none rounded-md border border-gray-300 px-3 py-2 text-left shadow-sm placeholder:text-gray-400 sm:text-sm">            {item?.name}          </MenuButton>        </div>        <Transition          as={Fragment}          enter="transition ease-out duration-100"          enterFrom="transform opacity-0 scale-95"          enterTo="transform opacity-100 scale-100"          leave="transition ease-in duration-75"          leaveFrom="transform opacity-100 scale-100"          leaveTo="transform opacity-0 scale-95"        >          <MenuItems className="absolute right-0 z-10 mt-2 w-full origin-top-right divide-y divide-gray-100 rounded-md bg-white shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none">            <div className="px-1 py-1 ">              {items.map((item) => {                return <MenuItem key={item.value}>                  <button                    className={'group flex w-full items-center rounded-md px-2 py-2 text-sm data-[active]:bg-gray-100'}                    onClick={() => {                      onChange && onChange(item.value)                    }}                  >                    {item.name}                  </button>                </MenuItem>              })}            </div>          </MenuItems>        </Transition>      </Menu>    </div>  )}
 |