Skip to main content
Glama

mcp-google-sheets

input.tsx2.33 kB
import { t } from 'i18next'; import { Paperclip } from 'lucide-react'; import * as React from 'react'; import { useImperativeHandle } from 'react'; import { cn } from '@/lib/utils'; import { SelectUtilButton } from '../custom/select-util-button'; export type InputProps = React.InputHTMLAttributes<HTMLInputElement> & { thin?: boolean; }; export const inputClass = 'flex h-9 w-full rounded-md border border-input-border bg-background 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'; const Input = React.forwardRef<HTMLInputElement, InputProps>( ({ className, type, thin = false, ...props }, ref) => { const [fileName, setFileName] = React.useState<string | null>(null); const inputRef = React.useRef<HTMLInputElement>(null); const handleFileChange = (event: React.ChangeEvent<HTMLInputElement>) => { const file = event.target.files?.[0]; setFileName(file ? file.name : null); props.onChange?.(event); }; useImperativeHandle(ref, () => inputRef.current!); const handleDivClick = () => { inputRef.current?.click(); }; return type === 'file' ? ( <> <input type="file" className="hidden" ref={inputRef} {...props} onChange={handleFileChange} /> <div onClick={handleDivClick} className={cn(inputClass, 'cursor-pointer items-center ', className)} > <div className={cn('flex truncate ', { 'text-muted-foreground': !fileName, })} > {fileName || t('Select a file')} </div> <div className="basis-1"> <SelectUtilButton tooltipText={t('Select a file')} Icon={Paperclip} ></SelectUtilButton> </div> </div> </> ) : ( <input type={type} className={cn(inputClass, className, { 'h-8 p-2': thin, })} ref={inputRef} {...props} /> ); }, ); Input.displayName = 'Input'; export { Input };

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/activepieces/activepieces'

If you have feedback or need assistance with the MCP directory API, please join our Discord server