llm-simple-router 0.5.4 → 0.5.5

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.
Files changed (64) hide show
  1. package/dist/middleware/auth.js +12 -2
  2. package/dist/monitor/request-tracker.d.ts +2 -1
  3. package/dist/monitor/request-tracker.js +3 -0
  4. package/dist/monitor/stats-aggregator.js +8 -7
  5. package/dist/proxy/orchestrator.js +6 -1
  6. package/dist/proxy/resilience.d.ts +0 -2
  7. package/dist/proxy/resilience.js +2 -3
  8. package/dist/proxy/scope.d.ts +2 -2
  9. package/dist/proxy/scope.js +4 -2
  10. package/frontend-dist/assets/{CardContent-GNY_j_L3.js → CardContent-CVofwD9T.js} +1 -1
  11. package/frontend-dist/assets/{CardTitle-BhXJbSoh.js → CardTitle-MLH-EpHz.js} +1 -1
  12. package/frontend-dist/assets/{Checkbox-n_sh6Lvx.js → Checkbox-KiNnjeB_.js} +1 -1
  13. package/frontend-dist/assets/{CollapsibleTrigger-DDCUOXDR.js → CollapsibleTrigger-CbiBtEE8.js} +1 -1
  14. package/frontend-dist/assets/{Collection-DbtqQ1jF.js → Collection-D9NeXDOI.js} +1 -1
  15. package/frontend-dist/assets/{Dashboard-Dy9frcgO.js → Dashboard-CuBkXd58.js} +1 -1
  16. package/frontend-dist/assets/{DialogTitle-BEWUnuJQ.js → DialogTitle-CTcpSq_w.js} +1 -1
  17. package/frontend-dist/assets/{Input-CmibY9Fx.js → Input-DDF6744B.js} +1 -1
  18. package/frontend-dist/assets/{Label-Cs__wFH0.js → Label-_cw0EkS1.js} +1 -1
  19. package/frontend-dist/assets/{Login-BciEc1TW.js → Login-Cca1HpLA.js} +1 -1
  20. package/frontend-dist/assets/{Logs-BkqwWW0-.js → Logs-CUIPRZEO.js} +1 -1
  21. package/frontend-dist/assets/{ModelMappings-DrCJ_TCf.js → ModelMappings-DEswiX1e.js} +1 -1
  22. package/frontend-dist/assets/Monitor-BXpf9sjE.js +1 -0
  23. package/frontend-dist/assets/{PopoverTrigger-DaKOMSVs.js → PopoverTrigger-DIOWDISK.js} +1 -1
  24. package/frontend-dist/assets/{PopperContent-DZ6plcjf.js → PopperContent-DIEU7Y6E.js} +1 -1
  25. package/frontend-dist/assets/{Providers-u8utX74M.js → Providers-CvYtuvfg.js} +1 -1
  26. package/frontend-dist/assets/{ProxyEnhancement-8_xhndGt.js → ProxyEnhancement-BxTbZGYB.js} +1 -1
  27. package/frontend-dist/assets/{RetryRules-D1psYDEP.js → RetryRules-COK28WDb.js} +1 -1
  28. package/frontend-dist/assets/{RouterKeys-ovPFGhjy.js → RouterKeys-DH7nUWDa.js} +1 -1
  29. package/frontend-dist/assets/{RovingFocusItem-Dsv9AkP7.js → RovingFocusItem-DyNl4G42.js} +1 -1
  30. package/frontend-dist/assets/{SelectValue-BoUWfZAg.js → SelectValue-DyjOpyaF.js} +1 -1
  31. package/frontend-dist/assets/{Settings-DXF-6A8C.js → Settings-BmG999ol.js} +1 -1
  32. package/frontend-dist/assets/{Setup-rVLqiz0d.js → Setup-D1xUsqUD.js} +1 -1
  33. package/frontend-dist/assets/{Switch-po5ZVBE3.js → Switch-DrDIdQ_V.js} +1 -1
  34. package/frontend-dist/assets/{TableHeader-Zyvq_0p2.js → TableHeader-BNPqkg9S.js} +1 -1
  35. package/frontend-dist/assets/{TabsTrigger-CgDhZGkT.js → TabsTrigger-D-fGrdG3.js} +1 -1
  36. package/frontend-dist/assets/{Teleport-CgTHarey.js → Teleport-BYzsRHC6.js} +1 -1
  37. package/frontend-dist/assets/{TooltipTrigger-C2qO21dQ.js → TooltipTrigger-C3v2O7fX.js} +1 -1
  38. package/frontend-dist/assets/{UnifiedRequestDialog-Dksad8eN.js → UnifiedRequestDialog-DJOIbAUb.js} +1 -1
  39. package/frontend-dist/assets/{VisuallyHidden-fbPmoMwi.js → VisuallyHidden-Bz0LPzC7.js} +1 -1
  40. package/frontend-dist/assets/{VisuallyHiddenInput-7j8wkPrW.js → VisuallyHiddenInput-Bf9hgsd7.js} +1 -1
  41. package/frontend-dist/assets/{alert-dialog-DbT3PzoF.js → alert-dialog-Bn1IauFR.js} +1 -1
  42. package/frontend-dist/assets/{badge-BVxnlnsH.js → badge-dyL-tG0V.js} +1 -1
  43. package/frontend-dist/assets/{button-BCrIpNwA.js → button-B6f3Nfab.js} +2 -2
  44. package/frontend-dist/assets/chevron-down-DKTxr1tk.js +1 -0
  45. package/frontend-dist/assets/{circle-question-mark-DRkkqjgG.js → circle-question-mark-WJzB-je7.js} +1 -1
  46. package/frontend-dist/assets/{dialog-BNlCZpHK.js → dialog-1FvPG-71.js} +1 -1
  47. package/frontend-dist/assets/{file-text-BavS6SrF.js → file-text-BFyk5DT1.js} +1 -1
  48. package/frontend-dist/assets/{index-DrBJPq6d.js → index-B2SjbR82.js} +1 -1
  49. package/frontend-dist/assets/index-uA-D1xVT.css +1 -0
  50. package/frontend-dist/assets/{lib-CGpNhf06.js → lib-C_27TgFv.js} +1 -1
  51. package/frontend-dist/assets/loader-circle-DEqD4BxX.js +1 -0
  52. package/frontend-dist/assets/{ohash.D__AXeF1-DkJnWU8a.js → ohash.D__AXeF1-BcwqVPVj.js} +1 -1
  53. package/frontend-dist/assets/{useClipboard-Bq8yZunx.js → useClipboard-DCoGBvxy.js} +1 -1
  54. package/frontend-dist/assets/{useLogRetention-BWPm3G_A.js → useLogRetention-BGcJntJ-.js} +1 -1
  55. package/frontend-dist/assets/useNonce-Ccld5giw.js +1 -0
  56. package/frontend-dist/assets/x-iwmjHBXS.js +1 -0
  57. package/frontend-dist/index.html +19 -19
  58. package/package.json +1 -1
  59. package/frontend-dist/assets/Monitor-C-b4qyuI.js +0 -1
  60. package/frontend-dist/assets/chevron-down-CWBwGxSp.js +0 -1
  61. package/frontend-dist/assets/index-BP4imfye.css +0 -1
  62. package/frontend-dist/assets/loader-circle-Cpd89XQ7.js +0 -1
  63. package/frontend-dist/assets/useNonce-D5lpSPNk.js +0 -1
  64. package/frontend-dist/assets/x-BFIp7DLt.js +0 -1
