@nlabs/gothamjs
Version:
Platform
97 lines (96 loc) • 13.8 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { cn } from '@nlabs/utils';
import { useMemo } from 'react';
import { Controller, useFormContext } from 'react-hook-form';
import { getCheckedClasses } from '../../utils/colorUtils';
export const Checkbox = ({ color = 'primary', label, defaultValue = false, description, error, containerClass = '', labelClass = '', name, optionClass = '', id, ...props })=>{
const { control, trigger } = useFormContext();
const optionClasses = useMemo(()=>cn(optionClass, getCheckedClasses(color)), [
color,
optionClass
]);
const checkboxId = id || name || label.toLowerCase().replace(/\s+/g, '-');
const descriptionId = description ? `${checkboxId}-description` : undefined;
const baseCheckboxClasses = `
col-start-1 row-start-1 appearance-none rounded-sm border border-gray-300 bg-white
checked:border-indigo-600 checked:bg-indigo-600 indeterminate:border-indigo-600
indeterminate:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2
focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100
disabled:checked:bg-gray-100 forced-colors:appearance-auto
${error ? 'border-red-300' : ''}
`.trim().replace(/\s+/g, ' ');
return /*#__PURE__*/ _jsx(Controller, {
control: control,
defaultValue: defaultValue,
name: name,
render: ({ field })=>/*#__PURE__*/ _jsx("fieldset", {
"aria-label": label,
children: /*#__PURE__*/ _jsxs("div", {
className: `flex gap-3 ${containerClass}`,
children: [
/*#__PURE__*/ _jsx("div", {
className: "flex h-6 shrink-0 items-center",
children: /*#__PURE__*/ _jsxs("div", {
className: "group grid size-4 grid-cols-1",
children: [
/*#__PURE__*/ _jsx("input", {
...props,
type: "checkbox",
id: checkboxId,
"aria-describedby": descriptionId,
className: `${baseCheckboxClasses} ${optionClasses}`,
checked: field.value,
onChange: (e)=>{
field.onChange(e.target.checked);
trigger(name);
}
}),
/*#__PURE__*/ _jsxs("svg", {
fill: "none",
viewBox: "0 0 14 14",
className: "pointer-events-none col-start-1 row-start-1 size-3.5 self-center justify-self-center stroke-white group-has-disabled:stroke-gray-950/25",
children: [
/*#__PURE__*/ _jsx("path", {
d: "M3 8L6 11L11 3.5",
strokeWidth: 2,
strokeLinecap: "round",
strokeLinejoin: "round",
className: "opacity-0 group-has-checked:opacity-100"
}),
/*#__PURE__*/ _jsx("path", {
d: "M3 7H11",
strokeWidth: 2,
strokeLinecap: "round",
strokeLinejoin: "round",
className: "opacity-0 group-has-indeterminate:opacity-100"
})
]
})
]
})
}),
/*#__PURE__*/ _jsxs("div", {
className: "text-sm/6",
children: [
/*#__PURE__*/ _jsx("label", {
htmlFor: checkboxId,
className: `font-medium text-gray-900 ${labelClass}`,
children: label
}),
description && /*#__PURE__*/ _jsx("p", {
id: descriptionId,
className: "text-gray-500",
children: description
}),
error && /*#__PURE__*/ _jsx("p", {
className: "text-red-600 mt-1",
children: error
})
]
})
]
})
})
});
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/gothamjs/src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import {cn} from '@nlabs/utils';\nimport {useMemo, type InputHTMLAttributes} from 'react';\nimport {Controller, useFormContext} from 'react-hook-form';\nimport {getCheckedClasses} from '../../utils/colorUtils';\n\nexport interface CheckboxProps extends Omit<InputHTMLAttributes<HTMLInputElement>, 'type' | 'className' | 'defaultValue'> {\n  color?: 'primary' | 'secondary' | 'error' | 'success' | 'warning';\n  containerClass?: string;\n  defaultValue?: boolean;\n  description?: string;\n  error?: string;\n  label: string;\n  labelClass?: string;\n  name: string;\n  optionClass?: string;\n}\n\nexport const Checkbox = ({\n  color = 'primary',\n  label,\n  defaultValue = false,\n  description,\n  error,\n  containerClass = '',\n  labelClass = '',\n  name,\n  optionClass = '',\n  id,\n  ...props\n}: CheckboxProps) => {\n  const {control, trigger} = useFormContext();\n  const optionClasses = useMemo(\n    () => cn(optionClass, getCheckedClasses(color)),\n    [color, optionClass]\n  );\n  const checkboxId = id || name || label.toLowerCase().replace(/\\s+/g, '-');\n  const descriptionId = description ? `${checkboxId}-description` : undefined;\n  const baseCheckboxClasses = `\n    col-start-1 row-start-1 appearance-none rounded-sm border border-gray-300 bg-white\n    checked:border-indigo-600 checked:bg-indigo-600 indeterminate:border-indigo-600\n    indeterminate:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2\n    focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100\n    disabled:checked:bg-gray-100 forced-colors:appearance-auto\n    ${error ? 'border-red-300' : ''}\n  `.trim().replace(/\\s+/g, ' ');\n  return (\n    <Controller\n      control={control}\n      defaultValue={defaultValue}\n      name={name}\n      render={({field}) => (\n        <fieldset aria-label={label}>\n          <div className={`flex gap-3 ${containerClass}`}>\n            <div className=\"flex h-6 shrink-0 items-center\">\n              <div className=\"group grid size-4 grid-cols-1\">\n                <input\n                  {...props}\n                  type=\"checkbox\"\n                  id={checkboxId}\n                  aria-describedby={descriptionId}\n                  className={`${baseCheckboxClasses} ${optionClasses}`}\n                  checked={field.value}\n                  onChange={(e) => {\n                    field.onChange(e.target.checked);\n                    trigger(name);\n                  }}\n                />\n                <svg\n                  fill=\"none\"\n                  viewBox=\"0 0 14 14\"\n                  className=\"pointer-events-none col-start-1 row-start-1 size-3.5 self-center justify-self-center stroke-white group-has-disabled:stroke-gray-950/25\"\n                >\n                  <path\n                    d=\"M3 8L6 11L11 3.5\"\n                    strokeWidth={2}\n                    strokeLinecap=\"round\"\n                    strokeLinejoin=\"round\"\n                    className=\"opacity-0 group-has-checked:opacity-100\"\n                  />\n                  <path\n                    d=\"M3 7H11\"\n                    strokeWidth={2}\n                    strokeLinecap=\"round\"\n                    strokeLinejoin=\"round\"\n                    className=\"opacity-0 group-has-indeterminate:opacity-100\"\n                  />\n                </svg>\n              </div>\n            </div>\n\n            <div className=\"text-sm/6\">\n              <label\n                htmlFor={checkboxId}\n                className={`font-medium text-gray-900 ${labelClass}`}\n              >\n                {label}\n              </label>\n              {description && (\n                <p id={descriptionId} className=\"text-gray-500\">\n                  {description}\n                </p>\n              )}\n              {error && (\n                <p className=\"text-red-600 mt-1\">{error}</p>\n              )}\n            </div>\n          </div>\n        </fieldset>\n      )}\n    />\n  );\n};"],"names":["cn","useMemo","Controller","useFormContext","getCheckedClasses","Checkbox","color","label","defaultValue","description","error","containerClass","labelClass","name","optionClass","id","props","control","trigger","optionClasses","checkboxId","toLowerCase","replace","descriptionId","undefined","baseCheckboxClasses","trim","render","field","fieldset","aria-label","div","className","input","type","aria-describedby","checked","value","onChange","e","target","svg","fill","viewBox","path","d","strokeWidth","strokeLinecap","strokeLinejoin","htmlFor","p"],"mappings":";AAAA,SAAQA,EAAE,QAAO,eAAe;AAChC,SAAQC,OAAO,QAAiC,QAAQ;AACxD,SAAQC,UAAU,EAAEC,cAAc,QAAO,kBAAkB;AAC3D,SAAQC,iBAAiB,QAAO,yBAAyB;AAczD,OAAO,MAAMC,WAAW,CAAC,EACvBC,QAAQ,SAAS,EACjBC,KAAK,EACLC,eAAe,KAAK,EACpBC,WAAW,EACXC,KAAK,EACLC,iBAAiB,EAAE,EACnBC,aAAa,EAAE,EACfC,IAAI,EACJC,cAAc,EAAE,EAChBC,EAAE,EACF,GAAGC,OACW;IACd,MAAM,EAACC,OAAO,EAAEC,OAAO,EAAC,GAAGf;IAC3B,MAAMgB,gBAAgBlB,QACpB,IAAMD,GAAGc,aAAaV,kBAAkBE,SACxC;QAACA;QAAOQ;KAAY;IAEtB,MAAMM,aAAaL,MAAMF,QAAQN,MAAMc,WAAW,GAAGC,OAAO,CAAC,QAAQ;IACrE,MAAMC,gBAAgBd,cAAc,GAAGW,WAAW,YAAY,CAAC,GAAGI;IAClE,MAAMC,sBAAsB,CAAC;;;;;;IAM3B,EAAEf,QAAQ,mBAAmB,GAAG;EAClC,CAAC,CAACgB,IAAI,GAAGJ,OAAO,CAAC,QAAQ;IACzB,qBACE,KAACpB;QACCe,SAASA;QACTT,cAAcA;QACdK,MAAMA;QACNc,QAAQ,CAAC,EAACC,KAAK,EAAC,iBACd,KAACC;gBAASC,cAAYvB;0BACpB,cAAA,MAACwB;oBAAIC,WAAW,CAAC,WAAW,EAAErB,gBAAgB;;sCAC5C,KAACoB;4BAAIC,WAAU;sCACb,cAAA,MAACD;gCAAIC,WAAU;;kDACb,KAACC;wCACE,GAAGjB,KAAK;wCACTkB,MAAK;wCACLnB,IAAIK;wCACJe,oBAAkBZ;wCAClBS,WAAW,GAAGP,oBAAoB,CAAC,EAAEN,eAAe;wCACpDiB,SAASR,MAAMS,KAAK;wCACpBC,UAAU,CAACC;4CACTX,MAAMU,QAAQ,CAACC,EAAEC,MAAM,CAACJ,OAAO;4CAC/BlB,QAAQL;wCACV;;kDAEF,MAAC4B;wCACCC,MAAK;wCACLC,SAAQ;wCACRX,WAAU;;0DAEV,KAACY;gDACCC,GAAE;gDACFC,aAAa;gDACbC,eAAc;gDACdC,gBAAe;gDACfhB,WAAU;;0DAEZ,KAACY;gDACCC,GAAE;gDACFC,aAAa;gDACbC,eAAc;gDACdC,gBAAe;gDACfhB,WAAU;;;;;;;sCAMlB,MAACD;4BAAIC,WAAU;;8CACb,KAACzB;oCACC0C,SAAS7B;oCACTY,WAAW,CAAC,0BAA0B,EAAEpB,YAAY;8CAEnDL;;gCAEFE,6BACC,KAACyC;oCAAEnC,IAAIQ;oCAAeS,WAAU;8CAC7BvB;;gCAGJC,uBACC,KAACwC;oCAAElB,WAAU;8CAAqBtB;;;;;;;;AAQlD,EAAE"}