rharuow-ds 1.5.4 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +61 -0
- package/dist/rharuow-ds.cjs.js +1 -1
- package/dist/rharuow-ds.es.js +784 -692
- package/dist/styles.css +1 -1
- package/dist/types/src/components/AsideSheet.d.ts +11 -0
- package/dist/types/src/components/Card.d.ts +1 -0
- package/dist/types/src/components/index.d.ts +1 -0
- package/dist/types/src/stories/AsideSheet.stories.d.ts +7 -0
- package/dist/types/src/stories/Tooltip.stories.d.ts +2 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -439,6 +439,67 @@ Componente de tooltip inteligente e acessível:
|
|
|
439
439
|
<Tooltip content="Este não aparece" disabled>
|
|
440
440
|
<Button>Tooltip desabilitado</Button>
|
|
441
441
|
</Tooltip>
|
|
442
|
+
|
|
443
|
+
### 🪟 AsideSheet
|
|
444
|
+
|
|
445
|
+
Componente tipo painel deslizante (sheet) que abre a partir das bordas da tela.
|
|
446
|
+
|
|
447
|
+
- ✅ Suporta controle programático (controlled) e estado interno (uncontrolled)
|
|
448
|
+
- ✅ Abre da direita para a esquerda ou da esquerda para a direita (`side: 'left' | 'right'`)
|
|
449
|
+
- ✅ Largura configurável via `size` ou `className`
|
|
450
|
+
- ✅ Acessível: foco gerenciado e comportamento esperado ao fechar (Esc)
|
|
451
|
+
|
|
452
|
+
Props principais:
|
|
453
|
+
|
|
454
|
+
- `isOpen?: boolean` — controla visibilidade (quando usado como controlled)
|
|
455
|
+
- `defaultOpen?: boolean` — estado inicial (uncontrolled)
|
|
456
|
+
- `onClose?: () => void` — callback chamado ao fechar
|
|
457
|
+
- `side?: 'left' | 'right'` — lado de abertura (padrão: 'right')
|
|
458
|
+
- `size?: 'sm' | 'md' | 'lg' | 'full'` — tamanho pré-definido do sheet
|
|
459
|
+
- `className?: string` — classes adicionais para o container
|
|
460
|
+
- `title?: string | React.ReactNode` — título opcional do painel
|
|
461
|
+
|
|
462
|
+
Exemplo de uso (controlado):
|
|
463
|
+
|
|
464
|
+
```tsx
|
|
465
|
+
import React from 'react';
|
|
466
|
+
import { AsideSheet, Button } from 'rharuow-ds';
|
|
467
|
+
|
|
468
|
+
function Example() {
|
|
469
|
+
const [open, setOpen] = React.useState(false);
|
|
470
|
+
|
|
471
|
+
return (
|
|
472
|
+
<div>
|
|
473
|
+
<Button onClick={() => setOpen(true)}>Abrir Aside</Button>
|
|
474
|
+
|
|
475
|
+
<AsideSheet
|
|
476
|
+
isOpen={open}
|
|
477
|
+
onClose={() => setOpen(false)}
|
|
478
|
+
side="right"
|
|
479
|
+
size="md"
|
|
480
|
+
>
|
|
481
|
+
<AsideSheet.Header>
|
|
482
|
+
<h3>Detalhes</h3>
|
|
483
|
+
</AsideSheet.Header>
|
|
484
|
+
|
|
485
|
+
<AsideSheet.Body>
|
|
486
|
+
<p>Conteúdo do painel.</p>
|
|
487
|
+
</AsideSheet.Body>
|
|
488
|
+
|
|
489
|
+
<AsideSheet.Footer>
|
|
490
|
+
<Button variant="outline" onClick={() => setOpen(false)}>
|
|
491
|
+
Fechar
|
|
492
|
+
</Button>
|
|
493
|
+
</AsideSheet.Footer>
|
|
494
|
+
</AsideSheet>
|
|
495
|
+
</div>
|
|
496
|
+
);
|
|
497
|
+
}
|
|
498
|
+
```
|
|
499
|
+
|
|
500
|
+
Veja a story do componente no Storybook para demonstrações e variações (left/right, controlled/uncontrolled):
|
|
501
|
+
|
|
502
|
+
[Storybook — AsideSheet](https://rharuow.github.io/rharuow-ds-docs/?path=/story/asidesheet--default)
|
|
442
503
|
```
|
|
443
504
|
|
|
444
505
|
---
|
package/dist/rharuow-ds.cjs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("react"),G=require("react-hook-form");function _e(t){const o=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const r in t)if(r!=="default"){const n=Object.getOwnPropertyDescriptor(t,r);Object.defineProperty(o,r,n.get?n:{enumerable:!0,get:()=>t[r]})}}return o.default=t,Object.freeze(o)}const e=_e(y);function ye(t){var o,r,n="";if(typeof t=="string"||typeof t=="number")n+=t;else if(typeof t=="object")if(Array.isArray(t)){var f=t.length;for(o=0;o<f;o++)t[o]&&(r=ye(t[o]))&&(n&&(n+=" "),n+=r)}else for(r in t)t[r]&&(n&&(n+=" "),n+=r);return n}function Te(){for(var t,o,r=0,n="",f=arguments.length;r<f;r++)(t=arguments[r])&&(o=ye(t))&&(n&&(n+=" "),n+=o);return n}function u(...t){return Te(...t)}const Pe=({children:t,variant:o="default",className:r="",...n})=>{const f="px-4 py-2 rounded font-medium transition",E={default:"bg-[var(--primary,#2563eb)] text-[var(--primary-text,#fff)] hover:bg-[var(--primary-hover,#1d4ed8)]",outline:"border border-[var(--primary,#2563eb)] text-[var(--primary,#2563eb)] bg-white hover:bg-[var(--primary-hover,#e0e7ff)]",secondary:"bg-[var(--secondary,#fbbf24)] text-[var(--secondary-text,#222)] hover:bg-[var(--secondary-hover,#f59e42)]"};return y.createElement("button",{className:u(f,E[o],r),...n},t)},Ee=e.forwardRef(({name:t,className:o,type:r="text",label:n,onFocus:f,onBlur:E,Icon:m,iconClassName:P,iconAction:z,containerClassName:C,...v},w)=>{var J,V,I;const[p,M]=e.useState(!1),[h,R]=e.useState(!1),c=G.useFormContext(),i=c==null?void 0:c.control,x=c==null?void 0:c.register,L=i&&t?G.useWatch({control:i,name:t}):void 0,k=v.value??L??"",g=(I=(V=(J=c==null?void 0:c.formState)==null?void 0:J.errors)==null?void 0:V[t])==null?void 0:I.message,H=["date","datetime-local","time","month","week"].includes(r),b=p||!!k||H,$=r==="password"?h?"text":"password":r,D=()=>e.createElement("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z",fill:"currentColor"})),N=()=>e.createElement("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z",fill:"currentColor"})),q=()=>{R(!h)};return e.createElement("div",{className:u("relative",C)},e.createElement("input",{id:v.id||t,type:$,className:u("peer flex h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 pt-6 pb-2 text-sm placeholder-transparent transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50",r==="password"||m?"pr-12":"",o),onFocus:S=>{M(!0),f&&f(S)},...c&&t?(()=>{const S=x(t),Q=S.onBlur;return{...S,ref:O=>{typeof w=="function"?w(O):w&&(w.current=O),S.ref&&S.ref(O)},onBlur:O=>{M(!1),E&&E(O),Q&&Q(O)}}})():{ref:w,onBlur:S=>{M(!1),E&&E(S)}},...v}),n&&e.createElement("label",{htmlFor:v.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",b?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},n),r==="password"&&e.createElement("button",{type:"button",className:"absolute top-1/2 right-3 -translate-y-1/2 text-gray-400 hover:text-[var(--primary,#2563eb)] transition-colors duration-200 focus:outline-none focus:text-[var(--primary,#2563eb)]",onClick:q,"aria-label":h?"Esconder senha":"Mostrar senha",tabIndex:-1},h?e.createElement(N,null):e.createElement(D,null)),m&&r!=="password"&&e.createElement("div",{className:u("absolute top-1/2 right-3 -translate-y-1/2 text-gray-400 cursor-pointer hover:text-[var(--primary,#2563eb)] transition-colors duration-200",P),onClick:z},e.createElement(m,null)),g&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},g))});Ee.displayName="Input";const Ce=e.forwardRef(({name:t,label:o,options:r,className:n,containerClassName:f,isClearable:E,searchable:m=!1,filterPlaceholder:P="Digite para filtrar...",caseSensitive:z=!1,filterFunction:C,onFocus:v,onBlur:w,...p},M)=>{var te,ae,l,_;const[h,R]=e.useState(!1),[c,i]=e.useState(!1),[x,L]=e.useState(""),[k,g]=e.useState({top:0,left:0,width:0}),F=e.useRef(null),H=e.useRef(null),b=G.useFormContext(),$=b==null?void 0:b.control,D=$&&t?G.useWatch({control:$,name:t}):void 0,N=p.value??D??"",q=(l=(ae=(te=b==null?void 0:b.formState)==null?void 0:te.errors)==null?void 0:ae[t])==null?void 0:l.message,V=C||((a,T)=>{const j=z?a.label:a.label.toLowerCase(),U=z?T:T.toLowerCase();return j.includes(U)}),I=x.trim()?r.filter(a=>V(a,x.trim())):r,S=r.find(a=>a.value===N),Q=m&&c?x:(S==null?void 0:S.label)||"",O=h||!!N||m&&!!x,A=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),X=e.useCallback(()=>{if(F.current&&c){const a=F.current.getBoundingClientRect(),T=A(),j=window.innerHeight,U=window.innerWidth,Y=152;let d=a.bottom+4,W=a.left;if(T){const re=j-a.bottom,s=a.top;re<Y&&s>Y&&(d=a.top-Y-4);const B=16,K=U-a.width-B;W=Math.min(Math.max(W,B),K)}else j-a.bottom<Y&&(d=a.top-Y-4);g({top:d,left:W,width:a.width})}},[c,A]);e.useEffect(()=>{if(X(),c){const a=()=>X(),T=()=>X();return window.addEventListener("resize",a),window.addEventListener("scroll",T,!0),()=>{window.removeEventListener("resize",a),window.removeEventListener("scroll",T,!0)}}},[c,X]),e.useEffect(()=>{const a=T=>{F.current&&!F.current.contains(T.target)&&(i(!1),R(!1))};return document.addEventListener("mousedown",a),()=>{document.removeEventListener("mousedown",a)}},[]);const ne=()=>{i(a=>!a),R(!0)},Z=a=>{R(!0),v&&v(a)},ee=a=>{w&&w(a)},le=a=>{L(a.target.value)},oe=a=>{if(b&&t&&b.setValue(t,a),p.onChange){const T={target:{value:a}};p.onChange(T)}i(!1),R(!1),L("")};return e.createElement("div",{className:u("relative",f),ref:F},e.createElement("div",{id:p.id||t,tabIndex:0,role:"button","aria-haspopup":"listbox","aria-expanded":c,className:u("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",n),onClick:m?void 0:ne,onFocus:m?void 0:Z,onBlur:m?void 0:ee,ref:M},m?e.createElement("input",{ref:H,type:"text",value:Q,onChange:le,onFocus:m?a=>{R(!0),i(!0),v&&v(a)}:void 0,onBlur:m?a=>{w&&w(a)}:void 0,placeholder:o?"":P||"Selecione...",className:u("w-full bg-transparent border-none outline-none text-sm",!N&&!x&&"text-gray-400")}):e.createElement("span",{className:u("block truncate",!N&&"text-gray-400")},((_=r.find(a=>a.value===N))==null?void 0:_.label)||!o&&"Selecione..."),E&&N&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:a=>{if(a.stopPropagation(),b&&t&&b.setValue(t,""),p.onChange){const T={target:{value:""}};p.onChange(T)}i(!1),R(!1)}},"✕")),o&&e.createElement("label",{htmlFor:p.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",O?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},o),e.createElement("div",{className:u("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",c?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:c?"9.5rem":"0",overflowY:r.length>3?"auto":"hidden",position:"fixed",top:c?`${k.top}px`:"auto",left:c?`${k.left}px`:"auto",width:c?`${k.width}px`:"auto",zIndex:9999,boxShadow:c?"var(--select-dropdown-shadow)":"none"}},I.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},"Nenhuma opção encontrada"):I.map(a=>e.createElement("div",{key:a.value,className:u("px-3 py-2 cursor-pointer text-sm transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",N===a.value&&"bg-[var(--select-dropdown-selected)]"),onMouseDown:()=>oe(a.value)},a.label))),q&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},q))});Ce.displayName="Select";const Ne=e.forwardRef(({name:t,className:o,label:r,onFocus:n,onBlur:f,Icon:E,iconClassName:m,iconAction:P,containerClassName:z,rows:C=4,...v},w)=>{var g,F,H;const[p,M]=e.useState(!1),h=G.useFormContext(),R=h==null?void 0:h.control,c=h==null?void 0:h.register,i=R&&t?G.useWatch({control:R,name:t}):void 0,x=v.value??i??"",L=(H=(F=(g=h==null?void 0:h.formState)==null?void 0:g.errors)==null?void 0:F[t])==null?void 0:H.message,k=p||!!x;return e.createElement("div",{className:u("relative",z)},e.createElement("textarea",{id:v.id||t,rows:C,className:u("peer flex min-h-[80px] w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 pt-6 pb-2 text-sm placeholder-transparent transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 resize-vertical",E?"pr-12":"",o),onFocus:b=>{M(!0),n&&n(b)},...h&&t?(()=>{const b=c(t),$=b.onBlur;return{...b,ref:D=>{typeof w=="function"?w(D):w&&(w.current=D),b.ref&&b.ref(D)},onBlur:D=>{M(!1),f&&f(D),$&&$(D)}}})():{ref:w,onBlur:b=>{M(!1),f&&f(b)}},...v}),r&&e.createElement("label",{htmlFor:v.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",k?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},r),E&&e.createElement("div",{className:u("absolute top-3 right-3 text-gray-400 cursor-pointer hover:text-[var(--primary,#2563eb)] transition-colors duration-200",m),onClick:P},e.createElement(E,null)),L&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},L))});Ne.displayName="Textarea";const Se=e.forwardRef(({name:t,label:o,loadOptions:r,className:n,containerClassName:f,isClearable:E,defaultOptions:m=!1,loadingMessage:P="Carregando...",noOptionsMessage:z="Nenhuma opção encontrada",searchable:C=!1,debounceMs:v=300,onFocus:w,onBlur:p,...M},h)=>{var j,U,Y;const[R,c]=e.useState(!1),[i,x]=e.useState(!1),[L,k]=e.useState([]),[g,F]=e.useState(!1),[H,b]=e.useState(""),[$,D]=e.useState(""),[N,q]=e.useState({top:0,left:0,width:0}),J=e.useRef(null),V=e.useRef(null),I=G.useFormContext(),S=I==null?void 0:I.control,Q=S&&t?G.useWatch({control:S,name:t}):void 0,O=M.value??Q??"",A=(Y=(U=(j=I==null?void 0:I.formState)==null?void 0:j.errors)==null?void 0:U[t])==null?void 0:Y.message,X=R||!!O,ne=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),Z=e.useCallback(()=>{if(J.current&&i){const d=J.current.getBoundingClientRect(),W=ne(),re=window.innerHeight,s=window.innerWidth,B=152;let K=d.bottom+4,ie=d.left;if(W){const se=re-d.bottom,de=d.top;se<B&&de>B&&(K=d.top-B-4);const ce=16,ue=s-d.width-ce;ie=Math.min(Math.max(ie,ce),ue)}else re-d.bottom<B&&(K=d.top-B-4);q({top:K,left:ie,width:d.width})}},[i,ne]);e.useEffect(()=>{if(Z(),i){const d=()=>Z(),W=()=>Z();return window.addEventListener("resize",d),window.addEventListener("scroll",W,!0),()=>{window.removeEventListener("resize",d),window.removeEventListener("scroll",W,!0)}}},[i,Z]),e.useEffect(()=>{const d=setTimeout(()=>{D(H)},v);return()=>clearTimeout(d)},[H,v]),e.useEffect(()=>{(i||m&&L.length===0)&&ee(C?$:void 0)},[$,i]),e.useEffect(()=>{m===!0?ee():Array.isArray(m)&&k(m)},[]);const ee=async d=>{try{F(!0);const W=await r(d);k(W)}catch(W){console.error("Error loading options:",W),k([])}finally{F(!1)}};e.useEffect(()=>{const d=W=>{J.current&&!J.current.contains(W.target)&&(x(!1),c(!1),b(""))};return document.addEventListener("mousedown",d),()=>{document.removeEventListener("mousedown",d)}},[]);const le=()=>{i||(x(!0),c(!0),C&&V.current&&setTimeout(()=>{var d;return(d=V.current)==null?void 0:d.focus()},0))},oe=d=>{c(!0),w&&w(d)},te=d=>{p&&p(d)},ae=d=>{b(d.target.value)},l=d=>{if(I&&t&&I.setValue(t,d),M.onChange){const W={target:{value:d}};M.onChange(W)}x(!1),c(!1),b("")},_=d=>{if(d.stopPropagation(),I&&t&&I.setValue(t,""),M.onChange){const W={target:{value:""}};M.onChange(W)}x(!1),c(!1),b("")},a=L.find(d=>d.value===O),T=C&&i?H:(a==null?void 0:a.label)||"";return e.createElement("div",{className:u("relative",f),ref:J},e.createElement("div",{id:M.id||t,tabIndex:C?-1:0,role:"button","aria-haspopup":"listbox","aria-expanded":i,className:u("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",n),onClick:le,onFocus:C?void 0:oe,onBlur:C?void 0:te,ref:h},C?e.createElement("input",{ref:V,type:"text",value:T,onChange:ae,onFocus:oe,onBlur:te,placeholder:o?"":"Selecione...",className:u("w-full bg-transparent border-none outline-none text-sm",!O&&!H&&"text-gray-400")}):e.createElement("span",{className:u("block truncate",!O&&"text-gray-400")},(a==null?void 0:a.label)||!o&&"Selecione..."),g&&e.createElement("div",{className:"absolute right-8 top-1/2 -translate-y-1/2"},e.createElement("div",{className:"animate-spin rounded-full h-4 w-4 border-b-2 border-[var(--primary,#2563eb)]"})),E&&O&&!g&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:_},"✕")),o&&e.createElement("label",{htmlFor:M.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",X?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},o),e.createElement("div",{className:u("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",i?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:i?"9.5rem":"0",overflowY:L.length>3?"auto":"hidden",position:"fixed",top:i?`${N.top}px`:"auto",left:i?`${N.left}px`:"auto",width:i?`${N.width}px`:"auto",zIndex:9999,boxShadow:i?"var(--select-dropdown-shadow)":"none"}},g?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},P):L.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},z):L.map(d=>e.createElement("div",{key:d.value,className:u("px-3 py-2 cursor-pointer text-sm transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",O===d.value&&"bg-[var(--select-dropdown-selected)]"),onMouseDown:()=>l(d.value)},d.label))),A&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},A))});Se.displayName="AsyncSelect";const ke=e.forwardRef(({name:t,label:o,options:r,className:n,containerClassName:f,isClearable:E,searchable:m=!1,filterPlaceholder:P="Digite para filtrar...",caseSensitive:z=!1,filterFunction:C,onFocus:v,onBlur:w,...p},M)=>{var oe,te,ae;const[h,R]=e.useState(!1),[c,i]=e.useState(!1),[x,L]=e.useState(""),[k,g]=e.useState({top:0,left:0,width:0}),F=e.useRef(null),H=e.useRef(null),b=G.useFormContext(),$=b==null?void 0:b.control,D=$&&t?G.useWatch({control:$,name:t}):void 0,N=p.value??D??[],q=(ae=(te=(oe=b==null?void 0:b.formState)==null?void 0:oe.errors)==null?void 0:te[t])==null?void 0:ae.message,V=C||((l,_)=>{const a=z?l.label:l.label.toLowerCase(),T=z?_:_.toLowerCase();return a.includes(T)}),I=x.trim()?r.filter(l=>V(l,x.trim())):r,S=h||N&&N.length>0||m&&!!x,Q=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),O=e.useCallback(()=>{if(F.current&&c){const l=F.current.getBoundingClientRect(),_=Q(),a=window.innerHeight,T=window.innerWidth,j=152;let U=l.bottom+4,Y=l.left;if(_){const d=a-l.bottom,W=l.top;d<j&&W>j&&(U=l.top-j-4);const re=16,s=T-l.width-re;Y=Math.min(Math.max(Y,re),s)}else a-l.bottom<j&&(U=l.top-j-4);g({top:U,left:Y,width:l.width})}},[c,Q]);e.useEffect(()=>{if(O(),c){const l=()=>O(),_=()=>O();return window.addEventListener("resize",l),window.addEventListener("scroll",_,!0),()=>{window.removeEventListener("resize",l),window.removeEventListener("scroll",_,!0)}}},[c,O]),e.useEffect(()=>{const l=_=>{F.current&&!F.current.contains(_.target)&&(i(!1),R(!1))};return document.addEventListener("mousedown",l),()=>{document.removeEventListener("mousedown",l)}},[]);const A=()=>{i(l=>!l),R(!0)},X=l=>{R(!0),v&&v(l)},ne=l=>{w&&w(l)},Z=l=>{var a;let _;N.includes(l)?_=N.filter(T=>T!==l):_=[...N,l],b&&t&&b.setValue(t,_),p.onChange&&((a=p.onChange)==null||a.call(p,{target:{value:_}})),R(!0)},ee=l=>{var _;l.stopPropagation(),b&&t&&b.setValue(t,[]),p.onChange&&((_=p.onChange)==null||_.call(p,{target:{value:[]}})),i(!1),R(!1)},le=l=>{L(l.target.value)};return e.createElement("div",{className:u("relative",f),ref:F},e.createElement("div",{id:p.id||t,tabIndex:0,role:"button","aria-haspopup":"listbox","aria-expanded":c,className:u("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",n),onClick:m?void 0:A,onFocus:m?void 0:X,onBlur:m?void 0:ne,ref:M},e.createElement("div",{className:"flex flex-nowrap gap-1 items-center min-h-[1.5rem] w-full overflow-x-auto",style:{scrollbarWidth:"none"}},N&&N.length>0?r.filter(l=>N.includes(l.value)).map(l=>e.createElement("span",{key:l.value,className:"flex items-center border border-blue-200 bg-blue-50 text-blue-700 rounded-2xl px-3 py-1 text-xs shadow-sm mr-1 gap-2",style:{maxWidth:"140px"}},e.createElement("span",{className:"truncate",title:l.label},l.label),e.createElement("button",{type:"button",className:"ml-1 text-[var(--primary,#2563eb)] hover:text-red-500 focus:outline-none w-4 h-4 flex items-center justify-center rounded-full transition-colors duration-150","aria-label":`Remover ${l.label}`,tabIndex:-1,onClick:_=>{_.stopPropagation();const a=N.filter(T=>T!==l.value);b&&t&&b.setValue(t,a),p.onChange&&p.onChange({target:{value:a}})}},e.createElement("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M3 3L9 9M9 3L3 9",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"}))))):!o&&!m&&e.createElement("span",{className:"text-gray-400 text-sm"},"Selecione..."),m&&e.createElement("input",{ref:H,type:"text",value:x,onChange:le,onFocus:l=>{R(!0),i(!0),v&&v(l)},onBlur:l=>{w&&w(l)},placeholder:o?N&&N.length>0?"":P:P||"Selecione...",className:"flex-1 bg-transparent border-none outline-none text-sm min-w-[100px]"})),E&&N&&N.length>0&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:ee},"✕")),o&&e.createElement("label",{htmlFor:p.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",S?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},o),e.createElement("div",{className:u("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",c?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:c?"9.5rem":"0",overflowY:r.length>3?"auto":"hidden",position:"fixed",top:c?`${k.top}px`:"auto",left:c?`${k.left}px`:"auto",width:c?`${k.width}px`:"auto",zIndex:9999,boxShadow:c?"var(--select-dropdown-shadow)":"none"}},I.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},"Nenhuma opção encontrada"):I.map(l=>e.createElement("div",{key:l.value,className:u("px-3 py-2 cursor-pointer text-sm flex items-center gap-2 transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",N.includes(l.value)&&"bg-[var(--select-dropdown-selected)] font-semibold"),onMouseDown:()=>Z(l.value)},e.createElement("input",{type:"checkbox",checked:N.includes(l.value),readOnly:!0,className:"accent-blue-500"}),l.label))),q&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},q))});ke.displayName="MultiSelect";const Re=e.forwardRef(({name:t,label:o,loadOptions:r,className:n,containerClassName:f,isClearable:E,defaultOptions:m=!1,loadingMessage:P="Carregando...",noOptionsMessage:z="Nenhuma opção encontrada",searchable:C=!1,debounceMs:v=300,maxSelectedDisplay:w=3,onFocus:p,onBlur:M,...h},R)=>{var d,W,re;const[c,i]=e.useState(!1),[x,L]=e.useState(!1),[k,g]=e.useState([]),[F,H]=e.useState(!1),[b,$]=e.useState(""),[D,N]=e.useState(""),[q,J]=e.useState({top:0,left:0,width:0}),V=e.useRef(null),I=e.useRef(null),S=G.useFormContext(),Q=S==null?void 0:S.control,O=Q&&t?G.useWatch({control:Q,name:t}):void 0,A=h.value??O??[],X=(re=(W=(d=S==null?void 0:S.formState)==null?void 0:d.errors)==null?void 0:W[t])==null?void 0:re.message,ne=c||A&&A.length>0,Z=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),ee=e.useCallback(()=>{if(V.current&&x){const s=V.current.getBoundingClientRect(),B=Z(),K=window.innerHeight,ie=window.innerWidth,se=152;let de=s.bottom+4,ce=s.left;if(B){const ue=K-s.bottom,Me=s.top;ue<se&&Me>se&&(de=s.top-se-4);const we=16,Le=ie-s.width-we;ce=Math.min(Math.max(ce,we),Le)}else K-s.bottom<se&&(de=s.top-se-4);J({top:de,left:ce,width:s.width})}},[x,Z]);e.useEffect(()=>{if(ee(),x){const s=()=>ee(),B=()=>ee();return window.addEventListener("resize",s),window.addEventListener("scroll",B,!0),()=>{window.removeEventListener("resize",s),window.removeEventListener("scroll",B,!0)}}},[x,ee]),e.useEffect(()=>{const s=setTimeout(()=>{N(b)},v);return()=>clearTimeout(s)},[b,v]),e.useEffect(()=>{(x||m&&k.length===0)&&le(C?D:void 0)},[D,x]),e.useEffect(()=>{m===!0?le():Array.isArray(m)&&g(m)},[]);const le=async s=>{try{H(!0);const B=await r(s);g(B)}catch(B){console.error("Error loading options:",B),g([])}finally{H(!1)}};e.useEffect(()=>{const s=B=>{V.current&&!V.current.contains(B.target)&&(L(!1),i(!1),$(""))};return document.addEventListener("mousedown",s),()=>{document.removeEventListener("mousedown",s)}},[]);const oe=()=>{x||(L(!0),i(!0),C&&I.current&&setTimeout(()=>{var s;return(s=I.current)==null?void 0:s.focus()},0))},te=s=>{i(!0),p&&p(s)},ae=s=>{M&&M(s)},l=s=>{$(s.target.value)},_=s=>{let B;A.includes(s)?B=A.filter(K=>K!==s):B=[...A,s],S&&t&&S.setValue(t,B),h.onChange&&h.onChange({target:{value:B}}),i(!0)},a=(s,B)=>{B.stopPropagation();const K=A.filter(ie=>ie!==s);S&&t&&S.setValue(t,K),h.onChange&&h.onChange({target:{value:K}})},T=s=>{s.stopPropagation(),S&&t&&S.setValue(t,[]),h.onChange&&h.onChange({target:{value:[]}}),L(!1),i(!1),$("")},j=k.filter(s=>A.includes(s.value)),U=j.slice(0,w),Y=j.length-w;return e.createElement("div",{className:u("relative",f),ref:V},e.createElement("div",{id:h.id||t,tabIndex:C?-1:0,role:"button","aria-haspopup":"listbox","aria-expanded":x,className:u("peer flex items-center min-h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-2 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",n),onClick:oe,onFocus:C?void 0:te,onBlur:C?void 0:ae,ref:R},e.createElement("div",{className:"flex flex-wrap gap-1 items-center min-h-[1.5rem] w-full"},U.map(s=>e.createElement("span",{key:s.value,className:"flex items-center border border-blue-200 bg-blue-50 text-blue-700 rounded-2xl px-3 py-1 text-xs shadow-sm gap-2",style:{maxWidth:"140px"}},e.createElement("span",{className:"truncate",title:s.label},s.label),e.createElement("button",{type:"button",className:"ml-1 text-[var(--primary,#2563eb)] hover:text-red-500 focus:outline-none w-4 h-4 flex items-center justify-center rounded-full transition-colors duration-150","aria-label":`Remover ${s.label}`,tabIndex:-1,onClick:B=>a(s.value,B)},e.createElement("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M3 3L9 9M9 3L3 9",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"}))))),Y>0&&e.createElement("span",{className:"flex items-center border border-gray-200 bg-gray-100 text-gray-600 rounded-2xl px-3 py-1 text-xs"},"+",Y," mais"),C?e.createElement("input",{ref:I,type:"text",value:b,onChange:l,onFocus:te,onBlur:ae,placeholder:A.length===0&&!o?"Selecione...":"",className:"flex-1 min-w-[120px] bg-transparent border-none outline-none text-sm"}):A.length===0&&!o&&e.createElement("span",{className:"text-gray-400 text-sm"},"Selecione...")),F&&e.createElement("div",{className:"absolute right-8 top-1/2 -translate-y-1/2"},e.createElement("div",{className:"animate-spin rounded-full h-4 w-4 border-b-2 border-[var(--primary,#2563eb)]"})),E&&A&&A.length>0&&!F&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:T},"✕")),o&&e.createElement("label",{htmlFor:h.id||t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",ne?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},o),e.createElement("div",{className:u("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",x?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:x?"9.5rem":"0",overflowY:k.length>3?"auto":"hidden",position:"fixed",top:x?`${q.top}px`:"auto",left:x?`${q.left}px`:"auto",width:x?`${q.width}px`:"auto",zIndex:9999,boxShadow:x?"var(--select-dropdown-shadow)":"none"}},F?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},P):k.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},z):k.map(s=>e.createElement("div",{key:s.value,className:u("px-3 py-2 cursor-pointer text-sm flex items-center gap-2 transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",A.includes(s.value)&&"bg-[var(--select-dropdown-selected)] font-semibold"),onMouseDown:()=>_(s.value)},e.createElement("input",{type:"checkbox",checked:A.includes(s.value),readOnly:!0,className:"accent-blue-500"}),s.label))),X&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},X))});Re.displayName="MultiAsyncSelect";const ze={sm:"h-10 text-sm px-3",md:"h-12 text-base px-4",lg:"h-16 text-lg px-6"},Fe=e.forwardRef(({name:t,label:o,options:r,className:n,containerClassName:f,optionClassName:E,direction:m="row",size:P="md",onFocus:z,onBlur:C,...v},w)=>{var x,L,k;const p=G.useFormContext(),M=p==null?void 0:p.control,h=M&&t?G.useWatch({control:M,name:t}):void 0,R=v.value??h??"",c=(k=(L=(x=p==null?void 0:p.formState)==null?void 0:x.errors)==null?void 0:L[t])==null?void 0:k.message,i=g=>{p&&t&&p.setValue(t,g),v.onChange&&v.onChange({target:{value:g}})};return e.createElement("div",{className:u("relative",f),ref:w},o&&e.createElement("label",{htmlFor:t,className:u("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm transition-all duration-200","top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white")},o),e.createElement("div",{className:u("flex gap-2 w-full pt-6",m==="row"?"flex-row":"flex-col",n),"aria-label":o,tabIndex:-1,onFocus:z,onBlur:C},r.map(g=>e.createElement("button",{key:g.value,type:"button",className:u("relative flex items-center justify-center border rounded-lg transition-all duration-200 shadow-sm px-4 focus:outline-none focus:ring-2 focus:ring-[var(--primary-hover,#dbeafe)]",ze[P],R===g.value?"border-[var(--primary,#2563eb)] bg-[var(--primary-hover,#dbeafe)] text-[var(--primary,#2563eb)] ring-2 ring-[var(--primary-hover,#dbeafe)] shadow-md transform scale-[1.02]":"border-gray-200 bg-white text-gray-600 hover:border-[var(--primary,#2563eb)] hover:bg-[var(--primary-hover,#dbeafe)] hover:text-[var(--primary,#2563eb)] hover:shadow-md",E),"aria-pressed":R===g.value,"data-selected":R===g.value,tabIndex:0,onClick:()=>i(g.value),onKeyDown:F=>{(F.key==="Enter"||F.key===" ")&&(F.preventDefault(),i(g.value))}},g.icon&&e.createElement("span",{className:"mr-2 text-lg flex items-center"},g.icon),e.createElement("span",{className:"truncate font-medium"},g.label)))),c&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},c))});Fe.displayName="RadioGroup";const fe=y.forwardRef(({children:t,className:o,as:r="div",...n},f)=>y.createElement(r,{ref:f,className:u("px-6 py-4 border-b","bg-[var(--card-header-bg,rgba(249,250,251,0.5))]","border-[var(--card-header-border,#e5e7eb)]","text-[var(--card-text,#111827)]",o),...n},t));fe.displayName="CardHeader";const me=y.forwardRef(({children:t,className:o,as:r="div",...n},f)=>y.createElement(r,{ref:f,className:u("px-6 py-4","flex-1","bg-[var(--card-bg,#ffffff)]","text-[var(--card-text,#111827)]",o),...n},t));me.displayName="CardBody";const pe=y.forwardRef(({children:t,className:o,as:r="div",...n},f)=>y.createElement(r,{ref:f,className:u("px-6 py-4 border-t","bg-[var(--card-footer-bg,rgba(249,250,251,0.5))]","border-[var(--card-footer-border,#e5e7eb)]","text-[var(--card-text,#111827)]",o),...n},t));pe.displayName="CardFooter";const Ie=y.forwardRef(({children:t,className:o,variant:r="default",size:n="md",padding:f="none",rounded:E="lg",constrainWidth:m=!1,...P},z)=>{const C={default:"bg-[var(--card-bg,#ffffff)] border border-[var(--card-border,#e5e7eb)] shadow-[var(--card-shadow-sm,0_1px_2px_0_rgb(0_0_0_/_0.05))]",outlined:"bg-[var(--card-bg,#ffffff)] border-2 border-[var(--primary,#2563eb)]",elevated:"bg-[var(--card-bg,#ffffff)] border border-[var(--card-border,#e5e7eb)] shadow-[var(--card-shadow-lg,0_10px_15px_-3px_rgb(0_0_0_/_0.1),_0_4px_6px_-4px_rgb(0_0_0_/_0.1))]",flat:"bg-[var(--card-bg,#ffffff)] border-0"},v={sm:"max-w-sm",md:"max-w-md",lg:"max-w-lg"},w={none:"",sm:"p-3",md:"p-4",lg:"p-6"},p={none:"rounded-none",sm:"rounded-sm",md:"rounded-md",lg:"rounded-lg",xl:"rounded-xl"};return y.createElement("div",{ref:z,className:u("flex flex-col",C[r],m&&v[n],w[f],p[E],o),...P},t)}),We=Object.assign(Ie,{Header:fe,Body:me,Footer:pe}),Be=y.forwardRef(({children:t,className:o,variant:r="default",size:n="md",responsive:f=!1,stickyHeader:E=!1,...m},P)=>{const z=u("w-full border-collapse bg-[var(--table-bg)] text-[var(--table-text)]",{"border border-[var(--table-border)]":r==="bordered"},{"text-sm":n==="sm","text-base":n==="md","text-lg":n==="lg"},o),C=u({"overflow-x-auto":f,"max-h-96 overflow-y-auto":E}),v=y.createElement("table",{ref:P,className:z,...m},t);return f||E?y.createElement("div",{className:C},v):v}),be=y.forwardRef(({children:t,className:o,as:r="thead",...n},f)=>y.createElement(r,{ref:f,className:u("border-b border-[var(--table-border)] bg-[var(--table-header-bg)]",{"sticky top-0 z-10":r==="thead"},o),...n},t)),ve=y.forwardRef(({children:t,className:o,as:r="tbody",...n},f)=>y.createElement(r,{ref:f,className:u("[&_tr:nth-child(odd)]:bg-[var(--table-row-odd)]","[&_tr:nth-child(even)]:bg-[var(--table-row-even)]",o),...n},t)),xe=y.forwardRef(({children:t,className:o,as:r="tfoot",...n},f)=>y.createElement(r,{ref:f,className:u("border-t border-[var(--table-border)] bg-[var(--table-header-bg)] font-medium",o),...n},t)),ge=y.forwardRef(({children:t,className:o,variant:r="default",...n},f)=>y.createElement("tr",{ref:f,className:u("border-b border-[var(--table-border)] transition-colors",{"hover:bg-[var(--table-row-hover)]":r==="hover","bg-[var(--table-row-selected)]":r==="selected"},o),...n},t)),he=y.forwardRef(({children:t,className:o,as:r="td",align:n="left",scope:f,colSpan:E,rowSpan:m,...P},z)=>y.createElement(r,{ref:z,scope:r==="th"?f:void 0,colSpan:E,rowSpan:m,className:u("px-4 py-3 text-left",{"font-semibold":r==="th","text-sm":r==="td","text-center":n==="center","text-right":n==="right"},o),...P},t));Be.displayName="Table";be.displayName="TableHeader";ve.displayName="TableBody";xe.displayName="TableFooter";ge.displayName="TableRow";he.displayName="TableCell";const Oe=Object.assign(Be,{Header:be,Body:ve,Footer:xe,Row:ge,Cell:he}),Ae=({content:t,children:o,position:r="top",className:n="",disabled:f=!1})=>{const[E,m]=y.useState(!1),[P,z]=y.useState(r),C=y.useRef(null),v=y.useRef(null);y.useEffect(()=>{if(!E||!C.current||!v.current)return;const i=C.current,L=v.current.getBoundingClientRect(),k=i.getBoundingClientRect();let g=r;const F=window.innerWidth,H=window.innerHeight;r==="top"&&L.top<k.height+10?g="bottom":r==="bottom"&&L.bottom+k.height+10>H?g="top":r==="left"&&L.left<k.width+10?g="right":r==="right"&&L.right+k.width+10>F&&(g="left"),z(g)},[E,r]);const w=()=>{f||m(!0)},p=()=>{m(!1)},M=()=>{f||m(!0)},h=()=>{m(!1)},R=()=>{const i="absolute z-[9999] pointer-events-none";switch(P){case"top":return`${i} bottom-full left-1/2 transform -translate-x-1/2 mb-2`;case"bottom":return`${i} top-full left-1/2 transform -translate-x-1/2 mt-2`;case"left":return`${i} right-full top-1/2 transform -translate-y-1/2 mr-2`;case"right":return`${i} left-full top-1/2 transform -translate-y-1/2 ml-2`;default:return`${i} bottom-full left-1/2 transform -translate-x-1/2 mb-2`}},c=()=>{const i="absolute w-2 h-2 bg-[var(--tooltip-bg,#374151)] transform rotate-45";switch(P){case"top":return`${i} top-full left-1/2 transform -translate-x-1/2 -translate-y-1/2`;case"bottom":return`${i} bottom-full left-1/2 transform -translate-x-1/2 translate-y-1/2`;case"left":return`${i} left-full top-1/2 transform -translate-y-1/2 -translate-x-1/2`;case"right":return`${i} right-full top-1/2 transform -translate-y-1/2 translate-x-1/2`;default:return`${i} top-full left-1/2 transform -translate-x-1/2 -translate-y-1/2`}};return f||!t?y.createElement(y.Fragment,null,o):y.createElement("div",{className:"relative inline-block",ref:v,onMouseEnter:w,onMouseLeave:p,onFocus:M,onBlur:h},o,E&&y.createElement("div",{ref:C,className:u(R(),"px-2 py-1 text-sm rounded whitespace-nowrap","bg-[var(--tooltip-bg,#374151)] text-[var(--tooltip-text,#fff)]","shadow-[var(--tooltip-shadow,0_10px_15px_-3px_rgb(0_0_0_/_0.1),_0_4px_6px_-4px_rgb(0_0_0_/_0.1))]","transition-opacity duration-200 ease-in-out",n),style:{zIndex:999999},role:"tooltip","aria-hidden":!E},t,y.createElement("div",{className:c()})))};exports.AsyncSelect=Se;exports.Button=Pe;exports.Card=We;exports.CardBody=me;exports.CardFooter=pe;exports.CardHeader=fe;exports.Input=Ee;exports.MultiAsyncSelect=Re;exports.MultiSelect=ke;exports.RadioGroup=Fe;exports.Select=Ce;exports.Table=Oe;exports.TableBody=ve;exports.TableCell=he;exports.TableFooter=xe;exports.TableHeader=be;exports.TableRow=ge;exports.Textarea=Ne;exports.Tooltip=Ae;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const x=require("react"),q=require("react-hook-form"),ye=require("react-dom");function Pe(t){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const r in t)if(r!=="default"){const o=Object.getOwnPropertyDescriptor(t,r);Object.defineProperty(a,r,o.get?o:{enumerable:!0,get:()=>t[r]})}}return a.default=t,Object.freeze(a)}const e=Pe(x);function Ee(t){var a,r,o="";if(typeof t=="string"||typeof t=="number")o+=t;else if(typeof t=="object")if(Array.isArray(t)){var c=t.length;for(a=0;a<c;a++)t[a]&&(r=Ee(t[a]))&&(o&&(o+=" "),o+=r)}else for(r in t)t[r]&&(o&&(o+=" "),o+=r);return o}function Ie(){for(var t,a,r=0,o="",c=arguments.length;r<c;r++)(t=arguments[r])&&(a=Ee(t))&&(o&&(o+=" "),o+=a);return o}function i(...t){return Ie(...t)}const We=({children:t,variant:a="default",className:r="",...o})=>{const c="px-4 py-2 rounded font-medium transition",N={default:"bg-[var(--primary,#2563eb)] text-[var(--primary-text,#fff)] hover:bg-[var(--primary-hover,#1d4ed8)]",outline:"border border-[var(--primary,#2563eb)] text-[var(--primary,#2563eb)] bg-white hover:bg-[var(--primary-hover,#e0e7ff)]",secondary:"bg-[var(--secondary,#fbbf24)] text-[var(--secondary-text,#222)] hover:bg-[var(--secondary-hover,#f59e42)]"};return x.createElement("button",{className:i(c,N[a],r),...o},t)},Ce=e.forwardRef(({name:t,className:a,type:r="text",label:o,onFocus:c,onBlur:N,Icon:p,iconClassName:P,iconAction:_,containerClassName:k,...g},w)=>{var J,V,O;const[f,M]=e.useState(!1),[E,B]=e.useState(!1),d=q.useFormContext(),v=d==null?void 0:d.control,h=d==null?void 0:d.register,C=v&&t?q.useWatch({control:v,name:t}):void 0,b=g.value??C??"",y=(O=(V=(J=d==null?void 0:d.formState)==null?void 0:J.errors)==null?void 0:V[t])==null?void 0:O.message,W=["date","datetime-local","time","month","week"].includes(r),m=f||!!b||W,$=r==="password"?E?"text":"password":r,D=()=>e.createElement("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z",fill:"currentColor"})),R=()=>e.createElement("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z",fill:"currentColor"})),G=()=>{B(!E)};return e.createElement("div",{className:i("relative",k)},e.createElement("input",{id:g.id||t,type:$,className:i("peer flex h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 pt-6 pb-2 text-sm placeholder-transparent transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50",r==="password"||p?"pr-12":"",a),onFocus:F=>{M(!0),c&&c(F)},...d&&t?(()=>{const F=h(t),Q=F.onBlur;return{...F,ref:z=>{typeof w=="function"?w(z):w&&(w.current=z),F.ref&&F.ref(z)},onBlur:z=>{M(!1),N&&N(z),Q&&Q(z)}}})():{ref:w,onBlur:F=>{M(!1),N&&N(F)}},...g}),o&&e.createElement("label",{htmlFor:g.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",m?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},o),r==="password"&&e.createElement("button",{type:"button",className:"absolute top-1/2 right-3 -translate-y-1/2 text-gray-400 hover:text-[var(--primary,#2563eb)] transition-colors duration-200 focus:outline-none focus:text-[var(--primary,#2563eb)]",onClick:G,"aria-label":E?"Esconder senha":"Mostrar senha",tabIndex:-1},E?e.createElement(R,null):e.createElement(D,null)),p&&r!=="password"&&e.createElement("div",{className:i("absolute top-1/2 right-3 -translate-y-1/2 text-gray-400 cursor-pointer hover:text-[var(--primary,#2563eb)] transition-colors duration-200",P),onClick:_},e.createElement(p,null)),y&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},y))});Ce.displayName="Input";const Ne=e.forwardRef(({name:t,label:a,options:r,className:o,containerClassName:c,isClearable:N,searchable:p=!1,filterPlaceholder:P="Digite para filtrar...",caseSensitive:_=!1,filterFunction:k,onFocus:g,onBlur:w,...f},M)=>{var te,ae,l,T;const[E,B]=e.useState(!1),[d,v]=e.useState(!1),[h,C]=e.useState(""),[b,y]=e.useState({top:0,left:0,width:0}),S=e.useRef(null),W=e.useRef(null),m=q.useFormContext(),$=m==null?void 0:m.control,D=$&&t?q.useWatch({control:$,name:t}):void 0,R=f.value??D??"",G=(l=(ae=(te=m==null?void 0:m.formState)==null?void 0:te.errors)==null?void 0:ae[t])==null?void 0:l.message,V=k||((n,I)=>{const j=_?n.label:n.label.toLowerCase(),U=_?I:I.toLowerCase();return j.includes(U)}),O=h.trim()?r.filter(n=>V(n,h.trim())):r,F=r.find(n=>n.value===R),Q=p&&d?h:(F==null?void 0:F.label)||"",z=E||!!R||p&&!!h,H=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),X=e.useCallback(()=>{if(S.current&&d){const n=S.current.getBoundingClientRect(),I=H(),j=window.innerHeight,U=window.innerWidth,Y=152;let u=n.bottom+4,A=n.left;if(I){const re=j-n.bottom,s=n.top;re<Y&&s>Y&&(u=n.top-Y-4);const L=16,K=U-n.width-L;A=Math.min(Math.max(A,L),K)}else j-n.bottom<Y&&(u=n.top-Y-4);y({top:u,left:A,width:n.width})}},[d,H]);e.useEffect(()=>{if(X(),d){const n=()=>X(),I=()=>X();return window.addEventListener("resize",n),window.addEventListener("scroll",I,!0),()=>{window.removeEventListener("resize",n),window.removeEventListener("scroll",I,!0)}}},[d,X]),e.useEffect(()=>{const n=I=>{S.current&&!S.current.contains(I.target)&&(v(!1),B(!1))};return document.addEventListener("mousedown",n),()=>{document.removeEventListener("mousedown",n)}},[]);const ne=()=>{v(n=>!n),B(!0)},Z=n=>{B(!0),g&&g(n)},ee=n=>{w&&w(n)},le=n=>{C(n.target.value)},oe=n=>{if(m&&t&&m.setValue(t,n),f.onChange){const I={target:{value:n}};f.onChange(I)}v(!1),B(!1),C("")};return e.createElement("div",{className:i("relative",c),ref:S},e.createElement("div",{id:f.id||t,tabIndex:0,role:"button","aria-haspopup":"listbox","aria-expanded":d,className:i("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",o),onClick:p?void 0:ne,onFocus:p?void 0:Z,onBlur:p?void 0:ee,ref:M},p?e.createElement("input",{ref:W,type:"text",value:Q,onChange:le,onFocus:p?n=>{B(!0),v(!0),g&&g(n)}:void 0,onBlur:p?n=>{w&&w(n)}:void 0,placeholder:a?"":P||"Selecione...",className:i("w-full bg-transparent border-none outline-none text-sm",!R&&!h&&"text-gray-400")}):e.createElement("span",{className:i("block truncate",!R&&"text-gray-400")},((T=r.find(n=>n.value===R))==null?void 0:T.label)||!a&&"Selecione..."),N&&R&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:n=>{if(n.stopPropagation(),m&&t&&m.setValue(t,""),f.onChange){const I={target:{value:""}};f.onChange(I)}v(!1),B(!1)}},"✕")),a&&e.createElement("label",{htmlFor:f.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",z?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},a),e.createElement("div",{className:i("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",d?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:d?"9.5rem":"0",overflowY:r.length>3?"auto":"hidden",position:"fixed",top:d?`${b.top}px`:"auto",left:d?`${b.left}px`:"auto",width:d?`${b.width}px`:"auto",zIndex:9999,boxShadow:d?"var(--select-dropdown-shadow)":"none"}},O.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},"Nenhuma opção encontrada"):O.map(n=>e.createElement("div",{key:n.value,className:i("px-3 py-2 cursor-pointer text-sm transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",R===n.value&&"bg-[var(--select-dropdown-selected)]"),onMouseDown:()=>oe(n.value)},n.label))),G&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},G))});Ne.displayName="Select";const Se=e.forwardRef(({name:t,className:a,label:r,onFocus:o,onBlur:c,Icon:N,iconClassName:p,iconAction:P,containerClassName:_,rows:k=4,...g},w)=>{var y,S,W;const[f,M]=e.useState(!1),E=q.useFormContext(),B=E==null?void 0:E.control,d=E==null?void 0:E.register,v=B&&t?q.useWatch({control:B,name:t}):void 0,h=g.value??v??"",C=(W=(S=(y=E==null?void 0:E.formState)==null?void 0:y.errors)==null?void 0:S[t])==null?void 0:W.message,b=f||!!h;return e.createElement("div",{className:i("relative",_)},e.createElement("textarea",{id:g.id||t,rows:k,className:i("peer flex min-h-[80px] w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 pt-6 pb-2 text-sm placeholder-transparent transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 resize-vertical",N?"pr-12":"",a),onFocus:m=>{M(!0),o&&o(m)},...E&&t?(()=>{const m=d(t),$=m.onBlur;return{...m,ref:D=>{typeof w=="function"?w(D):w&&(w.current=D),m.ref&&m.ref(D)},onBlur:D=>{M(!1),c&&c(D),$&&$(D)}}})():{ref:w,onBlur:m=>{M(!1),c&&c(m)}},...g}),r&&e.createElement("label",{htmlFor:g.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",b?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},r),N&&e.createElement("div",{className:i("absolute top-3 right-3 text-gray-400 cursor-pointer hover:text-[var(--primary,#2563eb)] transition-colors duration-200",p),onClick:P},e.createElement(N,null)),C&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},C))});Se.displayName="Textarea";const ke=e.forwardRef(({name:t,label:a,loadOptions:r,className:o,containerClassName:c,isClearable:N,defaultOptions:p=!1,loadingMessage:P="Carregando...",noOptionsMessage:_="Nenhuma opção encontrada",searchable:k=!1,debounceMs:g=300,onFocus:w,onBlur:f,...M},E)=>{var j,U,Y;const[B,d]=e.useState(!1),[v,h]=e.useState(!1),[C,b]=e.useState([]),[y,S]=e.useState(!1),[W,m]=e.useState(""),[$,D]=e.useState(""),[R,G]=e.useState({top:0,left:0,width:0}),J=e.useRef(null),V=e.useRef(null),O=q.useFormContext(),F=O==null?void 0:O.control,Q=F&&t?q.useWatch({control:F,name:t}):void 0,z=M.value??Q??"",H=(Y=(U=(j=O==null?void 0:O.formState)==null?void 0:j.errors)==null?void 0:U[t])==null?void 0:Y.message,X=B||!!z,ne=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),Z=e.useCallback(()=>{if(J.current&&v){const u=J.current.getBoundingClientRect(),A=ne(),re=window.innerHeight,s=window.innerWidth,L=152;let K=u.bottom+4,ie=u.left;if(A){const se=re-u.bottom,de=u.top;se<L&&de>L&&(K=u.top-L-4);const ce=16,ue=s-u.width-ce;ie=Math.min(Math.max(ie,ce),ue)}else re-u.bottom<L&&(K=u.top-L-4);G({top:K,left:ie,width:u.width})}},[v,ne]);e.useEffect(()=>{if(Z(),v){const u=()=>Z(),A=()=>Z();return window.addEventListener("resize",u),window.addEventListener("scroll",A,!0),()=>{window.removeEventListener("resize",u),window.removeEventListener("scroll",A,!0)}}},[v,Z]),e.useEffect(()=>{const u=setTimeout(()=>{D(W)},g);return()=>clearTimeout(u)},[W,g]),e.useEffect(()=>{(v||p&&C.length===0)&&ee(k?$:void 0)},[$,v]),e.useEffect(()=>{p===!0?ee():Array.isArray(p)&&b(p)},[]);const ee=async u=>{try{S(!0);const A=await r(u);b(A)}catch(A){console.error("Error loading options:",A),b([])}finally{S(!1)}};e.useEffect(()=>{const u=A=>{J.current&&!J.current.contains(A.target)&&(h(!1),d(!1),m(""))};return document.addEventListener("mousedown",u),()=>{document.removeEventListener("mousedown",u)}},[]);const le=()=>{v||(h(!0),d(!0),k&&V.current&&setTimeout(()=>{var u;return(u=V.current)==null?void 0:u.focus()},0))},oe=u=>{d(!0),w&&w(u)},te=u=>{f&&f(u)},ae=u=>{m(u.target.value)},l=u=>{if(O&&t&&O.setValue(t,u),M.onChange){const A={target:{value:u}};M.onChange(A)}h(!1),d(!1),m("")},T=u=>{if(u.stopPropagation(),O&&t&&O.setValue(t,""),M.onChange){const A={target:{value:""}};M.onChange(A)}h(!1),d(!1),m("")},n=C.find(u=>u.value===z),I=k&&v?W:(n==null?void 0:n.label)||"";return e.createElement("div",{className:i("relative",c),ref:J},e.createElement("div",{id:M.id||t,tabIndex:k?-1:0,role:"button","aria-haspopup":"listbox","aria-expanded":v,className:i("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",o),onClick:le,onFocus:k?void 0:oe,onBlur:k?void 0:te,ref:E},k?e.createElement("input",{ref:V,type:"text",value:I,onChange:ae,onFocus:oe,onBlur:te,placeholder:a?"":"Selecione...",className:i("w-full bg-transparent border-none outline-none text-sm",!z&&!W&&"text-gray-400")}):e.createElement("span",{className:i("block truncate",!z&&"text-gray-400")},(n==null?void 0:n.label)||!a&&"Selecione..."),y&&e.createElement("div",{className:"absolute right-8 top-1/2 -translate-y-1/2"},e.createElement("div",{className:"animate-spin rounded-full h-4 w-4 border-b-2 border-[var(--primary,#2563eb)]"})),N&&z&&!y&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:T},"✕")),a&&e.createElement("label",{htmlFor:M.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",X?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},a),e.createElement("div",{className:i("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",v?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:v?"9.5rem":"0",overflowY:C.length>3?"auto":"hidden",position:"fixed",top:v?`${R.top}px`:"auto",left:v?`${R.left}px`:"auto",width:v?`${R.width}px`:"auto",zIndex:9999,boxShadow:v?"var(--select-dropdown-shadow)":"none"}},y?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},P):C.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},_):C.map(u=>e.createElement("div",{key:u.value,className:i("px-3 py-2 cursor-pointer text-sm transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",z===u.value&&"bg-[var(--select-dropdown-selected)]"),onMouseDown:()=>l(u.value)},u.label))),H&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},H))});ke.displayName="AsyncSelect";const Re=e.forwardRef(({name:t,label:a,options:r,className:o,containerClassName:c,isClearable:N,searchable:p=!1,filterPlaceholder:P="Digite para filtrar...",caseSensitive:_=!1,filterFunction:k,onFocus:g,onBlur:w,...f},M)=>{var oe,te,ae;const[E,B]=e.useState(!1),[d,v]=e.useState(!1),[h,C]=e.useState(""),[b,y]=e.useState({top:0,left:0,width:0}),S=e.useRef(null),W=e.useRef(null),m=q.useFormContext(),$=m==null?void 0:m.control,D=$&&t?q.useWatch({control:$,name:t}):void 0,R=f.value??D??[],G=(ae=(te=(oe=m==null?void 0:m.formState)==null?void 0:oe.errors)==null?void 0:te[t])==null?void 0:ae.message,V=k||((l,T)=>{const n=_?l.label:l.label.toLowerCase(),I=_?T:T.toLowerCase();return n.includes(I)}),O=h.trim()?r.filter(l=>V(l,h.trim())):r,F=E||R&&R.length>0||p&&!!h,Q=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),z=e.useCallback(()=>{if(S.current&&d){const l=S.current.getBoundingClientRect(),T=Q(),n=window.innerHeight,I=window.innerWidth,j=152;let U=l.bottom+4,Y=l.left;if(T){const u=n-l.bottom,A=l.top;u<j&&A>j&&(U=l.top-j-4);const re=16,s=I-l.width-re;Y=Math.min(Math.max(Y,re),s)}else n-l.bottom<j&&(U=l.top-j-4);y({top:U,left:Y,width:l.width})}},[d,Q]);e.useEffect(()=>{if(z(),d){const l=()=>z(),T=()=>z();return window.addEventListener("resize",l),window.addEventListener("scroll",T,!0),()=>{window.removeEventListener("resize",l),window.removeEventListener("scroll",T,!0)}}},[d,z]),e.useEffect(()=>{const l=T=>{S.current&&!S.current.contains(T.target)&&(v(!1),B(!1))};return document.addEventListener("mousedown",l),()=>{document.removeEventListener("mousedown",l)}},[]);const H=()=>{v(l=>!l),B(!0)},X=l=>{B(!0),g&&g(l)},ne=l=>{w&&w(l)},Z=l=>{var n;let T;R.includes(l)?T=R.filter(I=>I!==l):T=[...R,l],m&&t&&m.setValue(t,T),f.onChange&&((n=f.onChange)==null||n.call(f,{target:{value:T}})),B(!0)},ee=l=>{var T;l.stopPropagation(),m&&t&&m.setValue(t,[]),f.onChange&&((T=f.onChange)==null||T.call(f,{target:{value:[]}})),v(!1),B(!1)},le=l=>{C(l.target.value)};return e.createElement("div",{className:i("relative",c),ref:S},e.createElement("div",{id:f.id||t,tabIndex:0,role:"button","aria-haspopup":"listbox","aria-expanded":d,className:i("peer flex items-center h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-3 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",o),onClick:p?void 0:H,onFocus:p?void 0:X,onBlur:p?void 0:ne,ref:M},e.createElement("div",{className:"flex flex-nowrap gap-1 items-center min-h-[1.5rem] w-full overflow-x-auto",style:{scrollbarWidth:"none"}},R&&R.length>0?r.filter(l=>R.includes(l.value)).map(l=>e.createElement("span",{key:l.value,className:"flex items-center border border-blue-200 bg-blue-50 text-blue-700 rounded-2xl px-3 py-1 text-xs shadow-sm mr-1 gap-2",style:{maxWidth:"140px"}},e.createElement("span",{className:"truncate",title:l.label},l.label),e.createElement("button",{type:"button",className:"ml-1 text-[var(--primary,#2563eb)] hover:text-red-500 focus:outline-none w-4 h-4 flex items-center justify-center rounded-full transition-colors duration-150","aria-label":`Remover ${l.label}`,tabIndex:-1,onClick:T=>{T.stopPropagation();const n=R.filter(I=>I!==l.value);m&&t&&m.setValue(t,n),f.onChange&&f.onChange({target:{value:n}})}},e.createElement("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M3 3L9 9M9 3L3 9",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"}))))):!a&&!p&&e.createElement("span",{className:"text-gray-400 text-sm"},"Selecione..."),p&&e.createElement("input",{ref:W,type:"text",value:h,onChange:le,onFocus:l=>{B(!0),v(!0),g&&g(l)},onBlur:l=>{w&&w(l)},placeholder:a?R&&R.length>0?"":P:P||"Selecione...",className:"flex-1 bg-transparent border-none outline-none text-sm min-w-[100px]"})),N&&R&&R.length>0&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:ee},"✕")),a&&e.createElement("label",{htmlFor:f.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",F?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},a),e.createElement("div",{className:i("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",d?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:d?"9.5rem":"0",overflowY:r.length>3?"auto":"hidden",position:"fixed",top:d?`${b.top}px`:"auto",left:d?`${b.left}px`:"auto",width:d?`${b.width}px`:"auto",zIndex:9999,boxShadow:d?"var(--select-dropdown-shadow)":"none"}},O.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},"Nenhuma opção encontrada"):O.map(l=>e.createElement("div",{key:l.value,className:i("px-3 py-2 cursor-pointer text-sm flex items-center gap-2 transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",R.includes(l.value)&&"bg-[var(--select-dropdown-selected)] font-semibold"),onMouseDown:()=>Z(l.value)},e.createElement("input",{type:"checkbox",checked:R.includes(l.value),readOnly:!0,className:"accent-blue-500"}),l.label))),G&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},G))});Re.displayName="MultiSelect";const Fe=e.forwardRef(({name:t,label:a,loadOptions:r,className:o,containerClassName:c,isClearable:N,defaultOptions:p=!1,loadingMessage:P="Carregando...",noOptionsMessage:_="Nenhuma opção encontrada",searchable:k=!1,debounceMs:g=300,maxSelectedDisplay:w=3,onFocus:f,onBlur:M,...E},B)=>{var u,A,re;const[d,v]=e.useState(!1),[h,C]=e.useState(!1),[b,y]=e.useState([]),[S,W]=e.useState(!1),[m,$]=e.useState(""),[D,R]=e.useState(""),[G,J]=e.useState({top:0,left:0,width:0}),V=e.useRef(null),O=e.useRef(null),F=q.useFormContext(),Q=F==null?void 0:F.control,z=Q&&t?q.useWatch({control:Q,name:t}):void 0,H=E.value??z??[],X=(re=(A=(u=F==null?void 0:F.formState)==null?void 0:u.errors)==null?void 0:A[t])==null?void 0:re.message,ne=d||H&&H.length>0,Z=e.useCallback(()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)||window.innerWidth<=768,[]),ee=e.useCallback(()=>{if(V.current&&h){const s=V.current.getBoundingClientRect(),L=Z(),K=window.innerHeight,ie=window.innerWidth,se=152;let de=s.bottom+4,ce=s.left;if(L){const ue=K-s.bottom,_e=s.top;ue<se&&_e>se&&(de=s.top-se-4);const we=16,Te=ie-s.width-we;ce=Math.min(Math.max(ce,we),Te)}else K-s.bottom<se&&(de=s.top-se-4);J({top:de,left:ce,width:s.width})}},[h,Z]);e.useEffect(()=>{if(ee(),h){const s=()=>ee(),L=()=>ee();return window.addEventListener("resize",s),window.addEventListener("scroll",L,!0),()=>{window.removeEventListener("resize",s),window.removeEventListener("scroll",L,!0)}}},[h,ee]),e.useEffect(()=>{const s=setTimeout(()=>{R(m)},g);return()=>clearTimeout(s)},[m,g]),e.useEffect(()=>{(h||p&&b.length===0)&&le(k?D:void 0)},[D,h]),e.useEffect(()=>{p===!0?le():Array.isArray(p)&&y(p)},[]);const le=async s=>{try{W(!0);const L=await r(s);y(L)}catch(L){console.error("Error loading options:",L),y([])}finally{W(!1)}};e.useEffect(()=>{const s=L=>{V.current&&!V.current.contains(L.target)&&(C(!1),v(!1),$(""))};return document.addEventListener("mousedown",s),()=>{document.removeEventListener("mousedown",s)}},[]);const oe=()=>{h||(C(!0),v(!0),k&&O.current&&setTimeout(()=>{var s;return(s=O.current)==null?void 0:s.focus()},0))},te=s=>{v(!0),f&&f(s)},ae=s=>{M&&M(s)},l=s=>{$(s.target.value)},T=s=>{let L;H.includes(s)?L=H.filter(K=>K!==s):L=[...H,s],F&&t&&F.setValue(t,L),E.onChange&&E.onChange({target:{value:L}}),v(!0)},n=(s,L)=>{L.stopPropagation();const K=H.filter(ie=>ie!==s);F&&t&&F.setValue(t,K),E.onChange&&E.onChange({target:{value:K}})},I=s=>{s.stopPropagation(),F&&t&&F.setValue(t,[]),E.onChange&&E.onChange({target:{value:[]}}),C(!1),v(!1),$("")},j=b.filter(s=>H.includes(s.value)),U=j.slice(0,w),Y=j.length-w;return e.createElement("div",{className:i("relative",c),ref:V},e.createElement("div",{id:E.id||t,tabIndex:k?-1:0,role:"button","aria-haspopup":"listbox","aria-expanded":h,className:i("peer flex items-center min-h-12 w-full border border-[var(--primary,#2563eb)] rounded-md bg-[var(--input-bg,#fff)] text-[var(--input-text,#222)] px-3 py-2 text-sm transition focus:outline-none focus:border-[var(--primary,#2563eb)] disabled:cursor-not-allowed disabled:opacity-50 appearance-none cursor-pointer relative",o),onClick:oe,onFocus:k?void 0:te,onBlur:k?void 0:ae,ref:B},e.createElement("div",{className:"flex flex-wrap gap-1 items-center min-h-[1.5rem] w-full"},U.map(s=>e.createElement("span",{key:s.value,className:"flex items-center border border-blue-200 bg-blue-50 text-blue-700 rounded-2xl px-3 py-1 text-xs shadow-sm gap-2",style:{maxWidth:"140px"}},e.createElement("span",{className:"truncate",title:s.label},s.label),e.createElement("button",{type:"button",className:"ml-1 text-[var(--primary,#2563eb)] hover:text-red-500 focus:outline-none w-4 h-4 flex items-center justify-center rounded-full transition-colors duration-150","aria-label":`Remover ${s.label}`,tabIndex:-1,onClick:L=>n(s.value,L)},e.createElement("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M3 3L9 9M9 3L3 9",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"}))))),Y>0&&e.createElement("span",{className:"flex items-center border border-gray-200 bg-gray-100 text-gray-600 rounded-2xl px-3 py-1 text-xs"},"+",Y," mais"),k?e.createElement("input",{ref:O,type:"text",value:m,onChange:l,onFocus:te,onBlur:ae,placeholder:H.length===0&&!a?"Selecione...":"",className:"flex-1 min-w-[120px] bg-transparent border-none outline-none text-sm"}):H.length===0&&!a&&e.createElement("span",{className:"text-gray-400 text-sm"},"Selecione...")),S&&e.createElement("div",{className:"absolute right-8 top-1/2 -translate-y-1/2"},e.createElement("div",{className:"animate-spin rounded-full h-4 w-4 border-b-2 border-[var(--primary,#2563eb)]"})),N&&H&&H.length>0&&!S&&e.createElement("button",{type:"button",tabIndex:-1,"aria-label":"Limpar seleção",className:"absolute right-2 top-1/2 -translate-y-1/2 text-gray-400 hover:text-red-500 bg-transparent p-1 rounded-full focus:outline-none",onClick:I},"✕")),a&&e.createElement("label",{htmlFor:E.id||t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm text-gray-400 transition-all duration-200",ne?"top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white":"top-3 scale-100 translate-y-0.5")},a),e.createElement("div",{className:i("absolute left-0 w-full mt-1 rounded-md transition-all duration-200 overflow-hidden","bg-[var(--select-dropdown-bg)] border-[var(--select-dropdown-border)] text-[var(--select-dropdown-text)]",h?"border max-h-36 opacity-100 scale-100":"max-h-0 opacity-0 scale-95 pointer-events-none"),style:{maxHeight:h?"9.5rem":"0",overflowY:b.length>3?"auto":"hidden",position:"fixed",top:h?`${G.top}px`:"auto",left:h?`${G.left}px`:"auto",width:h?`${G.width}px`:"auto",zIndex:9999,boxShadow:h?"var(--select-dropdown-shadow)":"none"}},S?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},P):b.length===0?e.createElement("div",{className:"px-3 py-2 text-sm text-gray-500 text-center"},_):b.map(s=>e.createElement("div",{key:s.value,className:i("px-3 py-2 cursor-pointer text-sm flex items-center gap-2 transition-colors duration-150","hover:bg-[var(--select-dropdown-hover)]",H.includes(s.value)&&"bg-[var(--select-dropdown-selected)] font-semibold"),onMouseDown:()=>T(s.value)},e.createElement("input",{type:"checkbox",checked:H.includes(s.value),readOnly:!0,className:"accent-blue-500"}),s.label))),X&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},X))});Fe.displayName="MultiAsyncSelect";const Oe={sm:"h-10 text-sm px-3",md:"h-12 text-base px-4",lg:"h-16 text-lg px-6"},Me=e.forwardRef(({name:t,label:a,options:r,className:o,containerClassName:c,optionClassName:N,direction:p="row",size:P="md",onFocus:_,onBlur:k,...g},w)=>{var h,C,b;const f=q.useFormContext(),M=f==null?void 0:f.control,E=M&&t?q.useWatch({control:M,name:t}):void 0,B=g.value??E??"",d=(b=(C=(h=f==null?void 0:f.formState)==null?void 0:h.errors)==null?void 0:C[t])==null?void 0:b.message,v=y=>{f&&t&&f.setValue(t,y),g.onChange&&g.onChange({target:{value:y}})};return e.createElement("div",{className:i("relative",c),ref:w},a&&e.createElement("label",{htmlFor:t,className:i("absolute left-3 z-10 origin-[0] cursor-text select-none text-sm transition-all duration-200","top-0 scale-90 -translate-y-1 text-xs text-[var(--primary,#2563eb)] p-1 rounded-full bg-white")},a),e.createElement("div",{className:i("flex gap-2 w-full pt-6",p==="row"?"flex-row":"flex-col",o),"aria-label":a,tabIndex:-1,onFocus:_,onBlur:k},r.map(y=>e.createElement("button",{key:y.value,type:"button",className:i("relative flex items-center justify-center border rounded-lg transition-all duration-200 shadow-sm px-4 focus:outline-none focus:ring-2 focus:ring-[var(--primary-hover,#dbeafe)]",Oe[P],B===y.value?"border-[var(--primary,#2563eb)] bg-[var(--primary-hover,#dbeafe)] text-[var(--primary,#2563eb)] ring-2 ring-[var(--primary-hover,#dbeafe)] shadow-md transform scale-[1.02]":"border-gray-200 bg-white text-gray-600 hover:border-[var(--primary,#2563eb)] hover:bg-[var(--primary-hover,#dbeafe)] hover:text-[var(--primary,#2563eb)] hover:shadow-md",N),"aria-pressed":B===y.value,"data-selected":B===y.value,tabIndex:0,onClick:()=>v(y.value),onKeyDown:S=>{(S.key==="Enter"||S.key===" ")&&(S.preventDefault(),v(y.value))}},y.icon&&e.createElement("span",{className:"mr-2 text-lg flex items-center"},y.icon),e.createElement("span",{className:"truncate font-medium"},y.label)))),d&&e.createElement("span",{className:"text-red-500 text-xs mt-1 block"},d))});Me.displayName="RadioGroup";const fe=x.forwardRef(({children:t,className:a,as:r="div",...o},c)=>x.createElement(r,{ref:c,className:i("px-6 py-4 border-b","bg-[var(--card-header-bg,rgba(249,250,251,0.5))]","border-[var(--card-header-border,#e5e7eb)]","text-[var(--card-text,#111827)]",a),...o},t));fe.displayName="CardHeader";const me=x.forwardRef(({children:t,className:a,as:r="div",...o},c)=>x.createElement(r,{ref:c,className:i("px-6 py-4","flex-1","bg-[var(--card-bg,#ffffff)]","text-[var(--card-text,#111827)]",a),...o},t));me.displayName="CardBody";const pe=x.forwardRef(({children:t,className:a,as:r="div",...o},c)=>x.createElement(r,{ref:c,className:i("px-6 py-4 border-t","bg-[var(--card-footer-bg,rgba(249,250,251,0.5))]","border-[var(--card-footer-border,#e5e7eb)]","text-[var(--card-text,#111827)]",a),...o},t));pe.displayName="CardFooter";const Ae=x.forwardRef(({children:t,className:a,variant:r="default",size:o="md",padding:c="none",rounded:N="lg",constrainWidth:p=!1,allowOverflow:P=!1,..._},k)=>{const g={default:"bg-[var(--card-bg,#ffffff)] border border-[var(--card-border,#e5e7eb)] shadow-[var(--card-shadow-sm,0_1px_2px_0_rgb(0_0_0_/_0.05))]",outlined:"bg-[var(--card-bg,#ffffff)] border-2 border-[var(--primary,#2563eb)]",elevated:"bg-[var(--card-bg,#ffffff)] border border-[var(--card-border,#e5e7eb)] shadow-[var(--card-shadow-lg,0_10px_15px_-3px_rgb(0_0_0_/_0.1),_0_4px_6px_-4px_rgb(0_0_0_/_0.1))]",flat:"bg-[var(--card-bg,#ffffff)] border-0"},w={sm:"max-w-sm",md:"max-w-md",lg:"max-w-lg"},f={none:"",sm:"p-3",md:"p-4",lg:"p-6"},M={none:"rounded-none",sm:"rounded-sm",md:"rounded-md",lg:"rounded-lg",xl:"rounded-xl"};return x.createElement("div",{ref:k,className:i("flex flex-col",!P&&"overflow-hidden",g[r],p&&w[o],f[c],M[N],a),..._},t)}),ze=Object.assign(Ae,{Header:fe,Body:me,Footer:pe}),Be=x.forwardRef(({children:t,className:a,variant:r="default",size:o="md",responsive:c=!1,stickyHeader:N=!1,...p},P)=>{const _=i("w-full border-collapse bg-[var(--table-bg)] text-[var(--table-text)]",{"border border-[var(--table-border)]":r==="bordered"},{"text-sm":o==="sm","text-base":o==="md","text-lg":o==="lg"},a),k=i({"overflow-x-auto":c,"max-h-96 overflow-y-auto":N}),g=x.createElement("table",{ref:P,className:_,...p},t);return c||N?x.createElement("div",{className:k},g):g}),be=x.forwardRef(({children:t,className:a,as:r="thead",...o},c)=>x.createElement(r,{ref:c,className:i("border-b border-[var(--table-border)] bg-[var(--table-header-bg)]",{"sticky top-0 z-10":r==="thead"},a),...o},t)),ve=x.forwardRef(({children:t,className:a,as:r="tbody",...o},c)=>x.createElement(r,{ref:c,className:i("[&_tr:nth-child(odd)]:bg-[var(--table-row-odd)]","[&_tr:nth-child(even)]:bg-[var(--table-row-even)]",a),...o},t)),xe=x.forwardRef(({children:t,className:a,as:r="tfoot",...o},c)=>x.createElement(r,{ref:c,className:i("border-t border-[var(--table-border)] bg-[var(--table-header-bg)] font-medium",a),...o},t)),ge=x.forwardRef(({children:t,className:a,variant:r="default",...o},c)=>x.createElement("tr",{ref:c,className:i("border-b border-[var(--table-border)] transition-colors",{"hover:bg-[var(--table-row-hover)]":r==="hover","bg-[var(--table-row-selected)]":r==="selected"},a),...o},t)),he=x.forwardRef(({children:t,className:a,as:r="td",align:o="left",scope:c,colSpan:N,rowSpan:p,...P},_)=>x.createElement(r,{ref:_,scope:r==="th"?c:void 0,colSpan:N,rowSpan:p,className:i("px-4 py-3 text-left",{"font-semibold":r==="th","text-sm":r==="td","text-center":o==="center","text-right":o==="right"},a),...P},t));Be.displayName="Table";be.displayName="TableHeader";ve.displayName="TableBody";xe.displayName="TableFooter";ge.displayName="TableRow";he.displayName="TableCell";const He=Object.assign(Be,{Header:be,Body:ve,Footer:xe,Row:ge,Cell:he}),$e=({content:t,children:a,position:r="top",className:o="",disabled:c=!1})=>{const[N,p]=x.useState(!1),[P,_]=x.useState(r),[k,g]=x.useState({}),w=x.useRef(null),f=x.useRef(null);x.useEffect(()=>{if(!N||!f.current)return;const b=f.current.getBoundingClientRect();let y=r,S=0,W=0;switch(r){case"top":S=b.top-8,W=b.left+b.width/2;break;case"bottom":S=b.bottom+8,W=b.left+b.width/2;break;case"left":S=b.top+b.height/2,W=b.left-8;break;case"right":S=b.top+b.height/2,W=b.right+8;break}if(w.current){const m=w.current.getBoundingClientRect(),$=window.innerWidth,D=window.innerHeight;r==="top"&&b.top<m.height+16?(y="bottom",S=b.bottom+8):r==="bottom"&&b.bottom+m.height+16>D?(y="top",S=b.top-8):r==="left"&&b.left<m.width+16?(y="right",W=b.right+8):r==="right"&&b.right+m.width+16>$&&(y="left",W=b.left-8)}_(y),g({position:"fixed",top:`${S}px`,left:`${W}px`,zIndex:9999})},[N,r]);const M=()=>{c||p(!0)},E=()=>{p(!1)},B=()=>{c||p(!0)},d=()=>{p(!1)},v=()=>{const C="pointer-events-none";switch(P){case"top":return`${C} transform -translate-x-1/2 -translate-y-full`;case"bottom":return`${C} transform -translate-x-1/2`;case"left":return`${C} transform -translate-x-full -translate-y-1/2`;case"right":return`${C} transform -translate-y-1/2`;default:return`${C} transform -translate-x-1/2 -translate-y-full`}},h=()=>{const C="absolute w-2 h-2 bg-[var(--tooltip-bg,#374151)] transform rotate-45";switch(P){case"top":return`${C} top-full left-1/2 -translate-x-1/2 -translate-y-1/2`;case"bottom":return`${C} bottom-full left-1/2 -translate-x-1/2 translate-y-1/2`;case"left":return`${C} left-full top-1/2 -translate-y-1/2 -translate-x-1/2`;case"right":return`${C} right-full top-1/2 -translate-y-1/2 translate-x-1/2`;default:return`${C} top-full left-1/2 -translate-x-1/2 -translate-y-1/2`}};return c||!t?x.createElement(x.Fragment,null,a):x.createElement(x.Fragment,null,x.createElement("div",{className:"relative inline-block",ref:f,onMouseEnter:M,onMouseLeave:E,onFocus:B,onBlur:d},a),N&&typeof document<"u"&&ye.createPortal(x.createElement("div",{ref:w,style:k,className:i(v(),"px-2 py-1 text-sm rounded whitespace-nowrap","bg-[var(--tooltip-bg,#374151)] text-[var(--tooltip-text,#fff)]","shadow-[var(--tooltip-shadow,0_10px_15px_-3px_rgb(0_0_0_/_0.1),_0_4px_6px_-4px_rgb(0_0_0_/_0.1))]","transition-opacity duration-200 ease-in-out",o),role:"tooltip","aria-hidden":!N},t,x.createElement("div",{className:h()})),document.body))},Le=({open:t,onClose:a,side:r="right",size:o="md",closeOnOverlayClick:c=!0,children:N,className:p="",...P})=>{const _=typeof document<"u"?document.body:null,k=o==="sm"?"w-64":o==="md"?"w-96":o==="lg"?"w-[36rem]":void 0,g=typeof o=="string"&&!["sm","md","lg"].includes(o)?{width:o}:void 0,w=x.createElement("div",{"aria-hidden":!t,className:i("fixed inset-0 z-50 flex",t?"pointer-events-auto":"pointer-events-none")},x.createElement("div",{className:i("absolute inset-0 bg-black/40 transition-opacity duration-200",t?"opacity-100":"opacity-0"),onMouseDown:f=>{c&&f.target===f.currentTarget&&a()}}),x.createElement("div",{className:i("relative h-full",r==="right"?"ml-auto":"mr-auto","flex-shrink-0"),style:g},x.createElement("aside",{role:"dialog","aria-modal":!0,className:i("h-full bg-white shadow-xl border-l border-gray-100 overflow-auto transition-transform duration-300",r==="right"?t?"translate-x-0":"translate-x-full":t?"translate-x-0":"-translate-x-full",k,p),style:g,...P},N)));return _?ye.createPortal(w,_):null};Le.displayName="AsideSheet";exports.AsideSheet=Le;exports.AsyncSelect=ke;exports.Button=We;exports.Card=ze;exports.CardBody=me;exports.CardFooter=pe;exports.CardHeader=fe;exports.Input=Ce;exports.MultiAsyncSelect=Fe;exports.MultiSelect=Re;exports.RadioGroup=Me;exports.Select=Ne;exports.Table=He;exports.TableBody=ve;exports.TableCell=he;exports.TableFooter=xe;exports.TableHeader=be;exports.TableRow=ge;exports.Textarea=Se;exports.Tooltip=$e;
|