@@ -53,15 +53,25 @@ const authMiddlewareRaw = (app, options, done) => {
53
53
  reply.code(HTTP_SERVICE_UNAVAILABLE).send({ error: { message: "Service not initialized" } });
54
54
  return reply;
55
55
  }
56
+ let token;
56
57
  const authHeader = request.headers.authorization;
57
- if (!authHeader || !authHeader.startsWith("Bearer ")) {
58
+ if (authHeader && authHeader.startsWith("Bearer ")) {
59
+ token = authHeader.slice(BEARER_PREFIX_LENGTH);
60
+ }
61
+ else {
62
+ // Fallback: Anthropic SDK sends API key via x-api-key header
63
+ const apiKeyHeader = request.headers["x-api-key"];
64
+ if (apiKeyHeader) {
65
+ token = apiKeyHeader;
66
+ }
67
+ }
68
+ if (!token) {
58
69
  if (proxyApiType) {
59
70
  logRejectedAuth(options.db, proxyApiType, HTTP_UNAUTHORIZED, "Invalid API key", request);
60
71
  }
61
72
  unauthorizedReply(reply);
62
73
  return reply;
63
74
  }
64
- const token = authHeader.slice(BEARER_PREFIX_LENGTH);
65
75
  const hash = createHash("sha256").update(token).digest("hex");
66
76
  const row = stmt.get(hash);
67
77
  if (!row) {
@@ -2,7 +2,7 @@ import type { ServerResponse } from "node:http";
2
2
  import { StatsAggregator } from "./stats-aggregator.js";
3
3
  import { RuntimeCollector } from "./runtime-collector.js";
4
4
  import type { ProviderSemaphoreManager } from "../proxy/semaphore.js";
5
- import type { ActiveRequest, ProviderConcurrencySnapshot, RuntimeMetrics, StatsSnapshot } from "./types.js";
5
+ import type { ActiveRequest, AttemptSnapshot, ProviderConcurrencySnapshot, RuntimeMetrics, StatsSnapshot } from "./types.js";
6
6
  export interface TrackerLogger {
7
7
  debug(obj: Record<string, unknown>, msg: string): void;
8
8
  warn(obj: Record<string, unknown>, msg: string): void;
@@ -31,6 +31,7 @@ export declare class RequestTracker {
31
31
  complete(id: string, result: {
32
32
  status: "completed" | "failed";
33
33
  statusCode?: number;
34
+ attempts?: AttemptSnapshot[];
34
35
  }): void;
35
36
  getActive(): ActiveRequest[];
36
37
  getRecent(limit?: number): ActiveRequest[];
@@ -73,6 +73,7 @@ export class RequestTracker {
73
73
  ...req,
74
74
  status: result.status,
75
75
  completedAt: now,
76
+ attempts: result.attempts ?? req.attempts,
76
77
  };
77
78
  this.activeMap.delete(id);
78
79
  this.streamAccumulators.delete(id);
@@ -161,6 +162,7 @@ export class RequestTracker {
161
162
  if (this.pushTimer)
162
163
  return;
163
164
  this.tickCount = 0;
165
+ this.runtimeCollector.start();
164
166
  this.pushTimer = setInterval(() => {
165
167
  this.tickCount++;
166
168
  this.cleanupRecent();
@@ -179,6 +181,7 @@ export class RequestTracker {
179
181
  clearInterval(this.pushTimer);
180
182
  this.pushTimer = null;
181
183
  }
184
+ this.runtimeCollector.stop();
182
185
  }
183
186
  broadcast(event, data) {
184
187
  // Strip clientRequest from broadcasts to reduce bandwidth;
@@ -34,13 +34,13 @@ function emptyAccumulator() {
34
34
  successCount: 0,
35
35
  errorCount: 0,
36
36
  retryCount: 0,
37
- latencySum: 0,
38
- latencyCount: 0,
37
+ latencyBuffer: new RingBuffer(PROVIDER_LATENCY_CAPACITY),
39
38
  errorsByCode: new Map(),
40
39
  };
41
40
  }
42
41
  const TOP_ERRORS_LIMIT = 5;
43
42
  const DEFAULT_CAPACITY = 1000;
43
+ const PROVIDER_LATENCY_CAPACITY = 200;
44
44
  const HTTP_SUCCESS_RANGE_MIN = 200;
45
45
  const HTTP_SUCCESS_RANGE_MAX = 400;
46
46
  const PERCENTILE_P50 = 0.5;
@@ -103,8 +103,7 @@ export class StatsAggregator {
103
103
  acc = emptyAccumulator();
104
104
  this.providers.set(providerId, acc);
105
105
  }
106
- acc.latencySum += ms;
107
- acc.latencyCount++;
106
+ acc.latencyBuffer.push(ms);
108
107
  }
109
108
  getStats() {
110
109
  const sorted = this.latencyBuffer.sorted();
@@ -123,9 +122,7 @@ export class StatsAggregator {
123
122
  totalRequests: acc.totalRequests,
124
123
  successCount: acc.successCount,
125
124
  errorCount: acc.errorCount,
126
- avgLatencyMs: acc.latencyCount > 0
127
- ? acc.latencySum / acc.latencyCount
128
- : 0,
125
+ avgLatencyMs: avgFromBuffer(acc.latencyBuffer),
129
126
  retryCount: acc.retryCount,
130
127
  topErrors,
131
128
  };
@@ -164,3 +161,7 @@ function percentile(sorted, p) {
164
161
  const idx = Math.ceil(p * sorted.length) - 1;
165
162
  return sorted[Math.max(0, Math.min(idx, sorted.length - 1))];
166
163
  }
164
+ function avgFromBuffer(buf) {
165
+ const sorted = buf.sorted();
166
+ return sorted.length > 0 ? sorted.reduce((s, v) => s + v, 0) / sorted.length : 0;
167
+ }
@@ -30,7 +30,12 @@ export class ProxyOrchestrator {
30
30
  this.deps.trackerScope.markQueued(trackerReq.id, false);
31
31
  }
32
32
  return this.executeResilience(config, ctx);
33
- }), (result) => this.extractTrackStatus(result));
33
+ }), (result) => this.extractTrackStatus(result), (result) => result.attempts.map(a => ({
34
+ statusCode: a.statusCode,
35
+ error: a.error,
36
+ latencyMs: a.latencyMs,
37
+ providerId: a.target.provider_id,
38
+ })));
34
39
  this.sendResponse(reply, result.result, ctx);
