1.1.0 • Published 8 months ago
hikma-ui v1.1.0
Hikma UI - A Modern Headless React Component Library based on TailwindCSS and React Hook Form
Description
Hikma UI is a collection of unstyled, headless React components that provide functionality without enforcing any specific styling. While built with TailwindCSS support, the components are style-agnostic and can be fully customized to match any design system.
Features
- Headless components with complete styling flexibility
- Zero default styles - bring your own CSS
- Built with TailwindCSS support (optional)
- Supports React with TypeScript
- Includes unstyled form components with React Hook Form integration
- Flexible button system with customizable variants and states
Prerequisites
- Node.js (v14.0 or later)
- React (v17.0 or later)
- TailwindCSS (v4.0 or later)
- Zod (v3.0 or later)
- Zod resolver (v3.0 or later) -->
Dependencies
Before installing Hikma UI, ensure you have the following peer dependencies installed:
npm install zod  Installation
Install the package via NPM:
npm install hikma-ui --saveUsage
To use Hikma UI, import the components you need from the library. For example:
import { useRef } from 'react';
import { UiForm, UiButton, UIFormRef } from 'hikma-ui';
import { z } from "zod"
const exampleSchema = z.object({
    name: z.string().min(2),
    email: z.string().email(),
    examples: z.array(z.object({
        name: z.string().min(2),
        phone: z.string().min(10),
    }))
})
type ExampleSchemaType = z.infer<typeof exampleSchema>
const exampleDefaultValues: ExampleSchemaType = {
    name: '',
    email: '',
    examples: [{ name: '', phone: ''} ],
}
const ExampleForm = () => {
    const formRef = useRef<UIFormRef<ExampleSchemaType>>(null)
    const onSubmitHandler = (value: ExampleSchemaType) => {
        console.log(value)
    } 
    return (
        <UIForm 
            schema={exampleSchema} 
            defaultValues={exampleDefaultValues} 
            onSubmit={onSubmitHandler}
            ref={formRef}
        >
            <UiGrid>
                <UiGrid.Item className='xl:col-span-12'>
                    <UIForm.Input<ExampleSchemaType> name="name" placeholder="Enter your name" />
                </UiGrid.Item>
                <UiGrid.Item className='xl:col-span-12'>
                    <UIForm.Select<ExampleSchemaType> name="email" placeholder="Enter your email" options={[{label: 'Option 1', value: '1'}]} />
                </UiGrid.Item>
                <UiGrid.Item className='xl:col-span-12'>
                    <div className="flex justify-end">
                        <UiButton label="Reset Form" onClick={()=>formRef.current?.reset()} variant="danger" />
                        <UiButton label="Submit" type="submit" />
                    </div>
                </UiGrid.Item>
            </UiGrid>
        </UIForm>
    )
}
export default ExampleForm1.1.0
8 months ago
1.1.0-alpha.3
8 months ago
1.1.0-alpha.2
8 months ago
1.1.0-alpha.1
9 months ago
1.1.0-next.1
9 months ago
1.0.0
9 months ago
0.0.2
1 year ago