@sudobility/entity-components 1.0.5 → 1.0.7
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/dist/index.esm.js +15 -15
- package/dist/index.umd.js +1 -1
- package/package.json +7 -7
package/dist/index.esm.js
CHANGED
|
@@ -249,14 +249,14 @@ const tr = (e, o) => {
|
|
|
249
249
|
}
|
|
250
250
|
A = !1;
|
|
251
251
|
}
|
|
252
|
-
const Y = x.length === 0 ? "" : x.length === 1 ? x[0] : c(x).join(":"),
|
|
252
|
+
const Y = x.length === 0 ? "" : x.length === 1 ? x[0] : c(x).join(":"), D = N ? Y + me : Y, F = D + T;
|
|
253
253
|
if (n.indexOf(F) > -1)
|
|
254
254
|
continue;
|
|
255
255
|
n.push(F);
|
|
256
256
|
const B = s(T, A);
|
|
257
257
|
for (let O = 0; O < B.length; ++O) {
|
|
258
258
|
const U = B[O];
|
|
259
|
-
n.push(
|
|
259
|
+
n.push(D + U);
|
|
260
260
|
}
|
|
261
261
|
i = f + (i.length > 0 ? " " + i : i);
|
|
262
262
|
}
|
|
@@ -294,14 +294,14 @@ const tr = (e, o) => {
|
|
|
294
294
|
// For example, `hsl(0 0% 0%)` would be classified as a length without this check.
|
|
295
295
|
// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.
|
|
296
296
|
Ir.test(e) && !Ar.test(e)
|
|
297
|
-
), Be = () => !1, Pr = (e) => Sr.test(e), Tr = (e) => Rr.test(e), Or = (e) => !d(e) && !m(e), Gr = (e) => _(e, _e, Be), d = (e) => je.test(e), j = (e) => _(e,
|
|
297
|
+
), Be = () => !1, Pr = (e) => Sr.test(e), Tr = (e) => Rr.test(e), Or = (e) => !d(e) && !m(e), Gr = (e) => _(e, _e, Be), d = (e) => je.test(e), j = (e) => _(e, We, Er), ce = (e) => _(e, Vr, b), Ie = (e) => _(e, Le, Be), jr = (e) => _(e, Ve, Tr), Z = (e) => _(e, De, Pr), m = (e) => Fe.test(e), $ = (e) => W(e, We), Fr = (e) => W(e, _r), Ae = (e) => W(e, Le), Br = (e) => W(e, _e), Lr = (e) => W(e, Ve), ee = (e) => W(e, De, !0), _ = (e, o, r) => {
|
|
298
298
|
const t = je.exec(e);
|
|
299
299
|
return t ? t[1] ? o(t[1]) : r(t[2]) : !1;
|
|
300
|
-
},
|
|
300
|
+
}, W = (e, o, r = !1) => {
|
|
301
301
|
const t = Fe.exec(e);
|
|
302
302
|
return t ? t[1] ? o(t[1]) : r : !1;
|
|
303
|
-
}, Le = (e) => e === "position" || e === "percentage", Ve = (e) => e === "image" || e === "url", _e = (e) => e === "length" || e === "size" || e === "bg-size",
|
|
304
|
-
const e = C("color"), o = C("font"), r = C("text"), t = C("font-weight"), s = C("tracking"), c = C("leading"), n = C("breakpoint"), l = C("container"), i = C("spacing"), u = C("radius"), f = C("shadow"), k = C("inset-shadow"), x = C("text-shadow"), N = C("drop-shadow"), y = C("blur"), v = C("perspective"), A = C("aspect"), T = C("ease"), Y = C("animate"),
|
|
303
|
+
}, Le = (e) => e === "position" || e === "percentage", Ve = (e) => e === "image" || e === "url", _e = (e) => e === "length" || e === "size" || e === "bg-size", We = (e) => e === "length", Vr = (e) => e === "number", _r = (e) => e === "family-name", De = (e) => e === "shadow", Wr = () => {
|
|
304
|
+
const e = C("color"), o = C("font"), r = C("text"), t = C("font-weight"), s = C("tracking"), c = C("leading"), n = C("breakpoint"), l = C("container"), i = C("spacing"), u = C("radius"), f = C("shadow"), k = C("inset-shadow"), x = C("text-shadow"), N = C("drop-shadow"), y = C("blur"), v = C("perspective"), A = C("aspect"), T = C("ease"), Y = C("animate"), D = () => ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"], F = () => [
|
|
305
305
|
"center",
|
|
306
306
|
"top",
|
|
307
307
|
"bottom",
|
|
@@ -395,14 +395,14 @@ const tr = (e, o) => {
|
|
|
395
395
|
* @see https://tailwindcss.com/docs/break-after
|
|
396
396
|
*/
|
|
397
397
|
"break-after": [{
|
|
398
|
-
"break-after":
|
|
398
|
+
"break-after": D()
|
|
399
399
|
}],
|
|
400
400
|
/**
|
|
401
401
|
* Break Before
|
|
402
402
|
* @see https://tailwindcss.com/docs/break-before
|
|
403
403
|
*/
|
|
404
404
|
"break-before": [{
|
|
405
|
-
"break-before":
|
|
405
|
+
"break-before": D()
|
|
406
406
|
}],
|
|
407
407
|
/**
|
|
408
408
|
* Break Inside
|
|
@@ -2770,13 +2770,13 @@ const tr = (e, o) => {
|
|
|
2770
2770
|
},
|
|
2771
2771
|
orderSensitiveModifiers: ["*", "**", "after", "backdrop", "before", "details-content", "file", "first-letter", "first-line", "marker", "placeholder", "selection"]
|
|
2772
2772
|
};
|
|
2773
|
-
},
|
|
2773
|
+
}, Dr = /* @__PURE__ */ kr(Wr);
|
|
2774
2774
|
function h(...e) {
|
|
2775
|
-
return
|
|
2775
|
+
return Dr(rr(e));
|
|
2776
2776
|
}
|
|
2777
2777
|
const Ur = {
|
|
2778
2778
|
owner: "bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",
|
|
2779
|
-
|
|
2779
|
+
manager: "bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",
|
|
2780
2780
|
member: "bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"
|
|
2781
2781
|
};
|
|
2782
2782
|
function $r({
|
|
@@ -3030,8 +3030,8 @@ const de = [
|
|
|
3030
3030
|
color: "text-purple-600 dark:text-purple-400"
|
|
3031
3031
|
},
|
|
3032
3032
|
{
|
|
3033
|
-
value: te.
|
|
3034
|
-
label: "
|
|
3033
|
+
value: te.MANAGER,
|
|
3034
|
+
label: "Manager",
|
|
3035
3035
|
description: "Can manage projects and API keys",
|
|
3036
3036
|
icon: Ye,
|
|
3037
3037
|
color: "text-blue-600 dark:text-blue-400"
|
|
@@ -3131,7 +3131,7 @@ function Ue({
|
|
|
3131
3131
|
}
|
|
3132
3132
|
const Xr = {
|
|
3133
3133
|
owner: "bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",
|
|
3134
|
-
|
|
3134
|
+
manager: "bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",
|
|
3135
3135
|
member: "bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"
|
|
3136
3136
|
};
|
|
3137
3137
|
function ot({
|
|
@@ -3304,7 +3304,7 @@ function qr(e) {
|
|
|
3304
3304
|
}
|
|
3305
3305
|
const Jr = {
|
|
3306
3306
|
owner: "bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",
|
|
3307
|
-
|
|
3307
|
+
manager: "bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",
|
|
3308
3308
|
member: "bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"
|
|
3309
3309
|
};
|
|
3310
3310
|
function nt({
|
package/dist/index.umd.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(z,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("react/jsx-runtime"),require("@heroicons/react/24/outline"),require("react"),require("@sudobility/types")):typeof define=="function"&&define.amd?define(["exports","react/jsx-runtime","@heroicons/react/24/outline","react","@sudobility/types"],r):(z=typeof globalThis<"u"?globalThis:z||self,r(z.EntityComponents={},z.ReactJSXRuntime,z.HeroiconsOutline,z.React,z.SudobilityTypes))})(this,(function(z,r,v,$,J){"use strict";function ue(e){var s,o,t="";if(typeof e=="string"||typeof e=="number")t+=e;else if(typeof e=="object")if(Array.isArray(e)){var a=e.length;for(s=0;s<a;s++)e[s]&&(o=ue(e[s]))&&(t&&(t+=" "),t+=o)}else for(o in e)e[o]&&(t&&(t+=" "),t+=o);return t}function Ue(){for(var e,s,o=0,t="",a=arguments.length;o<a;o++)(e=arguments[o])&&(s=ue(e))&&(t&&(t+=" "),t+=s);return t}const _e=(e,s)=>{const o=new Array(e.length+s.length);for(let t=0;t<e.length;t++)o[t]=e[t];for(let t=0;t<s.length;t++)o[e.length+t]=s[t];return o},We=(e,s)=>({classGroupId:e,validator:s}),fe=(e=new Map,s=null,o)=>({nextPart:e,validators:s,classGroupId:o}),H="-",ge=[],$e="arbitrary..",qe=e=>{const s=Ye(e),{conflictingClassGroups:o,conflictingClassGroupModifiers:t}=e;return{getClassGroupId:n=>{if(n.startsWith("[")&&n.endsWith("]"))return Xe(n);const l=n.split(H),i=l[0]===""&&l.length>1?1:0;return be(l,i,s)},getConflictingClassGroupIds:(n,l)=>{if(l){const i=t[n],m=o[n];return i?m?_e(m,i):i:m||ge}return o[n]||ge}}},be=(e,s,o)=>{if(e.length-s===0)return o.classGroupId;const a=e[s],c=o.nextPart.get(a);if(c){const m=be(e,s+1,c);if(m)return m}const n=o.validators;if(n===null)return;const l=s===0?e.join(H):e.slice(s).join(H),i=n.length;for(let m=0;m<i;m++){const f=n[m];if(f.validator(l))return f.classGroupId}},Xe=e=>e.slice(1,-1).indexOf(":")===-1?void 0:(()=>{const s=e.slice(1,-1),o=s.indexOf(":"),t=s.slice(0,o);return t?$e+t:void 0})(),Ye=e=>{const{theme:s,classGroups:o}=e;return Je(o,s)},Je=(e,s)=>{const o=fe();for(const t in e){const a=e[t];se(a,o,t,s)}return o},se=(e,s,o,t)=>{const a=e.length;for(let c=0;c<a;c++){const n=e[c];He(n,s,o,t)}},He=(e,s,o,t)=>{if(typeof e=="string"){Ke(e,s,o);return}if(typeof e=="function"){Qe(e,s,o,t);return}Ze(e,s,o,t)},Ke=(e,s,o)=>{const t=e===""?s:he(s,e);t.classGroupId=o},Qe=(e,s,o,t)=>{if(Re(e)){se(e(t),s,o,t);return}s.validators===null&&(s.validators=[]),s.validators.push(We(o,e))},Ze=(e,s,o,t)=>{const a=Object.entries(e),c=a.length;for(let n=0;n<c;n++){const[l,i]=a[n];se(i,he(s,l),o,t)}},he=(e,s)=>{let o=e;const t=s.split(H),a=t.length;for(let c=0;c<a;c++){const n=t[c];let l=o.nextPart.get(n);l||(l=fe(),o.nextPart.set(n,l)),o=l}return o},Re=e=>"isThemeGetter"in e&&e.isThemeGetter===!0,er=e=>{if(e<1)return{get:()=>{},set:()=>{}};let s=0,o=Object.create(null),t=Object.create(null);const a=(c,n)=>{o[c]=n,s++,s>e&&(s=0,t=o,o=Object.create(null))};return{get(c){let n=o[c];if(n!==void 0)return n;if((n=t[c])!==void 0)return a(c,n),n},set(c,n){c in o?o[c]=n:a(c,n)}}},ae="!",xe=":",rr=[],ye=(e,s,o,t,a)=>({modifiers:e,hasImportantModifier:s,baseClassName:o,maybePostfixModifierPosition:t,isExternal:a}),or=e=>{const{prefix:s,experimentalParseClassName:o}=e;let t=a=>{const c=[];let n=0,l=0,i=0,m;const f=a.length;for(let w=0;w<f;w++){const A=a[w];if(n===0&&l===0){if(A===xe){c.push(a.slice(i,w)),i=w+1;continue}if(A==="/"){m=w;continue}}A==="["?n++:A==="]"?n--:A==="("?l++:A===")"&&l--}const k=c.length===0?a:a.slice(i);let x=k,N=!1;k.endsWith(ae)?(x=k.slice(0,-1),N=!0):k.startsWith(ae)&&(x=k.slice(1),N=!0);const y=m&&m>i?m-i:void 0;return ye(c,N,x,y)};if(s){const a=s+xe,c=t;t=n=>n.startsWith(a)?c(n.slice(a.length)):ye(rr,!1,n,void 0,!0)}if(o){const a=t;t=c=>o({className:c,parseClassName:a})}return t},tr=e=>{const s=new Map;return e.orderSensitiveModifiers.forEach((o,t)=>{s.set(o,1e6+t)}),o=>{const t=[];let a=[];for(let c=0;c<o.length;c++){const n=o[c],l=n[0]==="[",i=s.has(n);l||i?(a.length>0&&(a.sort(),t.push(...a),a=[]),t.push(n)):a.push(n)}return a.length>0&&(a.sort(),t.push(...a)),t}},sr=e=>({cache:er(e.cacheSize),parseClassName:or(e),sortModifiers:tr(e),...qe(e)}),ar=/\s+/,nr=(e,s)=>{const{parseClassName:o,getClassGroupId:t,getConflictingClassGroupIds:a,sortModifiers:c}=s,n=[],l=e.trim().split(ar);let i="";for(let m=l.length-1;m>=0;m-=1){const f=l[m],{isExternal:k,modifiers:x,hasImportantModifier:N,baseClassName:y,maybePostfixModifierPosition:w}=o(f);if(k){i=f+(i.length>0?" "+i:i);continue}let A=!!w,j=t(A?y.substring(0,w):y);if(!j){if(!A){i=f+(i.length>0?" "+i:i);continue}if(j=t(y),!j){i=f+(i.length>0?" "+i:i);continue}A=!1}const Z=x.length===0?"":x.length===1?x[0]:c(x).join(":"),X=N?Z+ae:Z,U=X+j;if(n.indexOf(U)>-1)continue;n.push(U);const _=a(j,A);for(let F=0;F<_.length;++F){const Y=_[F];n.push(X+Y)}i=f+(i.length>0?" "+i:i)}return i},lr=(...e)=>{let s=0,o,t,a="";for(;s<e.length;)(o=e[s++])&&(t=we(o))&&(a&&(a+=" "),a+=t);return a},we=e=>{if(typeof e=="string")return e;let s,o="";for(let t=0;t<e.length;t++)e[t]&&(s=we(e[t]))&&(o&&(o+=" "),o+=s);return o},ir=(e,...s)=>{let o,t,a,c;const n=i=>{const m=s.reduce((f,k)=>k(f),e());return o=sr(m),t=o.cache.get,a=o.cache.set,c=l,l(i)},l=i=>{const m=t(i);if(m)return m;const f=nr(i,o);return a(i,f),f};return c=n,(...i)=>c(lr(...i))},cr=[],C=e=>{const s=o=>o[e]||cr;return s.isThemeGetter=!0,s},ve=/^\[(?:(\w[\w-]*):)?(.+)\]$/i,ke=/^\((?:(\w[\w-]*):)?(.+)\)$/i,dr=/^\d+\/\d+$/,pr=/^(\d+(\.\d+)?)?(xs|sm|md|lg|xl)$/,mr=/\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\b(calc|min|max|clamp)\(.+\)|^0$/,ur=/^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\(.+\)$/,fr=/^(inset_)?-?((\d+)?\.?(\d+)[a-z]+|0)_-?((\d+)?\.?(\d+)[a-z]+|0)/,gr=/^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\(.+\)$/,B=e=>dr.test(e),b=e=>!!e&&!Number.isNaN(Number(e)),O=e=>!!e&&Number.isInteger(Number(e)),ne=e=>e.endsWith("%")&&b(e.slice(0,-1)),E=e=>pr.test(e),br=()=>!0,hr=e=>mr.test(e)&&!ur.test(e),Ne=()=>!1,xr=e=>fr.test(e),yr=e=>gr.test(e),wr=e=>!d(e)&&!p(e),vr=e=>V(e,Ae,Ne),d=e=>ve.test(e),G=e=>V(e,Me,hr),le=e=>V(e,zr,b),Ce=e=>V(e,ze,Ne),kr=e=>V(e,Se,yr),K=e=>V(e,Ee,xr),p=e=>ke.test(e),q=e=>D(e,Me),Nr=e=>D(e,Sr),Ie=e=>D(e,ze),Cr=e=>D(e,Ae),Ir=e=>D(e,Se),Q=e=>D(e,Ee,!0),V=(e,s,o)=>{const t=ve.exec(e);return t?t[1]?s(t[1]):o(t[2]):!1},D=(e,s,o=!1)=>{const t=ke.exec(e);return t?t[1]?s(t[1]):o:!1},ze=e=>e==="position"||e==="percentage",Se=e=>e==="image"||e==="url",Ae=e=>e==="length"||e==="size"||e==="bg-size",Me=e=>e==="length",zr=e=>e==="number",Sr=e=>e==="family-name",Ee=e=>e==="shadow",Ar=ir(()=>{const e=C("color"),s=C("font"),o=C("text"),t=C("font-weight"),a=C("tracking"),c=C("leading"),n=C("breakpoint"),l=C("container"),i=C("spacing"),m=C("radius"),f=C("shadow"),k=C("inset-shadow"),x=C("text-shadow"),N=C("drop-shadow"),y=C("blur"),w=C("perspective"),A=C("aspect"),j=C("ease"),Z=C("animate"),X=()=>["auto","avoid","all","avoid-page","page","left","right","column"],U=()=>["center","top","bottom","left","right","top-left","left-top","top-right","right-top","bottom-right","right-bottom","bottom-left","left-bottom"],_=()=>[...U(),p,d],F=()=>["auto","hidden","clip","visible","scroll"],Y=()=>["auto","contain","none"],g=()=>[p,d,i],P=()=>[B,"full","auto",...g()],Oe=()=>[O,"none","subgrid",p,d],Ge=()=>["auto",{span:["full",O,p,d]},O,p,d],R=()=>[O,"auto",p,d],je=()=>["auto","min","max","fr",p,d],de=()=>["start","end","center","between","around","evenly","stretch","baseline","center-safe","end-safe"],W=()=>["start","end","center","stretch","center-safe","end-safe"],T=()=>["auto",...g()],L=()=>[B,"auto","full","dvw","dvh","lvw","lvh","svw","svh","min","max","fit",...g()],u=()=>[e,p,d],Fe=()=>[...U(),Ie,Ce,{position:[p,d]}],Le=()=>["no-repeat",{repeat:["","x","y","space","round"]}],Be=()=>["auto","cover","contain",Cr,vr,{size:[p,d]}],pe=()=>[ne,q,G],S=()=>["","none","full",m,p,d],M=()=>["",b,q,G],ee=()=>["solid","dashed","dotted","double"],Ve=()=>["normal","multiply","screen","overlay","darken","lighten","color-dodge","color-burn","hard-light","soft-light","difference","exclusion","hue","saturation","color","luminosity"],I=()=>[b,ne,Ie,Ce],De=()=>["","none",y,p,d],re=()=>["none",b,p,d],oe=()=>["none",b,p,d],me=()=>[b,p,d],te=()=>[B,"full",...g()];return{cacheSize:500,theme:{animate:["spin","ping","pulse","bounce"],aspect:["video"],blur:[E],breakpoint:[E],color:[br],container:[E],"drop-shadow":[E],ease:["in","out","in-out"],font:[wr],"font-weight":["thin","extralight","light","normal","medium","semibold","bold","extrabold","black"],"inset-shadow":[E],leading:["none","tight","snug","normal","relaxed","loose"],perspective:["dramatic","near","normal","midrange","distant","none"],radius:[E],shadow:[E],spacing:["px",b],text:[E],"text-shadow":[E],tracking:["tighter","tight","normal","wide","wider","widest"]},classGroups:{aspect:[{aspect:["auto","square",B,d,p,A]}],container:["container"],columns:[{columns:[b,d,p,l]}],"break-after":[{"break-after":X()}],"break-before":[{"break-before":X()}],"break-inside":[{"break-inside":["auto","avoid","avoid-page","avoid-column"]}],"box-decoration":[{"box-decoration":["slice","clone"]}],box:[{box:["border","content"]}],display:["block","inline-block","inline","flex","inline-flex","table","inline-table","table-caption","table-cell","table-column","table-column-group","table-footer-group","table-header-group","table-row-group","table-row","flow-root","grid","inline-grid","contents","list-item","hidden"],sr:["sr-only","not-sr-only"],float:[{float:["right","left","none","start","end"]}],clear:[{clear:["left","right","both","none","start","end"]}],isolation:["isolate","isolation-auto"],"object-fit":[{object:["contain","cover","fill","none","scale-down"]}],"object-position":[{object:_()}],overflow:[{overflow:F()}],"overflow-x":[{"overflow-x":F()}],"overflow-y":[{"overflow-y":F()}],overscroll:[{overscroll:Y()}],"overscroll-x":[{"overscroll-x":Y()}],"overscroll-y":[{"overscroll-y":Y()}],position:["static","fixed","absolute","relative","sticky"],inset:[{inset:P()}],"inset-x":[{"inset-x":P()}],"inset-y":[{"inset-y":P()}],start:[{start:P()}],end:[{end:P()}],top:[{top:P()}],right:[{right:P()}],bottom:[{bottom:P()}],left:[{left:P()}],visibility:["visible","invisible","collapse"],z:[{z:[O,"auto",p,d]}],basis:[{basis:[B,"full","auto",l,...g()]}],"flex-direction":[{flex:["row","row-reverse","col","col-reverse"]}],"flex-wrap":[{flex:["nowrap","wrap","wrap-reverse"]}],flex:[{flex:[b,B,"auto","initial","none",d]}],grow:[{grow:["",b,p,d]}],shrink:[{shrink:["",b,p,d]}],order:[{order:[O,"first","last","none",p,d]}],"grid-cols":[{"grid-cols":Oe()}],"col-start-end":[{col:Ge()}],"col-start":[{"col-start":R()}],"col-end":[{"col-end":R()}],"grid-rows":[{"grid-rows":Oe()}],"row-start-end":[{row:Ge()}],"row-start":[{"row-start":R()}],"row-end":[{"row-end":R()}],"grid-flow":[{"grid-flow":["row","col","dense","row-dense","col-dense"]}],"auto-cols":[{"auto-cols":je()}],"auto-rows":[{"auto-rows":je()}],gap:[{gap:g()}],"gap-x":[{"gap-x":g()}],"gap-y":[{"gap-y":g()}],"justify-content":[{justify:[...de(),"normal"]}],"justify-items":[{"justify-items":[...W(),"normal"]}],"justify-self":[{"justify-self":["auto",...W()]}],"align-content":[{content:["normal",...de()]}],"align-items":[{items:[...W(),{baseline:["","last"]}]}],"align-self":[{self:["auto",...W(),{baseline:["","last"]}]}],"place-content":[{"place-content":de()}],"place-items":[{"place-items":[...W(),"baseline"]}],"place-self":[{"place-self":["auto",...W()]}],p:[{p:g()}],px:[{px:g()}],py:[{py:g()}],ps:[{ps:g()}],pe:[{pe:g()}],pt:[{pt:g()}],pr:[{pr:g()}],pb:[{pb:g()}],pl:[{pl:g()}],m:[{m:T()}],mx:[{mx:T()}],my:[{my:T()}],ms:[{ms:T()}],me:[{me:T()}],mt:[{mt:T()}],mr:[{mr:T()}],mb:[{mb:T()}],ml:[{ml:T()}],"space-x":[{"space-x":g()}],"space-x-reverse":["space-x-reverse"],"space-y":[{"space-y":g()}],"space-y-reverse":["space-y-reverse"],size:[{size:L()}],w:[{w:[l,"screen",...L()]}],"min-w":[{"min-w":[l,"screen","none",...L()]}],"max-w":[{"max-w":[l,"screen","none","prose",{screen:[n]},...L()]}],h:[{h:["screen","lh",...L()]}],"min-h":[{"min-h":["screen","lh","none",...L()]}],"max-h":[{"max-h":["screen","lh",...L()]}],"font-size":[{text:["base",o,q,G]}],"font-smoothing":["antialiased","subpixel-antialiased"],"font-style":["italic","not-italic"],"font-weight":[{font:[t,p,le]}],"font-stretch":[{"font-stretch":["ultra-condensed","extra-condensed","condensed","semi-condensed","normal","semi-expanded","expanded","extra-expanded","ultra-expanded",ne,d]}],"font-family":[{font:[Nr,d,s]}],"fvn-normal":["normal-nums"],"fvn-ordinal":["ordinal"],"fvn-slashed-zero":["slashed-zero"],"fvn-figure":["lining-nums","oldstyle-nums"],"fvn-spacing":["proportional-nums","tabular-nums"],"fvn-fraction":["diagonal-fractions","stacked-fractions"],tracking:[{tracking:[a,p,d]}],"line-clamp":[{"line-clamp":[b,"none",p,le]}],leading:[{leading:[c,...g()]}],"list-image":[{"list-image":["none",p,d]}],"list-style-position":[{list:["inside","outside"]}],"list-style-type":[{list:["disc","decimal","none",p,d]}],"text-alignment":[{text:["left","center","right","justify","start","end"]}],"placeholder-color":[{placeholder:u()}],"text-color":[{text:u()}],"text-decoration":["underline","overline","line-through","no-underline"],"text-decoration-style":[{decoration:[...ee(),"wavy"]}],"text-decoration-thickness":[{decoration:[b,"from-font","auto",p,G]}],"text-decoration-color":[{decoration:u()}],"underline-offset":[{"underline-offset":[b,"auto",p,d]}],"text-transform":["uppercase","lowercase","capitalize","normal-case"],"text-overflow":["truncate","text-ellipsis","text-clip"],"text-wrap":[{text:["wrap","nowrap","balance","pretty"]}],indent:[{indent:g()}],"vertical-align":[{align:["baseline","top","middle","bottom","text-top","text-bottom","sub","super",p,d]}],whitespace:[{whitespace:["normal","nowrap","pre","pre-line","pre-wrap","break-spaces"]}],break:[{break:["normal","words","all","keep"]}],wrap:[{wrap:["break-word","anywhere","normal"]}],hyphens:[{hyphens:["none","manual","auto"]}],content:[{content:["none",p,d]}],"bg-attachment":[{bg:["fixed","local","scroll"]}],"bg-clip":[{"bg-clip":["border","padding","content","text"]}],"bg-origin":[{"bg-origin":["border","padding","content"]}],"bg-position":[{bg:Fe()}],"bg-repeat":[{bg:Le()}],"bg-size":[{bg:Be()}],"bg-image":[{bg:["none",{linear:[{to:["t","tr","r","br","b","bl","l","tl"]},O,p,d],radial:["",p,d],conic:[O,p,d]},Ir,kr]}],"bg-color":[{bg:u()}],"gradient-from-pos":[{from:pe()}],"gradient-via-pos":[{via:pe()}],"gradient-to-pos":[{to:pe()}],"gradient-from":[{from:u()}],"gradient-via":[{via:u()}],"gradient-to":[{to:u()}],rounded:[{rounded:S()}],"rounded-s":[{"rounded-s":S()}],"rounded-e":[{"rounded-e":S()}],"rounded-t":[{"rounded-t":S()}],"rounded-r":[{"rounded-r":S()}],"rounded-b":[{"rounded-b":S()}],"rounded-l":[{"rounded-l":S()}],"rounded-ss":[{"rounded-ss":S()}],"rounded-se":[{"rounded-se":S()}],"rounded-ee":[{"rounded-ee":S()}],"rounded-es":[{"rounded-es":S()}],"rounded-tl":[{"rounded-tl":S()}],"rounded-tr":[{"rounded-tr":S()}],"rounded-br":[{"rounded-br":S()}],"rounded-bl":[{"rounded-bl":S()}],"border-w":[{border:M()}],"border-w-x":[{"border-x":M()}],"border-w-y":[{"border-y":M()}],"border-w-s":[{"border-s":M()}],"border-w-e":[{"border-e":M()}],"border-w-t":[{"border-t":M()}],"border-w-r":[{"border-r":M()}],"border-w-b":[{"border-b":M()}],"border-w-l":[{"border-l":M()}],"divide-x":[{"divide-x":M()}],"divide-x-reverse":["divide-x-reverse"],"divide-y":[{"divide-y":M()}],"divide-y-reverse":["divide-y-reverse"],"border-style":[{border:[...ee(),"hidden","none"]}],"divide-style":[{divide:[...ee(),"hidden","none"]}],"border-color":[{border:u()}],"border-color-x":[{"border-x":u()}],"border-color-y":[{"border-y":u()}],"border-color-s":[{"border-s":u()}],"border-color-e":[{"border-e":u()}],"border-color-t":[{"border-t":u()}],"border-color-r":[{"border-r":u()}],"border-color-b":[{"border-b":u()}],"border-color-l":[{"border-l":u()}],"divide-color":[{divide:u()}],"outline-style":[{outline:[...ee(),"none","hidden"]}],"outline-offset":[{"outline-offset":[b,p,d]}],"outline-w":[{outline:["",b,q,G]}],"outline-color":[{outline:u()}],shadow:[{shadow:["","none",f,Q,K]}],"shadow-color":[{shadow:u()}],"inset-shadow":[{"inset-shadow":["none",k,Q,K]}],"inset-shadow-color":[{"inset-shadow":u()}],"ring-w":[{ring:M()}],"ring-w-inset":["ring-inset"],"ring-color":[{ring:u()}],"ring-offset-w":[{"ring-offset":[b,G]}],"ring-offset-color":[{"ring-offset":u()}],"inset-ring-w":[{"inset-ring":M()}],"inset-ring-color":[{"inset-ring":u()}],"text-shadow":[{"text-shadow":["none",x,Q,K]}],"text-shadow-color":[{"text-shadow":u()}],opacity:[{opacity:[b,p,d]}],"mix-blend":[{"mix-blend":[...Ve(),"plus-darker","plus-lighter"]}],"bg-blend":[{"bg-blend":Ve()}],"mask-clip":[{"mask-clip":["border","padding","content","fill","stroke","view"]},"mask-no-clip"],"mask-composite":[{mask:["add","subtract","intersect","exclude"]}],"mask-image-linear-pos":[{"mask-linear":[b]}],"mask-image-linear-from-pos":[{"mask-linear-from":I()}],"mask-image-linear-to-pos":[{"mask-linear-to":I()}],"mask-image-linear-from-color":[{"mask-linear-from":u()}],"mask-image-linear-to-color":[{"mask-linear-to":u()}],"mask-image-t-from-pos":[{"mask-t-from":I()}],"mask-image-t-to-pos":[{"mask-t-to":I()}],"mask-image-t-from-color":[{"mask-t-from":u()}],"mask-image-t-to-color":[{"mask-t-to":u()}],"mask-image-r-from-pos":[{"mask-r-from":I()}],"mask-image-r-to-pos":[{"mask-r-to":I()}],"mask-image-r-from-color":[{"mask-r-from":u()}],"mask-image-r-to-color":[{"mask-r-to":u()}],"mask-image-b-from-pos":[{"mask-b-from":I()}],"mask-image-b-to-pos":[{"mask-b-to":I()}],"mask-image-b-from-color":[{"mask-b-from":u()}],"mask-image-b-to-color":[{"mask-b-to":u()}],"mask-image-l-from-pos":[{"mask-l-from":I()}],"mask-image-l-to-pos":[{"mask-l-to":I()}],"mask-image-l-from-color":[{"mask-l-from":u()}],"mask-image-l-to-color":[{"mask-l-to":u()}],"mask-image-x-from-pos":[{"mask-x-from":I()}],"mask-image-x-to-pos":[{"mask-x-to":I()}],"mask-image-x-from-color":[{"mask-x-from":u()}],"mask-image-x-to-color":[{"mask-x-to":u()}],"mask-image-y-from-pos":[{"mask-y-from":I()}],"mask-image-y-to-pos":[{"mask-y-to":I()}],"mask-image-y-from-color":[{"mask-y-from":u()}],"mask-image-y-to-color":[{"mask-y-to":u()}],"mask-image-radial":[{"mask-radial":[p,d]}],"mask-image-radial-from-pos":[{"mask-radial-from":I()}],"mask-image-radial-to-pos":[{"mask-radial-to":I()}],"mask-image-radial-from-color":[{"mask-radial-from":u()}],"mask-image-radial-to-color":[{"mask-radial-to":u()}],"mask-image-radial-shape":[{"mask-radial":["circle","ellipse"]}],"mask-image-radial-size":[{"mask-radial":[{closest:["side","corner"],farthest:["side","corner"]}]}],"mask-image-radial-pos":[{"mask-radial-at":U()}],"mask-image-conic-pos":[{"mask-conic":[b]}],"mask-image-conic-from-pos":[{"mask-conic-from":I()}],"mask-image-conic-to-pos":[{"mask-conic-to":I()}],"mask-image-conic-from-color":[{"mask-conic-from":u()}],"mask-image-conic-to-color":[{"mask-conic-to":u()}],"mask-mode":[{mask:["alpha","luminance","match"]}],"mask-origin":[{"mask-origin":["border","padding","content","fill","stroke","view"]}],"mask-position":[{mask:Fe()}],"mask-repeat":[{mask:Le()}],"mask-size":[{mask:Be()}],"mask-type":[{"mask-type":["alpha","luminance"]}],"mask-image":[{mask:["none",p,d]}],filter:[{filter:["","none",p,d]}],blur:[{blur:De()}],brightness:[{brightness:[b,p,d]}],contrast:[{contrast:[b,p,d]}],"drop-shadow":[{"drop-shadow":["","none",N,Q,K]}],"drop-shadow-color":[{"drop-shadow":u()}],grayscale:[{grayscale:["",b,p,d]}],"hue-rotate":[{"hue-rotate":[b,p,d]}],invert:[{invert:["",b,p,d]}],saturate:[{saturate:[b,p,d]}],sepia:[{sepia:["",b,p,d]}],"backdrop-filter":[{"backdrop-filter":["","none",p,d]}],"backdrop-blur":[{"backdrop-blur":De()}],"backdrop-brightness":[{"backdrop-brightness":[b,p,d]}],"backdrop-contrast":[{"backdrop-contrast":[b,p,d]}],"backdrop-grayscale":[{"backdrop-grayscale":["",b,p,d]}],"backdrop-hue-rotate":[{"backdrop-hue-rotate":[b,p,d]}],"backdrop-invert":[{"backdrop-invert":["",b,p,d]}],"backdrop-opacity":[{"backdrop-opacity":[b,p,d]}],"backdrop-saturate":[{"backdrop-saturate":[b,p,d]}],"backdrop-sepia":[{"backdrop-sepia":["",b,p,d]}],"border-collapse":[{border:["collapse","separate"]}],"border-spacing":[{"border-spacing":g()}],"border-spacing-x":[{"border-spacing-x":g()}],"border-spacing-y":[{"border-spacing-y":g()}],"table-layout":[{table:["auto","fixed"]}],caption:[{caption:["top","bottom"]}],transition:[{transition:["","all","colors","opacity","shadow","transform","none",p,d]}],"transition-behavior":[{transition:["normal","discrete"]}],duration:[{duration:[b,"initial",p,d]}],ease:[{ease:["linear","initial",j,p,d]}],delay:[{delay:[b,p,d]}],animate:[{animate:["none",Z,p,d]}],backface:[{backface:["hidden","visible"]}],perspective:[{perspective:[w,p,d]}],"perspective-origin":[{"perspective-origin":_()}],rotate:[{rotate:re()}],"rotate-x":[{"rotate-x":re()}],"rotate-y":[{"rotate-y":re()}],"rotate-z":[{"rotate-z":re()}],scale:[{scale:oe()}],"scale-x":[{"scale-x":oe()}],"scale-y":[{"scale-y":oe()}],"scale-z":[{"scale-z":oe()}],"scale-3d":["scale-3d"],skew:[{skew:me()}],"skew-x":[{"skew-x":me()}],"skew-y":[{"skew-y":me()}],transform:[{transform:[p,d,"","none","gpu","cpu"]}],"transform-origin":[{origin:_()}],"transform-style":[{transform:["3d","flat"]}],translate:[{translate:te()}],"translate-x":[{"translate-x":te()}],"translate-y":[{"translate-y":te()}],"translate-z":[{"translate-z":te()}],"translate-none":["translate-none"],accent:[{accent:u()}],appearance:[{appearance:["none","auto"]}],"caret-color":[{caret:u()}],"color-scheme":[{scheme:["normal","dark","light","light-dark","only-dark","only-light"]}],cursor:[{cursor:["auto","default","pointer","wait","text","move","help","not-allowed","none","context-menu","progress","cell","crosshair","vertical-text","alias","copy","no-drop","grab","grabbing","all-scroll","col-resize","row-resize","n-resize","e-resize","s-resize","w-resize","ne-resize","nw-resize","se-resize","sw-resize","ew-resize","ns-resize","nesw-resize","nwse-resize","zoom-in","zoom-out",p,d]}],"field-sizing":[{"field-sizing":["fixed","content"]}],"pointer-events":[{"pointer-events":["auto","none"]}],resize:[{resize:["none","","y","x"]}],"scroll-behavior":[{scroll:["auto","smooth"]}],"scroll-m":[{"scroll-m":g()}],"scroll-mx":[{"scroll-mx":g()}],"scroll-my":[{"scroll-my":g()}],"scroll-ms":[{"scroll-ms":g()}],"scroll-me":[{"scroll-me":g()}],"scroll-mt":[{"scroll-mt":g()}],"scroll-mr":[{"scroll-mr":g()}],"scroll-mb":[{"scroll-mb":g()}],"scroll-ml":[{"scroll-ml":g()}],"scroll-p":[{"scroll-p":g()}],"scroll-px":[{"scroll-px":g()}],"scroll-py":[{"scroll-py":g()}],"scroll-ps":[{"scroll-ps":g()}],"scroll-pe":[{"scroll-pe":g()}],"scroll-pt":[{"scroll-pt":g()}],"scroll-pr":[{"scroll-pr":g()}],"scroll-pb":[{"scroll-pb":g()}],"scroll-pl":[{"scroll-pl":g()}],"snap-align":[{snap:["start","end","center","align-none"]}],"snap-stop":[{snap:["normal","always"]}],"snap-type":[{snap:["none","x","y","both"]}],"snap-strictness":[{snap:["mandatory","proximity"]}],touch:[{touch:["auto","none","manipulation"]}],"touch-x":[{"touch-pan":["x","left","right"]}],"touch-y":[{"touch-pan":["y","up","down"]}],"touch-pz":["touch-pinch-zoom"],select:[{select:["none","text","all","auto"]}],"will-change":[{"will-change":["auto","scroll","contents","transform",p,d]}],fill:[{fill:["none",...u()]}],"stroke-w":[{stroke:[b,q,G,le]}],stroke:[{stroke:["none",...u()]}],"forced-color-adjust":[{"forced-color-adjust":["auto","none"]}]},conflictingClassGroups:{overflow:["overflow-x","overflow-y"],overscroll:["overscroll-x","overscroll-y"],inset:["inset-x","inset-y","start","end","top","right","bottom","left"],"inset-x":["right","left"],"inset-y":["top","bottom"],flex:["basis","grow","shrink"],gap:["gap-x","gap-y"],p:["px","py","ps","pe","pt","pr","pb","pl"],px:["pr","pl"],py:["pt","pb"],m:["mx","my","ms","me","mt","mr","mb","ml"],mx:["mr","ml"],my:["mt","mb"],size:["w","h"],"font-size":["leading"],"fvn-normal":["fvn-ordinal","fvn-slashed-zero","fvn-figure","fvn-spacing","fvn-fraction"],"fvn-ordinal":["fvn-normal"],"fvn-slashed-zero":["fvn-normal"],"fvn-figure":["fvn-normal"],"fvn-spacing":["fvn-normal"],"fvn-fraction":["fvn-normal"],"line-clamp":["display","overflow"],rounded:["rounded-s","rounded-e","rounded-t","rounded-r","rounded-b","rounded-l","rounded-ss","rounded-se","rounded-ee","rounded-es","rounded-tl","rounded-tr","rounded-br","rounded-bl"],"rounded-s":["rounded-ss","rounded-es"],"rounded-e":["rounded-se","rounded-ee"],"rounded-t":["rounded-tl","rounded-tr"],"rounded-r":["rounded-tr","rounded-br"],"rounded-b":["rounded-br","rounded-bl"],"rounded-l":["rounded-tl","rounded-bl"],"border-spacing":["border-spacing-x","border-spacing-y"],"border-w":["border-w-x","border-w-y","border-w-s","border-w-e","border-w-t","border-w-r","border-w-b","border-w-l"],"border-w-x":["border-w-r","border-w-l"],"border-w-y":["border-w-t","border-w-b"],"border-color":["border-color-x","border-color-y","border-color-s","border-color-e","border-color-t","border-color-r","border-color-b","border-color-l"],"border-color-x":["border-color-r","border-color-l"],"border-color-y":["border-color-t","border-color-b"],translate:["translate-x","translate-y","translate-none"],"translate-none":["translate","translate-x","translate-y","translate-z"],"scroll-m":["scroll-mx","scroll-my","scroll-ms","scroll-me","scroll-mt","scroll-mr","scroll-mb","scroll-ml"],"scroll-mx":["scroll-mr","scroll-ml"],"scroll-my":["scroll-mt","scroll-mb"],"scroll-p":["scroll-px","scroll-py","scroll-ps","scroll-pe","scroll-pt","scroll-pr","scroll-pb","scroll-pl"],"scroll-px":["scroll-pr","scroll-pl"],"scroll-py":["scroll-pt","scroll-pb"],touch:["touch-x","touch-y","touch-pz"],"touch-x":["touch"],"touch-y":["touch"],"touch-pz":["touch"]},conflictingClassGroupModifiers:{"font-size":["leading"]},orderSensitiveModifiers:["*","**","after","backdrop","before","details-content","file","first-letter","first-line","marker","placeholder","selection"]}});function h(...e){return Ar(Ue(e))}const Mr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",admin:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Pe({entity:e,isSelected:s=!1,onClick:o,className:t,onTrack:a,trackingLabel:c,componentName:n="EntityCard"}){const l=e.entityType==="personal",i=l?v.UserIcon:v.BuildingOffice2Icon,m=()=>{a?.({action:"click",trackingLabel:c,componentName:n}),o?.()};return r.jsx("div",{onClick:o?m:void 0,className:h("rounded-lg border p-4 transition-all",o&&"cursor-pointer hover:border-primary",s&&"border-primary bg-primary/5",!s&&"border-border bg-card",t),children:r.jsxs("div",{className:"flex items-start gap-3",children:[r.jsx("div",{className:h("flex h-10 w-10 items-center justify-center rounded-full",l?"bg-blue-100 dark:bg-blue-900":"bg-purple-100 dark:bg-purple-900"),children:e.avatarUrl?r.jsx("img",{src:e.avatarUrl,alt:e.displayName,className:"h-10 w-10 rounded-full object-cover"}):r.jsx(i,{className:h("h-5 w-5",l?"text-blue-600 dark:text-blue-400":"text-purple-600 dark:text-purple-400")})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("h3",{className:"font-medium text-foreground truncate",children:e.displayName}),r.jsx("span",{className:h("text-xs px-2 py-0.5 rounded-full font-medium",Mr[e.userRole]),children:e.userRole})]}),r.jsx("p",{className:"text-sm text-muted-foreground",children:l?"Personal workspace":"Organization"}),e.description&&r.jsx("p",{className:"text-sm text-muted-foreground mt-1 line-clamp-2",children:e.description})]})]})})}function Er({entities:e,selectedSlug:s,onSelect:o,isLoading:t=!1,emptyMessage:a="No workspaces found",className:c,onTrack:n,trackingLabel:l,componentName:i="EntityList"}){if(t)return r.jsx("div",{className:h("space-y-3",c),children:[1,2,3].map(f=>r.jsx("div",{className:"h-24 rounded-lg border border-border bg-muted animate-pulse"},f))});if(e.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",c),children:a});const m=f=>{n?.({action:"select",trackingLabel:l,componentName:i}),o?.(f)};return r.jsx("div",{className:h("space-y-3",c),children:e.map(f=>r.jsx(Pe,{entity:f,isSelected:f.entitySlug===s,onClick:o?()=>m(f):void 0,onTrack:n,trackingLabel:l},f.id))})}function Pr({entities:e,currentEntity:s,onSelect:o,onCreateNew:t,isLoading:a=!1,className:c,onTrack:n,trackingLabel:l,componentName:i="EntitySelector"}){const[m,f]=$.useState(!1),k=()=>{n?.({action:"toggle",trackingLabel:l,componentName:i}),f(!m)},x=y=>{n?.({action:"select",trackingLabel:l,componentName:i}),o(y),f(!1)},N=()=>{n?.({action:"create_new",trackingLabel:l,componentName:i}),t?.(),f(!1)};return r.jsxs("div",{className:h("relative",c),children:[r.jsxs("button",{type:"button",onClick:k,disabled:a,className:h("flex items-center gap-2 px-3 py-2 rounded-lg border","bg-background hover:bg-muted transition-colors","focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2",a&&"opacity-50 cursor-not-allowed"),children:[s?r.jsxs(r.Fragment,{children:[s.entityType==="personal"?r.jsx(v.UserIcon,{className:"h-4 w-4 text-blue-600 dark:text-blue-400"}):r.jsx(v.BuildingOffice2Icon,{className:"h-4 w-4 text-purple-600 dark:text-purple-400"}),r.jsx("span",{className:"font-medium text-sm truncate max-w-[150px]",children:s.displayName})]}):r.jsx("span",{className:"text-sm text-muted-foreground",children:"Select workspace"}),r.jsx(v.ChevronDownIcon,{className:h("h-4 w-4 text-muted-foreground transition-transform",m&&"rotate-180")})]}),m&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>f(!1)}),r.jsx("div",{className:h("absolute top-full left-0 mt-1 z-50","min-w-[220px] rounded-lg border bg-popover shadow-lg","animate-in fade-in-0 zoom-in-95"),children:r.jsxs("div",{className:"p-1",children:[e.filter(y=>y.entityType==="personal").map(y=>r.jsx(Te,{entity:y,isSelected:y.id===s?.id,onClick:()=>x(y)},y.id)),e.some(y=>y.entityType==="personal")&&e.some(y=>y.entityType==="organization")&&r.jsx("div",{className:"my-1 h-px bg-border"}),e.filter(y=>y.entityType==="organization").map(y=>r.jsx(Te,{entity:y,isSelected:y.id===s?.id,onClick:()=>x(y)},y.id)),t&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"my-1 h-px bg-border"}),r.jsxs("button",{type:"button",onClick:N,className:h("flex items-center gap-2 w-full px-2 py-1.5 rounded","text-sm text-primary hover:bg-muted transition-colors"),children:[r.jsx(v.PlusIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Create organization"})]})]})]})})]})]})}function Te({entity:e,isSelected:s,onClick:o}){const t=e.entityType==="personal",a=t?v.UserIcon:v.BuildingOffice2Icon;return r.jsxs("button",{type:"button",onClick:o,className:h("flex items-center gap-2 w-full px-2 py-1.5 rounded","text-sm transition-colors",s?"bg-primary/10 text-primary":"hover:bg-muted text-foreground"),children:[r.jsx(a,{className:h("h-4 w-4",t?"text-blue-600 dark:text-blue-400":"text-purple-600 dark:text-purple-400")}),r.jsx("span",{className:"flex-1 text-left truncate",children:e.displayName}),s&&r.jsx(v.CheckIcon,{className:"h-4 w-4"})]})}const ie=[{value:J.EntityRole.OWNER,label:"Owner",description:"Full access to all settings and members",icon:v.ShieldCheckIcon,color:"text-purple-600 dark:text-purple-400"},{value:J.EntityRole.ADMIN,label:"Admin",description:"Can manage projects and API keys",icon:v.BriefcaseIcon,color:"text-blue-600 dark:text-blue-400"},{value:J.EntityRole.MEMBER,label:"Member",description:"Read-only access",icon:v.EyeIcon,color:"text-gray-600 dark:text-gray-400"}];function ce({value:e,onChange:s,disabled:o=!1,className:t,onTrack:a,trackingLabel:c,componentName:n="MemberRoleSelector"}){const[l,i]=$.useState(!1),m=ie.find(x=>x.value===e)||ie[2],f=()=>{o||(a?.({action:"toggle",trackingLabel:c,componentName:n}),i(!l))},k=x=>{a?.({action:"select",trackingLabel:c,componentName:n}),s(x),i(!1)};return r.jsxs("div",{className:h("relative",t),children:[r.jsxs("button",{type:"button",onClick:f,disabled:o,className:h("flex items-center gap-1.5 px-2 py-1 rounded border text-sm","bg-background transition-colors",o?"opacity-50 cursor-not-allowed":"hover:bg-muted cursor-pointer"),children:[r.jsx(m.icon,{className:h("h-3.5 w-3.5",m.color)}),r.jsx("span",{children:m.label}),r.jsx(v.ChevronDownIcon,{className:h("h-3.5 w-3.5 text-muted-foreground transition-transform",l&&"rotate-180")})]}),l&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>i(!1)}),r.jsx("div",{className:h("absolute top-full right-0 mt-1 z-50","min-w-[200px] rounded-lg border bg-popover shadow-lg p-1","animate-in fade-in-0 zoom-in-95"),children:ie.map(x=>r.jsxs("button",{type:"button",onClick:()=>k(x.value),className:h("flex items-start gap-2 w-full px-2 py-2 rounded text-left","transition-colors",x.value===e?"bg-primary/10":"hover:bg-muted"),children:[r.jsx(x.icon,{className:h("h-4 w-4 mt-0.5",x.color)}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("span",{className:"font-medium text-sm",children:x.label}),x.value===e&&r.jsx(v.CheckIcon,{className:"h-3.5 w-3.5 text-primary"})]}),r.jsx("p",{className:"text-xs text-muted-foreground",children:x.description})]})]},x.value))})]})]})}const Tr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",admin:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Or({members:e,currentUserId:s,canManage:o=!1,onRoleChange:t,onRemove:a,isLoading:c=!1,emptyMessage:n="No members found",className:l,onTrack:i,trackingLabel:m,componentName:f="MemberList"}){if(c)return r.jsx("div",{className:h("space-y-2",l),children:[1,2,3].map(N=>r.jsx("div",{className:"h-16 rounded-lg border border-border bg-muted animate-pulse"},N))});if(e.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",l),children:n});const k=(N,y)=>{i?.({action:"role_change",trackingLabel:m,componentName:f}),t?.(N,y)},x=N=>{i?.({action:"remove",trackingLabel:m,componentName:f}),a?.(N)};return r.jsx("div",{className:h("divide-y divide-border rounded-lg border",l),children:e.map(N=>r.jsx(Gr,{member:N,isSelf:N.userId===s,canManage:o,onRoleChange:t?k:void 0,onRemove:a?x:void 0},N.id))})}function Gr({member:e,isSelf:s,canManage:o,onRoleChange:t,onRemove:a}){const c=e.user?.displayName||e.user?.email||"Unknown user",n=e.user?.email;return r.jsxs("div",{className:"flex items-center gap-3 p-3",children:[r.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-muted",children:r.jsx(v.UserIcon,{className:"h-5 w-5 text-muted-foreground"})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("p",{className:"font-medium text-foreground truncate",children:c}),s&&r.jsx("span",{className:"text-xs text-muted-foreground",children:"(you)"})]}),n&&r.jsx("p",{className:"text-sm text-muted-foreground truncate",children:n})]}),o&&t&&!s?r.jsx(ce,{value:e.role,onChange:l=>t(e.userId,l)}):r.jsx("span",{className:h("text-xs px-2 py-1 rounded-full font-medium",Tr[e.role]),children:e.role}),o&&a&&!s&&r.jsx("button",{type:"button",onClick:()=>a(e.userId),className:h("p-1.5 rounded hover:bg-destructive/10 text-muted-foreground","hover:text-destructive transition-colors"),title:"Remove member",children:r.jsx(v.TrashIcon,{className:"h-4 w-4"})})]})}function jr({onSubmit:e,isSubmitting:s=!1,defaultRole:o=J.EntityRole.MEMBER,className:t,onTrack:a,trackingLabel:c,componentName:n="InvitationForm"}){const[l,i]=$.useState(""),[m,f]=$.useState(o),[k,x]=$.useState(null),N=async y=>{if(y.preventDefault(),x(null),!l.trim()){x("Email is required");return}if(!Fr(l)){x("Please enter a valid email address");return}a?.({action:"submit",trackingLabel:c,componentName:n});try{await e({email:l.trim(),role:m}),i(""),f(o)}catch(w){x(w.message||"Failed to send invitation")}};return r.jsxs("form",{onSubmit:N,className:h("space-y-4",t),children:[r.jsxs("div",{className:"flex gap-2",children:[r.jsxs("div",{className:"relative flex-1",children:[r.jsx(v.EnvelopeIcon,{className:"absolute left-3 top-1/2 -translate-y-1/2 h-4 w-4 text-muted-foreground"}),r.jsx("input",{type:"email",value:l,onChange:y=>i(y.target.value),placeholder:"Enter email address",disabled:s,className:h("w-full pl-10 pr-3 py-2 rounded-lg border bg-background","text-sm placeholder:text-muted-foreground","focus:outline-none focus:ring-2 focus:ring-primary focus:border-transparent",k&&"border-destructive focus:ring-destructive",s&&"opacity-50 cursor-not-allowed")})]}),r.jsx(ce,{value:m,onChange:f,disabled:s}),r.jsxs("button",{type:"submit",disabled:s||!l.trim(),className:h("flex items-center gap-2 px-4 py-2 rounded-lg","bg-primary text-primary-foreground font-medium text-sm","hover:bg-primary/90 transition-colors","focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2",(s||!l.trim())&&"opacity-50 cursor-not-allowed"),children:[s?r.jsx(v.ArrowPathIcon,{className:"h-4 w-4 animate-spin"}):r.jsx(v.PaperAirplaneIcon,{className:"h-4 w-4"}),r.jsx("span",{className:"hidden sm:inline",children:"Invite"})]})]}),k&&r.jsx("p",{className:"text-sm text-destructive",children:k})]})}function Fr(e){return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e)}const Lr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",admin:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Br({invitations:e,mode:s,onCancel:o,onAccept:t,onDecline:a,isLoading:c=!1,emptyMessage:n="No pending invitations",className:l,onTrack:i,trackingLabel:m,componentName:f="InvitationList"}){const k=e.filter(w=>w.status==="pending");if(c)return r.jsx("div",{className:h("space-y-2",l),children:[1,2].map(w=>r.jsx("div",{className:"h-16 rounded-lg border border-border bg-muted animate-pulse"},w))});if(k.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",l),children:n});const x=w=>{i?.({action:"cancel",trackingLabel:m,componentName:f}),o?.(w)},N=w=>{i?.({action:"accept",trackingLabel:m,componentName:f}),t?.(w)},y=w=>{i?.({action:"decline",trackingLabel:m,componentName:f}),a?.(w)};return r.jsx("div",{className:h("divide-y divide-border rounded-lg border",l),children:k.map(w=>r.jsx(Vr,{invitation:w,mode:s,onCancel:o?x:void 0,onAccept:t?N:void 0,onDecline:a?y:void 0},w.id))})}function Vr({invitation:e,mode:s,onCancel:o,onAccept:t,onDecline:a}){const c=new Date(e.expiresAt),n=c<new Date,l=Math.ceil((c.getTime()-Date.now())/(1e3*60*60*24));return r.jsxs("div",{className:"flex items-center gap-3 p-3",children:[r.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-muted",children:r.jsx(v.EnvelopeIcon,{className:"h-5 w-5 text-muted-foreground"})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[s==="user"&&e.entity?r.jsx("p",{className:"font-medium text-foreground truncate",children:e.entity.displayName}):r.jsx("p",{className:"font-medium text-foreground truncate",children:e.email}),r.jsx("span",{className:h("text-xs px-2 py-0.5 rounded-full font-medium",Lr[e.role]),children:e.role})]}),r.jsxs("div",{className:"flex items-center gap-1.5 text-sm text-muted-foreground",children:[r.jsx(v.ClockIcon,{className:"h-3.5 w-3.5"}),n?r.jsx("span",{className:"text-destructive",children:"Expired"}):r.jsxs("span",{children:["Expires in ",l," days"]})]})]}),s==="admin"&&o&&r.jsx("button",{type:"button",onClick:()=>o(e.id),className:h("p-1.5 rounded hover:bg-destructive/10 text-muted-foreground","hover:text-destructive transition-colors"),title:"Cancel invitation",children:r.jsx(v.XCircleIcon,{className:"h-4 w-4"})}),s==="user"&&r.jsxs("div",{className:"flex items-center gap-2",children:[a&&r.jsxs("button",{type:"button",onClick:()=>a(e.token),className:h("flex items-center gap-1.5 px-3 py-1.5 rounded-lg text-sm","border hover:bg-muted transition-colors"),children:[r.jsx(v.XMarkIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Decline"})]}),t&&r.jsxs("button",{type:"button",onClick:()=>t(e.token),disabled:n,className:h("flex items-center gap-1.5 px-3 py-1.5 rounded-lg text-sm","bg-primary text-primary-foreground","hover:bg-primary/90 transition-colors",n&&"opacity-50 cursor-not-allowed"),children:[r.jsx(v.CheckIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Accept"})]})]})]})}z.EntityCard=Pe,z.EntityList=Er,z.EntitySelector=Pr,z.InvitationForm=jr,z.InvitationList=Br,z.MemberList=Or,z.MemberRoleSelector=ce,z.cn=h,Object.defineProperty(z,Symbol.toStringTag,{value:"Module"})}));
|
|
1
|
+
(function(z,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("react/jsx-runtime"),require("@heroicons/react/24/outline"),require("react"),require("@sudobility/types")):typeof define=="function"&&define.amd?define(["exports","react/jsx-runtime","@heroicons/react/24/outline","react","@sudobility/types"],r):(z=typeof globalThis<"u"?globalThis:z||self,r(z.EntityComponents={},z.ReactJSXRuntime,z.HeroiconsOutline,z.React,z.SudobilityTypes))})(this,(function(z,r,v,$,J){"use strict";function ue(e){var s,o,t="";if(typeof e=="string"||typeof e=="number")t+=e;else if(typeof e=="object")if(Array.isArray(e)){var a=e.length;for(s=0;s<a;s++)e[s]&&(o=ue(e[s]))&&(t&&(t+=" "),t+=o)}else for(o in e)e[o]&&(t&&(t+=" "),t+=o);return t}function _e(){for(var e,s,o=0,t="",a=arguments.length;o<a;o++)(e=arguments[o])&&(s=ue(e))&&(t&&(t+=" "),t+=s);return t}const De=(e,s)=>{const o=new Array(e.length+s.length);for(let t=0;t<e.length;t++)o[t]=e[t];for(let t=0;t<s.length;t++)o[e.length+t]=s[t];return o},We=(e,s)=>({classGroupId:e,validator:s}),fe=(e=new Map,s=null,o)=>({nextPart:e,validators:s,classGroupId:o}),H="-",ge=[],$e="arbitrary..",qe=e=>{const s=Ye(e),{conflictingClassGroups:o,conflictingClassGroupModifiers:t}=e;return{getClassGroupId:n=>{if(n.startsWith("[")&&n.endsWith("]"))return Xe(n);const l=n.split(H),i=l[0]===""&&l.length>1?1:0;return be(l,i,s)},getConflictingClassGroupIds:(n,l)=>{if(l){const i=t[n],m=o[n];return i?m?De(m,i):i:m||ge}return o[n]||ge}}},be=(e,s,o)=>{if(e.length-s===0)return o.classGroupId;const a=e[s],c=o.nextPart.get(a);if(c){const m=be(e,s+1,c);if(m)return m}const n=o.validators;if(n===null)return;const l=s===0?e.join(H):e.slice(s).join(H),i=n.length;for(let m=0;m<i;m++){const f=n[m];if(f.validator(l))return f.classGroupId}},Xe=e=>e.slice(1,-1).indexOf(":")===-1?void 0:(()=>{const s=e.slice(1,-1),o=s.indexOf(":"),t=s.slice(0,o);return t?$e+t:void 0})(),Ye=e=>{const{theme:s,classGroups:o}=e;return Je(o,s)},Je=(e,s)=>{const o=fe();for(const t in e){const a=e[t];se(a,o,t,s)}return o},se=(e,s,o,t)=>{const a=e.length;for(let c=0;c<a;c++){const n=e[c];He(n,s,o,t)}},He=(e,s,o,t)=>{if(typeof e=="string"){Ke(e,s,o);return}if(typeof e=="function"){Qe(e,s,o,t);return}Ze(e,s,o,t)},Ke=(e,s,o)=>{const t=e===""?s:he(s,e);t.classGroupId=o},Qe=(e,s,o,t)=>{if(Re(e)){se(e(t),s,o,t);return}s.validators===null&&(s.validators=[]),s.validators.push(We(o,e))},Ze=(e,s,o,t)=>{const a=Object.entries(e),c=a.length;for(let n=0;n<c;n++){const[l,i]=a[n];se(i,he(s,l),o,t)}},he=(e,s)=>{let o=e;const t=s.split(H),a=t.length;for(let c=0;c<a;c++){const n=t[c];let l=o.nextPart.get(n);l||(l=fe(),o.nextPart.set(n,l)),o=l}return o},Re=e=>"isThemeGetter"in e&&e.isThemeGetter===!0,er=e=>{if(e<1)return{get:()=>{},set:()=>{}};let s=0,o=Object.create(null),t=Object.create(null);const a=(c,n)=>{o[c]=n,s++,s>e&&(s=0,t=o,o=Object.create(null))};return{get(c){let n=o[c];if(n!==void 0)return n;if((n=t[c])!==void 0)return a(c,n),n},set(c,n){c in o?o[c]=n:a(c,n)}}},ae="!",xe=":",rr=[],ye=(e,s,o,t,a)=>({modifiers:e,hasImportantModifier:s,baseClassName:o,maybePostfixModifierPosition:t,isExternal:a}),or=e=>{const{prefix:s,experimentalParseClassName:o}=e;let t=a=>{const c=[];let n=0,l=0,i=0,m;const f=a.length;for(let w=0;w<f;w++){const A=a[w];if(n===0&&l===0){if(A===xe){c.push(a.slice(i,w)),i=w+1;continue}if(A==="/"){m=w;continue}}A==="["?n++:A==="]"?n--:A==="("?l++:A===")"&&l--}const k=c.length===0?a:a.slice(i);let x=k,N=!1;k.endsWith(ae)?(x=k.slice(0,-1),N=!0):k.startsWith(ae)&&(x=k.slice(1),N=!0);const y=m&&m>i?m-i:void 0;return ye(c,N,x,y)};if(s){const a=s+xe,c=t;t=n=>n.startsWith(a)?c(n.slice(a.length)):ye(rr,!1,n,void 0,!0)}if(o){const a=t;t=c=>o({className:c,parseClassName:a})}return t},tr=e=>{const s=new Map;return e.orderSensitiveModifiers.forEach((o,t)=>{s.set(o,1e6+t)}),o=>{const t=[];let a=[];for(let c=0;c<o.length;c++){const n=o[c],l=n[0]==="[",i=s.has(n);l||i?(a.length>0&&(a.sort(),t.push(...a),a=[]),t.push(n)):a.push(n)}return a.length>0&&(a.sort(),t.push(...a)),t}},sr=e=>({cache:er(e.cacheSize),parseClassName:or(e),sortModifiers:tr(e),...qe(e)}),ar=/\s+/,nr=(e,s)=>{const{parseClassName:o,getClassGroupId:t,getConflictingClassGroupIds:a,sortModifiers:c}=s,n=[],l=e.trim().split(ar);let i="";for(let m=l.length-1;m>=0;m-=1){const f=l[m],{isExternal:k,modifiers:x,hasImportantModifier:N,baseClassName:y,maybePostfixModifierPosition:w}=o(f);if(k){i=f+(i.length>0?" "+i:i);continue}let A=!!w,j=t(A?y.substring(0,w):y);if(!j){if(!A){i=f+(i.length>0?" "+i:i);continue}if(j=t(y),!j){i=f+(i.length>0?" "+i:i);continue}A=!1}const Z=x.length===0?"":x.length===1?x[0]:c(x).join(":"),X=N?Z+ae:Z,_=X+j;if(n.indexOf(_)>-1)continue;n.push(_);const D=a(j,A);for(let F=0;F<D.length;++F){const Y=D[F];n.push(X+Y)}i=f+(i.length>0?" "+i:i)}return i},lr=(...e)=>{let s=0,o,t,a="";for(;s<e.length;)(o=e[s++])&&(t=we(o))&&(a&&(a+=" "),a+=t);return a},we=e=>{if(typeof e=="string")return e;let s,o="";for(let t=0;t<e.length;t++)e[t]&&(s=we(e[t]))&&(o&&(o+=" "),o+=s);return o},ir=(e,...s)=>{let o,t,a,c;const n=i=>{const m=s.reduce((f,k)=>k(f),e());return o=sr(m),t=o.cache.get,a=o.cache.set,c=l,l(i)},l=i=>{const m=t(i);if(m)return m;const f=nr(i,o);return a(i,f),f};return c=n,(...i)=>c(lr(...i))},cr=[],C=e=>{const s=o=>o[e]||cr;return s.isThemeGetter=!0,s},ve=/^\[(?:(\w[\w-]*):)?(.+)\]$/i,ke=/^\((?:(\w[\w-]*):)?(.+)\)$/i,dr=/^\d+\/\d+$/,pr=/^(\d+(\.\d+)?)?(xs|sm|md|lg|xl)$/,mr=/\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\b(calc|min|max|clamp)\(.+\)|^0$/,ur=/^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\(.+\)$/,fr=/^(inset_)?-?((\d+)?\.?(\d+)[a-z]+|0)_-?((\d+)?\.?(\d+)[a-z]+|0)/,gr=/^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\(.+\)$/,B=e=>dr.test(e),b=e=>!!e&&!Number.isNaN(Number(e)),O=e=>!!e&&Number.isInteger(Number(e)),ne=e=>e.endsWith("%")&&b(e.slice(0,-1)),E=e=>pr.test(e),br=()=>!0,hr=e=>mr.test(e)&&!ur.test(e),Ne=()=>!1,xr=e=>fr.test(e),yr=e=>gr.test(e),wr=e=>!d(e)&&!p(e),vr=e=>V(e,Ae,Ne),d=e=>ve.test(e),G=e=>V(e,Me,hr),le=e=>V(e,zr,b),Ce=e=>V(e,ze,Ne),kr=e=>V(e,Se,yr),K=e=>V(e,Ee,xr),p=e=>ke.test(e),q=e=>U(e,Me),Nr=e=>U(e,Sr),Ie=e=>U(e,ze),Cr=e=>U(e,Ae),Ir=e=>U(e,Se),Q=e=>U(e,Ee,!0),V=(e,s,o)=>{const t=ve.exec(e);return t?t[1]?s(t[1]):o(t[2]):!1},U=(e,s,o=!1)=>{const t=ke.exec(e);return t?t[1]?s(t[1]):o:!1},ze=e=>e==="position"||e==="percentage",Se=e=>e==="image"||e==="url",Ae=e=>e==="length"||e==="size"||e==="bg-size",Me=e=>e==="length",zr=e=>e==="number",Sr=e=>e==="family-name",Ee=e=>e==="shadow",Ar=ir(()=>{const e=C("color"),s=C("font"),o=C("text"),t=C("font-weight"),a=C("tracking"),c=C("leading"),n=C("breakpoint"),l=C("container"),i=C("spacing"),m=C("radius"),f=C("shadow"),k=C("inset-shadow"),x=C("text-shadow"),N=C("drop-shadow"),y=C("blur"),w=C("perspective"),A=C("aspect"),j=C("ease"),Z=C("animate"),X=()=>["auto","avoid","all","avoid-page","page","left","right","column"],_=()=>["center","top","bottom","left","right","top-left","left-top","top-right","right-top","bottom-right","right-bottom","bottom-left","left-bottom"],D=()=>[..._(),p,d],F=()=>["auto","hidden","clip","visible","scroll"],Y=()=>["auto","contain","none"],g=()=>[p,d,i],P=()=>[B,"full","auto",...g()],Oe=()=>[O,"none","subgrid",p,d],Ge=()=>["auto",{span:["full",O,p,d]},O,p,d],R=()=>[O,"auto",p,d],je=()=>["auto","min","max","fr",p,d],de=()=>["start","end","center","between","around","evenly","stretch","baseline","center-safe","end-safe"],W=()=>["start","end","center","stretch","center-safe","end-safe"],T=()=>["auto",...g()],L=()=>[B,"auto","full","dvw","dvh","lvw","lvh","svw","svh","min","max","fit",...g()],u=()=>[e,p,d],Fe=()=>[..._(),Ie,Ce,{position:[p,d]}],Le=()=>["no-repeat",{repeat:["","x","y","space","round"]}],Be=()=>["auto","cover","contain",Cr,vr,{size:[p,d]}],pe=()=>[ne,q,G],S=()=>["","none","full",m,p,d],M=()=>["",b,q,G],ee=()=>["solid","dashed","dotted","double"],Ve=()=>["normal","multiply","screen","overlay","darken","lighten","color-dodge","color-burn","hard-light","soft-light","difference","exclusion","hue","saturation","color","luminosity"],I=()=>[b,ne,Ie,Ce],Ue=()=>["","none",y,p,d],re=()=>["none",b,p,d],oe=()=>["none",b,p,d],me=()=>[b,p,d],te=()=>[B,"full",...g()];return{cacheSize:500,theme:{animate:["spin","ping","pulse","bounce"],aspect:["video"],blur:[E],breakpoint:[E],color:[br],container:[E],"drop-shadow":[E],ease:["in","out","in-out"],font:[wr],"font-weight":["thin","extralight","light","normal","medium","semibold","bold","extrabold","black"],"inset-shadow":[E],leading:["none","tight","snug","normal","relaxed","loose"],perspective:["dramatic","near","normal","midrange","distant","none"],radius:[E],shadow:[E],spacing:["px",b],text:[E],"text-shadow":[E],tracking:["tighter","tight","normal","wide","wider","widest"]},classGroups:{aspect:[{aspect:["auto","square",B,d,p,A]}],container:["container"],columns:[{columns:[b,d,p,l]}],"break-after":[{"break-after":X()}],"break-before":[{"break-before":X()}],"break-inside":[{"break-inside":["auto","avoid","avoid-page","avoid-column"]}],"box-decoration":[{"box-decoration":["slice","clone"]}],box:[{box:["border","content"]}],display:["block","inline-block","inline","flex","inline-flex","table","inline-table","table-caption","table-cell","table-column","table-column-group","table-footer-group","table-header-group","table-row-group","table-row","flow-root","grid","inline-grid","contents","list-item","hidden"],sr:["sr-only","not-sr-only"],float:[{float:["right","left","none","start","end"]}],clear:[{clear:["left","right","both","none","start","end"]}],isolation:["isolate","isolation-auto"],"object-fit":[{object:["contain","cover","fill","none","scale-down"]}],"object-position":[{object:D()}],overflow:[{overflow:F()}],"overflow-x":[{"overflow-x":F()}],"overflow-y":[{"overflow-y":F()}],overscroll:[{overscroll:Y()}],"overscroll-x":[{"overscroll-x":Y()}],"overscroll-y":[{"overscroll-y":Y()}],position:["static","fixed","absolute","relative","sticky"],inset:[{inset:P()}],"inset-x":[{"inset-x":P()}],"inset-y":[{"inset-y":P()}],start:[{start:P()}],end:[{end:P()}],top:[{top:P()}],right:[{right:P()}],bottom:[{bottom:P()}],left:[{left:P()}],visibility:["visible","invisible","collapse"],z:[{z:[O,"auto",p,d]}],basis:[{basis:[B,"full","auto",l,...g()]}],"flex-direction":[{flex:["row","row-reverse","col","col-reverse"]}],"flex-wrap":[{flex:["nowrap","wrap","wrap-reverse"]}],flex:[{flex:[b,B,"auto","initial","none",d]}],grow:[{grow:["",b,p,d]}],shrink:[{shrink:["",b,p,d]}],order:[{order:[O,"first","last","none",p,d]}],"grid-cols":[{"grid-cols":Oe()}],"col-start-end":[{col:Ge()}],"col-start":[{"col-start":R()}],"col-end":[{"col-end":R()}],"grid-rows":[{"grid-rows":Oe()}],"row-start-end":[{row:Ge()}],"row-start":[{"row-start":R()}],"row-end":[{"row-end":R()}],"grid-flow":[{"grid-flow":["row","col","dense","row-dense","col-dense"]}],"auto-cols":[{"auto-cols":je()}],"auto-rows":[{"auto-rows":je()}],gap:[{gap:g()}],"gap-x":[{"gap-x":g()}],"gap-y":[{"gap-y":g()}],"justify-content":[{justify:[...de(),"normal"]}],"justify-items":[{"justify-items":[...W(),"normal"]}],"justify-self":[{"justify-self":["auto",...W()]}],"align-content":[{content:["normal",...de()]}],"align-items":[{items:[...W(),{baseline:["","last"]}]}],"align-self":[{self:["auto",...W(),{baseline:["","last"]}]}],"place-content":[{"place-content":de()}],"place-items":[{"place-items":[...W(),"baseline"]}],"place-self":[{"place-self":["auto",...W()]}],p:[{p:g()}],px:[{px:g()}],py:[{py:g()}],ps:[{ps:g()}],pe:[{pe:g()}],pt:[{pt:g()}],pr:[{pr:g()}],pb:[{pb:g()}],pl:[{pl:g()}],m:[{m:T()}],mx:[{mx:T()}],my:[{my:T()}],ms:[{ms:T()}],me:[{me:T()}],mt:[{mt:T()}],mr:[{mr:T()}],mb:[{mb:T()}],ml:[{ml:T()}],"space-x":[{"space-x":g()}],"space-x-reverse":["space-x-reverse"],"space-y":[{"space-y":g()}],"space-y-reverse":["space-y-reverse"],size:[{size:L()}],w:[{w:[l,"screen",...L()]}],"min-w":[{"min-w":[l,"screen","none",...L()]}],"max-w":[{"max-w":[l,"screen","none","prose",{screen:[n]},...L()]}],h:[{h:["screen","lh",...L()]}],"min-h":[{"min-h":["screen","lh","none",...L()]}],"max-h":[{"max-h":["screen","lh",...L()]}],"font-size":[{text:["base",o,q,G]}],"font-smoothing":["antialiased","subpixel-antialiased"],"font-style":["italic","not-italic"],"font-weight":[{font:[t,p,le]}],"font-stretch":[{"font-stretch":["ultra-condensed","extra-condensed","condensed","semi-condensed","normal","semi-expanded","expanded","extra-expanded","ultra-expanded",ne,d]}],"font-family":[{font:[Nr,d,s]}],"fvn-normal":["normal-nums"],"fvn-ordinal":["ordinal"],"fvn-slashed-zero":["slashed-zero"],"fvn-figure":["lining-nums","oldstyle-nums"],"fvn-spacing":["proportional-nums","tabular-nums"],"fvn-fraction":["diagonal-fractions","stacked-fractions"],tracking:[{tracking:[a,p,d]}],"line-clamp":[{"line-clamp":[b,"none",p,le]}],leading:[{leading:[c,...g()]}],"list-image":[{"list-image":["none",p,d]}],"list-style-position":[{list:["inside","outside"]}],"list-style-type":[{list:["disc","decimal","none",p,d]}],"text-alignment":[{text:["left","center","right","justify","start","end"]}],"placeholder-color":[{placeholder:u()}],"text-color":[{text:u()}],"text-decoration":["underline","overline","line-through","no-underline"],"text-decoration-style":[{decoration:[...ee(),"wavy"]}],"text-decoration-thickness":[{decoration:[b,"from-font","auto",p,G]}],"text-decoration-color":[{decoration:u()}],"underline-offset":[{"underline-offset":[b,"auto",p,d]}],"text-transform":["uppercase","lowercase","capitalize","normal-case"],"text-overflow":["truncate","text-ellipsis","text-clip"],"text-wrap":[{text:["wrap","nowrap","balance","pretty"]}],indent:[{indent:g()}],"vertical-align":[{align:["baseline","top","middle","bottom","text-top","text-bottom","sub","super",p,d]}],whitespace:[{whitespace:["normal","nowrap","pre","pre-line","pre-wrap","break-spaces"]}],break:[{break:["normal","words","all","keep"]}],wrap:[{wrap:["break-word","anywhere","normal"]}],hyphens:[{hyphens:["none","manual","auto"]}],content:[{content:["none",p,d]}],"bg-attachment":[{bg:["fixed","local","scroll"]}],"bg-clip":[{"bg-clip":["border","padding","content","text"]}],"bg-origin":[{"bg-origin":["border","padding","content"]}],"bg-position":[{bg:Fe()}],"bg-repeat":[{bg:Le()}],"bg-size":[{bg:Be()}],"bg-image":[{bg:["none",{linear:[{to:["t","tr","r","br","b","bl","l","tl"]},O,p,d],radial:["",p,d],conic:[O,p,d]},Ir,kr]}],"bg-color":[{bg:u()}],"gradient-from-pos":[{from:pe()}],"gradient-via-pos":[{via:pe()}],"gradient-to-pos":[{to:pe()}],"gradient-from":[{from:u()}],"gradient-via":[{via:u()}],"gradient-to":[{to:u()}],rounded:[{rounded:S()}],"rounded-s":[{"rounded-s":S()}],"rounded-e":[{"rounded-e":S()}],"rounded-t":[{"rounded-t":S()}],"rounded-r":[{"rounded-r":S()}],"rounded-b":[{"rounded-b":S()}],"rounded-l":[{"rounded-l":S()}],"rounded-ss":[{"rounded-ss":S()}],"rounded-se":[{"rounded-se":S()}],"rounded-ee":[{"rounded-ee":S()}],"rounded-es":[{"rounded-es":S()}],"rounded-tl":[{"rounded-tl":S()}],"rounded-tr":[{"rounded-tr":S()}],"rounded-br":[{"rounded-br":S()}],"rounded-bl":[{"rounded-bl":S()}],"border-w":[{border:M()}],"border-w-x":[{"border-x":M()}],"border-w-y":[{"border-y":M()}],"border-w-s":[{"border-s":M()}],"border-w-e":[{"border-e":M()}],"border-w-t":[{"border-t":M()}],"border-w-r":[{"border-r":M()}],"border-w-b":[{"border-b":M()}],"border-w-l":[{"border-l":M()}],"divide-x":[{"divide-x":M()}],"divide-x-reverse":["divide-x-reverse"],"divide-y":[{"divide-y":M()}],"divide-y-reverse":["divide-y-reverse"],"border-style":[{border:[...ee(),"hidden","none"]}],"divide-style":[{divide:[...ee(),"hidden","none"]}],"border-color":[{border:u()}],"border-color-x":[{"border-x":u()}],"border-color-y":[{"border-y":u()}],"border-color-s":[{"border-s":u()}],"border-color-e":[{"border-e":u()}],"border-color-t":[{"border-t":u()}],"border-color-r":[{"border-r":u()}],"border-color-b":[{"border-b":u()}],"border-color-l":[{"border-l":u()}],"divide-color":[{divide:u()}],"outline-style":[{outline:[...ee(),"none","hidden"]}],"outline-offset":[{"outline-offset":[b,p,d]}],"outline-w":[{outline:["",b,q,G]}],"outline-color":[{outline:u()}],shadow:[{shadow:["","none",f,Q,K]}],"shadow-color":[{shadow:u()}],"inset-shadow":[{"inset-shadow":["none",k,Q,K]}],"inset-shadow-color":[{"inset-shadow":u()}],"ring-w":[{ring:M()}],"ring-w-inset":["ring-inset"],"ring-color":[{ring:u()}],"ring-offset-w":[{"ring-offset":[b,G]}],"ring-offset-color":[{"ring-offset":u()}],"inset-ring-w":[{"inset-ring":M()}],"inset-ring-color":[{"inset-ring":u()}],"text-shadow":[{"text-shadow":["none",x,Q,K]}],"text-shadow-color":[{"text-shadow":u()}],opacity:[{opacity:[b,p,d]}],"mix-blend":[{"mix-blend":[...Ve(),"plus-darker","plus-lighter"]}],"bg-blend":[{"bg-blend":Ve()}],"mask-clip":[{"mask-clip":["border","padding","content","fill","stroke","view"]},"mask-no-clip"],"mask-composite":[{mask:["add","subtract","intersect","exclude"]}],"mask-image-linear-pos":[{"mask-linear":[b]}],"mask-image-linear-from-pos":[{"mask-linear-from":I()}],"mask-image-linear-to-pos":[{"mask-linear-to":I()}],"mask-image-linear-from-color":[{"mask-linear-from":u()}],"mask-image-linear-to-color":[{"mask-linear-to":u()}],"mask-image-t-from-pos":[{"mask-t-from":I()}],"mask-image-t-to-pos":[{"mask-t-to":I()}],"mask-image-t-from-color":[{"mask-t-from":u()}],"mask-image-t-to-color":[{"mask-t-to":u()}],"mask-image-r-from-pos":[{"mask-r-from":I()}],"mask-image-r-to-pos":[{"mask-r-to":I()}],"mask-image-r-from-color":[{"mask-r-from":u()}],"mask-image-r-to-color":[{"mask-r-to":u()}],"mask-image-b-from-pos":[{"mask-b-from":I()}],"mask-image-b-to-pos":[{"mask-b-to":I()}],"mask-image-b-from-color":[{"mask-b-from":u()}],"mask-image-b-to-color":[{"mask-b-to":u()}],"mask-image-l-from-pos":[{"mask-l-from":I()}],"mask-image-l-to-pos":[{"mask-l-to":I()}],"mask-image-l-from-color":[{"mask-l-from":u()}],"mask-image-l-to-color":[{"mask-l-to":u()}],"mask-image-x-from-pos":[{"mask-x-from":I()}],"mask-image-x-to-pos":[{"mask-x-to":I()}],"mask-image-x-from-color":[{"mask-x-from":u()}],"mask-image-x-to-color":[{"mask-x-to":u()}],"mask-image-y-from-pos":[{"mask-y-from":I()}],"mask-image-y-to-pos":[{"mask-y-to":I()}],"mask-image-y-from-color":[{"mask-y-from":u()}],"mask-image-y-to-color":[{"mask-y-to":u()}],"mask-image-radial":[{"mask-radial":[p,d]}],"mask-image-radial-from-pos":[{"mask-radial-from":I()}],"mask-image-radial-to-pos":[{"mask-radial-to":I()}],"mask-image-radial-from-color":[{"mask-radial-from":u()}],"mask-image-radial-to-color":[{"mask-radial-to":u()}],"mask-image-radial-shape":[{"mask-radial":["circle","ellipse"]}],"mask-image-radial-size":[{"mask-radial":[{closest:["side","corner"],farthest:["side","corner"]}]}],"mask-image-radial-pos":[{"mask-radial-at":_()}],"mask-image-conic-pos":[{"mask-conic":[b]}],"mask-image-conic-from-pos":[{"mask-conic-from":I()}],"mask-image-conic-to-pos":[{"mask-conic-to":I()}],"mask-image-conic-from-color":[{"mask-conic-from":u()}],"mask-image-conic-to-color":[{"mask-conic-to":u()}],"mask-mode":[{mask:["alpha","luminance","match"]}],"mask-origin":[{"mask-origin":["border","padding","content","fill","stroke","view"]}],"mask-position":[{mask:Fe()}],"mask-repeat":[{mask:Le()}],"mask-size":[{mask:Be()}],"mask-type":[{"mask-type":["alpha","luminance"]}],"mask-image":[{mask:["none",p,d]}],filter:[{filter:["","none",p,d]}],blur:[{blur:Ue()}],brightness:[{brightness:[b,p,d]}],contrast:[{contrast:[b,p,d]}],"drop-shadow":[{"drop-shadow":["","none",N,Q,K]}],"drop-shadow-color":[{"drop-shadow":u()}],grayscale:[{grayscale:["",b,p,d]}],"hue-rotate":[{"hue-rotate":[b,p,d]}],invert:[{invert:["",b,p,d]}],saturate:[{saturate:[b,p,d]}],sepia:[{sepia:["",b,p,d]}],"backdrop-filter":[{"backdrop-filter":["","none",p,d]}],"backdrop-blur":[{"backdrop-blur":Ue()}],"backdrop-brightness":[{"backdrop-brightness":[b,p,d]}],"backdrop-contrast":[{"backdrop-contrast":[b,p,d]}],"backdrop-grayscale":[{"backdrop-grayscale":["",b,p,d]}],"backdrop-hue-rotate":[{"backdrop-hue-rotate":[b,p,d]}],"backdrop-invert":[{"backdrop-invert":["",b,p,d]}],"backdrop-opacity":[{"backdrop-opacity":[b,p,d]}],"backdrop-saturate":[{"backdrop-saturate":[b,p,d]}],"backdrop-sepia":[{"backdrop-sepia":["",b,p,d]}],"border-collapse":[{border:["collapse","separate"]}],"border-spacing":[{"border-spacing":g()}],"border-spacing-x":[{"border-spacing-x":g()}],"border-spacing-y":[{"border-spacing-y":g()}],"table-layout":[{table:["auto","fixed"]}],caption:[{caption:["top","bottom"]}],transition:[{transition:["","all","colors","opacity","shadow","transform","none",p,d]}],"transition-behavior":[{transition:["normal","discrete"]}],duration:[{duration:[b,"initial",p,d]}],ease:[{ease:["linear","initial",j,p,d]}],delay:[{delay:[b,p,d]}],animate:[{animate:["none",Z,p,d]}],backface:[{backface:["hidden","visible"]}],perspective:[{perspective:[w,p,d]}],"perspective-origin":[{"perspective-origin":D()}],rotate:[{rotate:re()}],"rotate-x":[{"rotate-x":re()}],"rotate-y":[{"rotate-y":re()}],"rotate-z":[{"rotate-z":re()}],scale:[{scale:oe()}],"scale-x":[{"scale-x":oe()}],"scale-y":[{"scale-y":oe()}],"scale-z":[{"scale-z":oe()}],"scale-3d":["scale-3d"],skew:[{skew:me()}],"skew-x":[{"skew-x":me()}],"skew-y":[{"skew-y":me()}],transform:[{transform:[p,d,"","none","gpu","cpu"]}],"transform-origin":[{origin:D()}],"transform-style":[{transform:["3d","flat"]}],translate:[{translate:te()}],"translate-x":[{"translate-x":te()}],"translate-y":[{"translate-y":te()}],"translate-z":[{"translate-z":te()}],"translate-none":["translate-none"],accent:[{accent:u()}],appearance:[{appearance:["none","auto"]}],"caret-color":[{caret:u()}],"color-scheme":[{scheme:["normal","dark","light","light-dark","only-dark","only-light"]}],cursor:[{cursor:["auto","default","pointer","wait","text","move","help","not-allowed","none","context-menu","progress","cell","crosshair","vertical-text","alias","copy","no-drop","grab","grabbing","all-scroll","col-resize","row-resize","n-resize","e-resize","s-resize","w-resize","ne-resize","nw-resize","se-resize","sw-resize","ew-resize","ns-resize","nesw-resize","nwse-resize","zoom-in","zoom-out",p,d]}],"field-sizing":[{"field-sizing":["fixed","content"]}],"pointer-events":[{"pointer-events":["auto","none"]}],resize:[{resize:["none","","y","x"]}],"scroll-behavior":[{scroll:["auto","smooth"]}],"scroll-m":[{"scroll-m":g()}],"scroll-mx":[{"scroll-mx":g()}],"scroll-my":[{"scroll-my":g()}],"scroll-ms":[{"scroll-ms":g()}],"scroll-me":[{"scroll-me":g()}],"scroll-mt":[{"scroll-mt":g()}],"scroll-mr":[{"scroll-mr":g()}],"scroll-mb":[{"scroll-mb":g()}],"scroll-ml":[{"scroll-ml":g()}],"scroll-p":[{"scroll-p":g()}],"scroll-px":[{"scroll-px":g()}],"scroll-py":[{"scroll-py":g()}],"scroll-ps":[{"scroll-ps":g()}],"scroll-pe":[{"scroll-pe":g()}],"scroll-pt":[{"scroll-pt":g()}],"scroll-pr":[{"scroll-pr":g()}],"scroll-pb":[{"scroll-pb":g()}],"scroll-pl":[{"scroll-pl":g()}],"snap-align":[{snap:["start","end","center","align-none"]}],"snap-stop":[{snap:["normal","always"]}],"snap-type":[{snap:["none","x","y","both"]}],"snap-strictness":[{snap:["mandatory","proximity"]}],touch:[{touch:["auto","none","manipulation"]}],"touch-x":[{"touch-pan":["x","left","right"]}],"touch-y":[{"touch-pan":["y","up","down"]}],"touch-pz":["touch-pinch-zoom"],select:[{select:["none","text","all","auto"]}],"will-change":[{"will-change":["auto","scroll","contents","transform",p,d]}],fill:[{fill:["none",...u()]}],"stroke-w":[{stroke:[b,q,G,le]}],stroke:[{stroke:["none",...u()]}],"forced-color-adjust":[{"forced-color-adjust":["auto","none"]}]},conflictingClassGroups:{overflow:["overflow-x","overflow-y"],overscroll:["overscroll-x","overscroll-y"],inset:["inset-x","inset-y","start","end","top","right","bottom","left"],"inset-x":["right","left"],"inset-y":["top","bottom"],flex:["basis","grow","shrink"],gap:["gap-x","gap-y"],p:["px","py","ps","pe","pt","pr","pb","pl"],px:["pr","pl"],py:["pt","pb"],m:["mx","my","ms","me","mt","mr","mb","ml"],mx:["mr","ml"],my:["mt","mb"],size:["w","h"],"font-size":["leading"],"fvn-normal":["fvn-ordinal","fvn-slashed-zero","fvn-figure","fvn-spacing","fvn-fraction"],"fvn-ordinal":["fvn-normal"],"fvn-slashed-zero":["fvn-normal"],"fvn-figure":["fvn-normal"],"fvn-spacing":["fvn-normal"],"fvn-fraction":["fvn-normal"],"line-clamp":["display","overflow"],rounded:["rounded-s","rounded-e","rounded-t","rounded-r","rounded-b","rounded-l","rounded-ss","rounded-se","rounded-ee","rounded-es","rounded-tl","rounded-tr","rounded-br","rounded-bl"],"rounded-s":["rounded-ss","rounded-es"],"rounded-e":["rounded-se","rounded-ee"],"rounded-t":["rounded-tl","rounded-tr"],"rounded-r":["rounded-tr","rounded-br"],"rounded-b":["rounded-br","rounded-bl"],"rounded-l":["rounded-tl","rounded-bl"],"border-spacing":["border-spacing-x","border-spacing-y"],"border-w":["border-w-x","border-w-y","border-w-s","border-w-e","border-w-t","border-w-r","border-w-b","border-w-l"],"border-w-x":["border-w-r","border-w-l"],"border-w-y":["border-w-t","border-w-b"],"border-color":["border-color-x","border-color-y","border-color-s","border-color-e","border-color-t","border-color-r","border-color-b","border-color-l"],"border-color-x":["border-color-r","border-color-l"],"border-color-y":["border-color-t","border-color-b"],translate:["translate-x","translate-y","translate-none"],"translate-none":["translate","translate-x","translate-y","translate-z"],"scroll-m":["scroll-mx","scroll-my","scroll-ms","scroll-me","scroll-mt","scroll-mr","scroll-mb","scroll-ml"],"scroll-mx":["scroll-mr","scroll-ml"],"scroll-my":["scroll-mt","scroll-mb"],"scroll-p":["scroll-px","scroll-py","scroll-ps","scroll-pe","scroll-pt","scroll-pr","scroll-pb","scroll-pl"],"scroll-px":["scroll-pr","scroll-pl"],"scroll-py":["scroll-pt","scroll-pb"],touch:["touch-x","touch-y","touch-pz"],"touch-x":["touch"],"touch-y":["touch"],"touch-pz":["touch"]},conflictingClassGroupModifiers:{"font-size":["leading"]},orderSensitiveModifiers:["*","**","after","backdrop","before","details-content","file","first-letter","first-line","marker","placeholder","selection"]}});function h(...e){return Ar(_e(e))}const Mr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",manager:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Pe({entity:e,isSelected:s=!1,onClick:o,className:t,onTrack:a,trackingLabel:c,componentName:n="EntityCard"}){const l=e.entityType==="personal",i=l?v.UserIcon:v.BuildingOffice2Icon,m=()=>{a?.({action:"click",trackingLabel:c,componentName:n}),o?.()};return r.jsx("div",{onClick:o?m:void 0,className:h("rounded-lg border p-4 transition-all",o&&"cursor-pointer hover:border-primary",s&&"border-primary bg-primary/5",!s&&"border-border bg-card",t),children:r.jsxs("div",{className:"flex items-start gap-3",children:[r.jsx("div",{className:h("flex h-10 w-10 items-center justify-center rounded-full",l?"bg-blue-100 dark:bg-blue-900":"bg-purple-100 dark:bg-purple-900"),children:e.avatarUrl?r.jsx("img",{src:e.avatarUrl,alt:e.displayName,className:"h-10 w-10 rounded-full object-cover"}):r.jsx(i,{className:h("h-5 w-5",l?"text-blue-600 dark:text-blue-400":"text-purple-600 dark:text-purple-400")})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("h3",{className:"font-medium text-foreground truncate",children:e.displayName}),r.jsx("span",{className:h("text-xs px-2 py-0.5 rounded-full font-medium",Mr[e.userRole]),children:e.userRole})]}),r.jsx("p",{className:"text-sm text-muted-foreground",children:l?"Personal workspace":"Organization"}),e.description&&r.jsx("p",{className:"text-sm text-muted-foreground mt-1 line-clamp-2",children:e.description})]})]})})}function Er({entities:e,selectedSlug:s,onSelect:o,isLoading:t=!1,emptyMessage:a="No workspaces found",className:c,onTrack:n,trackingLabel:l,componentName:i="EntityList"}){if(t)return r.jsx("div",{className:h("space-y-3",c),children:[1,2,3].map(f=>r.jsx("div",{className:"h-24 rounded-lg border border-border bg-muted animate-pulse"},f))});if(e.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",c),children:a});const m=f=>{n?.({action:"select",trackingLabel:l,componentName:i}),o?.(f)};return r.jsx("div",{className:h("space-y-3",c),children:e.map(f=>r.jsx(Pe,{entity:f,isSelected:f.entitySlug===s,onClick:o?()=>m(f):void 0,onTrack:n,trackingLabel:l},f.id))})}function Pr({entities:e,currentEntity:s,onSelect:o,onCreateNew:t,isLoading:a=!1,className:c,onTrack:n,trackingLabel:l,componentName:i="EntitySelector"}){const[m,f]=$.useState(!1),k=()=>{n?.({action:"toggle",trackingLabel:l,componentName:i}),f(!m)},x=y=>{n?.({action:"select",trackingLabel:l,componentName:i}),o(y),f(!1)},N=()=>{n?.({action:"create_new",trackingLabel:l,componentName:i}),t?.(),f(!1)};return r.jsxs("div",{className:h("relative",c),children:[r.jsxs("button",{type:"button",onClick:k,disabled:a,className:h("flex items-center gap-2 px-3 py-2 rounded-lg border","bg-background hover:bg-muted transition-colors","focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2",a&&"opacity-50 cursor-not-allowed"),children:[s?r.jsxs(r.Fragment,{children:[s.entityType==="personal"?r.jsx(v.UserIcon,{className:"h-4 w-4 text-blue-600 dark:text-blue-400"}):r.jsx(v.BuildingOffice2Icon,{className:"h-4 w-4 text-purple-600 dark:text-purple-400"}),r.jsx("span",{className:"font-medium text-sm truncate max-w-[150px]",children:s.displayName})]}):r.jsx("span",{className:"text-sm text-muted-foreground",children:"Select workspace"}),r.jsx(v.ChevronDownIcon,{className:h("h-4 w-4 text-muted-foreground transition-transform",m&&"rotate-180")})]}),m&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>f(!1)}),r.jsx("div",{className:h("absolute top-full left-0 mt-1 z-50","min-w-[220px] rounded-lg border bg-popover shadow-lg","animate-in fade-in-0 zoom-in-95"),children:r.jsxs("div",{className:"p-1",children:[e.filter(y=>y.entityType==="personal").map(y=>r.jsx(Te,{entity:y,isSelected:y.id===s?.id,onClick:()=>x(y)},y.id)),e.some(y=>y.entityType==="personal")&&e.some(y=>y.entityType==="organization")&&r.jsx("div",{className:"my-1 h-px bg-border"}),e.filter(y=>y.entityType==="organization").map(y=>r.jsx(Te,{entity:y,isSelected:y.id===s?.id,onClick:()=>x(y)},y.id)),t&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"my-1 h-px bg-border"}),r.jsxs("button",{type:"button",onClick:N,className:h("flex items-center gap-2 w-full px-2 py-1.5 rounded","text-sm text-primary hover:bg-muted transition-colors"),children:[r.jsx(v.PlusIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Create organization"})]})]})]})})]})]})}function Te({entity:e,isSelected:s,onClick:o}){const t=e.entityType==="personal",a=t?v.UserIcon:v.BuildingOffice2Icon;return r.jsxs("button",{type:"button",onClick:o,className:h("flex items-center gap-2 w-full px-2 py-1.5 rounded","text-sm transition-colors",s?"bg-primary/10 text-primary":"hover:bg-muted text-foreground"),children:[r.jsx(a,{className:h("h-4 w-4",t?"text-blue-600 dark:text-blue-400":"text-purple-600 dark:text-purple-400")}),r.jsx("span",{className:"flex-1 text-left truncate",children:e.displayName}),s&&r.jsx(v.CheckIcon,{className:"h-4 w-4"})]})}const ie=[{value:J.EntityRole.OWNER,label:"Owner",description:"Full access to all settings and members",icon:v.ShieldCheckIcon,color:"text-purple-600 dark:text-purple-400"},{value:J.EntityRole.MANAGER,label:"Manager",description:"Can manage projects and API keys",icon:v.BriefcaseIcon,color:"text-blue-600 dark:text-blue-400"},{value:J.EntityRole.MEMBER,label:"Member",description:"Read-only access",icon:v.EyeIcon,color:"text-gray-600 dark:text-gray-400"}];function ce({value:e,onChange:s,disabled:o=!1,className:t,onTrack:a,trackingLabel:c,componentName:n="MemberRoleSelector"}){const[l,i]=$.useState(!1),m=ie.find(x=>x.value===e)||ie[2],f=()=>{o||(a?.({action:"toggle",trackingLabel:c,componentName:n}),i(!l))},k=x=>{a?.({action:"select",trackingLabel:c,componentName:n}),s(x),i(!1)};return r.jsxs("div",{className:h("relative",t),children:[r.jsxs("button",{type:"button",onClick:f,disabled:o,className:h("flex items-center gap-1.5 px-2 py-1 rounded border text-sm","bg-background transition-colors",o?"opacity-50 cursor-not-allowed":"hover:bg-muted cursor-pointer"),children:[r.jsx(m.icon,{className:h("h-3.5 w-3.5",m.color)}),r.jsx("span",{children:m.label}),r.jsx(v.ChevronDownIcon,{className:h("h-3.5 w-3.5 text-muted-foreground transition-transform",l&&"rotate-180")})]}),l&&r.jsxs(r.Fragment,{children:[r.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>i(!1)}),r.jsx("div",{className:h("absolute top-full right-0 mt-1 z-50","min-w-[200px] rounded-lg border bg-popover shadow-lg p-1","animate-in fade-in-0 zoom-in-95"),children:ie.map(x=>r.jsxs("button",{type:"button",onClick:()=>k(x.value),className:h("flex items-start gap-2 w-full px-2 py-2 rounded text-left","transition-colors",x.value===e?"bg-primary/10":"hover:bg-muted"),children:[r.jsx(x.icon,{className:h("h-4 w-4 mt-0.5",x.color)}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("span",{className:"font-medium text-sm",children:x.label}),x.value===e&&r.jsx(v.CheckIcon,{className:"h-3.5 w-3.5 text-primary"})]}),r.jsx("p",{className:"text-xs text-muted-foreground",children:x.description})]})]},x.value))})]})]})}const Tr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",manager:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Or({members:e,currentUserId:s,canManage:o=!1,onRoleChange:t,onRemove:a,isLoading:c=!1,emptyMessage:n="No members found",className:l,onTrack:i,trackingLabel:m,componentName:f="MemberList"}){if(c)return r.jsx("div",{className:h("space-y-2",l),children:[1,2,3].map(N=>r.jsx("div",{className:"h-16 rounded-lg border border-border bg-muted animate-pulse"},N))});if(e.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",l),children:n});const k=(N,y)=>{i?.({action:"role_change",trackingLabel:m,componentName:f}),t?.(N,y)},x=N=>{i?.({action:"remove",trackingLabel:m,componentName:f}),a?.(N)};return r.jsx("div",{className:h("divide-y divide-border rounded-lg border",l),children:e.map(N=>r.jsx(Gr,{member:N,isSelf:N.userId===s,canManage:o,onRoleChange:t?k:void 0,onRemove:a?x:void 0},N.id))})}function Gr({member:e,isSelf:s,canManage:o,onRoleChange:t,onRemove:a}){const c=e.user?.displayName||e.user?.email||"Unknown user",n=e.user?.email;return r.jsxs("div",{className:"flex items-center gap-3 p-3",children:[r.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-muted",children:r.jsx(v.UserIcon,{className:"h-5 w-5 text-muted-foreground"})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("p",{className:"font-medium text-foreground truncate",children:c}),s&&r.jsx("span",{className:"text-xs text-muted-foreground",children:"(you)"})]}),n&&r.jsx("p",{className:"text-sm text-muted-foreground truncate",children:n})]}),o&&t&&!s?r.jsx(ce,{value:e.role,onChange:l=>t(e.userId,l)}):r.jsx("span",{className:h("text-xs px-2 py-1 rounded-full font-medium",Tr[e.role]),children:e.role}),o&&a&&!s&&r.jsx("button",{type:"button",onClick:()=>a(e.userId),className:h("p-1.5 rounded hover:bg-destructive/10 text-muted-foreground","hover:text-destructive transition-colors"),title:"Remove member",children:r.jsx(v.TrashIcon,{className:"h-4 w-4"})})]})}function jr({onSubmit:e,isSubmitting:s=!1,defaultRole:o=J.EntityRole.MEMBER,className:t,onTrack:a,trackingLabel:c,componentName:n="InvitationForm"}){const[l,i]=$.useState(""),[m,f]=$.useState(o),[k,x]=$.useState(null),N=async y=>{if(y.preventDefault(),x(null),!l.trim()){x("Email is required");return}if(!Fr(l)){x("Please enter a valid email address");return}a?.({action:"submit",trackingLabel:c,componentName:n});try{await e({email:l.trim(),role:m}),i(""),f(o)}catch(w){x(w.message||"Failed to send invitation")}};return r.jsxs("form",{onSubmit:N,className:h("space-y-4",t),children:[r.jsxs("div",{className:"flex gap-2",children:[r.jsxs("div",{className:"relative flex-1",children:[r.jsx(v.EnvelopeIcon,{className:"absolute left-3 top-1/2 -translate-y-1/2 h-4 w-4 text-muted-foreground"}),r.jsx("input",{type:"email",value:l,onChange:y=>i(y.target.value),placeholder:"Enter email address",disabled:s,className:h("w-full pl-10 pr-3 py-2 rounded-lg border bg-background","text-sm placeholder:text-muted-foreground","focus:outline-none focus:ring-2 focus:ring-primary focus:border-transparent",k&&"border-destructive focus:ring-destructive",s&&"opacity-50 cursor-not-allowed")})]}),r.jsx(ce,{value:m,onChange:f,disabled:s}),r.jsxs("button",{type:"submit",disabled:s||!l.trim(),className:h("flex items-center gap-2 px-4 py-2 rounded-lg","bg-primary text-primary-foreground font-medium text-sm","hover:bg-primary/90 transition-colors","focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2",(s||!l.trim())&&"opacity-50 cursor-not-allowed"),children:[s?r.jsx(v.ArrowPathIcon,{className:"h-4 w-4 animate-spin"}):r.jsx(v.PaperAirplaneIcon,{className:"h-4 w-4"}),r.jsx("span",{className:"hidden sm:inline",children:"Invite"})]})]}),k&&r.jsx("p",{className:"text-sm text-destructive",children:k})]})}function Fr(e){return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e)}const Lr={owner:"bg-purple-100 text-purple-700 dark:bg-purple-900 dark:text-purple-300",manager:"bg-blue-100 text-blue-700 dark:bg-blue-900 dark:text-blue-300",member:"bg-gray-100 text-gray-700 dark:bg-gray-800 dark:text-gray-300"};function Br({invitations:e,mode:s,onCancel:o,onAccept:t,onDecline:a,isLoading:c=!1,emptyMessage:n="No pending invitations",className:l,onTrack:i,trackingLabel:m,componentName:f="InvitationList"}){const k=e.filter(w=>w.status==="pending");if(c)return r.jsx("div",{className:h("space-y-2",l),children:[1,2].map(w=>r.jsx("div",{className:"h-16 rounded-lg border border-border bg-muted animate-pulse"},w))});if(k.length===0)return r.jsx("div",{className:h("text-center py-8 text-muted-foreground",l),children:n});const x=w=>{i?.({action:"cancel",trackingLabel:m,componentName:f}),o?.(w)},N=w=>{i?.({action:"accept",trackingLabel:m,componentName:f}),t?.(w)},y=w=>{i?.({action:"decline",trackingLabel:m,componentName:f}),a?.(w)};return r.jsx("div",{className:h("divide-y divide-border rounded-lg border",l),children:k.map(w=>r.jsx(Vr,{invitation:w,mode:s,onCancel:o?x:void 0,onAccept:t?N:void 0,onDecline:a?y:void 0},w.id))})}function Vr({invitation:e,mode:s,onCancel:o,onAccept:t,onDecline:a}){const c=new Date(e.expiresAt),n=c<new Date,l=Math.ceil((c.getTime()-Date.now())/(1e3*60*60*24));return r.jsxs("div",{className:"flex items-center gap-3 p-3",children:[r.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-muted",children:r.jsx(v.EnvelopeIcon,{className:"h-5 w-5 text-muted-foreground"})}),r.jsxs("div",{className:"flex-1 min-w-0",children:[r.jsxs("div",{className:"flex items-center gap-2",children:[s==="user"&&e.entity?r.jsx("p",{className:"font-medium text-foreground truncate",children:e.entity.displayName}):r.jsx("p",{className:"font-medium text-foreground truncate",children:e.email}),r.jsx("span",{className:h("text-xs px-2 py-0.5 rounded-full font-medium",Lr[e.role]),children:e.role})]}),r.jsxs("div",{className:"flex items-center gap-1.5 text-sm text-muted-foreground",children:[r.jsx(v.ClockIcon,{className:"h-3.5 w-3.5"}),n?r.jsx("span",{className:"text-destructive",children:"Expired"}):r.jsxs("span",{children:["Expires in ",l," days"]})]})]}),s==="admin"&&o&&r.jsx("button",{type:"button",onClick:()=>o(e.id),className:h("p-1.5 rounded hover:bg-destructive/10 text-muted-foreground","hover:text-destructive transition-colors"),title:"Cancel invitation",children:r.jsx(v.XCircleIcon,{className:"h-4 w-4"})}),s==="user"&&r.jsxs("div",{className:"flex items-center gap-2",children:[a&&r.jsxs("button",{type:"button",onClick:()=>a(e.token),className:h("flex items-center gap-1.5 px-3 py-1.5 rounded-lg text-sm","border hover:bg-muted transition-colors"),children:[r.jsx(v.XMarkIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Decline"})]}),t&&r.jsxs("button",{type:"button",onClick:()=>t(e.token),disabled:n,className:h("flex items-center gap-1.5 px-3 py-1.5 rounded-lg text-sm","bg-primary text-primary-foreground","hover:bg-primary/90 transition-colors",n&&"opacity-50 cursor-not-allowed"),children:[r.jsx(v.CheckIcon,{className:"h-4 w-4"}),r.jsx("span",{children:"Accept"})]})]})]})}z.EntityCard=Pe,z.EntityList=Er,z.EntitySelector=Pr,z.InvitationForm=jr,z.InvitationList=Br,z.MemberList=Or,z.MemberRoleSelector=ce,z.cn=h,Object.defineProperty(z,Symbol.toStringTag,{value:"Module"})}));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sudobility/entity-components",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.7",
|
|
4
4
|
"description": "Entity/Organization UI components for React",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.umd.js",
|
|
@@ -38,18 +38,18 @@
|
|
|
38
38
|
"author": "John Q Huang",
|
|
39
39
|
"license": "MIT",
|
|
40
40
|
"peerDependencies": {
|
|
41
|
-
"@sudobility/components": "
|
|
42
|
-
"@sudobility/design": "^1.1.
|
|
43
|
-
"@sudobility/types": "^1.9.
|
|
41
|
+
"@sudobility/components": "^4.0.156",
|
|
42
|
+
"@sudobility/design": "^1.1.18",
|
|
43
|
+
"@sudobility/types": "^1.9.44",
|
|
44
44
|
"react": "^18.0.0 || ^19.0.0",
|
|
45
45
|
"react-dom": "^18.0.0 || ^19.0.0"
|
|
46
46
|
},
|
|
47
47
|
"devDependencies": {
|
|
48
48
|
"@eslint/js": "^9.38.0",
|
|
49
49
|
"ajv": "^8.17.1",
|
|
50
|
-
"@sudobility/components": "
|
|
51
|
-
"@sudobility/design": "^1.1.
|
|
52
|
-
"@sudobility/types": "^1.9.
|
|
50
|
+
"@sudobility/components": "^4.0.159",
|
|
51
|
+
"@sudobility/design": "^1.1.18",
|
|
52
|
+
"@sudobility/types": "^1.9.45",
|
|
53
53
|
"@testing-library/dom": "^10.4.0",
|
|
54
54
|
"@testing-library/jest-dom": "^6.4.2",
|
|
55
55
|
"@testing-library/react": "^16.0.0",
|