35
40
  return result;
36
41
  }
@@ -25,8 +25,6 @@ export interface ResilienceConfig {
25
25
  failoverThreshold: number;
26
26
  ruleMatcher?: RetryRuleMatcher;
27
27
  isFailover: boolean;
28
- /** DB 规则 max_retries 的全局安全阀,防止单规则配置导致过多重试 */
29
- globalRetryCap?: number;
30
28
  /** 全局迭代上限,防止极端配置导致 while(true) 循环过多 */
31
29
  iterationCap?: number;
32
30
  }
@@ -29,7 +29,6 @@ export function createStrategy(rule) {
29
29
  const RETRYABLE_THROW_CODES = new Set(["ETIMEDOUT", "ECONNRESET", "ECONNREFUSED"]);
30
30
  const HTTP_TOO_MANY_REQUESTS = 429;
31
31
  const DEFAULT_THROW_MAX_RETRIES = 3;
32
- const DEFAULT_RETRY_CAP = 3;
33
32
  const DEFAULT_ITERATION_CAP = 50;
34
33
  // ---------- Internal helpers ----------
35
34
  function isRetryableThrow(err) {
@@ -94,7 +93,7 @@ export class ResilienceLayer {
94
93
  const matchedRule = body && config.ruleMatcher
95
94
  ? config.ruleMatcher.match(result.statusCode, body)
96
95
  : null;
97
- if (matchedRule && state.attemptCount < Math.min(matchedRule.max_retries, config.globalRetryCap ?? DEFAULT_RETRY_CAP)) {
96
+ if (matchedRule && state.attemptCount < matchedRule.max_retries) {
98
97
  const strategy = createStrategy(matchedRule);
99
98
  const headers = extractHeaders(result);
100
99
  const retryAfterMs = result.statusCode === HTTP_TOO_MANY_REQUESTS
@@ -110,7 +109,7 @@ export class ResilienceLayer {
110
109
  const body = extractBody(result);
111
110
  if (body && config.ruleMatcher) {
112
111
  const matchedRule = config.ruleMatcher.match(result.statusCode, body);
113
- if (matchedRule && state.attemptCount < Math.min(matchedRule.max_retries, config.globalRetryCap ?? DEFAULT_RETRY_CAP)) {
112
+ if (matchedRule && state.attemptCount < matchedRule.max_retries) {
114
113
  const strategy = createStrategy(matchedRule);
115
114
  return { action: "retry", delayMs: strategy.getDelay(state.attemptCount) };
116
115
  }
@@ -1,6 +1,6 @@
1
1
  import type { ProviderSemaphoreManager } from "./semaphore.js";
2
2
  import type { RequestTracker } from "../monitor/request-tracker.js";
3
- import type { ActiveRequest } from "../monitor/types.js";
3
+ import type { ActiveRequest, AttemptSnapshot } from "../monitor/types.js";
4
4
  export declare class SemaphoreScope {
5
5
  private manager;
6
6
  constructor(manager: ProviderSemaphoreManager);
@@ -12,7 +12,7 @@ export declare class TrackerScope {
12
12
  track<T>(req: ActiveRequest, fn: () => Promise<T>, extractStatus: (result: T) => {
13
13
  status: "completed" | "failed";
14
14
  statusCode?: number;
15
- }): Promise<T>;
15
+ }, extractAttempts?: (result: T) => AttemptSnapshot[]): Promise<T>;
16
16
  /** 通知 tracker 请求进入/离开信号量队列,触发前端即时广播 */
17
17
  markQueued(id: string, queued: boolean): void;
18
18
  }
@@ -18,11 +18,13 @@ export class TrackerScope {
18
18
  constructor(tracker) {
19
19
  this.tracker = tracker;
20
20
  }
21
- async track(req, fn, extractStatus) {
21
+ async track(req, fn, extractStatus, extractAttempts) {
22
22
  this.tracker.start(req);
23
23
  try {
24
24
  const result = await fn();
25
- this.tracker.complete(req.id, extractStatus(result));
25
+ const status = extractStatus(result);
26
+ const attempts = extractAttempts ? extractAttempts(result) : undefined;
27
+ this.tracker.complete(req.id, { ...status, attempts });
26
28
  return result;
27
29
  }
28
30
  catch (e) {
@@ -1 +1 @@
1
- import{G as e,It as t,J as n,Pt as r,lt as i,ot as a,r as o}from"./button-BCrIpNwA.js";var s=[`data-size`],c=n({__name:`Card`,props:{class:{type:[Boolean,null,String,Object,Array]},size:{default:`default`}},setup(n){let c=n;return(l,u)=>(a(),e(`div`,{"data-slot":`card`,"data-size":n.size,class:t(r(o)(`ring-foreground/10 bg-card text-card-foreground gap-4 overflow-hidden rounded-lg py-4 text-sm ring-1 has-data-[slot=card-footer]:pb-0 has-[>img:first-child]:pt-0 data-[size=sm]:gap-3 data-[size=sm]:py-3 data-[size=sm]:has-data-[slot=card-footer]:pb-0 *:[img:first-child]:rounded-t-lg *:[img:last-child]:rounded-b-lg group/card flex flex-col`,c.class))},[i(l.$slots,`default`)],10,s))}}),l=n({__name:`CardContent`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-content`,class:t(r(o)(`px-4 group-data-[size=sm]/card:px-3`,s.class))},[i(n.$slots,`default`)],2))}});export{c as n,l as t};
1
+ import{G as e,It as t,J as n,Pt as r,lt as i,ot as a,r as o}from"./button-B6f3Nfab.js";var s=[`data-size`],c=n({__name:`Card`,props:{class:{type:[Boolean,null,String,Object,Array]},size:{default:`default`}},setup(n){let c=n;return(l,u)=>(a(),e(`div`,{"data-slot":`card`,"data-size":n.size,class:t(r(o)(`ring-foreground/10 bg-card text-card-foreground gap-4 overflow-hidden rounded-lg py-4 text-sm ring-1 has-data-[slot=card-footer]:pb-0 has-[>img:first-child]:pt-0 data-[size=sm]:gap-3 data-[size=sm]:py-3 data-[size=sm]:has-data-[slot=card-footer]:pb-0 *:[img:first-child]:rounded-t-lg *:[img:last-child]:rounded-b-lg group/card flex flex-col`,c.class))},[i(l.$slots,`default`)],10,s))}}),l=n({__name:`CardContent`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-content`,class:t(r(o)(`px-4 group-data-[size=sm]/card:px-3`,s.class))},[i(n.$slots,`default`)],2))}});export{c as n,l as t};
@@ -1 +1 @@
1
- import{G as e,It as t,J as n,Pt as r,lt as i,ot as a,r as o}from"./button-BCrIpNwA.js";var s=n({__name:`CardHeader`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-header`,class:t(r(o)(`gap-1 rounded-t-xl px-4 group-data-[size=sm]/card:px-3 [.border-b]:pb-4 group-data-[size=sm]/card:[.border-b]:pb-3 group/card-header @container/card-header grid auto-rows-min items-start has-data-[slot=card-action]:grid-cols-[1fr_auto] has-data-[slot=card-description]:grid-rows-[auto_auto]`,s.class))},[i(n.$slots,`default`)],2))}}),c=n({__name:`CardTitle`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-title`,class:t(r(o)(`text-base leading-snug font-medium group-data-[size=sm]/card:text-sm cn-font-heading`,s.class))},[i(n.$slots,`default`)],2))}});export{s as n,c as t};
1
+ import{G as e,It as t,J as n,Pt as r,lt as i,ot as a,r as o}from"./button-B6f3Nfab.js";var s=n({__name:`CardHeader`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-header`,class:t(r(o)(`gap-1 rounded-t-xl px-4 group-data-[size=sm]/card:px-3 [.border-b]:pb-4 group-data-[size=sm]/card:[.border-b]:pb-3 group/card-header @container/card-header grid auto-rows-min items-start has-data-[slot=card-action]:grid-cols-[1fr_auto] has-data-[slot=card-description]:grid-rows-[auto_auto]`,s.class))},[i(n.$slots,`default`)],2))}}),c=n({__name:`CardTitle`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(n){let s=n;return(n,c)=>(a(),e(`div`,{"data-slot":`card-title`,class:t(r(o)(`text-base leading-snug font-medium group-data-[size=sm]/card:text-sm cn-font-heading`,s.class))},[i(n.$slots,`default`)],2))}});export{s as n,c as t};
@@ -1 +1 @@
1
- import{J as e,L as t,Lt as n,Pt as r,R as i,U as a,V as o,W as s,X as c,dt as l,i as u,lt as d,m as f,o as p,ot as m,q as h,r as g,tt as _,x as v,yt as y}from"./button-BCrIpNwA.js";import{g as b,o as x,u as S,y as C}from"./Teleport-CgTHarey.js";import{n as w,t as T}from"./ohash.D__AXeF1-DkJnWU8a.js";import{n as E}from"./VisuallyHidden-fbPmoMwi.js";import{t as D}from"./VisuallyHiddenInput-7j8wkPrW.js";import{t as O}from"./RovingFocusItem-Dsv9AkP7.js";function k(e,t){return b(e)?!1:Array.isArray(e)?e.some(e=>T(e,t)):T(e,t)}var[A,j]=C(`CheckboxGroupRoot`);function M(e){return e===`indeterminate`}function N(e){return M(e)?`indeterminate`:e?`checked`:`unchecked`}var[P,F]=C(`CheckboxRoot`),I=e({inheritAttrs:!1,__name:`CheckboxRoot`,props:{defaultValue:{type:null,required:!1},modelValue:{type:null,required:!1,default:void 0},disabled:{type:Boolean,required:!1},value:{type:null,required:!1,default:`on`},id:{type:String,required:!1},trueValue:{type:null,required:!1,default:()=>!0},falseValue:{type:null,required:!1,default:()=>!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`button`},name:{type:String,required:!1},required:{type:Boolean,required:!1}},emits:[`update:modelValue`],setup(e,{emit:n}){let c=e,h=n,{forwardRef:g,currentElement:v}=p(),x=A(null),S=f(c,`modelValue`,h,{defaultValue:c.defaultValue??c.falseValue,passive:c.modelValue===void 0}),C=o(()=>x?.disabled.value||c.disabled),w=o(()=>T(S.value,c.trueValue)),j=o(()=>b(x?.modelValue.value)?S.value===`indeterminate`?`indeterminate`:w.value:k(x.modelValue.value,c.value));function P(){if(b(x?.modelValue.value))S.value===`indeterminate`?S.value=c.trueValue:S.value=w.value?c.falseValue:c.trueValue;else{let e=[...x.modelValue.value||[]];if(k(e,c.value)){let t=e.findIndex(e=>T(e,c.value));e.splice(t,1)}else e.push(c.value);x.modelValue.value=e}}let I=E(v),L=o(()=>c.id&&v.value?document.querySelector(`[for="${c.id}"]`)?.innerText:void 0);return F({disabled:C,state:j}),(e,n)=>(m(),a(l(r(x)?.rovingFocus.value?r(O):r(u)),_(e.$attrs,{id:e.id,ref:r(g),role:`checkbox`,"as-child":e.asChild,as:e.as,type:e.as===`button`?`button`:void 0,"aria-checked":r(M)(j.value)?`mixed`:j.value,"aria-required":e.required,"aria-label":e.$attrs[`aria-label`]||L.value,"data-state":r(N)(j.value),"data-disabled":C.value?``:void 0,disabled:C.value,focusable:r(x)?.rovingFocus.value?!C.value:void 0,onKeydown:t(i(()=>{},[`prevent`]),[`enter`]),onClick:P}),{default:y(()=>[d(e.$slots,`default`,{modelValue:r(S),state:j.value}),r(I)&&e.name&&!r(x)?(m(),a(r(D),{key:0,type:`checkbox`,checked:!!j.value,name:e.name,value:e.value,disabled:C.value,required:e.required},null,8,[`checked`,`name`,`value`,`disabled`,`required`])):s(`v-if`,!0)]),_:3},16,[`id`,`as-child`,`as`,`type`,`aria-checked`,`aria-required`,`aria-label`,`data-state`,`data-disabled`,`disabled`,`focusable`,`onKeydown`]))}}),L=e({__name:`CheckboxIndicator`,props:{forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`span`}},setup(e){let{forwardRef:t}=p(),n=P();return(e,i)=>(m(),a(r(x),{present:e.forceMount||r(M)(r(n).state.value)||r(n).state.value===!0},{default:y(()=>[h(r(u),_({ref:r(t),"data-state":r(N)(r(n).state.value),"data-disabled":r(n).disabled.value?``:void 0,style:{pointerEvents:`none`},"as-child":e.asChild,as:e.as},e.$attrs),{default:y(()=>[d(e.$slots,`default`)]),_:3},16,[`data-state`,`data-disabled`,`as-child`,`as`])]),_:3},8,[`present`]))}}),R=e({__name:`Checkbox`,props:{defaultValue:{},modelValue:{},disabled:{type:Boolean},value:{},id:{},trueValue:{},falseValue:{},asChild:{type:Boolean},as:{},name:{},required:{type:Boolean},class:{type:[Boolean,null,String,Object,Array]}},emits:[`update:modelValue`],setup(e,{emit:t}){let i=e,o=t,s=S(v(i,`class`),o);return(e,t)=>(m(),a(r(I),_({"data-slot":`checkbox`},r(s),{class:r(g)(`border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary aria-invalid:aria-checked:border-primary aria-invalid:border-destructive dark:aria-invalid:border-destructive/50 focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 flex size-4 items-center justify-center rounded-md border transition-colors group-has-disabled/field:opacity-50 focus-visible:ring-3 aria-invalid:ring-3 peer relative shrink-0 outline-none after:absolute after:-inset-x-3 after:-inset-y-2 disabled:cursor-not-allowed disabled:opacity-50`,i.class)}),{default:y(t=>[h(r(L),{"data-slot":`checkbox-indicator`,class:`[&>svg]:size-3.5 grid place-content-center text-current transition-none`},{default:y(()=>[d(e.$slots,`default`,n(c(t)),()=>[h(r(w))])]),_:2},1024)]),_:3},16,[`class`]))}});export{R as t};
1
+ import{J as e,L as t,Lt as n,Pt as r,R as i,U as a,V as o,W as s,X as c,dt as l,i as u,lt as d,m as f,o as p,ot as m,q as h,r as g,tt as _,x as v,yt as y}from"./button-B6f3Nfab.js";import{g as b,o as x,u as S,y as C}from"./Teleport-BYzsRHC6.js";import{n as w,t as T}from"./ohash.D__AXeF1-BcwqVPVj.js";import{n as E}from"./VisuallyHidden-Bz0LPzC7.js";import{t as D}from"./VisuallyHiddenInput-Bf9hgsd7.js";import{t as O}from"./RovingFocusItem-DyNl4G42.js";function k(e,t){return b(e)?!1:Array.isArray(e)?e.some(e=>T(e,t)):T(e,t)}var[A,j]=C(`CheckboxGroupRoot`);function M(e){return e===`indeterminate`}function N(e){return M(e)?`indeterminate`:e?`checked`:`unchecked`}var[P,F]=C(`CheckboxRoot`),I=e({inheritAttrs:!1,__name:`CheckboxRoot`,props:{defaultValue:{type:null,required:!1},modelValue:{type:null,required:!1,default:void 0},disabled:{type:Boolean,required:!1},value:{type:null,required:!1,default:`on`},id:{type:String,required:!1},trueValue:{type:null,required:!1,default:()=>!0},falseValue:{type:null,required:!1,default:()=>!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`button`},name:{type:String,required:!1},required:{type:Boolean,required:!1}},emits:[`update:modelValue`],setup(e,{emit:n}){let c=e,h=n,{forwardRef:g,currentElement:v}=p(),x=A(null),S=f(c,`modelValue`,h,{defaultValue:c.defaultValue??c.falseValue,passive:c.modelValue===void 0}),C=o(()=>x?.disabled.value||c.disabled),w=o(()=>T(S.value,c.trueValue)),j=o(()=>b(x?.modelValue.value)?S.value===`indeterminate`?`indeterminate`:w.value:k(x.modelValue.value,c.value));function P(){if(b(x?.modelValue.value))S.value===`indeterminate`?S.value=c.trueValue:S.value=w.value?c.falseValue:c.trueValue;else{let e=[...x.modelValue.value||[]];if(k(e,c.value)){let t=e.findIndex(e=>T(e,c.value));e.splice(t,1)}else e.push(c.value);x.modelValue.value=e}}let I=E(v),L=o(()=>c.id&&v.value?document.querySelector(`[for="${c.id}"]`)?.innerText:void 0);return F({disabled:C,state:j}),(e,n)=>(m(),a(l(r(x)?.rovingFocus.value?r(O):r(u)),_(e.$attrs,{id:e.id,ref:r(g),role:`checkbox`,"as-child":e.asChild,as:e.as,type:e.as===`button`?`button`:void 0,"aria-checked":r(M)(j.value)?`mixed`:j.value,"aria-required":e.required,"aria-label":e.$attrs[`aria-label`]||L.value,"data-state":r(N)(j.value),"data-disabled":C.value?``:void 0,disabled:C.value,focusable:r(x)?.rovingFocus.value?!C.value:void 0,onKeydown:t(i(()=>{},[`prevent`]),[`enter`]),onClick:P}),{default:y(()=>[d(e.$slots,`default`,{modelValue:r(S),state:j.value}),r(I)&&e.name&&!r(x)?(m(),a(r(D),{key:0,type:`checkbox`,checked:!!j.value,name:e.name,value:e.value,disabled:C.value,required:e.required},null,8,[`checked`,`name`,`value`,`disabled`,`required`])):s(`v-if`,!0)]),_:3},16,[`id`,`as-child`,`as`,`type`,`aria-checked`,`aria-required`,`aria-label`,`data-state`,`data-disabled`,`disabled`,`focusable`,`onKeydown`]))}}),L=e({__name:`CheckboxIndicator`,props:{forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`span`}},setup(e){let{forwardRef:t}=p(),n=P();return(e,i)=>(m(),a(r(x),{present:e.forceMount||r(M)(r(n).state.value)||r(n).state.value===!0},{default:y(()=>[h(r(u),_({ref:r(t),"data-state":r(N)(r(n).state.value),"data-disabled":r(n).disabled.value?``:void 0,style:{pointerEvents:`none`},"as-child":e.asChild,as:e.as},e.$attrs),{default:y(()=>[d(e.$slots,`default`)]),_:3},16,[`data-state`,`data-disabled`,`as-child`,`as`])]),_:3},8,[`present`]))}}),R=e({__name:`Checkbox`,props:{defaultValue:{},modelValue:{},disabled:{type:Boolean},value:{},id:{},trueValue:{},falseValue:{},asChild:{type:Boolean},as:{},name:{},required:{type:Boolean},class:{type:[Boolean,null,String,Object,Array]}},emits:[`update:modelValue`],setup(e,{emit:t}){let i=e,o=t,s=S(v(i,`class`),o);return(e,t)=>(m(),a(r(I),_({"data-slot":`checkbox`},r(s),{class:r(g)(`border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary aria-invalid:aria-checked:border-primary aria-invalid:border-destructive dark:aria-invalid:border-destructive/50 focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 flex size-4 items-center justify-center rounded-md border transition-colors group-has-disabled/field:opacity-50 focus-visible:ring-3 aria-invalid:ring-3 peer relative shrink-0 outline-none after:absolute after:-inset-x-3 after:-inset-y-2 disabled:cursor-not-allowed disabled:opacity-50`,i.class)}),{default:y(t=>[h(r(L),{"data-slot":`checkbox-indicator`,class:`[&>svg]:size-3.5 grid place-content-center text-current transition-none`},{default:y(()=>[d(e.$slots,`default`,n(c(t)),()=>[h(r(w))])]),_:2},1024)]),_:3},16,[`class`]))}});export{R as t};
@@ -1 +1 @@
1
- import{Dt as e,J as t,Lt as n,Mt as r,Pt as i,U as a,V as o,W as s,X as c,d as l,gt as u,i as d,it as f,lt as p,m,nt as h,o as g,ot as _,q as v,tt as y,yt as b}from"./button-BCrIpNwA.js";import{c as x,o as S,u as C,y as w}from"./Teleport-CgTHarey.js";var[T,E]=w(`CollapsibleRoot`),D=t({__name:`CollapsibleRoot`,props:{defaultOpen:{type:Boolean,required:!1,default:!1},open:{type:Boolean,required:!1,default:void 0},disabled:{type:Boolean,required:!1},unmountOnHide:{type:Boolean,required:!1,default:!0},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`update:open`],setup(e,{expose:t,emit:n}){let o=e,s=m(o,`open`,n,{defaultValue:o.defaultOpen,passive:o.open===void 0}),{disabled:c,unmountOnHide:l}=r(o);return E({contentId:``,disabled:c,open:s,unmountOnHide:l,onOpenToggle:()=>{c.value||(s.value=!s.value)}}),t({open:s}),g(),(e,t)=>(_(),a(i(d),{as:e.as,"as-child":o.asChild,"data-state":i(s)?`open`:`closed`,"data-disabled":i(c)?``:void 0},{default:b(()=>[p(e.$slots,`default`,{open:i(s)})]),_:3},8,[`as`,`as-child`,`data-state`,`data-disabled`]))}}),O=t({inheritAttrs:!1,__name:`CollapsibleContent`,props:{forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`contentFound`],setup(t,{emit:n}){let r=t,c=n,m=T();m.contentId||=x(void 0,`reka-collapsible-content`);let C=e(),{forwardRef:w,currentElement:E}=g(),D=e(0),O=e(0),k=o(()=>m.open.value),A=e(k.value),j=e();u(()=>[k.value,C.value?.present],async()=>{await h();let e=E.value;if(!e)return;j.value=j.value||{transitionDuration:e.style.transitionDuration,animationName:e.style.animationName},e.style.transitionDuration=`0s`,e.style.animationName=`none`;let t=e.getBoundingClientRect();O.value=t.height,D.value=t.width,A.value||(e.style.transitionDuration=j.value.transitionDuration,e.style.animationName=j.value.animationName)},{immediate:!0});let M=o(()=>A.value&&m.open.value);return f(()=>{requestAnimationFrame(()=>{A.value=!1})}),l(E,`beforematch`,e=>{requestAnimationFrame(()=>{m.onOpenToggle(),c(`contentFound`)})}),(e,t)=>(_(),a(i(S),{ref_key:`presentRef`,ref:C,present:e.forceMount||i(m).open.value,"force-mount":!0},{default:b(({present:t})=>[v(i(d),y(e.$attrs,{id:i(m).contentId,ref:i(w),"as-child":r.asChild,as:e.as,hidden:t?void 0:i(m).unmountOnHide.value?``:`until-found`,"data-state":M.value?void 0:i(m).open.value?`open`:`closed`,"data-disabled":i(m).disabled?.value?``:void 0,style:{"--reka-collapsible-content-height":`${O.value}px`,"--reka-collapsible-content-width":`${D.value}px`}}),{default:b(()=>[!i(m).unmountOnHide.value||t?p(e.$slots,`default`,{key:0}):s(`v-if`,!0)]),_:2},1040,[`id`,`as-child`,`as`,`hidden`,`data-state`,`data-disabled`,`style`])]),_:3},8,[`present`]))}}),k=t({__name:`CollapsibleTrigger`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`button`}},setup(e){let t=e;g();let n=T();return(e,r)=>(_(),a(i(d),{type:e.as===`button`?`button`:void 0,as:e.as,"as-child":t.asChild,"aria-controls":i(n).contentId,"aria-expanded":i(n).open.value,"data-state":i(n).open.value?`open`:`closed`,"data-disabled":i(n).disabled?.value?``:void 0,disabled:i(n).disabled?.value,onClick:i(n).onOpenToggle},{default:b(()=>[p(e.$slots,`default`)]),_:3},8,[`type`,`as`,`as-child`,`aria-controls`,`aria-expanded`,`data-state`,`data-disabled`,`disabled`,`onClick`]))}}),A=t({__name:`Collapsible`,props:{defaultOpen:{type:Boolean},open:{type:Boolean},disabled:{type:Boolean},unmountOnHide:{type:Boolean},asChild:{type:Boolean},as:{}},emits:[`update:open`],setup(e,{emit:t}){let r=C(e,t);return(e,t)=>(_(),a(i(D),y({"data-slot":`collapsible`},i(r)),{default:b(t=>[p(e.$slots,`default`,n(c(t)))]),_:3},16))}}),j=t({__name:`CollapsibleContent`,props:{forceMount:{type:Boolean},asChild:{type:Boolean},as:{}},setup(e){let t=e;return(e,n)=>(_(),a(i(O),y({"data-slot":`collapsible-content`},t),{default:b(()=>[p(e.$slots,`default`)]),_:3},16))}}),M=t({__name:`CollapsibleTrigger`,props:{asChild:{type:Boolean},as:{}},setup(e){let t=e;return(e,n)=>(_(),a(i(k),y({"data-slot":`collapsible-trigger`},t),{default:b(()=>[p(e.$slots,`default`)]),_:3},16))}});export{j as n,A as r,M as t};
1
+ import{Dt as e,J as t,Lt as n,Mt as r,Pt as i,U as a,V as o,W as s,X as c,d as l,gt as u,i as d,it as f,lt as p,m,nt as h,o as g,ot as _,q as v,tt as y,yt as b}from"./button-B6f3Nfab.js";import{c as x,o as S,u as C,y as w}from"./Teleport-BYzsRHC6.js";var[T,E]=w(`CollapsibleRoot`),D=t({__name:`CollapsibleRoot`,props:{defaultOpen:{type:Boolean,required:!1,default:!1},open:{type:Boolean,required:!1,default:void 0},disabled:{type:Boolean,required:!1},unmountOnHide:{type:Boolean,required:!1,default:!0},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`update:open`],setup(e,{expose:t,emit:n}){let o=e,s=m(o,`open`,n,{defaultValue:o.defaultOpen,passive:o.open===void 0}),{disabled:c,unmountOnHide:l}=r(o);return E({contentId:``,disabled:c,open:s,unmountOnHide:l,onOpenToggle:()=>{c.value||(s.value=!s.value)}}),t({open:s}),g(),(e,t)=>(_(),a(i(d),{as:e.as,"as-child":o.asChild,"data-state":i(s)?`open`:`closed`,"data-disabled":i(c)?``:void 0},{default:b(()=>[p(e.$slots,`default`,{open:i(s)})]),_:3},8,[`as`,`as-child`,`data-state`,`data-disabled`]))}}),O=t({inheritAttrs:!1,__name:`CollapsibleContent`,props:{forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`contentFound`],setup(t,{emit:n}){let r=t,c=n,m=T();m.contentId||=x(void 0,`reka-collapsible-content`);let C=e(),{forwardRef:w,currentElement:E}=g(),D=e(0),O=e(0),k=o(()=>m.open.value),A=e(k.value),j=e();u(()=>[k.value,C.value?.present],async()=>{await h();let e=E.value;if(!e)return;j.value=j.value||{transitionDuration:e.style.transitionDuration,animationName:e.style.animationName},e.style.transitionDuration=`0s`,e.style.animationName=`none`;let t=e.getBoundingClientRect();O.value=t.height,D.value=t.width,A.value||(e.style.transitionDuration=j.value.transitionDuration,e.style.animationName=j.value.animationName)},{immediate:!0});let M=o(()=>A.value&&m.open.value);return f(()=>{requestAnimationFrame(()=>{A.value=!1})}),l(E,`beforematch`,e=>{requestAnimationFrame(()=>{m.onOpenToggle(),c(`contentFound`)})}),(e,t)=>(_(),a(i(S),{ref_key:`presentRef`,ref:C,present:e.forceMount||i(m).open.value,"force-mount":!0},{default:b(({present:t})=>[v(i(d),y(e.$attrs,{id:i(m).contentId,ref:i(w),"as-child":r.asChild,as:e.as,hidden:t?void 0:i(m).unmountOnHide.value?``:`until-found`,"data-state":M.value?void 0:i(m).open.value?`open`:`closed`,"data-disabled":i(m).disabled?.value?``:void 0,style:{"--reka-collapsible-content-height":`${O.value}px`,"--reka-collapsible-content-width":`${D.value}px`}}),{default:b(()=>[!i(m).unmountOnHide.value||t?p(e.$slots,`default`,{key:0}):s(`v-if`,!0)]),_:2},1040,[`id`,`as-child`,`as`,`hidden`,`data-state`,`data-disabled`,`style`])]),_:3},8,[`present`]))}}),k=t({__name:`CollapsibleTrigger`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`button`}},setup(e){let t=e;g();let n=T();return(e,r)=>(_(),a(i(d),{type:e.as===`button`?`button`:void 0,as:e.as,"as-child":t.asChild,"aria-controls":i(n).contentId,"aria-expanded":i(n).open.value,"data-state":i(n).open.value?`open`:`closed`,"data-disabled":i(n).disabled?.value?``:void 0,disabled:i(n).disabled?.value,onClick:i(n).onOpenToggle},{default:b(()=>[p(e.$slots,`default`)]),_:3},8,[`type`,`as`,`as-child`,`aria-controls`,`aria-expanded`,`data-state`,`data-disabled`,`disabled`,`onClick`]))}}),A=t({__name:`Collapsible`,props:{defaultOpen:{type:Boolean},open:{type:Boolean},disabled:{type:Boolean},unmountOnHide:{type:Boolean},asChild:{type:Boolean},as:{}},emits:[`update:open`],setup(e,{emit:t}){let r=C(e,t);return(e,t)=>(_(),a(i(D),y({"data-slot":`collapsible`},i(r)),{default:b(t=>[p(e.$slots,`default`,n(c(t)))]),_:3},16))}}),j=t({__name:`CollapsibleContent`,props:{forceMount:{type:Boolean},asChild:{type:Boolean},as:{}},setup(e){let t=e;return(e,n)=>(_(),a(i(O),y({"data-slot":`collapsible-content`},t),{default:b(()=>[p(e.$slots,`default`)]),_:3},16))}}),M=t({__name:`CollapsibleTrigger`,props:{asChild:{type:Boolean},as:{}},setup(e){let t=e;return(e,n)=>(_(),a(i(k),y({"data-slot":`collapsible-trigger`},t),{default:b(()=>[p(e.$slots,`default`)]),_:3},16))}});export{j as n,A as r,M as t};
@@ -1 +1 @@
1
- import{Dt as e,J as t,Q as n,V as r,Z as i,_t as a,a as o,gt as s,st as c,u as l,wt as u}from"./button-BCrIpNwA.js";import{h as d}from"./Teleport-CgTHarey.js";function f(t){let n=d({dir:e(`ltr`)});return r(()=>t?.value||n.dir?.value||`ltr`)}function p(){let t=e();return{primitiveElement:t,currentElement:r(()=>[`#text`,`#comment`].includes(t.value?.$el.nodeName)?t.value?.$el.nextElementSibling:l(t))}}var m=`data-reka-collection-item`;function h(l={}){let{key:d=``,isProvider:f=!1}=l,h=`${d}CollectionProvider`,g;if(f){let t=e(new Map);g={collectionRef:e(),itemMap:t},c(h,g)}else g=n(h);let _=(e=!1)=>{let t=g.collectionRef.value;if(!t)return[];let n=Array.from(t.querySelectorAll(`[${m}]`)),r=Array.from(g.itemMap.value.values()).sort((e,t)=>n.indexOf(e.ref)-n.indexOf(t.ref));return e?r:r.filter(e=>e.ref.dataset.disabled!==``)},v=t({name:`CollectionSlot`,inheritAttrs:!1,setup(e,{slots:t,attrs:n}){let{primitiveElement:r,currentElement:a}=p();return s(a,()=>{g.collectionRef.value=a.value}),()=>i(o,{ref:r,...n},t)}}),y=t({name:`CollectionItem`,inheritAttrs:!1,props:{value:{validator:()=>!0}},setup(e,{slots:t,attrs:n}){let{primitiveElement:r,currentElement:s}=p();return a(t=>{if(s.value){let n=u(s.value);g.itemMap.value.set(n,{ref:s.value,value:e.value}),t(()=>g.itemMap.value.delete(n))}}),()=>i(o,{...n,[m]:``,ref:r},t)}});return{getItems:_,reactiveItems:r(()=>Array.from(g.itemMap.value.values())),itemMapSize:r(()=>g.itemMap.value.size),CollectionSlot:v,CollectionItem:y}}export{p as n,f as r,h as t};
1
+ import{Dt as e,J as t,Q as n,V as r,Z as i,_t as a,a as o,gt as s,st as c,u as l,wt as u}from"./button-B6f3Nfab.js";import{h as d}from"./Teleport-BYzsRHC6.js";function f(t){let n=d({dir:e(`ltr`)});return r(()=>t?.value||n.dir?.value||`ltr`)}function p(){let t=e();return{primitiveElement:t,currentElement:r(()=>[`#text`,`#comment`].includes(t.value?.$el.nodeName)?t.value?.$el.nextElementSibling:l(t))}}var m=`data-reka-collection-item`;function h(l={}){let{key:d=``,isProvider:f=!1}=l,h=`${d}CollectionProvider`,g;if(f){let t=e(new Map);g={collectionRef:e(),itemMap:t},c(h,g)}else g=n(h);let _=(e=!1)=>{let t=g.collectionRef.value;if(!t)return[];let n=Array.from(t.querySelectorAll(`[${m}]`)),r=Array.from(g.itemMap.value.values()).sort((e,t)=>n.indexOf(e.ref)-n.indexOf(t.ref));return e?r:r.filter(e=>e.ref.dataset.disabled!==``)},v=t({name:`CollectionSlot`,inheritAttrs:!1,setup(e,{slots:t,attrs:n}){let{primitiveElement:r,currentElement:a}=p();return s(a,()=>{g.collectionRef.value=a.value}),()=>i(o,{ref:r,...n},t)}}),y=t({name:`CollectionItem`,inheritAttrs:!1,props:{value:{validator:()=>!0}},setup(e,{slots:t,attrs:n}){let{primitiveElement:r,currentElement:s}=p();return a(t=>{if(s.value){let n=u(s.value);g.itemMap.value.set(n,{ref:s.value,value:e.value}),t(()=>g.itemMap.value.delete(n))}}),()=>i(o,{...n,[m]:``,ref:r},t)}});return{getItems:_,reactiveItems:r(()=>Array.from(g.itemMap.value.values())),itemMapSize:r(()=>g.itemMap.value.size),CollectionSlot:v,CollectionItem:y}}export{p as n,f as r,h as t};