UNPKG

@nlabs/gothamjs

Version:
97 lines (96 loc) 13.8 kB
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"}